国产日韩欧美一区二区三区综合,日本黄色免费在线,国产精品麻豆欧美日韩ww,色综合狠狠操

極客小將

您現在的位置是:首頁 » python編程資訊

資訊內容

學習使用python的statsmodels模塊擬合ARIMA模型

極客小將2021-02-03-
簡介免費學習推薦:python視頻教程導入必要包和模塊fromscipyimportstatsimportpandasaspdimportmatplotlib.pyplotaspltimportstatsmodels.apiassmfromstatsmodels.tsa.arima.modelimpor

極客小將版權所有。

L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

免費學習推薦:python視頻教程L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

導入必要包和模塊L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

from scipy import statsimport pandas as pdimport matplotlib.pyplot as pltimport statsmodels.api as smfrom statsmodels.tsa.arima.model import ARIMAfrom statsmodels.graphics.tsaplots import plot_predict plt.rcParams['font.sans-serif']=['simhei']#用于正常顯示中文標簽plt.rcParams['axes.unicode_minus']=False#用于正常顯示負號

1.讀取數據并畫圖L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

data=pd.read_csv('數據/客運量.csv',index_col=0)data.index = pd.Index(sm.tsa.datetools.dates_from_range('1949', '2008'))#將時間列改為專門時間格式,方便后期操作data.plot(figsize=(12,8),marker='o',color='black',ylabel='客運量')#畫圖

#本文所使用的客流量時間序列數據:https://download.csdn.net/download/weixin_45590329/14143811
#時間序列折線圖如下所示,顯然數據有遞增趨勢,初步判斷數據不平穩L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

2.平穩性檢驗L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

sm.tsa.adfuller(data,regression='c')sm.tsa.adfuller(data,regression='nc')sm.tsa.adfuller(data,regression='ct')

進行三種形式的ADF單位根檢驗,如部分結果所示,發現序列不平穩L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

3.對數據作一階差分處理L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

diff=data.diff(1)diff.dropna(inplace=True)diff.plot(figsize=(12,8),marker='o',color='black')#畫圖

作出數據一階差分后折線圖,初步判斷平穩L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

4.對一階差分數據進行平穩性檢驗L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

sm.tsa.adfuller(diff,regression='c')sm.tsa.adfuller(diff,regression='nc')sm.tsa.adfuller(diff,regression='ct')

如圖所示,說明序列平穩L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

5.確定ARIMA(p,d,q)階數L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

fig = plt.figure(figsize=(12,8))ax1 = fig.add_subplot(211)fig = sm.graphics.tsa.plot_acf(diff.values.squeeze(), lags=12, ax=ax1)#自相關系數圖1階截尾,決定MA(1)ax2 = fig.add_subplot(212)fig = sm.graphics.tsa.plot_pacf(diff, lags=12, ax=ax2)#偏相關系數圖1階截尾,決定AR(1)

根據自相關系數圖ACF和偏自相關系數圖PACF,將原始數據確定為ARIMA(1,1,1)模型L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

6.參數估計L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

model = ARIMA(data, order=(1, 1, 1)).fit()#擬合模型model.summary()#統計信息匯總#系數檢驗params=model.params#系數tvalues=model.tvalues#系數t值bse=model.bse#系數標準誤pvalues=model.pvalues#系數p值#繪制殘差序列折線圖resid=model.resid#殘差序列fig = plt.figure(figsize=(12,8))ax = fig.add_subplot(111)ax = model.resid.plot(ax=ax)#計算模型擬合值fit=model.predict(exog=data[['TLHYL']])

7.模型檢驗L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

#8.1.檢驗序列自相關sm.stats.durbin_watson(model.resid.values)#DW檢驗:靠近2——正常;靠近0——正自相關;靠近4——負自相關#8.2.AIC和BIC準則model.aic#模型的AIC值model.bic#模型的BIC值#8.3.殘差序列正態性檢驗stats.normaltest(resid)#檢驗序列殘差是否為正態分布#**終檢驗結果顯示無法拒絕原假設,說明殘差序列為正態分布,模型擬合良好#8.4.繪制殘差序列自相關圖和偏自相關圖fig = plt.figure(figsize=(12,8))ax1 = fig.add_subplot(211)fig = sm.graphics.tsa.plot_acf(resid.values.squeeze(), lags=12, ax=ax1)ax2 = fig.add_subplot(212)fig = sm.graphics.tsa.plot_pacf(resid, lags=12, ax=ax2)#如果兩圖都零階截尾,這說明模型擬合良好

8.預測L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

#預測至2016年的數據。由于ARIMA模型有兩個參數,至少需要包含兩個初始數據,因此從2006年開始預測predict = model.predict('2006', '2016', dynamic=True)print(predict)#畫預測圖及置信區間圖fig, ax = plt.subplots(figsize=(10,8))fig = plot_predict(model, start='2002', end='2006', ax=ax)legend = ax.legend(loc='upper left')

大量免費學習推薦,敬請訪問python教程(視頻)L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

以上就是學習使用python的statsmodels模塊擬合ARIMA模型的詳細內容,更多請關注少兒編程網其它相關文章!L4N少兒編程網-Scratch_Python_教程_免費兒童編程學習平臺

預約試聽課

已有385人預約都是免費的,你也試試吧...

主站蜘蛛池模板: 延安市| 仙居县| 青河县| 丽江市| 磴口县| 新民市| 南昌市| 洛扎县| 分宜县| 海盐县| 盐亭县| 棋牌| 石门县| 兰坪| 林甸县| 武宣县| 曲靖市| 阿城市| 田东县| 长顺县| 三亚市| 南川市| 淮滨县| 青岛市| 吉林市| 威远县| 南平市| 巴彦淖尔市| 修文县| 达日县| 贡嘎县| 基隆市| 宝丰县| 德令哈市| 穆棱市| 菏泽市| 仪陇县| 兰西县| 内丘县| 通化市| 察隅县|