Python scipy.curve_拟合当exp的指数本身具有指数(常数)时不拟合

Python scipy.curve_拟合当exp的指数本身具有指数(常数)时不拟合,python,scipy,curve-fitting,data-fitting,scipy-optimize,Python,Scipy,Curve Fitting,Data Fitting,Scipy Optimize,我试图拟合这条曲线: def logistic2_model(x, a, b, dtau, tau): return a/(1+b*np.exp(-np.power((x-dtau)/tau, 0.9))) 使用曲线拟合 x = [54L, 55L, 56L, 57L, 58L, 59L, 60L, 61L, 62L, 63L, 64L, 65L, 66L, 67L, 68L, 69L, 70L, 71L, 72L, 73L, 74L, 75L, 76L, 77L, 78L, 79L,

我试图拟合这条曲线:

def logistic2_model(x, a, b, dtau, tau):
    return a/(1+b*np.exp(-np.power((x-dtau)/tau, 0.9)))
使用曲线拟合

x = [54L, 55L, 56L, 57L, 58L, 59L, 60L, 61L, 62L, 63L, 64L, 65L, 66L, 67L, 68L, 69L, 70L, 71L, 72L, 73L, 74L, 75L, 76L, 77L, 78L, 79L, 80L, 81L, 82L, 83L, 84L, 85L, 86L, 87L, 88L, 89L, 90L, 91L, 92L, 93L, 94L, 95L, 96L, 97L, 98L, 99L]
y = [229.0, 322.0, 400.0, 650.0, 888.0, 1128.0, 1694.0, 2036.0, 2502.0, 3089.0, 3858.0, 4636.0, 5883.0, 7375.0, 9172.0, 10149.0, 12462.0, 15113.0, 17660.0, 21157.0, 24747.0, 27980.0, 31506.0, 35713.0, 41035.0, 47021.0, 53578.0, 59138.0, 63927.0, 69176.0, 74386.0, 80539.0, 86498.0, 92472.0, 97689.0, 101739.0, 105792.0, 110574.0, 115242.0, 119827.0, 124632.0, 128948.0, 132547.0, 135586.0, 139422.0, 143626.0]

p0 = [1.52646450e+05, 1.56215676e-01, 9.59401246e+01, 6.23161909e+00]
fit = curve_fit(logistic2_model, x, y, maxfev=100000, p0=p0)
它只有在使用1.0时才有效。如果我使用任何其他浮动,即使是接近,它只是到达maxfev而没有成功。对于2.0,它在原则上是可行的,但拟合的曲线没有任何意义

p0是指数等于1.0时获得的拟合:

我最初的目标是将该指数添加到参数中以进行拟合,但如果它不能像那样工作,那就没有希望了


有什么提示吗?

请添加完整的代码,包括绘图

对于测试,请使用1.0的收敛解,并将0.95和1.05的点添加到绘图中。这应该给我们和你们一个想法,你们的方程对这个参数有多敏感。可能是方程变得疯狂了

对于您发布的解决方案(0.9),返回的协方差矩阵仅为
np.inf

文件中说明:

如果解的雅可比矩阵没有满秩,那么 另一方面,“lm”方法返回一个填充了np.inf的矩阵 “trf”和“dogbox”方法使用Moore-Penrose伪逆进行计算 协方差矩阵

您可以使用
method='trf'
method='dogbox'
看看这是否能奏效


但可能至少有两个变量调整相同的事情,并且不是独立的。

我犯了一个天真的错误,没有检查函数的实际值。指数的基数是负数,当然,函数无法拟合。

您能提供
x
y
吗?您可以使用初始猜测绘制数据和模型;很可能是关于
p0
;如果你选择得明智,效果会更好