To start off, this is the problem.
The mathematical constant π (pi) is an irrational number with value approximately 3.1415928… The precise value of π is equal to the following infinite sum: π = 4/1 – 4/3 + 4/5 – 4/7 + 4/9 – 4/11 + … We can get a good approximation of π by computing the sum of the first few terms. Write a function approxPi() that takes as a parameter a floating point value error and approximates the constant π within error by computing the above sum, term by term, until the absolute value of the difference between the current sum and the previous sum (with one fewer terms) is no greater than error. Once the function finds that the difference is less than error, it should return the new sum. Please note that this function should not use any functions or constants from the math module. You are supposed to use the described algorithm to approximate π, not use the built-in value in Python.
I’d really appreciate it if someone could help me understand what the problem is asking, since I’ve read it so many times but still can’t fully understand what it’s saying. I looked through my textbook and found a similar problem for approximating e using e’s infinite sum: 1/0! + 1/1! + 1/2! + 1/3!+…
def approxE(error):
import math
'returns approximation of e within error'
prev = 1 # approximation 0
current = 2 # approximation 1
i = 2 # index of next approximation
while current-prev > error:
#while difference between current and previous
#approximation is too large
#current approximation
prev = current #becomes previous
#compute new approximation
current = prev + 1/math.factorial(i) # based on index i
i += 1 #index of next approximation
return current
I tried to model my program after this, but I don’t feel I’m getting any closer to the solution.
def approxPi(error):
'float ==> float, returns approximation of pi within error'
#π = 4/1 - 4/3 + 4/5 - 4/7 + 4/9 - 4/11 + ...
prev = 4 # 4/1 = 4 : approx 0
current = 2.6666 # 4/1 - 4/3 = 2.6666 : approx 1
i = 5 # index of next approx is 5
while current-prev > error:
prev = current
current = prev +- 1/i
i = i +- 2
return current
The successful program should return
approxPi(0.5) = 3.3396825396825403 and approxPi(0.05) = 3.1659792728432157
Again, any help would be appreciated. I’d like to just understand what I’m doing wrong in this.
If you’re trying to approximate pi using that series, start by writing out a few terms:
And then write a function that returns the nth term of the series:
From there, the code is pretty generic:
It seems to work for me: