Goldschmidt-Division

Aus testwiki
Zur Navigation springen Zur Suche springen

Die Goldschmidt-Division ist ein Verfahren, um eine Division in einer digitalen Schaltung schnell und mit geringem Hardwareaufwand zu realisieren.[1] Dabei wird die Division auf eine Multiplikation zurückgeführt, womit bereits evtl. vorhandene Multiplizierer mitverwendet werden können.

Der Ansatz der Goldschmidt-Division ist die Betrachtung der Division als Bruch ZN, welcher so lange mit dem Faktor Fi erweitert wird, bis der Nenner nahe genug an den Wert 1 konvergiert ist. Der Wert des Zählers entspricht somit dann dem Ergebnis der Division.

Q=ZNF1F1F2F2FF.

Die auszuführenden Schritte sind:

  1. Wähle einen geeigneten Faktor Fi.
  2. Multipliziere Zähler und Nenner mit Fi.
  3. Wenn der Nenner nahe genug an 1 herangekommen ist, gib den Zähler zurück, andernfalls fahre mit Schritt 1 fort.

Sind Z und N so skaliert, dass 0<N<1, dann können die Erweiterungsfaktoren Fi einfach berechnet werden:

Fi+1=2Ni.

Damit ergibt sich:

Z0N0=ZN,Zi+1Ni+1=ZiFi+1NiFi+1.

Nach einer genügend großen Zahl von Iterationen k ist der gesuchte Quotient Q=Zk.

Bei der Umsetzung als Schaltung können die Multiplikationen von Nenner und Zähler parallel durchgeführt werden, was eine schnelle Abarbeitung des Algorithmus ermöglicht. Die Goldschmidt-Division wird in den AMD-Athlon-CPUs und späteren Modellen verwendet.[2][3]

Binomische Formel

Die Faktoren der Goldschmidt-Division können so gewählt werden, dass eine Vereinfachung mit der binomischen Formel möglich ist.

Angenommen ZN wurde mit einer Zweierpotenz so skaliert, dass N(12,1].

Wir setzen N=1x und Fi+1=1+x(2i).

Dann gilt:

Z1x=Z(1+x)1x2=Z(1+x)(1+x2)1x4=Z(1+x)(1+x2)(1+x(2n1))1x(2n)

Da x[0,12) können wir nach n Schritten 1x(2n) zu 1 runden. Der maximale relative Fehler ist dabei 2(2n), und wir erhalten eine Genauigkeit von 2n Digitalstellen. Dieser Algorithmus wird auch als die IBM-Methode bezeichnet.[4]

Ähnliche Verfahren

Einzelnachweise

  1. Applications of Division by Convergence by Robert E. Goldschmidt. Massachusetts Institute of Technology, 1964.
  2. Stuart F. Oberman, "Floating Point Division and Square Root Algorithms and Implementation in the AMD-K7 Microprocessor", in Proc. IEEE Symposium on Computer Arithmetic, S. 106–115, 1999
  3. Peter Soderquist and Miriam Leeser, "Division and Square Root: Choosing the Right Implementation", IEEE Micro, Band 17 No.4, S. 56–66, July/August 1997
  4. Vorlage:Internetquelle

en:Goldschmidt division