成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

開(kāi)發(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,那么擬合出來(lái)的曲線就是二次函數(shù),自由度是3,擬合出來(lái)的曲線就是3次函數(shù) 

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

  1. # 解決坐標(biāo)軸刻度負(fù)號(hào)亂碼 
  2. plt.rcParams['axes.unicode_minus'] = False 
  3. # 解決中文亂碼問(wèn)題 
  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ù)來(lái)把這些點(diǎn)擬合成一條3次曲線

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

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

  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方?

評(píng)估指標(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ù)矩陣計(jì)算R方

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

先來(lái)看下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')  # 畫(huà)擬合曲線 
  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ù)重新畫(huà)圖

  1. Curve_Fitting(x,y,3) 

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

 

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

2017-10-05 13:38:22

LSTM過(guò)擬合欠擬合

2022-08-10 15:56:40

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

2024-04-29 14:54:36

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

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)

2020-12-27 21:14:06

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

2021-12-27 10:56:10

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

2020-07-14 10:40:49

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

2025-04-30 01:40:00

2017-09-08 10:00:39

PythonR語(yǔ)言開(kāi)發(fā)

2011-11-30 16:31:00

TimZon

2017-08-19 08:36:25

貝葉斯優(yōu)化超參數(shù)函數(shù)
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 久久久久久久久淑女av国产精品 | 久久国产精品久久久久久 | 中文字幕1区2区 | 中文字幕国产 | 成人一级片在线观看 | 成人免费高清 | 亚洲狠狠丁香婷婷综合久久久 | 久久久久黑人 | 国产在线视频一区二区 | 美女露尿口视频 | 国产精品视频网 | 最新中文字幕一区 | 久久精品16| 欧洲一级毛片 | 亚洲成人av | 91久久久久久 | 亚洲精品视频在线观看视频 | 成人国产精品久久久 | 国产精品久久久久久久久久久免费看 | 夜夜艹天天干 | 欧美精品久久 | 午夜精品一区二区三区免费视频 | 日日操夜夜操天天操 | 亚洲传媒在线 | 国产精品久久久久久久岛一牛影视 | 在线国产欧美 | 狠狠的干 | 久久久久久黄 | 色网站在线免费观看 | 啪一啪在线视频 | 国产一区二区三区免费 | 久久99精品国产99久久6男男 | 欧美一区二区视频 | 国产欧美日韩在线观看 | 国产欧美视频一区二区 | 日韩国产欧美 | 黄色毛片在线看 | 国产一二三视频在线观看 | 久久久久免费观看 | 成年人免费在线视频 | 在线观看国产视频 |