日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

polyfit()函數(shù)可以使用最小二乘法將一些點(diǎn)擬合成一條曲線。

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序定制開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了桐柏免費(fèi)建站歡迎大家使用!

 
 
 
  1. numpy.polyfit(x, y, deg, rcond=None, full=False, w=None, cov=False) 
  2. # x:要擬合點(diǎn)的橫坐標(biāo) 
  3. # y:要擬合點(diǎn)的縱坐標(biāo) 
  4. # deg:自由度.例如:自由度為2,那么擬合出來的曲線就是二次函數(shù),自由度是3,擬合出來的曲線就是3次函數(shù) 

首先我們先來構(gòu)造一下需要被擬合的散點(diǎn)

 
 
 
  1. # 解決坐標(biāo)軸刻度負(fù)號(hào)亂碼 
  2. plt.rcParams['axes.unicode_minus'] = False 
  3. # 解決中文亂碼問題 
  4. plt.rcParams['font.sans-serif'] = ['Simhei'] 
  5.  
  6. import numpy as np 
  7. import matplotlib.pyplot as plt 
  8. x = np.arange(-1, 1, 0.02) 
  9. y = 2 * np.sin(x * 2.3) + np.random.rand(len(x)) 

然后打印一下看看

 
 
 
  1. plt.scatter(x, y) 
  2. plt.show() 

然后用polyfit函數(shù)來把這些點(diǎn)擬合成一條3次曲線

 
 
 
  1. parameter = np.polyfit(x, y, 3) 

輸出的結(jié)果為3次方程的參數(shù),我們可以像下面這樣把方程拼接出來

 
 
 
  1. y2 = parameter[0] * x ** 3 + parameter[1] * x ** 2 + parameter[2] * x + parameter[3] 

將擬合后的結(jié)果打印一下

 
 
 
  1. plt.scatter(x, y) 
  2. plt.plot(x, y2, color='g') 
  3. plt.show() 

還可以使用poly1d()函數(shù)幫我們拼接方程,結(jié)果是一樣的

 
 
 
  1. p = np.poly1d(parameter) 
  2. plt.scatter(x, y) 
  3. plt.plot(x, p(x), color='g') 
  4. plt.show() 

 

評(píng)估指標(biāo)R方

二維散點(diǎn)進(jìn)行任意函數(shù)的最小二乘擬合

最小二乘中相關(guān)系數(shù)與R方的關(guān)系推導(dǎo)

其中,

利用相關(guān)系數(shù)矩陣計(jì)算R方

 
 
 
  1. correlation = np.corrcoef(y, y2)[0,1]  #相關(guān)系數(shù) 
  2. correlation**2   #R方 

先來看下poly1d函數(shù)自帶的輸出結(jié)果

 
 
 
  1. p = np.poly1d(parameter,variable='x') 
  2. print(p) 

這里是把結(jié)果輸出到兩行里了,但是輸出到兩行是非常不方便的

嘗試下自己編寫函數(shù),使輸出到一行里

 
 
 
  1. parameter=[-2.44919641, -0.01856314,  4.12010434,  0.47296566]  #系數(shù) 
  2. aa='' 
  3. deg=3 
  4. for i in range(deg+1): 
  5.         bb=round(parameter[i],2)     #bb是i次項(xiàng)系數(shù) 
  6.         if bb>=0: 
  7.             if i==0: 
  8.                 bb=str(bb) 
  9.             else: 
  10.                 bb=' +'+str(bb) 
  11.         else: 
  12.             bb=' '+str(bb) 
  13.         if deg==i: 
  14.             aaaa=aa+bb 
  15.         else: 
  16.             aaaa=aa+bb+'x^'+str(deg-i) 
  17. print(aa) 

封裝成函數(shù)

 
 
 
  1. def Curve_Fitting(x,y,deg): 
  2.     parameter = np.polyfit(x, y, deg)    #擬合deg次多項(xiàng)式 
  3.     p = np.poly1d(parameter)             #擬合deg次多項(xiàng)式 
  4.     aa=''                               #方程拼接  —————————————————— 
  5.     for i in range(deg+1):  
  6.         bb=round(parameter[i],2) 
  7.         if bb>0: 
  8.             if i==0: 
  9.                 bb=str(bb) 
  10.             else: 
  11.                 bb='+'+str(bb) 
  12.         else: 
  13.             bb=str(bb) 
  14.         if deg==i: 
  15.             aaaa=aa+bb 
  16.         else: 
  17.             aaaa=aa+bb+'x^'+str(deg-i)    #方程拼接  —————————————————— 
  18.     plt.scatter(x, y)     #原始數(shù)據(jù)散點(diǎn)圖 
  19.     plt.plot(x, p(x), color='g')  # 畫擬合曲線 
  20.    # plt.text(-1,0,aa,fontdict={'size':'10','color':'b'}) 
  21.     plt.legend([aa,round(np.corrcoef(y, p(x))[0,1]**2,2)])   #拼接好的方程和R方放到圖例 
  22.     plt.show() 
  23. #    print('曲線方程為:',aa) 
  24. #    print('     r^2為:',round(np.corrcoef(y, p(x))[0,1]**2,2)) 

利用封裝的函數(shù)重新畫圖

 
 
 
  1. Curve_Fitting(x,y,3) 

網(wǎng)站名稱:python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?
轉(zhuǎn)載注明:http://www.dlmjj.cn/article/cddsdde.html