你的代码与公式不匹配。从下一个学期推断一个学期有点太难了;-)这个
1/(5x^5)
术语不是的倍数
1/(3x^3)
学期
下面是直接为公式建模的代码:
from decimal import Decimal
def atan_recip(x):
# Calculate arctan(1/x)
x = Decimal(x)
total = Decimal(0)
sign = 1
for i in range(1, 35, 2):
total += sign / (i * x ** i)
sign = -sign
print(total)
atan_recip(5)
输出符合您的预期:
0.2
0.1973333333333333333333333333
0.1973973333333333333333333333
0.1973955047619047619047619047
0.1973955616507936507936507936
0.1973955597889754689754689754
0.1973955598519908535908535908
0.1973955598498063202575202575
0.1973955598498834214339908457
0.1973955598498806620234645299
0.1973955598498807618878454823
0.1973955598498807582406246127
0.1973955598498807583748423407
0.1973955598498807583698713137
0.1973955598498807583700564416
0.1973955598498807583700495142
0.1973955598498807583700497745