scipy.optimize curve_fit返回错误的值

时间:2012-09-06 15:48:36

标签: python scipy curve-fitting

我试图用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

我做错了什么?

2 个答案:

答案 0 :(得分:3)

当它们具有不同的含义时,不要使用xX作为变量名称(或者您可能不知道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]]))