Benjamin Peterson | 90f5ba5 | 2010-03-11 22:53:45 +0000 | [diff] [blame^] | 1 | #! /usr/bin/env python3 |
Guido van Rossum | ec758ea | 1991-06-04 20:36:54 +0000 | [diff] [blame] | 2 | |
| 3 | # Print digits of pi forever. |
| 4 | # |
| 5 | # The algorithm, using Python's 'long' integers ("bignums"), works |
| 6 | # with continued fractions, and was conceived by Lambert Meertens. |
| 7 | # |
| 8 | # See also the ABC Programmer's Handbook, by Geurts, Meertens & Pemberton, |
| 9 | # published by Prentice-Hall (UK) Ltd., 1990. |
| 10 | |
| 11 | import sys |
| 12 | |
| 13 | def main(): |
Collin Winter | 6f2df4d | 2007-07-17 20:59:35 +0000 | [diff] [blame] | 14 | k, a, b, a1, b1 = 2, 4, 1, 12, 4 |
Georg Brandl | 38c34ef | 2009-10-10 21:13:21 +0000 | [diff] [blame] | 15 | while True: |
Moshe Zadka | 38e083b | 2001-02-20 16:13:43 +0000 | [diff] [blame] | 16 | # Next approximation |
Collin Winter | 6f2df4d | 2007-07-17 20:59:35 +0000 | [diff] [blame] | 17 | p, q, k = k*k, 2*k+1, k+1 |
Moshe Zadka | 38e083b | 2001-02-20 16:13:43 +0000 | [diff] [blame] | 18 | a, b, a1, b1 = a1, b1, p*a+q*a1, p*b+q*b1 |
| 19 | # Print common digits |
Benjamin Peterson | d7b0328 | 2008-09-13 15:58:53 +0000 | [diff] [blame] | 20 | d, d1 = a//b, a1//b1 |
Moshe Zadka | 38e083b | 2001-02-20 16:13:43 +0000 | [diff] [blame] | 21 | while d == d1: |
| 22 | output(d) |
Collin Winter | 6f2df4d | 2007-07-17 20:59:35 +0000 | [diff] [blame] | 23 | a, a1 = 10*(a%b), 10*(a1%b1) |
Benjamin Peterson | d7b0328 | 2008-09-13 15:58:53 +0000 | [diff] [blame] | 24 | d, d1 = a//b, a1//b1 |
Guido van Rossum | ec758ea | 1991-06-04 20:36:54 +0000 | [diff] [blame] | 25 | |
Guido van Rossum | 0b2b440 | 1992-08-31 10:54:17 +0000 | [diff] [blame] | 26 | def output(d): |
Moshe Zadka | 38e083b | 2001-02-20 16:13:43 +0000 | [diff] [blame] | 27 | # Use write() to avoid spaces between the digits |
Moshe Zadka | 38e083b | 2001-02-20 16:13:43 +0000 | [diff] [blame] | 28 | sys.stdout.write(str(d)) |
| 29 | # Flush so the output is seen immediately |
| 30 | sys.stdout.flush() |
Guido van Rossum | 0b2b440 | 1992-08-31 10:54:17 +0000 | [diff] [blame] | 31 | |
Johannes Gijsbers | 7a8c43e | 2004-09-11 16:34:35 +0000 | [diff] [blame] | 32 | if __name__ == "__main__": |
| 33 | main() |