我试图用scipy来适应一个特定的功能,我得到了奇怪的结果。我决定测试一些我知道答案的东西,所以我创造了这个:
from scipy.optimize import curve_fit as cf
import numpy as np
import random
def func(x,a):
return a+X
X =[]
for i in range (10):
V = random.random()
X.append(i+3 + V/10)
print cf(func, np.array(range(10)),np.array(X))
我预计会得到3左右的东西,不过,这里是输出:
(array([ -2.18158824e-12]), inf)
作为旁注,我试图看看我向func
发送了什么,我得到了这个:
print func(np.array(range(10)),3)
Traceback (most recent call last):
File "/tmp/py1759O-P", line 16, in <module>
print func(np.array(range(10)),3)
File "/tmp/py1759O-P", line 6, in func
return a+X
TypeError: unsupported operand type(s) for +: 'int' and 'list
我做错了什么?
答案 0 :(得分:3)
当它们具有不同的含义时,不要使用x
和X
作为变量名称(或者您可能不知道Python区分大小写?):
def func(x,a):
return a+X
X =[]
x
是一个numpy数组,X
是一个列表,a
是一个标量参数值。
a+X
会导致错误,因为您无法将标量添加到列表中。
答案 1 :(得分:1)
在func中,参数为x
,但X
用于函数体中。
以下是您的代码的修改版本。它使用numpy的更多功能(例如np.random.random()而不是random.random())。
from scipy.optimize import curve_fit as cf
import numpy as np
def func(x, a):
return a + x
n = 10
xdata = np.arange(n)
ydata = func(xdata, 3) + np.random.random(n) / 10
print cf(func, xdata, ydata)
输出
(array([ 3.04734293]), array([[ 8.19208558e-05]]))