lmfit模型拟合与预测

2024-09-24 20:27:58 发布

您现在位置:Python中文网/ 问答频道 /正文

我采用lmfit进行曲线拟合,并使用该拟合模型进行预测。但是,下面的代码没有达到我想要的效果。你能帮忙吗?谢谢。在

import numpy as np
from lmfit import Model

def linearModel(x, a0, a1):
    return a0+a1*x

#main code begin here
X=[1,2,4]  # data for fitting
y=[2,4,6]  # data for fitting
gmodel = Model(linearModel)  #select model      
params = gmodel.make_params(a0=1, a1=1) # initial params
result = gmodel.fit(y, params, x=X) # curve fitting
x1=[1, 2, 3] # input for prediction
a=result.eval(x)   # prediction

Tags: 模型importfordatamodela1paramsresult
1条回答
网友
1楼 · 发布于 2024-09-24 20:27:58

最好包括实际运行的代码、得到的结果和预期的结果。在

这里的主要问题是语法错误。其次,应该使用numpy数组,而不是列表。第三,如文档所示(参见https://lmfit.github.io/lmfit-py/model.html#lmfit.model.ModelResult.evalresult.eval()将把params作为第一个参数,而不是自变量。简而言之,您希望将最后两行替换为

x1 = np.array([1, 2, 3]) # input for prediction
a = result.eval(x=x1)   # prediction

这应该会像预期的那样起作用。在

当然,你不需要lmfit来进行线性回归。;). 在

相关问题 更多 >