日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Python進行統計建模

瀏覽:30日期:2022-07-14 14:25:00

前言

大家好,在之前的文章中我們已經講解了很多Python數據處理的方法比如讀取數據、缺失值處理、數據降維等,也介紹了一些數據可視化的方法如Matplotlib、pyecharts等,那么在掌握了這些基礎技能之后,要進行更深入的分析就需要掌握一些常用的建模方法,本文將講解如何利用Python進行統計分析。和之前的文章類似,本文只講如何用代碼實現,不做理論推導與過多的結果解釋(事實上常用的模型可以很輕松的查到完美的推導與解析)。因此讀者需要掌握一些基本的統計模型比如回歸模型、時間序列等。

Statsmodels簡介

在Python 中統計建模分析最常用的就是Statsmodels模塊。Statsmodels是一個主要用來進行統計計算與統計建模的Python庫。主要有以下功能:

探索性分析:包含列聯表、鏈式方程多重插補等探索性數據分析方法以及與統計模型結果的可視化圖表,例如擬合圖、箱線圖、相關圖、時間序列圖等 回歸模型:線性回歸模型、非線性回歸模型、廣義線性模型、線性混合效應模型等 其他功能:方差分析、時間序列分析等模型的參數估計與估計參數的假設檢驗等

安裝 brew install Statsmodels 文檔 github.com/statsmodels/statsmodels

線性回歸模型:普通最小二乘估計

線性模型有普通最小二乘(OLS)廣義最小二乘(GLS)、加權最小二乘(WLS)等,Statsmodels對線性模型有較好的支持,來看個最簡單的例子:普通最小二乘(OLS)

首先導入相關包

%matplotlib inlineimport numpy as npimport statsmodels.api as smimport matplotlib.pyplot as pltfrom statsmodels.sandbox.regression.predstd import wls_prediction_stdnp.random.seed(9876789)

然后創建數據,先設置樣本量為100

nsample = 100 #樣本數量

然后設置x1和x2,x1是0到10等差排列,x2是x1的平方

x = np.linspace(0, 10, 100)X = np.column_stack((x, x**2))

再設置beta、誤差項與響應變量y

beta = np.array([1, 0.1, 10])e = np.random.normal(size=nsample)X = sm.add_constant(X)y = np.dot(X, beta) + e

接著建立回歸模型

model = sm.OLS(y, X) results = model.fit()print(results.summary())

查看模型結果

Python進行統計建模

是不是和R語言輸出的結果形式很接近?回歸系數值、P-value、R-squared等評估回歸模型的參數值全部都有,還可以使用dir(results)獲得全部變量的值并調取出來

print(’Parameters: ’, results.params)print(’R2: ’, results.rsquared)

那么回歸模型的就是y=1.3423-0.0402x1+10.0103x2,當然這個模型可以繼續優化那么就交給讀者完成。接下來我們來繪制一下樣本點與回歸曲線

y_fitted = results.fittedvaluesfig, ax = plt.subplots(figsize=(8,6))ax.plot(x, y, ’o’, label=’data’)ax.plot(x, y_fitted, ’r--.’,label=’OLS’)ax.legend(loc=’best’)

Python進行統計建模

時間序列:ARMA

關于時間序列的模型有很多,我們選擇ARMA模型示例,首先導入相關包并生成數據

%matplotlib inlineimport numpy as npimport statsmodels.api as smimport pandas as pdfrom statsmodels.tsa.arima_process import arma_generate_samplenp.random.seed(12345)arparams = np.array([.75, -.25])maparams = np.array([.65, .35])arparams = np.r_[1, -arparams]maparams = np.r_[1, maparams]nobs = 250y = arma_generate_sample(arparams, maparams, nobs)

接著,我們可以添加一些日期信息。對于本例,我們將使用pandas時間序列并建立模型

dates = sm.tsa.datetools.dates_from_range(’1980m1’, length=nobs)y = pd.Series(y, index=dates)arma_mod = sm.tsa.ARMA(y, order=(2,2))arma_res = arma_mod.fit(trend=’nc’, disp=-1)

Python進行統計建模

最后再做一下預測

import matplotlib.pyplot as pltfig, ax = plt.subplots(figsize=(10,8))fig = arma_res.plot_predict(start=’1999-06-30’, end=’2001-05-31’, ax=ax)legend = ax.legend(loc=’upper left’)

Python進行統計建模

回歸診斷:估計回歸模型

首先導入相關包

%matplotlib inlinefrom statsmodels.compat import lzipimport numpy as npimport pandas as pdimport statsmodels.formula.api as smfimport statsmodels.stats.api as smsimport matplotlib.pyplot as plt

然后加載數據

url = ’https://raw.githubusercontent.com/vincentarelbundock/Rdatasets/master/csv/HistData/Guerry.csv’dat = pd.read_csv(url)

擬合模型

results = smf.ols(’Lottery ~ Literacy + np.log(Pop1831)’, data=dat).fit()

查看結果

print(results.summary())

Python進行統計建模

回歸診斷:殘差的正態性

Jarque-Bera test:

name = [’Jarque-Bera’, ’Chi^2 two-tail prob.’, ’Skew’, ’Kurtosis’]test = sms.jarque_bera(results.resid)lzip(name, test)####結果[(’Jarque-Bera’, 3.3936080248431666),(’Chi^2 two-tail prob.’, 0.1832683123166337),(’Skew’, -0.48658034311223375),(’Kurtosis’, 3.003417757881633)]

Omni test:

name = [’Chi^2’, ’Two-tail probability’]test = sms.omni_normtest(results.resid)lzip(name, test)####結果[(’Chi^2’, 3.713437811597181), (’Two-tail probability’, 0.15618424580304824)]

回歸診斷:異方差

Breush-Pagan test:

name = [’Lagrange multiplier statistic’, ’p-value’, ’f-value’, ’f p-value’]test = sms.het_breuschpagan(results.resid, results.model.exog)lzip(name, test)###結果[(’Lagrange multiplier statistic’, 4.893213374093957),(’p-value’, 0.08658690502352209),(’f-value’, 2.503715946256434),(’f p-value’, 0.08794028782673029)]Goldfeld-Quandt test

name = [’F statistic’, ’p-value’]test = sms.het_goldfeldquandt(results.resid, results.model.exog)lzip(name, test)####結果[(’F statistic’, 1.1002422436378152), (’p-value’, 0.3820295068692507)]

回歸診斷:多重共線性

檢查多重共線性可以使用

np.linalg.cond(results.model.exog)

結果是702.1792145490062,說明存在較強多重共線性。

結束語

以上就是Statsmodels的基本功能介紹,如果熟悉R的讀者會發現很多命令與R是類似的。最后想多說一句,全文沒有出現太多模型的理論知識,因為這些模型的推導過程隨便百度一搜都能得到十分詳細的優質回答,因此在學會如何用計算機實現之后必須要回過頭去理解模型里每一個參數是怎樣得到,又有哪些含義才算真正搞定。

以上就是Python進行統計建模的詳細內容,更多關于Python統計建模的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩影片在线观看| 免费在线观看一区| 裤袜国产欧美精品一区| 国产精品成人一区二区不卡| 精品国产一区二区三区2021| 麻豆视频久久| 久久精品国产999大香线蕉| 美女尤物国产一区| а√天堂8资源在线| 亚洲精品.com| 欧美+日本+国产+在线a∨观看| 亚洲精品网址| 亚洲ww精品| 国产精品一区二区99| 国产一区二区三区四区二区| 日韩精品社区| 97精品国产福利一区二区三区| 91欧美日韩| 91精品蜜臀一区二区三区在线| 欧美1区2区3区| 日本伊人久久| 激情综合网站| 国产亚洲一区二区三区不卡| 亚洲激情久久| 国产午夜久久av| 91久久久久| 日韩精品一卡| 久久精品福利| 日本一区二区高清不卡| 日韩精品欧美成人高清一区二区| 91欧美极品| 成人日韩在线观看| 久久一区亚洲| 免费日韩av片| 美日韩一区二区三区| 丰满少妇一区| 亚洲调教视频在线观看| 婷婷综合成人| 精品久久91| 欧美在线影院| 久久精品99久久久| 成人三级高清视频在线看| 欧美1区免费| 在线一区二区三区视频| 免费视频一区二区三区在线观看| 99久久九九| 亚洲精品大全| 久久精品99久久久| 欧美三区四区| 日韩一区精品| 久久激情一区| 国产欧美日韩在线一区二区| 亚洲va在线| 欧美天堂一区二区| 激情综合亚洲| 国产精品v亚洲精品v日韩精品| 蜜桃成人av| 久久丁香四色| 午夜在线视频一区二区区别| 精品日韩一区| 综合亚洲色图| 色偷偷色偷偷色偷偷在线视频| 免费精品视频| 色偷偷色偷偷色偷偷在线视频| 亚洲精品麻豆| 国产精品av久久久久久麻豆网| 国产精品中文字幕亚洲欧美| 国产一区导航| 三级小说欧洲区亚洲区| 日韩激情网站| 日韩视频不卡| 日韩成人三级| 国产精品www994| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲伦乱视频| 久久精品国产福利| 婷婷成人av| 国产拍在线视频| 国产欧美一区二区三区米奇| 老司机精品久久| 久久久国产精品一区二区中文| 国产福利资源一区| 日本在线成人| 好吊视频一区二区三区四区| 国产精品二区不卡| 欧美日本不卡| 日韩影片在线观看| 丝袜脚交一区二区| 今天的高清视频免费播放成人| 欧美激情五月| 日韩精彩视频在线观看| 中文在线不卡| 国产精品99在线观看| 国产精品久av福利在线观看| 天堂av一区| 99视频在线精品国自产拍免费观看| 婷婷综合六月| 日本欧洲一区二区| 日韩精品91| 日本午夜精品久久久| 九一精品国产| 国产成人精品一区二区免费看京| 国产亚洲一区二区三区啪| 亚洲欧美一区在线| 私拍精品福利视频在线一区| 麻豆国产欧美一区二区三区 | 国产亚洲亚洲| 日韩三区免费| 亚洲在线观看| 日本久久二区| 欧洲一级精品| 国产精品亚洲人成在99www| 日韩欧乱色一区二区三区在线| 亚洲高清成人| 青青草伊人久久| 精品国产亚洲日本| 日本欧美一区二区| 蜜臀久久99精品久久久久久9 | 免费不卡中文字幕在线| 亚洲伦乱视频| 欧美日一区二区| 91久久黄色| 丝袜诱惑制服诱惑色一区在线观看| 亚洲一区区二区| 只有精品亚洲| 日韩不卡一二三区| 欧美日韩一区二区国产| 国产欧美自拍一区| 久久精品国产网站| 美女av在线免费看| 色婷婷久久久| 亚洲www啪成人一区二区| 久久久久欧美精品| 99视频精品全部免费在线视频| 欧美a级片一区| 亚洲欧美激情诱惑| 色狠狠一区二区三区| 亚洲专区欧美专区| 欧美日中文字幕| 亚洲欧美日韩国产综合精品二区| 中国女人久久久| 蜜桃视频在线观看一区二区| 黄色精品网站| 蜜桃视频免费观看一区| 日韩一区二区三免费高清在线观看| 欧美视频精品全部免费观看| 日本91福利区| 欧美激情福利| 日韩精品欧美| 免费欧美在线视频| 国产精品亚洲综合久久| 福利片在线一区二区| 黑丝美女一区二区| 五月国产精品| 丰满少妇一区| 99国产精品视频免费观看一公开 | 在线视频观看日韩| 亚洲一区av| 美女久久99| 午夜av成人| 蜜臀av国产精品久久久久| 欧美午夜网站| 亚洲精品一级二级| 亚洲午夜免费| 久久精品二区亚洲w码| 99久久婷婷| 日韩高清不卡一区二区| 国产传媒av在线| 男女男精品视频网| 精品国产一区二区三区2021| 1000部精品久久久久久久久| 日本一区二区三区视频在线看 | 日韩精品一区二区三区中文| 国产精品a级| 亚洲一级影院| 午夜性色一区二区三区免费视频| 日韩欧美看国产| 亚洲人成毛片在线播放女女| 99国产精品一区二区| 国产传媒在线| 香蕉成人av| 精品免费视频| av中文资源在线资源免费观看| 欧美影院精品| 天堂va在线高清一区| 日本在线视频一区二区| 水野朝阳av一区二区三区| 午夜欧美精品久久久久久久| 日韩专区精品| 六月婷婷综合| 亚洲一级高清| 欧美日韩亚洲国产精品| 欧美va亚洲va日韩∨a综合色| 婷婷精品在线| 婷婷亚洲综合| 天堂中文av在线资源库| 丝袜美腿诱惑一区二区三区| 日韩久久精品网| 久久精品国产免费| 日韩精品一二三|