【发布时间】:2018-02-18 20:04:44
【问题描述】:
我正在尝试用给定的数据将曲线拟合到下面的等式中。等式是Rate=k*Concentration^n。我遇到了麻烦,因为安装时的n 是-6,这是不可能的,所以我试图在min=0 设置一个界限。但是,我收到未定义的术语参数错误。任何帮助都会非常感谢。
from IPython import get_ipython
get_ipython().magic('reset -sf')
import numpy as np
from lmfit import Model
import matplotlib.pyplot as plt
# Homework Problem #2
Time = np.array ([0, 48, 76, 124, 204, 238, 289])
Concentration =np.array ([19.04, 17.6, 16.9, 15.8, 14.41, 13.94, 13.37])
# Rate Determination
Rate=Concentration/Time
# Model Definition
def rateEq(Concentration, k, n):
return k*(Concentration)**n
# Model creation
model=Model(rateEq)
# Parameters
params = parameters()
params.add(k=0.001)
params.add(n=0.001)
par.set(min=0)
# Data Fit v
result=model.fit(Rate, params, Concentration=Concentration)
# Print and Plot Results
print(result.fit_report())
result.plot_fit()
【问题讨论】:
-
我对您的问题进行了一些改进,等待批准。通过修改您的问题在我进行编辑的地方发布您的错误代码。欢迎来到 SO,完成游览并享受 SO ;-)
标签: python numpy matplotlib lmfit