關(guān)于多元線性回歸分析——Python&SPSS
原始數(shù)據(jù)在這里
1.觀察數(shù)據(jù)
首先,用Pandas打開數(shù)據(jù),并進行觀察。
import numpy import pandas as pd import matplotlib.pyplot as plt %matplotlib inline data = pd.read_csv('Folds5x2_pp.csv') data.head()
會看到數(shù)據(jù)如下所示:
這份數(shù)據(jù)代表了一個循環(huán)發(fā)電廠,每個數(shù)據(jù)有5列,分別是:AT(溫度), V(壓力), AP(濕度), RH(壓強), PE(輸出電力)。我們不用糾結(jié)于每項具體的意思。
我們的問題是得到一個線性的關(guān)系,對應(yīng)PE是樣本輸出,而AT/V/AP/RH這4個是樣本特征, 機器學(xué)習(xí)的目的就是得到一個線性回歸模型,即: PE=θ0+θ1∗AT+θ2∗V+θ3∗AP+θ4∗RH 而需要學(xué)習(xí)的,就是θ0,θ1,θ2,θ3,θ4這5個參數(shù)。
接下來對數(shù)據(jù)進行歸一化處理:
data = (data - data.mean())/data.std()
因為回歸線的截距θ0是不受樣本特征影響的,因此我們在此可以設(shè)立一個X0=1,使得回歸模型為:
PE=θ0*X0+θ1∗AT+θ2∗V+θ3∗AP+θ4∗RH
將方程向量化可得:
PE = hθ(x) = θx (θ應(yīng)轉(zhuǎn)置)
2.線性回歸
在線性回歸中,首先應(yīng)建立 cost function,當 cost function 的值最小時所取得θ值為所求的θ。
在線性回歸中,Cost function如下所示:
因此,可以在Python中建立函數(shù)求損失方程:
def CostFunction(X,y,theta): inner = np.power((X*theta.T)-y,2) return np.sum(inner)/(2*len(X))
然后,設(shè)初始θ為=[0,0,0,0,0],可得到最初的J(θ)值為0.49994774247491858,代碼如下所示
col = data.shape[1] X = data.iloc[:,0:col-1] y = data.iloc[:,col-1:col] X = np.matrix(X.values) y = np.matrix(y.values) theta = np.matrix(np.array([0,0,0,0,0])) temp = np.matrix(np.zeros(theta.shape)) CostFunction(X,y,theta)
接下來,有兩種方法可以使用。1.梯度下降法(gradient descent)和 2.最小二乘法(normal equation)。在此我們使用梯度下降法來求解。
梯度下降法是求得J對θ的偏導(dǎo)數(shù),通過設(shè)置步長,迭代使J(θ)逐步下降,從而求得局部最優(yōu)解。
公式如下所示:
j:特征編號
m:樣本編號
我們可以在Python中寫出計算迭代后的θ和J(θ)
def gradientDescent(X,y,theta,alpha,iters): temp = np.matrix(np.zeros(theta.shape)) parameters = int(theta.ravel().shape[1]) cost = np.zeros(iters) for i in range(iters): error = (X*theta.T)-y for j in range(parameters): term = np.multiply(error,X[:,j]) temp[0,j] = theta[0,j] - (alpha/len(X))*np.sum(term) theta = temp cost[i] = CostFunction(X,y,theta) return theta,cost
在此,我設(shè)置初始的α為0.1,可求得迭代1000次后θ0,θ1,θ2,θ3,θ4的值分別是:
-5.22080706e-14,-8.63485491e-01,-1.74182863e-01,2.16058120e-02,-1.35205248e-01
此時 J(θ)的值為0.0379648。
通過,可視化J(θ)和迭代次數(shù)可以發(fā)現(xiàn),J(θ)收斂的非常快。
畫圖觀察預(yù)測值和損失值,距離直線約近說明損失越小:
predicted = X*g.T predicted = predicted.flatten().A[0] y_f= y.flatten().A[0] fig, ax = plt.subplots() ax.scatter(y_f,predicted) ax.plot([y.min(), y.max()], [y.min(), y.max()], 'k--', lw=4) ax.set_xlabel('Measured') ax.set_ylabel('Predicted') plt.show()
3.sckit-learn
因為J(θ)收斂的太快了…所以我又用sckit-learn和SPSS驗證了一下。
先看sckit-learn,在sklearn中,線性回歸是使用的最小二乘法而不是梯度下降法,用起來也十分的簡單。
代碼如下:
from sklearn import linear_model model = linear_model.LinearRegression() model.fit(X, y)
打印出θ值后發(fā)現(xiàn)和梯度下降法算出來的相差無幾,θ0,θ1,θ2,θ3,θ4的值分別是:
0,-0.86350078,-0.17417154,0.02160293,-0.13521023
4.SPSS
在看看SPSS
同樣先將數(shù)據(jù)標準化后進行線
然后進行線性回歸分析得到結(jié)果:
嘛…和前面兩種方法的結(jié)果也差不多…就這樣吧。
以上這篇關(guān)于多元線性回歸分析——Python&SPSS就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺析Python數(shù)字類型和字符串類型的內(nèi)置方法
這篇文章主要介紹了Python數(shù)字類型和字符串類型的內(nèi)置方法,本文通過實例代碼講解的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12Python圖像處理庫PIL的ImageFont模塊使用介紹
這篇文章主要介紹了Python圖像處理庫PIL的ImageFont模塊使用介紹,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02Python測試網(wǎng)絡(luò)連通性示例【基于ping】
這篇文章主要介紹了Python測試網(wǎng)絡(luò)連通性,結(jié)合實例形式分析了Python通過發(fā)送ping請求測試網(wǎng)絡(luò)連通性相關(guān)操作技巧,需要的朋友可以參考下2018-08-08python如何獲取網(wǎng)絡(luò)數(shù)據(jù)
這篇文章主要介紹了python如何獲取網(wǎng)絡(luò)數(shù)據(jù),幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下2021-04-04python 列表,數(shù)組,矩陣兩兩轉(zhuǎn)換tolist()的實例
下面小編就為大家分享一篇python 列表,數(shù)組,矩陣兩兩轉(zhuǎn)換tolist()的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04Python中type的構(gòu)造函數(shù)參數(shù)含義說明
這篇文章主要介紹了Python中type的構(gòu)造函數(shù)參數(shù)含義說明,本文用一個編碼實例解釋Python type的參數(shù)的作用和含義,需要的朋友可以參考下2015-06-06python虛擬環(huán)境virualenv的安裝與使用
virtualenv 是一個創(chuàng)建隔絕的Python環(huán)境的工具。virtualenv創(chuàng)建一個包含所有必要的可執(zhí)行文件的文件夾,用來使用Python工程所需的包。下面這篇文章就給大家介紹了python虛擬環(huán)境virualenv的安裝與使用,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-12-12