亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

scipy.optimize curve_fit 的麻煩

scipy.optimize curve_fit 的麻煩

30秒到達戰場 2022-07-19 16:54:31
我在使用 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個贊

有兩個問題:

  1. 功能定義

  2. 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()

輸出:

http://img1.sycdn.imooc.com//62d6716b00012f1905930429.jpg

查看完整回答
反對 回復 2022-07-19
  • 1 回答
  • 0 關注
  • 85 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號