logo

时间序列平稳时序模型

wangzf / 2022-04-25


目录

平稳时间序列分析介绍

一个时间序列经过预处理被识别为 平稳非白噪声时间序列,就说明该序列是一个蕴含相关信息的平稳序列。 在统计上,通常是建立一个线性模型来拟合该序列的发展,借此提取该序列中的有用信息。

假设一个时间序列经过预处理被识别为 平稳非白噪声时间序列,就可以利用 ARMA 模型对该序列建模。 ARMA(Auto Regression Moving Average) 模型的全称是 自回归移动平均模型, 它是目前最常用的拟合平稳序列的模型。它又可以细分为 AR 模型、MA 模型、ARMA 模型三类。

建模的基本步骤为:

img

建模步骤详解:

  1. 求出该观察序列的样本自相关系数 (ACF) 和样本偏自相关系数 (PACF) 的值;
  2. 根据样本自相关系数 (ACF) 和偏自相关系数 (PACF) 的性质, 选择阶数适当的 ARMA(p, q) 模型进行拟合;
  3. 估计模型中的位置参数的值;
  4. 检验模型的有效性;
    • 如果拟合模型通不过检验,转向步骤 2,重新选择模型再拟合
  5. 模型优化;
    • 如果拟合模型通过检验,仍然转向步骤 2,充分考虑各种可能, 建立多个拟合模型,从所有通过检验的拟合模型中选择最优模型
  6. 利用拟合模型,预测序列的将来走势。

白噪声模型

白噪声序列 εt 是指期望为 0,方差有限,且不存在序列相依性的序列。 白噪声序列性质的数学表示如下:

在实际建模中,往往需要做出更强的白噪声假设,因此还有两种白噪声序列:

在后续的模型构建中,我们会看到这三种白噪声在时间序列分析中的作用。

AR 模型

AR 模型介绍

AR(p) 模型,称为 p 阶自回归模型(Autoregression)。 该模型适用于 无趋势(trend)无季节性(seasonal) 因素的单变量时间序列。 其数学表达式为:

xt=ϕ0+ϕ1xt1+ϕ2xt2++ϕpxtp+εt

自回归模型实际上是指由 xt历史观测值白噪声序列构造出的时间序列。 与传统的回归相似,该模型的解释变量为 xt 的历史观测值;与传统的回归模型不同的是, 该模型的解释变量为被解释变量自身的滞后观测值,因此得名自回归模型。

自回归模型中一类非常特殊且重要的模型是带漂移项的随机游走(random walk)。 带漂移项的随机游走的模型为 xt=δ+xt1+ε,其中 δ 称为漂移项。 当 δ=0 时,该模型简称为随机游走。当 x0=0 时, 易得 xt=δt+j=1tεj。易知,随机游走序列是非平稳时间序列。

AR 模型性质

AR(p) 有三个限制条件:

中心化 AR

另外,ϕ0 是常数,当 ϕ0=0 时,为中心化的 AR(p) 模型; 当 ϕ00时,为非中心化的 AR(p) 模型, 可以通过以下变换,转化为中心化 AR(p) 序列

yt=xtμ μ=c1ϕ1ϕ2ϕp

ytxt 的中心化序列,相当于将非中心化序列上下平移了 μ

AR 平稳性检验

由于 AR(p) 模型拟合的是平稳序列,所以拟合后的模型也应该为平稳的,因此在拟合完模型后, 为了保险,会将模型拟合后的结果再做平稳性检验,看拟合模型是否平稳。

MA 模型

MA 模型介绍

MA(p) 模型,称为 q 阶移动平均(Moving Average, MA)模型。 为残差误差(residual erros)的线性函数,与计算原始时间序列的 移动平均 不同, 该模型适用于 无趋势(trend)无季节性(seasonal) 因素的单变量时间序列, 因为 MA 模型其实是对白噪声序列建模。其数学表达式为:

xt=μ+εt+θ1εt1+θ2εt2++θqεtq

移动平均模型实际上是指由白噪声序列进行滑动窗口计算平均得到的序列。 例如,若以 εt 表示一个白噪声序列, 则 yt=(εt2+εt1+εt)/3 即表示一个滑动窗口长度为 3 的简单(等权重)移动平均模型。 不难发现,滑动平均的序列比原来的白噪声序列更加平滑,围绕均值 0 上下相对较慢地振荡。 并且 yt=(εt2+εt1+εt)/3yt1=(εt3+εt2+εt1)/3 中具有共同的元素 εt2εt1,从而使得它们之间具有相依相。对时间序列进行线性组合也常常被称为 滤波(filtering)

MA 模型性质

MA(q) 有两个限制条件:

中心化 MA

另外,μ 是常数,当 μ=0 时,为中心化的 MA(q) 模型;当 μ0 时, 为非中心化 MA(q) 模型,可以通过以下变换,转化为中心化 MA(q) 序列:

yt=xtμ

MA 可逆性检验

不同于 AR 模型,MA 模型拟合后会做可逆性检验。因为 MA 模型会出现:一个自相关系数未必唯一对应一个平稳时间序列模型, 因此会考察 MA 模型的可逆性,模型可逆,说明它 ACF 具有唯一性。而不可逆,说明 ACF 不唯一,会导致模型选择变得困难, 比如 MA(3) 和 MA(4) 的 ACF 相同,你选哪个?

误差项是不可观察的,其中的 εt 是由 ε0 递推过来的, 而 ε0 有专门的获取方法,可以参考这里。具体介绍如下:

img

ARMA 模型

ARMA(p, q) 模型,称为 自回归移动平均(Auto-Regressive Moving Average)模型, 是 时间序列残差误差 的线性函数,是 AR(p) 和 MA(q) 模型的组合, 该模型适用于 无趋势(trend)无季节性(seasonal) 因素的单变量时间序列。

ARMA 模型的数学表达式为:

{xt=ϕ0+ϕ1xt1++ϕpxtp+εt+θ1εt1++θqεtqϕp0,θq0E(εt)=0,Var(εt)=σε2,E(εtεs)=0,stE(xsεt)=0,s<t

ARMA 模型的另一种形式:

(1i=1pϕiBi)xt=(1i=1qθiBi)εt Φ(B)xt=Θ(B)εt

所以 AR(p) 和 MA(q) 实际上是 ARMA(p, p) 模型的特例,它们统称为 ARMA 模型。 而 ARMA(p, p) 模型的统计性质也正是 AR(p) 模型和 MA(p) 模型统计性质的有机结合。

ARMA 建模流程

总结来说,AR/MA/ARMA 模型适用于平稳非纯随机序列。它的建模流程如下图所示,其实和上图一样, 只不过下图把流程细化了,尤其是 “计算 ACF、PACF” 和 “ARMA 模型识别” 这两块是重点。

img

计算 ACF 和 PACF

ACF 和 PACF 的核心价值是:揭示时间序列的自相关性。它们的应用场景有:

ACF

自相关系数(Autocorrelation Coefficient, AC)是用来描述时序数据自身不同时期的相关程度, 即度量历史数据对现在产生的影响。自相关函数(Autocorrelation Function, ACF)是自相关系数构成的序列。

ACF 考察当前 t 序列与其延迟 k 期序列之间的相关性:

p^k=t=1nk(xtx¯)(xt+kx¯)t=1n(xtx¯)2,0<k<n

其中:

根据 ACF 求出滞后 k 自相关系数时,实际上得到并不是 xtxtk 之间单纯的相关关系。 因为 xt 同时还会受到中间 k1 个随机变量 xt1,xt2,,xtk+1 的影响, 而这 k1 个随机变量又都和 xtk 具有相关关系, 所以自相关系数里面实际掺杂了其他变量对 xtxtk 的影响。

PACF

偏自相关系数(Partical Autocorrelation Coefficient, PAC)同自相关系数大同小异, 在计算相关性时移除了中间变量的间接影响。 偏自相关函数(Partical AutoCorrelation Function, PACF)是偏自相关系数构成的序列。

在剔除了中间 k1 个随机变量 xt1,xt2,,xtk+1 的干扰之后, xtkxt 影响的相关程度,叫偏自相关系数(PACF)。

ϕ^kk=D^kD^,0<k<n

D^=[1p^1p^k1p^11p^k2p^k1p^k21]

D^k=[1p^1p^1p^11p^2p^k1p^k2p^k]

不同滞后期得到的偏自相关系数,叫偏自相关图。

ACF 和 PACF 计算示例

原序列:

x=[2,3,4,3,8,7]

滞后(lag=1)序列:

A=[2,3,4,3,8] B=[3,4,3,8,7]

原序列均值、方差:

x¯=i=16xi=4.5 σ2(x)=i=16(xix¯)(xix¯)=4.916

AB 的相关系数:

r(lag=1)=15i=15(Aix¯)(Bix¯)=1.75

自相关系数:

ACF(lag=1)=r(lag=1)σ2(x)=1.754.91666667=0.3559322

Python API:

import statsmodels.api as sm

X = [2, 3, 4, 3, 8, 7]

acf_value = sm.tsa.stattools.acf(X, nlags = 1, adjusted = True)
pacf_value = sm.tsa.stattools.pacf(x, nlags = 1)
print(acf_value)
print(pacf_value)

[1, 0.3559322]
[1, 0.3559322]

ACF 和 PACF 可视化

import numpy as np
import pandas as pd
import akshare as ak
from matplotlib import pyplot as plt
from statsmodels.graphics.tsaplots import plot_acf, plot_pacf
np.random.seed(123)

# -------------- 准备数据 --------------
# 白噪声
white_noise = np.random.standard_normal(size = 1000)

# 随机游走
x = np.random.standard_normal(size = 1000)
random_walk = np.cumsum(x)

# GDP
df = ak.macro_china_gdp()
df = df.set_index('季度')
df.index = pd.to_datetime(df.index)
gdp = df['国内生产总值-绝对值'][::-1].astype('float')

# GDP DIFF
gdp_diff = gdp.diff(4).dropna()
# -------------- 绘制图形 --------------
fig, ax = plt.subplots(4, 2)
fig.subplots_adjust(hspace = 0.5)

plot_acf(white_noise, ax = ax[0][0])
ax[0][0].set_title('ACF(white_noise)')
plot_pacf(white_noise, ax = ax[0][1])
ax[0][1].set_title('PACF(white_noise)')

plot_acf(random_walk, ax = ax[1][0])
ax[1][0].set_title('ACF(random_walk)')
plot_pacf(random_walk, ax = ax[1][1])
ax[1][1].set_title('PACF(random_walk)')

plot_acf(gdp, ax = ax[2][0])
ax[2][0].set_title('ACF(gdp)')
plot_pacf(gdp, ax = ax[2][1])
ax[2][1].set_title('PACF(gdp)')

plot_acf(gdp_diff, ax = ax[3][0])
ax[3][0].set_title('ACF(gdp_diff)')
plot_pacf(gdp_diff, ax = ax[3][1])
ax[3][1].set_title('PACF(gdp_diff)')

plt.show()

img

  1. 白噪声的自相关系数很快就衰减到 0 附近,是明显的平稳序列
    • 滞后期为 0 时自相关系数(ACF)和偏自相关系数(PACF)其实就是序列自己和自己的相关性,故为 1; 滞后期为 1 时,自相关系数为 0,表示白噪声无自相关性
  2. 随机游走,自相关系数下降非常缓慢,故为非平稳序列;另从偏自相关系数中可以看到随机游走只和前一项有关
  3. GDP 数据的自相关图中也可以看到存在一定的周期性,滞后 4、8、12 等自相关系数较大下降较慢, 差分后下降多一些起到一定效果,认为差分后序列是平稳的。同可视化数据一样,直观判断带有较强主观性, 但能让我们对数据有更直观的认识

模型识别

基于 ACF 和 PACF 图,可以参考下图,进行模型定阶(即确定 pq 的取值)。 其中,AR 看 PACF 定 p,MA 看 ACF 定 q

p^k ϕ^kk 模型定阶
拖尾 p 阶截尾 AR(p) 模型
q 阶截尾 拖尾 MA(q) 模型
拖尾 拖尾 ARMA(p,q) 模型

拖尾是指趋向于 0,截尾是指为 0,但实际上并不能出现完美的理论截尾,但可以利用 2 倍标准差范围辅助判断:

我们看一个例子,会更好帮助理解模型定阶:

img

参数估计

ARMA(p, q) 参数估计有以下三种:

模型检验

模型显著性检验分两方面检验:

模型优化

若同一个序列出现两个拟合模型(例如:AR(2) 和 ARMA(2, 1))都显著有效,该如何选择?可以基于 AIC 和 BIC(SBC) 信息准则。 信息准则衡量的是模型拟合精度和参数个数,我们希望参数个数小且模型精度好

AIC=2ln()+2()

AIC 越小,模型越优秀。但 AIC 有不足,就是 AIC 的拟合误差会受样本容量放大而被影响,样本容量越大, 往往 AIC 选择的模型会含有更多的参数。为此,BIC 加入对未知参数个数的惩罚权重:

AIC=2ln()+ln(x)()

参考