我在使用 scipy 優化包擬合曲線時遇到了一些麻煩。我的代碼是:import numpy as npimport matplotlib.pyplot as pltfrom scipy.optimize import curve_fitdef Function_EXD_2(x, d, e): return d*np.exp(-x/e)x = np.array([135, 126, 120, 100, 90, 85, 80, 70, 65, 60])y = np.array([207, 263, 401, 460, 531, 576, 1350, 2317, 2340, 2834])popt, pcov = curve_fit(Function_EXD_2, x, y)print(popt, pcov)我得到 popt = [1,1],所以優化不起作用。我已經在 R 中完成了“相同”,我正在執行 popt = [44237.53, 22.21] aprox。有人可以幫我嗎?
1 回答

largeQ
TA貢獻2039條經驗 獲得超8個贊
有兩個問題:
功能定義
x 數組需要從
0
我已經翻轉了您的數據值并為擬合算法添加了界限
import numpy as np
import matplotlib.pyplot as plt
from scipy.optimize import curve_fit
def func(x, a, b, c):
return a * np.exp(-b * x) + c
x = np.array([135, 126, 120, 100, 90, 85, 80, 70, 65, 60])
y = np.array([207, 263, 401, 460, 531, 576, 1350, 2317, 2340, 2834])
# flip array values
x = x[::-1] - np.amin(x)
y = y[::-1]
# fit function
popt, pcov = curve_fit(func, x, y, bounds=(-10**6, 10**6))
# plot data
x_data = np.linspace(1, 80, 100)
plt.plot(x, y, '.')
plt.plot(x_data, func(x_data, popt[0], popt[1], popt[2]))
plt.show()
輸出:
添加回答
舉報
0/150
提交
取消