Newton's Method
Newton might be wondering what nowadays goes under his name. Nowadays, what is known as Newton's (or Newton-Raphson) method is an iterative process set up to approximate roots of equations
Let a be a root of the equation f(x) = 0, so that
f(a) = f(x) + (a - x) f '(x) + (a - x)² f ''(γ)/2. |
Since f(a) = 0 and assuming (a - x)² f ''(γ)/2 is small relative to the first term, we may write
0 ≈ f(x) + (a - x) f '(x) |
In other words,
a ≈ x - f(x) / f '(x). |
This suggests an iterative process:
(1) | xn + 1 = xn - f(xn) / f '(xn), n = 0, 1, ... |
with x0 chosen arbitrarily but hopefully in a neighborhood of the root a. The iterations have a simple geometric interpretation.
The tangent to the graph of y = f(x) at point (xn, f(xn)) is given by the linear equation
(2) | y = f(xn) + (x - xn) f '(xn). |
The idea behind Newton's method is that the latter equation is easier to solve (even several times in a row) than the original equation
x = xn - f(xn) / f '(xn) |
which is exactly xn + 1 in (1).
The applet below helps visualize the process.
What if applet does not run? |
To start iterations click anywhere in the applet area. This defines the abcissa x0 on the x-axis. The next click will clear the area. Once the starting point x0 is set you can specify the number of iterations you wish to observe. The best way is to increase the number of iterations by one at a time.
Newton's iterations do not always converge. For example, they may loop up in a vicinity of a local extreme:
Error Analysis
Assuming f '' exists and is continuous in a vicinity of a root a of the equation
f(a) = f(xn) + (a - xn) f '(xn) + (a - xn)² f ''(γn)/2, |
where γxn is between a and xn. Since
0 = f(xn) / f '(xn) + a - xn + (a - xn)² f ''(γn) / 2f '(xn). |
The way Newton's iterations run, the term f(xn) / f '(xn) is exactly
0 = xn - xn+1 + a - xn + (a - xn)² f ''(γn) / 2f '(xn). |
Solved for a - xn+1 the above becomes
a - xn+1 = [-f ''(γn) / 2f '(xn)] (a - xn)² |
showing that the error estimate on an iteration is proportional to the square of a similar estimate on the previous iteration. Assuming that the iterates do congregate towards the root and relying on the continuity of both f ' and f '' around a, we approximate
-f ''(γn) / 2f '(xn) ≈ -f ''(a) / 2f '(a) = M |
so that
a - xn+1 ≈ M (a - xn)². |
This leads to
a - xn+1 ≈ [M (a - x0)]2n. |
Thus, to insure convergence of the iterations, we need
|M (a - x0)| < 1 |
showing how close to the root the initial approximation x0 should be chosen to insure convergence:
|a - x0| < 1 / |M|. |
An Example
Let's find an approximation to √2. To this end, we may define
xn + 1 = xn - (x²n - 2) / 2xn |
or, after simplifications,
(3) | xn + 1 = ½(xn + 2 / xn). |
Observe that if the iterations converge to a, i.e. if limn→∞xn = a, then it follows from (3) that
a = ½(a + 2 / a) |
implying a² = 2. So let's start with x0 = 1. Then
x1 | = (1 + 2/1) / 2 | |
= 3/2. |
Next,
x2 | = (3/2 + 2/(3/2)) / 2 | |
= (3/2 + 4/3) / 2 | ||
= 17 / 12, etc |
And
x2 | = (17/12 + 2/(17/12)) / 2 | |
= (17/12 + 24/17) / 2 | ||
= (289 + 288) / 408 | ||
= 577 / 408, etc. |
In Java double precision the iterations appear as:
i | xi | ||
---|---|---|---|
0 | 1 | ||
1 | 1.5 | ||
2 | 1.4166666666666665 | ||
3 | 1.4142156862745097 | ||
4 | 1.4142135623746899 | ||
5 | 1.414213562373095 | ||
6 | 1.414213562373095 |
In a similar way, taking f(x) = x² - N yields
(3) | xn + 1 = ½(xn + N / xn). |
as an approximation to √N. The first few iterations may well be calculated by hand.
This method for approximating square roots was known to Heron of Alexandria in the first century A.D. Already then it was possible to argue [The Princeton Companion to Mathematics, p. 110] that, since (xn + N/xn) / 2 is the arithmetic mean of xn and N/xn and since √N lies between xn and N/xn, xn+1 will be close to √N if xn is and may be closer.
References
- K. Atkinson, Elementary Numerical Analysis, John Wiley & Sons, 1985
- T. Gowers (ed.), The Princeton Companion to Mathematics, Princeton University Press, 2008
|Activities| |Contact| |Front page| |Contents| |Algebra|
Copyright © 1996-2018 Alexander Bogomolny
72099736