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

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

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

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

  1. numpy.polyfit(x, y, deg, rcond=Nonefull=Falsew=Nonecov=False
  2. # x:要擬合點的橫坐標 
  3. # y:要擬合點的縱坐標 
  4. # deg:自由度.例如:自由度為2,那么擬合出來的曲線就是二次函數,自由度是3,擬合出來的曲線就是3次函數 

首先我們先來構造一下需要被擬合的散點

  1. # 解決坐標軸刻度負號亂碼 
  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散點圖:如何添加擬合線并顯示擬合方程與R方?

然后用polyfit函數來把這些點擬合成一條3次曲線

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

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

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

將擬合后的結果打印一下

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

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

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

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

 

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

評估指標R方

二維散點進行任意函數的最小二乘擬合

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

最小二乘中相關系數與R方的關系推導

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

其中,

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

利用相關系數矩陣計算R方

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

先來看下poly1d函數自帶的輸出結果

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

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

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

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

  1. parameter=[-2.44919641, -0.01856314,  4.12010434,  0.47296566]  #系數 
  2. aa='' 
  3. deg=3 
  4. for i in range(deg+1): 
  5.         bb=round(parameter[i],2)     #bb是i次項系數 
  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散點圖:如何添加擬合線并顯示擬合方程與R方?

封裝成函數

  1. def Curve_Fitting(x,y,deg): 
  2.     parameter = np.polyfit(x, y, deg)    #擬合deg次多項式 
  3.     p = np.poly1d(parameter)             #擬合deg次多項式 
  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)     #原始數據散點圖 
  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)) 

利用封裝的函數重新畫圖

  1. Curve_Fitting(x,y,3) 

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

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2017-10-05 13:38:22

LSTM過擬合欠擬合

2022-08-10 15:56:40

機器學習算法深度學習

2024-04-29 14:54:36

機器學習過擬合模型人工智能

2023-10-30 10:29:50

C++最小二乘法

2023-05-26 00:31:13

數據維度5D散點圖

2025-04-27 09:12:42

2012-11-15 16:49:03

GISShapefile

2019-12-20 09:15:48

神經網絡數據圖形

2023-03-06 14:12:47

深度學習

2021-01-20 15:30:25

模型人工智能深度學習

2018-07-03 09:12:23

深度學習正則化Python

2021-12-27 10:56:10

MySQL數據庫命令

2020-12-27 21:14:06

Python機器學習算法

2022-04-11 14:04:29

散點圖Harmony操作系統

2020-07-14 10:40:49

Keras權重約束神經網絡

2025-04-30 01:40:00

2017-09-08 10:00:39

PythonR語言開發

2011-11-30 16:31:00

TimZon

2017-08-19 08:36:25

貝葉斯優化超參數函數
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产成人麻豆免费观看 | 久久久久中文字幕 | 日韩av电影在线观看 | 日韩视频一区二区在线 | 日韩视频精品在线 | 99热播放| 欧产日产国产精品视频 | 国产成人精品一区二区 | 精品国产免费人成在线观看 | 999精品在线观看 | 美人の美乳で授乳プレイ | 蜜桃视频在线观看免费视频网站www | 一区二区三区在线观看视频 | 伊人伊人 | 国产精品自产av一区二区三区 | 国产在线观看一区二区 | 欧产日产国产精品v | 欧美中文在线 | 人人看人人草 | 国产色片在线 | 日日噜噜噜夜夜爽爽狠狠视频, | 欧美国产日韩一区二区三区 | 欧美精品乱码久久久久久按摩 | 黄色精品 | 欧美成人精品一区二区男人看 | 日本三级在线 | 九九热在线观看视频 | a在线观看 | 亚洲精品99| 久久久精品网站 | 天天曰天天干 | 真人一级毛片 | 在线不卡视频 | av网站在线播放 | 欧美精品被 | 精品网站999 | a级在线免费观看 | 欧美 日韩 综合 | 51ⅴ精品国产91久久久久久 | 国产精品一区二区免费 | 国产日韩精品视频 |