python編程線性回歸代碼示例
用python進行線性回歸分析非常方便,有現(xiàn)成的庫可以使用比如:numpy.linalog.lstsq例子、scipy.stats.linregress例子、pandas.ols例子等。
不過本文使用sklearn庫的linear_model.LinearRegression,支持任意維度,非常好用。
一、二維直線的例子
預(yù)備知識:線性方程y=a∗x+b。y=a∗x+b表示平面一直線
下面的例子中,我們根據(jù)房屋面積、房屋價格的歷史數(shù)據(jù),建立線性回歸模型。
然后,根據(jù)給出的房屋面積,來預(yù)測房屋價格。這里是數(shù)據(jù)來源
import pandas as pd from io import StringIO from sklearn import linear_model import matplotlib.pyplot as plt # 房屋面積與價格歷史數(shù)據(jù)(csv文件) csv_data = 'square_feet,price\n150,6450\n200,7450\n250,8450\n300,9450\n350,11450\n400,15450\n600,18450\n' # 讀入dataframe df = pd.read_csv(StringIO(csv_data)) print(df) # 建立線性回歸模型 regr = linear_model.LinearRegression() # 擬合 regr.fit(df['square_feet'].reshape(-1, 1), df['price']) # 注意此處.reshape(-1, 1),因為X是一維的! # 不難得到直線的斜率、截距 a, b = regr.coef_, regr.intercept_ # 給出待預(yù)測面積 area = 238.5 # 方式1:根據(jù)直線方程計算的價格 print(a * area + b) # 方式2:根據(jù)predict方法預(yù)測的價格 print(regr.predict(area)) # 畫圖 # 1.真實的點 plt.scatter(df['square_feet'], df['price'], color='blue') # 2.擬合的直線 plt.plot(df['square_feet'], regr.predict(df['square_feet'].reshape(-1,1)), color='red', linewidth=4) plt.show()

二、三維平面的例子
預(yù)備知識:線性方程z=a∗x+b∗y+c。z=a∗x+b∗y+c 表示空間一平面
由于找不到真實數(shù)據(jù),只好自己虛擬一組數(shù)據(jù)。
import numpy as np from sklearn import linear_model from mpl_toolkits.mplot3d import Axes3D import matplotlib.pyplot as plt xx, yy = np.meshgrid(np.linspace(0,10,10), np.linspace(0,100,10)) zz = 1.0 * xx + 3.5 * yy + np.random.randint(0,100,(10,10)) # 構(gòu)建成特征、值的形式 X, Z = np.column_stack((xx.flatten(),yy.flatten())), zz.flatten() # 建立線性回歸模型 regr = linear_model.LinearRegression() # 擬合 regr.fit(X, Z) # 不難得到平面的系數(shù)、截距 a, b = regr.coef_, regr.intercept_ # 給出待預(yù)測的一個特征 x = np.array([[5.8, 78.3]]) # 方式1:根據(jù)線性方程計算待預(yù)測的特征x對應(yīng)的值z(注意:np.sum) print(np.sum(a * x) + b) # 方式2:根據(jù)predict方法預(yù)測的值z print(regr.predict(x)) # 畫圖 fig = plt.figure() ax = fig.gca(projection='3d') # 1.畫出真實的點 ax.scatter(xx, yy, zz) # 2.畫出擬合的平面 ax.plot_wireframe(xx, yy, regr.predict(X).reshape(10,10)) ax.plot_surface(xx, yy, regr.predict(X).reshape(10,10), alpha=0.3) plt.show()
效果圖

總結(jié)
以上就是本文關(guān)于python編程線性回歸代碼示例的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
- Python編程實現(xiàn)使用線性回歸預(yù)測數(shù)據(jù)
- 8種用Python實現(xiàn)線性回歸的方法對比詳解
- Python線性回歸實戰(zhàn)分析
- python 機器學(xué)習(xí)之支持向量機非線性回歸SVR模型
- python實現(xiàn)機器學(xué)習(xí)之多元線性回歸
- python 線性回歸分析模型檢驗標準--擬合優(yōu)度詳解
- Python scikit-learn 做線性回歸的示例代碼
- Python數(shù)據(jù)分析之雙色球基于線性回歸算法預(yù)測下期中獎結(jié)果示例
- python用線性回歸預(yù)測股票價格的實現(xiàn)代碼
- python基于numpy的線性回歸
相關(guān)文章
Python優(yōu)化技巧之利用ctypes提高執(zhí)行速度
ctypes是Python的一個外部庫,提供和C語言兼容的數(shù)據(jù)類型,可以很方便地調(diào)用C DLL中的函數(shù)。今天我們就來詳細探討下ctypes庫的使用技巧2016-09-09
Python中的字符串類型基本知識學(xué)習(xí)教程
這篇文章主要介紹了Python中的字符串類型基本知識學(xué)習(xí)教程,包括轉(zhuǎn)義符和字符串拼接以及原始字符串等基礎(chǔ)知識講解,需要的朋友可以參考下2016-02-02
5個Python使用F-String進行格式化的實用技巧分享
F-String(格式化字符串字面值)是在Python?3.6中引入的,它是一種非常強大且靈活的字符串格式化方法,本文總結(jié)了5個實用的F-String技巧,相信一定能讓你的代碼輸出更加的美觀,快跟隨小編一起學(xué)習(xí)起來吧2024-03-03
python實現(xiàn)mysql的單引號字符串過濾方法
這篇文章主要介紹了python實現(xiàn)mysql的單引號字符串過濾方法,以一個較為詳細的實例形式分析了Python針對MySQL的操作及字符串過濾的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-11-11
詳解Django中views數(shù)據(jù)查詢使用locals()函數(shù)進行優(yōu)化
這篇文章主要介紹了Django中views數(shù)據(jù)查詢使用locals()函數(shù)進行優(yōu)化,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08

