这是我的代码块:
x = [1.6, 2, 2.5, 3.2, 4, 4.5]
y = [2, 8, 14, 15, 8, 2]
r = 2.8
e = []
def err(x, y, r):
n = len(x) - 1
a = y.copy()
for i in range(1, n + 1):
for j in range(n, i - 1, -1):
a[j] = float(a[j] - a[j-1])/float(x[j] - x[j-i])
for k in range(n):
e[k] = float(a[0:k])*float(x[0:k] - r)
return e
这是牛顿多项式插值的误差计算。这是完整的错误消息:
TypeError Traceback (most recent call last)
<ipython-input-3-dafb0d988dac> in <module>()
----> 1 err(x, y, r)
<ipython-input-2-7d51080e7243> in err(x, y, r)
9 a[j] = float(a[j] - a[j-1])/float(x[j] - x[j-i])
10 for k in range(n):
---> 11 e[k] = float(a[0:k])*float(x[0:k] - r)
12 return e
TypeError: float() argument must be a string or a number, not 'list'
我已经待了几个小时了,无法解决此问题。我希望这里有人可以提供帮助(我是Python的新手)。预先感谢。
牛顿插值的误差计算为:
a0*(r-x0), a1*(r-x0)*(r-x1), a1*(r-x0)*(r-x1)*(r-x2) .... a5*(r-x0)*(r-x1)*(r-x2)*(r-x3)*(r-x4)*(r-x5)
(在这种情况下,对于5次多项式,它会一直运行到a5)。
“ a”值包含在列表a
中。此外,x
是一个固定值(在这种情况下,r = 2.8),x0,x1,x2等来自x = [1.6、2、2.5、3.2、4、4.5]