forked from geekpradd/PythonPi
-
Notifications
You must be signed in to change notification settings - Fork 0
/
PythonPi.py
88 lines (73 loc) · 2.06 KB
/
PythonPi.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
"""
Name: pi.py
Purpose: Get the value of Pi to n number of decimal places
Author: Pradipta (geekpradd)
Algorithm: Chudnovsky Algorithm
License: MIT
Module Dependencies:
Math provides fast square rooting
Decimal gives the Decimal data type which is much better than Float
sys is needed to set the depth for recursion.
"""
from __future__ import print_function
import math, sys
from decimal import *
getcontext().rounding = ROUND_FLOOR
sys.setrecursionlimit(100000)
python2 = sys.version_info[0] == 2
if python2:
input = raw_input
def factorial(n):
"""
Return the Factorial of a number using recursion
Parameters:
n -- Number to get factorial of
"""
if not n:
return 1
return n*factorial(n-1)
def getIteratedValue(k):
"""
Return the Iterations as given in the Chudnovsky Algorithm.
k iterations gives k-1 decimal places.. Since we need k decimal places
make iterations equal to k+1
Parameters:
k -- Number of Decimal Digits to get
"""
k = k+1
getcontext().prec = k
sum=0
for k in range(k):
first = factorial(6*k)*(13591409+545140134*k)
down = factorial(3*k)*(factorial(k))**3*(640320**(3*k))
sum += first/down
return Decimal(sum)
def getValueOfPi(k):
"""
Returns the calculated value of Pi using the iterated value of the loop
and some division as given in the Chudnovsky Algorithm
Parameters:
k -- Number of Decimal Digits upto which the value of Pi should be calculated
"""
iter = getIteratedValue(k)
up = 426880*math.sqrt(10005)
pi = Decimal(up)/iter
return pi
def shell():
"""
Console Function to create the interactive Shell.
Runs only when __name__ == __main__ that is when the script is being called directly
No return value and Parameters
"""
print ("Welcome to Pi Calculator. In the shell below Enter the number of digits upto which the value of Pi should be calculated or enter quit to exit")
while True:
print (">>> ", end='')
entry = input()
if entry == "quit":
break
if not entry.isdigit():
print ("You did not enter a number. Try again")
else:
print (getValueOfPi(int(entry)))
if __name__=='__main__':
shell()