Newton-Raphson-Division

Aus testwiki
Version vom 29. März 2023, 07:40 Uhr von imported>Redonebird (Abschnittlink korrigiert)
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)
Zur Navigation springen Zur Suche springen

Das Newton–Raphson-Divisions-Verfahren benutzt das Newton-Verfahren, um den Kehrwert eines Nenners N zu finden und diesen mit einem Zähler Z zu multiplizieren für das Ergebnis des Vorlage:Nowrap

Wegen der besonderen Bedeutung für die Computertechnik wird das Verfahren im Folgenden für das Dualsystem vorgestellt. Es lässt sich aber auch bei jeder anderen Basis anwenden.

Schritte

Die Schritte des Newton–Raphson-Divisionsverfahrens sind:

  1. Finden einer ersten Näherung X0 für den Kehrwert 1/N des Nenners N.
  2. Berechnen immer besserer Näherungen X1,X2,,XS des Kehrwerts. Hier wird vom Newton-Verfahren Gebrauch gemacht.
  3. Berechnen des Quotienten durch Multiplikation des Zählers mit dem Kehrwert des Nenners: Q=ZXS.

Newton-Verfahren

Die Anwendung des Newton-Verfahrens benötigt eine Funktion f(X), die eine Nullstelle bei X=1/N hat. Die naheliegende Funktion f(X)=NX1 hat triviale für das Newton-Verfahren untaugliche Ableitungen. Eine brauchbare Funktion ist f(X)=1/XN mit f(X)=1/X2. Wegen f(X)<0 schneidet der Graph der Funktion die X-Achse transversal, d. h. nicht-berührend. Für die Newton–Iteration ist

Xi+1=Xif(Xi)f(Xi)=Xi1/XiN1/Xi2=Xi+Xi(1NXi)=Xi(2NXi),

was ausgehend von Xi ausschließlich über Multiplikation und Subtraktion (oder zwei fused multiply-add-Operationen) berechnet werden kann.

Konvergenzgeschwindigkeit

Wenn der Fehler als ϵi=NXi1 definiert ist, dann ist:

ϵi+1=NXi+11=N(Xi(2NXi))1=2NXiN2Xi21=(N2Xi22NXi+1)=(NXi1)2=ϵi2.

Diese Quadrierung des Fehlers bei jedem Schritt – die sog. quadratische Konvergenz des Newton-Verfahrens – sorgt dafür, dass die Anzahl der korrekten Ziffern sich bei jeder Iteration in etwa verdoppelt; eine Eigenschaft die beim Rechnen mit Langzahlen besonders wertvoll ist.

Da für diese Methode die Konvergenzgeschwindigkeit exakt quadratisch ist, folgt, dass

S=log2P+1log217

Schritte für eine Genauigkeit von P Binärstellen ausreichen. Das sind 3 für single und 4 für sowohl double wie extended precision IEEE 754 Formate.

Finden einer ersten Näherung

Durch Bitverschiebungen kann der Nenner N ins Intervall 0,5N<1 gebracht werden. Dieselbe Anzahl Shifts sollte der Zähler Z erfahren, so dass der Quotient ungeändert bleibt. Danach kann man eine lineare Approximation der Form

1N:X0:=T1+T2N   mit   T1:=4817   und   T2:=3217

anwenden, um das Verfahren zu initialisieren.

Die Koeffizienten T1 und T2 dieser linearen (Polynomgrad 1) Approximation ergeben sich folgendermaßen. Der relative Fehler ist |(T1+T2N1/N)/(1/N)|=|N(T1+T2N)1|. Der Minimalwert des maximalen solchen Fehlers im Intervall [0,5;1[ wird gegeben durch den Alternantensatz von Tschebyscheff angewendet auf die Funktion F(N)=N(T1+T2N)1. Das lokale Extremum von F(N) findet statt, wenn F(N)=0 ist, was die Lösung N=T1/(2T2) hat. Nach dem genannten Alternantensatz muss diese Funktion am Extremum (im Inneren) das umgekehrte Vorzeichen als an den Rändern des Intervalls haben, also F(1/2)=F(1)=F(T1/(2T2)). Für die zwei Unbekannten in den zwei Gleichungen ergibt sich die Lösung T1=48/17 und T2=32/17, und der maximale relative Fehler ist F(1)=1/17. Nach dieser Approximation ist der relative Fehler des Anfangswertes

|ϵ0|1170,059.

Pseudocode

Das Folgende berechnet den Quotienten von Z und N mit einer Genauigkeit von P Binärstellen:

Drücke N aus als M × 2e mit 1 ≤ M < 2 (Standard-Gleitkomma-Darstellung)
N' := N / 2e+1             // Bitverschiebungen resp. Verkleinerung des Exponenten
Z' := Z / 2e+1
X := 48/17 − 32/17 × N'   // erste Näherung mit der gleichen Genauigkeit wie N
Vorlage:Nowrap   // kann für fixes P vorausberechnet werden
    X := X + X × (1 - N' × X)
end
return Z' × X

Diese Methode benötigt bspw. für eine double-precision Gleitkomma-Division 10 Multiplikationen, 9 Additionen und 2 Shifts.

Literatur

Ähnliche Verfahren