Python實(shí)現(xiàn)批量梯度下降法(BGD)擬合曲線
1. 導(dǎo)入庫
import numpy as np #矩陣運(yùn)算 import matplotlib.pyplot as plt #可視化 import random #產(chǎn)生數(shù)據(jù)擾動
2. 產(chǎn)生數(shù)據(jù)
擬合曲線 y = 2 × x2 + x + 1
X_m = np.mat([[i**2, i, 1] for i in range(-10,10)]) #矩陣類型,用于運(yùn)算 y_m = np.mat([[2*x[0,0]+x[0,1]+1+random.normalvariate(0,1)] for x in X_m]) #矩陣類型,用于運(yùn)算 X_a = np.asarray(X_m[:,1].T)[0] #array類型,用于可視化 y_a = np.asarray(y_m.T)[0] #array類型,用于可視化 plt.scatter(X_a, y_a) #顯示數(shù)據(jù) plt.show()

3. BGD
def BGD(X,y,w0,step,e): #批量梯度下降法
n=0
while n<=10000:
w1 = w0-step*X.T.dot(X.dot(w0)-y)/X.shape[0]
dw = w1-w0;
if dw.dot(dw.T)[0,0] <= e**2:
return w1
n += 1
w0 = w1
return w1
4. 計(jì)算
w_m = BGD(X_m,y_m,np.mat([[5],[3],[2]]),1e-4,1e-20) #可自行調(diào)參 w_a = np.asarray(w_m.T)[0] print(w_a)
array([1.99458492, 0.91587829, 1.48498921])
5. 評價(jià)( R 2)
y_mean = y_a.mean() y_pre = np.array([w_a[0]*x[0,0]+w_a[1]*x[0,1]+w_a[2] for x in X_m]) SSR = ((y_pre-y_mean)**2).sum() SST = ((y_a-y_mean)**2).sum() R2 = SSR/SST print(R2)
0.9845542903194531
我們可以認(rèn)為擬合效果不錯(cuò)。如果 R 2 R^{2} R2的值接近0,可能需要重新調(diào)參。
6. 結(jié)果展示
X = np.linspace(-10,10,50) y = np.array([w_a[0]*x**2+w_a[1]*x+w_a[2] for x in X]) plt.scatter(X_a,y_a) plt.plot(X,y) plt.show()

到此這篇關(guān)于Python實(shí)現(xiàn)批量梯度下降法(BGD)擬合曲線的文章就介紹到這了,更多相關(guān)Python 批量梯度下降內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python中rasterio庫的實(shí)現(xiàn)
Rasterio是一個(gè)用于讀寫光柵數(shù)據(jù)的Python庫,它專注于快速和可靠地處理大規(guī)模地理空間柵格數(shù)據(jù),本文主要介紹了Python中rasterio庫的實(shí)現(xiàn),感興趣的可以了解一下2025-04-04
Python學(xué)習(xí)之configparser模塊的使用詳解
ConfigParser是用來讀取配置文件的包。這篇文章主要通過一些簡單的實(shí)例帶大家了解一下ConfigParser模塊的具體使用,感興趣的小伙伴跟隨小編一起了解一下2023-01-01
一文詳解凱撒密碼的原理及Python實(shí)現(xiàn)
凱撒密碼是古羅馬愷撒大帝用來對軍事情報(bào)進(jìn)行加密的算法,它采用了替換方法對信息中的每一個(gè)英文字符循環(huán)替換為字母表序列該字符后面第三個(gè)字符。本文主要為大家講解了凱撒密碼的原理及實(shí)現(xiàn),需要的可以參考一下2022-08-08
pyspark給dataframe增加新的一列的實(shí)現(xiàn)示例
這篇文章主要介紹了pyspark給dataframe增加新的一列的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
Python進(jìn)階_關(guān)于命名空間與作用域(詳解)
下面小編就為大家?guī)硪黄狿ython進(jìn)階_關(guān)于命名空間與作用域(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05
Github?Copilot結(jié)合python的使用方法詳解
最近也是聽說github出了一種最新的插件叫做copilot,于是申請了,下面這篇文章主要給大家介紹了關(guān)于Github?Copilot結(jié)合python使用的相關(guān)資料,需要的朋友可以參考下2022-04-04
conda配置python虛擬環(huán)境的實(shí)現(xiàn)步驟
本文主要介紹了conda配置python虛擬環(huán)境的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
python selenium 獲取接口數(shù)據(jù)的實(shí)現(xiàn)
這篇文章主要介紹了python selenium 獲取接口數(shù)據(jù)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12

