基本概念

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

p: 自回归阶数
q: 滑动平均阶数
d: 时间序列成为平稳时所做的差分次数

AR - Auto Regression, 自回归模型:AR可以解决当前数据与后期数据之间的关系;表示为自回归模型 AR( p )
在这里插入图片描述在这里插入图片描述

MA - Moving Average,移动平均模型:MA则可以解决随机变动也就是噪声的问题;表示为移动平均模型 MA(q)
在这里插入图片描述
在这里插入图片描述

ARMA - Auto Regression and Moving Average,自回归移动平均模型。自回归移动平均模型(ARMA)是与自回归(AR)和移动平均模型(MA)两部分组成;表示为ARMA(p, d)。(以上三类模型可以直接应用于平稳时间序列模型)
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

ARIMA - Auto Regression Integreate Moving Average,差分自回归移动平均模型。同前面的三种模型,ARIMA模型也是基于平稳的时间序列的或者差分化后是稳定的,另外前面的几种模型都可以看作ARIMA的某种特殊形式。表示为ARIMA(p, d, q)。(前面三种模型,d=0,即平稳时间序列模型不需要做差分)
ARIMA模型是在ARMA模型演变出来的,它实际上是先对数据做了差分,之后再使用ARMA模型;换句话说,ARIMA模型是先将非平稳数据变得平稳(用差分),之后再用ARMA模型处理平稳数据在这里插入图片描述在这里插入图片描述

在这里插入图片描述





基本流程

导入模型

import sys
import os
import warnings
warnings.filterwarnings("ignore")
import pandas as pd
import numpy as np
from arch.unitroot import ADF
import matplotlib.pylab as plt
%matplotlib inline
from matplotlib.pylab import style
style.use('ggplot')
import statsmodels.api as sm
import statsmodels.formula.api as smf
import statsmodels.tsa.api as smt
from statsmodels.tsa.stattools import adfuller 
from statsmodels.stats.diagnostic import acorr_ljungbox 
from statsmodels.graphics.api import qqplot
pd.set_option('display.float_format', lambda x: '%.5f' % x) 
np.set_printoptions(precision=5, suppress=True) 
"""中文显示问题"""
plt.rcParams['font.family'] = ['sans-serif']
plt.rcParams['font.sans-serif'] = ['SimHei']

在这里插入图片描述








AR、MA和ARMA模型都必须是 “平稳非白噪声序列”,所以需要 “平稳性检验“ 和 “白噪声检验”

1.平稳性检验

1)什么是序列平稳

在这里插入图片描述





2)检验是否平稳

第一和第二种方式很直观,但也很主观。它们全靠肉眼的判断和判断人的经验,不同的人看到同样的图形,很可能会给出不同的判断。
大部分情况选择第三种方法:单位根检验




方法一:观察序列图:若个体值要围绕序列均值上下波动,没有明显的上升或下降趋势,则是平稳序列。

如果出现上升或下降趋势,需要对原始序列进行差分平稳化处理在 3)不平稳序列转平稳序列部分,会讲如何差分平稳化

在这里插入图片描述






方法二:观察自相关图:平稳的序列的自相关图(ACF)偏相关图(PACF)不是拖尾就是截尾。

拖尾:始终有非零取值,不会在k大于某个常数后就恒等于零(或在0附近随机波动),顾名思义,就是序列缓慢衰减,“尾巴”慢慢拖着滑下来,:
截尾:在大于某个常数k后快速趋于0为k阶截尾,突然截断了,像个悬崖

在这里插入图片描述
这张图可以看出,左图(自相关函数图)呈现出拖尾特征(2阶拖尾),而右图(偏自相关函数图)呈现出截尾特征(2阶截尾)

在这里插入图片描述
这张图可以看出,左图(自相关函数图)呈现出截尾特征(1阶截尾),而右图(偏自相关函数图)呈现出拖尾特征(1阶拖尾)

在这里插入图片描述
这张图可以看出,左图(自相关函数图)呈现出拖尾特征(2阶拖尾),右图(偏自相关函数图)也呈现出拖尾特征(1阶拖尾)







方法三:单位根检验:当一个时间序列的滞后算子多项式方程存在单位根时,我们认为该时间序列是非平稳的;反之,当该方程不存在单位根时,我们认为该时间序列是平稳的。在这里插入图片描述

常见的单位根检验方法有DF检ADF检验PP检验,今天我们会用ADF检验来为大家演示
在Python中,有两个常用的包提供了ADF检验,分别是statsmodel和arch。

第一种方法:使用statsmodel的方法为:
from statsmodels.stats.diagnostic import unitroot_adf

unitroot_adf(df.pct_chg)
输出为:
这里包含了检验值、p-value、滞后阶数、自由度等信息。
我们看到了检验统计量为-14.46,远小于1%的临界值-3.47,即p值远小于0.01,因此我们拒绝原假设,认为该时间序列是平稳的。(这里原假设是存在单位根,即时间序列为非平稳的。)



第二种方法:使用arch的方法为:
from arch.unitroot import ADF

ADF(df.pct_chg)

其输出信息与statsmodel基本是一致的。

其他案例使用方法二

print("单位根检验:\n")
print(ADF(data.diff1.dropna()))  
单位根检验:

   Augmented Dickey-Fuller Results   
=====================================
Test Statistic                 -3.156
P-value                         0.023
Lags                                0
-------------------------------------

Trend: Constant
Critical Values: -3.63 (1%), -2.95 (5%), -2.61 (10%)
Null Hypothesis: The process contains a unit root.
Alternative Hypothesis: The process is weakly stationary.

单位根检验: 对其一阶差分进行单位根检验,得到:1%、%5、%10不同程度拒绝原假设的统计值和ADF Test result的比较,本数据中,P-value 为 0.023,接近0,ADF Test result同时小于5%、10%即说明很好地拒绝该假设,本数据中,ADF结果为-3.156,拒绝原假设,即一阶差分后数据是平稳的。





方法四:以上几个方法融合,即几种方法都做:结果更具有说服力
1.绘制时序图,观察是否存在波动和向上或向下的趋势
2.做相关系数图,若随时间间隔 k 增大,自相关系数迅速衰减则序列平稳;若随时间间隔 k 增大,自相关系数衰减缓慢则序列不平稳
3.进行单位根检验,P-值<α时,拒绝存在单位根的原假设,序列平稳。





3)不平稳序列转为平稳序列

取对数可以消除数据波动变大趋势
对数列进行差分,可以消除数据增长趋势性季节性

对于非平稳序列,如果先进行差分后的结果不满足要求,则需要在原有基础上继续进行差分,直到差分后的结果属于平稳性序列

方法:差分变换

fig = plt.figure(figsize=(12,8))
ax1= fig.add_subplot(111)
diff1 = dta.diff(1)
diff1.plot(ax=ax1)

在这里插入图片描述
从下图可以看出,预测数列取对数并作一阶差分后的图形
在这里插入图片描述

选择其中一个检验方法,检验之后发现:
预测数列取对数并作一阶差分后的图形显示基本消除了长期趋势性的影响,趋于平稳化,满足ARIMA模型建模的基本要求。





2.白噪声检验

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

from statsmodels.stats.diagnostic import acorr_ljungbox
acorr_ljungbox(data.diff1.dropna(), lags = [i for i in range(1,12)],boxpierce=True)
(array([11.30402, 13.03896, 13.37637, 14.24184, 14.6937 , 15.33042,
        16.36099, 16.76433, 18.15565, 18.16275, 18.21663]),
 array([0.00077, 0.00147, 0.00389, 0.00656, 0.01175, 0.01784, 0.02202,
        0.03266, 0.03341, 0.05228, 0.07669]),
 array([10.4116 , 11.96391, 12.25693, 12.98574, 13.35437, 13.85704,
        14.64353, 14.94072, 15.92929, 15.93415, 15.9696 ]),
 array([0.00125, 0.00252, 0.00655, 0.01135, 0.02027, 0.03127, 0.04085,
        0.06031, 0.06837, 0.10153, 0.14226]))

通过P<αP<α(α通常为0.05),拒绝原假设,故差分后的序列是平稳的非白噪声序列,可以进行下一步建模








3.模型定阶:计算自相关函数ACF 和 偏自相关函数PACF

若你检验方法选择方法二,则你已经得到了ACF和PACF,但检验方法最好还是选择单位根检验

流程:

1.根据ACF图和PACF图判断,序列平稳化后,使用AR、MA、ARMA中哪种模型
2.判断p,q阶数是多少

(前两步都是看ACF和PACF图来判断)
3.可能ARMA有多个p,q决定的模型(因为可能ACF和PACF图可以看出多个p和q),这时要通过信息标准AIC和BIC来协助选择模型
选择AIC、BIC值最小的,因为AIC、BIC越小,模型越好

但要注意的是,这些准则不能说明某一个模型的精确度,也即是说,对于三个模型A,B,C,我们能够判断出C模型是最好的,但不能保证C模型能够很好地刻画数据,因为有可能三个模型都是糟糕的。

赤池信息准则 (akaike information criterion) :AIC鼓励数据拟合的优良性但是尽量避免出现过度拟合(Overfitting)的情况。所以优先考虑的模型应是AIC值最小的那一个
在这里插入图片描述

贝叶斯信息准则 (bayesian information criterion) :
在这里插入图片描述

其中 L 是该模型下的最大似然, n 是数据数量, k 是模型的变量个数。




在这里插入图片描述
在这里插入图片描述




在这里插入图片描述

模型ACFPACF
AR拖尾截尾
MA截尾拖尾
ARMA拖尾拖尾







检查平稳时间序列的自相关图和偏自相关图。
通过sm.graphics.tsa.plot_acfsm.graphics.tsa.plot_pacf得到图形
其中 lags 表示滞后的阶数,以上分别得到 ACF 图和 PACF 图

例子1:

1) 观察ACF和PACF图,判断是哪种模型

dta= dta.diff(1)#我们已经知道要使用一阶差分的时间序列,之前判断差分的程序可以注释掉
fig = plt.figure(figsize=(12,8))
ax1=fig.add_subplot(211)
fig = sm.graphics.tsa.plot_acf(dta,lags=40,ax=ax1)
ax2 = fig.add_subplot(212)
fig = sm.graphics.tsa.plot_pacf(dta,lags=40,ax=ax2)

在这里插入图片描述

通过两图观察得到:

  • 自相关图显示滞后有三个阶超出了置信边界;
  • 偏相关图显示在滞后1至7阶(lags 1,2,…,7)时的偏自相关系数超出了置信边界,从lag 7之后偏自相关系数值缩小至0 则有以下模型可以供选择:
  1. ARMA(0,1)模型:即自相关图在滞后1阶之后缩小为0,且偏自相关缩小至0,则是一个阶数q=1的移动平均模型;
  2. ARMA(7,0)模型:即偏自相关图在滞后7阶之后缩小为0,且自相关缩小至0,则是一个阶层p=3的自回归模型;
  3. ARMA(7,1)模型:即使得自相关和偏自相关都缩小至零。则是一个混合模型。




2) AIC BIC选择其中最佳模型

dta是差分后的序列
因为使用的是ARMA模型

arma_mod20 = sm.tsa.ARMA(dta,(7,0)).fit() # dta是差分后的序列
print(arma_mod20.aic,arma_mod20.bic,arma_mod20.hqic)
arma_mod30 = sm.tsa.ARMA(dta,(0,1)).fit()
print(arma_mod30.aic,arma_mod30.bic,arma_mod30.hqic)
arma_mod40 = sm.tsa.ARMA(dta,(7,1)).fit()
print(arma_mod40.aic,arma_mod40.bic,arma_mod40.hqic)
arma_mod50 = sm.tsa.ARMA(dta,(8,0)).fit()
print(arma_mod50.aic,arma_mod50.bic,arma_mod50.hqic)

在这里插入图片描述

可以看到ARMA(7,0)的AIC,BIC,HQIC均最小,因此是最佳模型。




例子2:

1) 观察ACF和PACF图,判断是哪种模型

在这里插入图片描述

从一阶差分序列的自相关图和偏自相关图可以发现:

  • 自相关图拖尾或一阶截尾
  • 偏自相关图一阶截尾,
  • 所以我们可以建立ARIMA(1,1,0)、ARIMA(1,1,1)、ARIMA(0,1,1)模型。




2) AIC BIC选择其中最佳模型

data[“xt”]是没有差分的序列
因为使用的是ARIMA模型

arma_mod20 = sm.tsa.ARIMA(data["xt"],(1,1,0)).fit() # data["xt"]是没有差分的数据
arma_mod30 = sm.tsa.ARIMA(data["xt"],(0,1,1)).fit()
arma_mod40 = sm.tsa.ARIMA(data["xt"],(1,1,1)).fit()
values = [[arma_mod20.aic,arma_mod20.bic,arma_mod20.hqic],[arma_mod30.aic,arma_mod30.bic,arma_mod30.hqic],[arma_mod40.aic,arma_mod40.bic,arma_mod40.hqic]]
df = pd.DataFrame(values,index=["AR(1,1,0)","MA(0,1,1)","ARMA(1,1,1)"],columns=["AIC","BIC","hqic"])
df

AICBIChqic
AR(1,1,0)253.09159257.84215254.74966
MA(0,1,1)251.97340256.72396253.63147
ARMA(1,1,1)254.09159258.84535259.74966

选择模型MA(0, 1, 1),即ARIMA(0, 1, 1)




4.参数估计

from statsmodels.tsa.arima_model import ARIMA
model = ARIMA(data["xt"], order=(0,1,1))
result = model.fit()
print(result.summary())
                             ARIMA Model Results                              
==============================================================================
Dep. Variable:                   D.xt   No. Observations:                   36
Model:                 ARIMA(0, 1, 1)   Log Likelihood                -122.987
Method:                       css-mle   S.D. of innovations              7.309
Date:                Tue, 22 Dec 2020   AIC                            251.973
Time:                        09:11:55   BIC                            256.724
Sample:                    01-01-1953   HQIC                           253.631
                         - 01-01-1988                                         
==============================================================================
                 coef    std err          z      P>|z|      [0.025      0.975]
------------------------------------------------------------------------------
const          4.9956      2.014      2.481      0.013       1.048       8.943
ma.L1.D.xt     0.6710      0.165      4.071      0.000       0.348       0.994
                                    Roots                                    
=============================================================================
                  Real          Imaginary           Modulus         Frequency
-----------------------------------------------------------------------------
MA.1           -1.4902           +0.0000j            1.4902            0.5000
-----------------------------------------------------------------------------





5.模型检验

在这里插入图片描述

1) 参数的显著性检验

在这里插入图片描述
在这里插入图片描述

P<α(α通常为0.05),拒绝原假设,,认为该参数显著非零MA(2)模型拟合该序列,残差序列已实现白噪声




2)模型的显著性检验

在这里插入图片描述

resid = result.resid#残差
fig = plt.figure(figsize=(12,8))
ax = fig.add_subplot(111)
fig = qqplot(resid, line='q', ax=ax, fit=True)

在这里插入图片描述

qq图显示,我们看到红色的KDE线与N(0,1)平行,这是残留物正太分布的良好指标,说明残差序列是白噪声序列,模型的信息的提取充分,当让大家也可以使用前面介绍的检验白噪声的方法LB统计量来检验

ARIMA(0,1,1)模型拟合该序列,残差序列已实现白噪声,且参数均显著非零。说明ARIMA(0,1,1)模型是该序列的有效拟合模型





6.模型预测

pred = result.predict('1988', '1990',dynamic=True, typ='levels')
print (pred)
1988-01-01   278.35527
1989-01-01   283.35088
1990-01-01   288.34649
Freq: AS-JAN, dtype: float64
plt.figure(figsize=(12, 8))
plt.xticks(rotation=45)
plt.plot(pred)
plt.plot(data.xt)
plt.show()

在这里插入图片描述






7.预测结果分析

在这里插入图片描述
平均绝对误差:
在这里插入图片描述
平均相对误差:
在这里插入图片描述
预测均方差:
在这里插入图片描述
其中,y_i为序列的实际数据,\widehat{y}_i为模型预测数据。

例如:
在这里插入图片描述

由上表预测结果及各项评价指标的对比可知,ARIMA模型预测结果明显优于移动平均法,从平均相对误差上来看,ARIMA模型为6.93%,比移动平均法提高了将近15%,且预测的均方差也较小,仅0.4298。由此可见:该模型能较准确地预测出备件消耗的变化趋势,可为备件消耗量的预测提供依据。










引用:
https://blog.csdn.net/qixizhuang/article/details/86716149
https://zhidao.baidu.com/question/288273884.html
https://zhuanlan.zhihu.com/p/343617191
https://blog.csdn.net/qq_43613793/article/details/109908418
https://blog.csdn.net/qq_45176548/article/details/116771331
https://blog.csdn.net/weixin_41555408/article/details/117218457
https://blog.csdn.net/weixin_41636030/article/details/89138638
https://www.zhihu.com/question/48447779/answer/112330897
https://blog.csdn.net/u010414589/article/details/49622625
https://wiki.mbalib.com/wiki/ARIMA%E6%A8%A1%E5%9E%8B
https://blog.csdn.net/qq_45176548/article/details/111504846

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐