自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

開發(fā) 后端
polyfit()函數(shù)可以使用最小二乘法將一些點(diǎn)擬合成一條曲線,那么如何添加擬合線并顯示擬合方程與R方?

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

  1. numpy.polyfit(x, y, deg, rcond=Nonefull=Falsew=Nonecov=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ù)號亂碼 
  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() 

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

然后用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() 

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

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

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

 

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

評估指標(biāo)R方

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

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

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

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

其中,

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

利用相關(guān)系數(shù)矩陣計算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) 

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

這里是把結(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) 

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

封裝成函數(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) 

python散點(diǎn)圖:如何添加擬合線并顯示擬合方程與R方?

 

責(zé)任編輯:趙寧寧 來源: 今日頭條
相關(guān)推薦

2017-10-05 13:38:22

LSTM過擬合欠擬合

2022-08-10 15:56:40

機(jī)器學(xué)習(xí)算法深度學(xué)習(xí)

2024-04-29 14:54:36

機(jī)器學(xué)習(xí)過擬合模型人工智能

2023-10-30 10:29:50

C++最小二乘法

2023-05-26 00:31:13

數(shù)據(jù)維度5D散點(diǎn)圖

2019-12-20 09:15:48

神經(jīng)網(wǎng)絡(luò)數(shù)據(jù)圖形

2025-04-27 09:12:42

2012-11-15 16:49:03

GISShapefile

2023-03-06 14:12:47

深度學(xué)習(xí)

2021-01-20 15:30:25

模型人工智能深度學(xué)習(xí)

2018-07-03 09:12:23

深度學(xué)習(xí)正則化Python

2022-04-11 14:04:29

散點(diǎn)圖Harmony操作系統(tǒng)

2017-09-08 10:00:39

PythonR語言開發(fā)

2020-12-27 21:14:06

Python機(jī)器學(xué)習(xí)算法

2021-12-27 10:56:10

MySQL數(shù)據(jù)庫命令

2017-08-19 08:36:25

貝葉斯優(yōu)化超參數(shù)函數(shù)

2020-07-14 10:40:49

Keras權(quán)重約束神經(jīng)網(wǎng)絡(luò)

2011-11-30 16:31:00

TimZon

2025-04-30 01:40:00

回歸CNN機(jī)器學(xué)習(xí)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號