산술 기하 평균을 이용한 원주율의 계산
이 항목의 스프링노트 원문주소
개요
- 산술기하평균함수(AGM, arithmetic-geometric mean)을 활용하여 파이값을 빠르게 계산할 수 알고리즘
타원적분
- 타원적분 항목 참조
\(K(k) = \int_0^{\frac{\pi}{2}} \frac{d\theta}{\sqrt{1-k^2 \sin^2\theta}}\)
\(E(k) = \int_0^{\frac{\pi}{2}} \sqrt{1-k^2 \sin^2\theta}}d\theta}{\)
\(k'=\sqrt{1-k^2}=\frac{\theta_4^2(\tau)}{\theta_3^2(\tau)}\)
\(K'(k) = K(k')\)
\(E'(k) = E(k')\)
타원적분에 대한 르장드르 항등식
- 르장드르 항등식
\(E(k)K'(k)+E'(k)K(k)-K(k)K'(k)=\frac{\pi}{2}\)
- 특별히 다음과 같은 관계가 성립함
\(2K(\frac{1}{\sqrt{2}})E(\frac{1}{\sqrt{2}})-K(\frac{1}{\sqrt{2}})^2=\frac{\pi}{2}\)
- 타원적분 항목 참조
산술기하평균함수
- 양수 k가 주어졌을 때, 산술기하평균을 이용하여 다음과 같이 두 수열을 정의할 수 있다
 \(a_0=1\), \(b_0=\sqrt{1-k^2}\), \(a_{n+1}={a_n+b_n \over 2}\), \(b_{n+1}=\sqrt{a_n b_n}\)
- 두 수열 \(a_n\)과 \(b_n\)은 같은 수로 수렴한다
- 이 수렴값 \(M(k)\)를 이용하여 정의된 함수 M을 산술기하평균함수라 하자
렘니스케이트 곡선과 파이
- 렘니스케이트(lemniscate) 곡선과 타원적분 에서 다음을 알 수 있다
 \(\frac{\omega}{2}=\frac{1}{\sqrt{2}}K(\frac{1}{\sqrt2})\)
 \(\frac{\pi}{\omega}=M(1,{\sqrt2})\)
타원적분과 AGM의 관계
- 위의 렘니스케이트에 등장하는 공식 또는 란덴변환(Landen's transformation) 에 의해 다음이 성립함.
\(K(k)=\frac{\pi}{2M(1,\sqrt{1-k^2})}\)
특별히, \(K(\frac{1}{\sqrt2})=\frac{\pi}{2M(1,\frac{1}{\sqrt2})}\)
- AGM 수열과 타원적분
 \(a_{n+1}={a_n+b_n \over 2}\), \(b_{n+1}=\sqrt{a_n b_n}\) , \(a_0=1\), \(b_0=\sqrt{1-k^2}\) , \(c_n=\sqrt{a_n^2-b_n^2}\)
\(\sum_{i=0}^{\infty} 2^{i-1} c_i^2 = 1 - \frac{E(k)}{K(k)}\)
가우스-살라민 알고리즘
다음과 같이 수열 \(a_n,b_n,c_n,\pi_n\)을 정의하자.
\(a_0=1\), \(b_0=\frac{1}{\sqrt{2}}\)
\(c_n=\sqrt{a_n^2-b_n^2}=\frac{c_{n-1}^2}{4a_n}\)
\(\pi_n=\frac{2a_{n+1}^2}{1-\sum_{k=0}^{n} 2^kc_k^2}\)
수열 \(\pi_n\)은 \(\pi\)로 수렴한다.
(증명)
\(M=M(1,1/\sqrt{2})\), \(K=K(1/\sqrt{2})\), \(E=E(1/\sqrt{2})\)로 두면,
\(2KE-K^2=\frac{\pi}{2}\) 즉, \(\frac{2E}{K}-1=\frac{\pi}{2K^2}\)
\(2MK=\pi\)
\(\sum_{i=0}^{\infty} 2^{i-1} c_i^2 = 1 - \frac{E}{K}\)이다.
따라서
\(\lim_{n\to \infty}\pi_n=\frac{2M^2}{1-2(1-E/K)}=\frac{2M^2}{{\pi}/{2K^2}}=\frac{\pi^2/2K^2}{{\pi}/{2K^2}}=\pi\)■
- 수열 \(\pi_n\)의 처음 여섯항을 계산한 결과
 3.1405792505221682483113312689758233117734402375129
 3.1415926462135422821493444319826957743144372233456
 3.1415926535897932382795127748018639743812255048354
 3.1415926535897932384626433832795028841971146782836
 3.1415926535897932384626433832795028841971693993751
 3.1415926535897932384626433832795028841971693993751
또다른 알고리즘
\(x_0=\sqrt{2}\) ,\(\pi_0=2+\sqrt{2}}\), \(y_1=\sqrt[4]{2}\)
\(x_n=\frac{1}{2}(\sqrt{x_n}+\frac{1}{\sqrt{x_n}})}, n\geq0\) , \(y_n=\frac{y_{n+1}\sqrt{x_n}+\frac{1}{\sqrt{x_{n}}}}{y_n+1}}, n\geq1\) , \(\pi_n=\pi_{n-1}\frac{x_n+1}{y_n+1}}, n\geq1\)
- 위에 정의된 수열 \(\pi_n\)은 파이로 수렴하게 된다. 다음은 처음 여섯개의 항을 계산한 결과.
3.1426067539416226007907198236183018919713562462772
3.1415926609660442304977522351203396906792842568645
3.1415926535897932386457739917571417940347896238675
3.1415926535897932384626433832795028841972241204666
 3.1415926535897932384626433832795028841971693993751
 3.1415926535897932384626433832795028841971693993751
- 한번씩 계산할 때마다, 대략 두 배 정도 정확한 자리수
- 9번째까지 계산한다면, 1000자리 이상의 파이값을 계산
- 매쓰매티카 코드
 - x[0]:=Sqrt[2]
 p[0]:=2+Sqrt[2]
 y[1]:=Power[2,(4)^-1]
 x[n_]:=1/2 (Sqrt[x[n-1]]+1/Sqrt[x[n-1]])
 y[n_]:=(y[n-1] Sqrt[x[n-1]]+1/Sqrt[x[n-1]])/(y[n-1]+1)
 p[n_]:=p[n-1] (x[n]+1)/(y[n]+1)
 Table[N[p[i],50],{i,1,10}]//TableForm
 
- x[0]:=Sqrt[2]
관련된 학부 과목과 미리 알고 있으면 좋은 것들
관련된 대학원 과목
관련된 항목들
관련도서
- Pi and the AGM
 - Jonathan M. Borwein, Peter B. Borwein, 1998
 
위키링크
- http://en.wikipedia.org/wiki/Arithmetic-geometric_mean
- http://en.wikipedia.org/wiki/Salamin-Brent_algorithm
관련논문
- Multiple-precision zero-finding methods and the complexity of elementary function evaluation
 - R. P. Brent, Analytic Computational Complexity (edited by J. F. Traub), Academic Press, New York, 1975, 151–176
 
- The arithmetic-geometric mean of Gauss (pdf)
 - D.A. Cox, Enseignement Math. 30 (1984) 275-330
 
- Gauss and the arithmetic-geometric mean
 - D.A. Cox, Notices Amer. Math. Soc. 32(2) (1985) 147-151
 
- Gauss, Landen, Ramanujan, the Arithmetic-Geometric Mean, Ellipses, π, and the Ladies Diary
 - Gert Almkvist and Bruce Berndt
- The American Mathematical Monthly, Vol. 95, No. 7 (Aug. - Sep., 1988), pp. 585-608
 
- Ramanujan, Modular Equations, and Approximations to Pi or How to Compute One Billion Digits of Pi
 - J. M. Borwein, P. B. Borwein and D. H. Bailey, The American Mathematical Monthly, Vol. 96, No. 3 (Mar., 1989), pp. 201-219
 
- Recent Calculations of π: The Gauss-Salamin Algorithm
 - Nick Lord, The Mathematical Gazette, Vol. 76, No. 476 (Jul., 1992), pp. 231-242
 
- The Ubiquitous π
 - Dario Castellanos, Mathematics Magazine, Vol. 61, No. 2 (Apr., 1988), pp. 67-98
 
- The Arithmetic-Geometric Mean and Fast Computation of Elementary Functions
 - J. M. Borwein and P. B. Borwein, SIAM Review, Vol. 26, No. 3 (Jul., 1984), pp. 351-366
 
- Computation of pi Using Arithmetic-Geometric Mean (pdf)
 - E. Salamin, Mathematics of Computation 30(1976) 565-570