欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

python之擬合的實現

系統 2013 0

一、多項式擬合

多項式擬合的話,用的的是numpy這個庫的polyfit這個函數。那么多項式擬合,最簡單的當然是,一次多項式擬合了,就是線性回歸。直接看代碼吧

            
import numpy as np
 
def linear_regression(x,y):
 #y=bx+a,線性回歸
 num=len(x)
 b=(np.sum(x*y)-num*np.mean(x)*np.mean(y))/(np.sum(x*x)-num*np.mean(x)**2)
 a=np.mean(y)-b*np.mean(x)
 return np.array([b,a])
def f(x):
 return 2*x+1
x=np.linspace(-5,5)
y=f(x)+np.random.randn(len(x))#加入噪音
y_fit=np.polyfit(x,y,1)#一次多項式擬合,也就是線性回歸
print(linear_regression(x,y))
print(y_fit)
          

手寫線性回歸我還是會的,然后我們來看下輸出:

[1.9937839 1.24167225]
[1.9937839 1.24167225]

由于有random每次顯示的結果都不一樣,但很明顯的是上下兩個print是意料之中的一樣,emmmmm,一次多項式擬合的源代碼應該就是像我寫的那樣。好了,那么一次以上呢?咳咳,我數學不算太好,還是老老實實用庫函數吧,順便畫下圖,見識它的威力。

            
import numpy as np
from matplotlib import pyplot as plt
 
def f(x):
 return x**2+1
def f_fit(x,y_fit):
 a,b,c=y_fit.tolist()
 return a*x**2+b*x+c
x=np.linspace(-5,5)
y=f(x)+np.random.randn(len(x))#加入噪音
y_fit=np.polyfit(x,y,2)#二次多項式擬合
y_show=np.poly1d(y_fit)#函數優美的形式
print(y_show)#打印
y1=f_fit(x,y_fit)
plt.plot(x,f(x),'r',label='original')
plt.scatter(x,y,c='g',label='before_fitting')#散點圖
plt.plot(x,y1,'b--',label='fitting')
plt.title('polyfitting')
plt.xlabel('x')
plt.ylabel('y')
plt.legend()#顯示標簽
plt.show()
          

輸出:

2
1.001 x - 0.04002 x + 0.8952

python之擬合的實現_第1張圖片

擬合效果看起來還是不錯的。

二、各種函數的擬合

一般來說,多項式的擬合就能擬合很多函數了,比如指數函數,取對數就能化為多項式函數,甚至是一次多項式函數。可是,那些三角函數之類的復雜函數不能化為多項式去擬合,怎么辦呢?要用到scipy.optimize的curve_fit函數了。

直接貼代碼:

            
import numpy as np
from matplotlib import pyplot as plt
from scipy.optimize import curve_fit
 
def f(x):
 return 2*np.sin(x)+3
def f_fit(x,a,b):
 return a*np.sin(x)+b
def f_show(x,p_fit):
 a,b=p_fit.tolist()
 return a*np.sin(x)+b
x=np.linspace(-2*np.pi,2*np.pi)
y=f(x)+0.5*np.random.randn(len(x))#加入了噪音
p_fit,pcov=curve_fit(f_fit,x,y)#曲線擬合
print(p_fit)#最優參數
print(pcov)#最優參數的協方差估計矩陣
y1=f_show(x,p_fit)
plt.plot(x,f(x),'r',label='original')
plt.scatter(x,y,c='g',label='before_fitting')#散點圖
plt.plot(x,y1,'b--',label='fitting')
plt.xlabel('x')
plt.ylabel('y')
plt.legend()
plt.show()
          

輸出:

[1.91267059 3.04489528]
[[ 9.06910892e-03 -1.83703696e-11]
[-1.83703696e-11 4.44386331e-03]]

python之擬合的實現_第2張圖片

使用方法基礎的就是這樣了。然后更多詳細的參數的使用就是要看官網了。

1、https://docs.scipy.org/doc/numpy/reference/generated/numpy.polyfit.html

2、https://docs.scipy.org/doc/scipy-0.18.1/reference/generated/scipy.optimize.curve_fit.html

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 日本jizzz| 青青草娱乐视频 | 一区二区三区高清在线观看 | 成年人在线视频网站 | 在线一区视频 | 97国产精品最新 | 久久综合九色综合91 | 狠狠色噜噜狠狠狠狠米奇7777 | 一本一本大道香蕉久在线精品 | 精一区二区| 大开眼界 无删减 | 日韩男人的天堂 | 在线播放亚洲 | 国产一级毛片午夜福 | 国产欧美视频一区二区三区 | 日本三级韩国三级香港三级 | 综合导航 | 色淫湿视频 | 亚洲欧美在线播放 | 99精品视频在线免费观看 | 成人午夜精品久久久久久久小说 | 欧美一级色| 欧美一区二区三区久久久 | 97碰碰在线视视频 | 天天操天天插天天干 | 国产日产久久 | 日韩一区二区三区四区五区 | 人人爱免费在线观看 | 日韩欧美一区二区三区免费观看 | 日韩福利在线 | 色婷婷成人做爰A片免费看网站 | 国产精品无码人妻系列AV | 日韩在线视频观看免费 | 久久国产影院 | 成人国产精品免费视频 | 欧美日韩精品一区二区在线线 | 夜夜夜操操操 | 人人人人澡 | 日本高清色视频在线观看免费 | 久久久久国产视频 | 在线观看日本中文字幕 |