|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
在做那个小练习不知道这个怎么错了。。。我没安numpy,所以想使用62的基础去做63的题。
我看网上说是math。exp的小数太多溢出了,但没教怎么解决
import math
def F(x):
return (math.exp(abs(x))-1)/(math.exp(abs(x))+1)
X = list([-0.9, -0.8, -0.7, -0.6, -0.5, -0.4, -0.3, -0.2, -0.1, 0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])
Y = list([13.1441,11.5536,10.1961,9.0416,8.0625,7.2336,6.5321,5.9376,5.4321,5.0,4.6281,4.3056,4.0241,3.7776,3.5625,3.3776,3.2241,3.1056,3.0281,3.0])
a=b=c=d=e=f=0
for repeat in range(100):
for i in range(20):
c1 = a*(X[i]**5) + b*(X[i]**4) + c*(X[i]**3) + d*(X[i]**2) + e*X[i]
e1 = Y[i] - f - c1
d1 = e1 * F(e1)
a += d1
b += d1
c += d1
d += d1
e += d1
c2 = a*(X[i]**5) + b*(X[i]**4) + c*(X[i]**3) + d*(X[i]**2) + e*X[i] + f
e2 =Y[i]-c2
d2 =e2 * F(e2)
f += d2
print(a,b,c,d,e,f)
|
|