Gauss–Legendre algorithm
The Gauss–Legendre algorithm is an algorithm to compute the digits of π. It is notable for being rapidly convergent, with only 25 iterations producing 45 million correct digits of π. However, the drawback is that it is computer memory-intensive and therefore sometimes Machin-like formulas are used instead.
The method is based on the individual work of Carl Friedrich Gauss (1777–1855) and Adrien-Marie Legendre (1752–1833) combined with modern algorithms for multiplication and square roots. It repeatedly replaces two numbers by their arithmetic and geometric mean, in order to approximate their arithmetic-geometric mean.
The version presented below is also known as the Gauss–Euler, Brent–Salamin (or Salamin–Brent) algorithm;[1] it was independently discovered in 1975 by Richard Brent and Eugene Salamin. It was used to compute the first 206,158,430,000 decimal digits of π on September 18 to 20, 1999, and the results were checked with Borwein's algorithm.
Algorithm
1. Initial value setting:
2. Repeat the following instructions until the difference of and is within the desired accuracy:
3. π is then approximated as:
The first three iterations give (approximations given up to and including the first incorrect digit):
The algorithm has quadratic convergence, which essentially means that the number of correct digits doubles with each iteration of the algorithm.
Mathematical background
Limits of the arithmetic–geometric mean
The arithmetic–geometric mean of two numbers, a0 and b0, is found by calculating the limit of the sequences
which both converge to the same limit.
If and then the limit is where is the complete elliptic integral of the first kind
If , , then
where is the complete elliptic integral of the second kind:
- and
Elementary proof with integral calculus
The Gauss-Legendre algorithm can be proven without elliptic modular functions. This is done here[5] and here[6] using only integral calculus.
See also
- Numerical approximations of π
References
- Brent, Richard, Old and New Algorithms for pi, Letters to the Editor, Notices of the AMS 60(1), p. 7
- Brent, Richard (1975), Traub, J F (ed.), "Multiple-precision zero-finding methods and the complexity of elementary function evaluation", Analytic Computational Complexity, New York: Academic Press, pp. 151–176, retrieved 8 September 2007
- Salamin, Eugene, Computation of pi, Charles Stark Draper Laboratory ISS memo 74–19, 30 January 1974, Cambridge, Massachusetts
- Salamin, Eugene (1976), "Computation of pi Using Arithmetic–Geometric Mean", Mathematics of Computation, 30 (135), pp. 565–570, doi:10.2307/2005327, ISSN 0025-5718
- Lord, Nick (1992), "Recent Calculations of π: The Gauss-Salamin Algorithm", The Mathematical Gazette, 76 (476): 231–242, doi:10.2307/3619132, JSTOR 3619132
- Milla, Lorenz (2019), Easy Proof of Three Recursive π-Algorithms, arXiv:1907.04110