时间序列*稳性检测1
在上一篇文章中我们介绍了时间序列及一些时间序列预测模型。我们可以看到在进行预测时有一些模型表现较好,而另一些模型的预测结果却不尽人意。这是因为不同的时间序列模型对原始数据的要求是不同的,例如之前提到的ARIMA模型,要求时间序列数据*稳,否则得出的预测结果就会相差较大。本篇文章我们介绍时间序列的*稳性、随机性检验及相关时间序列数据处理方法。
时间序列的*稳性、随机性检验
在拿到时间序列数据后,首先要对数据的随机性和*稳性进行检测, 这两个检测是时间序列预测的重要部分,根据不同检测结果需要采取不同的分析方法。
为什么时间序列要求*稳性呢?*稳性就是要求由样本拟合出的曲线在未来一段时间内仍然能够以现有的形态和趋势发展下去,这样预测结果才会有意义。
- 对于*稳声序列, 它的均值和方差是常数, 现已有一套非常成熟的*稳序列的建模方法。 通常是建立一个线性模型来拟合该序列的发展,借此提取该序列的有用信息。
- 对于非*稳序列, 由于它的均值和方差不稳定, 处理方法一般是将其转变为*稳序列,这样就可以应用有关*稳时间序列的分析方法, 如建立 ARIMA模型来进行相应的研究,或者分解趋势与季节性等并根据情况应用指数*滑模型等。
- 对于纯随机序列, 又称为白噪声序列, 序列的各项之间没有任何相关关系, 序列在进行完全无序的随机波动, 可以终止对该序列的分析。 白噪声序列是没有信息可提取的*稳序列。
在讲解*稳性和随机性的定义之前,我们先介绍一下时间序列中常用的几个特征统计量。
时间序列的特征统计量
对于一个时间序列任意时刻的序列值\(\left\{ X _ { t } , t \in T \right\}\),任意时刻的序列值\(X_t\)都是一个随机变量,记其分布函数为\(F_t(x)\),则其特征统计量均值、方差、自协方差函数、自相关系数的定义分别如下:
- 均值: 表示时间序列在各个时刻取值的*均值,其定义如下:
- 方差: 表示时间序列在各个时刻围绕其均值波动的*均程度,其定义如下:
- 自协方差 : 表示时间序列任意两个时刻直接的相关性,任取\(t,s\in T\),则其定义如下:
- 自相关系数: 同自协方差函数,其定义如下:
*稳时间序列的定义与检验
*稳时间序列的定义
*稳时间序列按照限定条件的严格程度可以分为以下两种类型:
- 严*稳时间序列: 指时间序列的所有统计性质不会随着时间的推移而发生变化,即其联合概率分布在任何时间间隔都是相同的。设\(\{X_t\}\)为一时间序列,对任意的正整数m,任取\(t_1,t_2,...,t_m\in T\),对任意整数\(\tau\),有:
则称时间序列\(\{X_t\}\)为严*稳时间序列。 - 宽*稳时间序列: 宽*稳时间序列则认为只要时间序列的低阶距(二阶)*稳,则该时间序列*似*稳。如果时间序列\(\{X_t\}\)满足以下三个条件:
在现实生活中,时间序列是很难满足严*稳时间序列的要求的,因此,一般所讲的*稳时间序列在默认情况下都是指宽*稳时间序列。根据宽*稳时间序列的条件,我们可以容易得到宽*稳时间序列所具有的性质:
- 均值为常数,即:任取\(t\in T\),有\(EX_t = \mu\),其中\(\mu\)为常数。
- 方差也为常数,即:\(D X _ { t } = \gamma ( t , t ) = \gamma ( 0 ) , \quad \forall t \in T\)
- 自协方差函数和自相关系数只依赖于时间的*移长度,而与时间的起点无关。即:\(\gamma(t , s ) = \gamma(k , k + s - t ), \quad \forall t , s , k \in T\),因此可以记\(\gamma(k)\)为时间序列\(\{X_t\}\)的延迟k自协方差函数。
由于*稳时间序列具有这些优良性质,因此,对于一个*稳时间序列来说,其待估计的参数量就变得少了很多,因为他们的均值、方差都是一样的,因此,可以利用全部的样本来估计总体的均值和方差,即:
这也是为什么说当拿到一个时间序列后,需要对其进行*稳性检验。
*稳时间序列的检验
那么,当拿到一个时间序列后,应该如何对其进行*稳性的检验呢?目前,对时间序列的*稳性检验主要有两种方法,
- 一种是图检法,即根据时序图和自相关图进行直观判断,
- 另一种是构造检验统计量的方法,有单位根检验法等方法。
图检法
对于图检法,我们一般绘制时间序列的时序图,考虑以下三个图形:
- 在第一幅图中,我们可以清楚地看到,均值随时间而变化(增加),呈现上升的趋势。因此,这是一个非*稳序列。*稳序列不应该呈现出随时间变化的趋势。
- 第二幅图显然看不到序列的趋势,但序列的变化是一个时间的函数。正如前面提到的,*稳序列的方差必须是一个常数。
- 再来看第三幅图,随着时间的增加,序列传播后变得更*,这意味着协方差是时间的函数。
所以上述三个例子均是非*稳时间序列.
再看下面的时序图:
在这张图中,均值、方差和协方差都是常数,这就是*稳时间序列.
另一方面,我们也可以通过自相关图来进行检验,
- 对于*稳时间序列,其自相关图一般随着阶数的递增,自相关系数会迅速衰减至0附*,
- 而非*稳时间序列则可能存在先减后增或者周期性波动等变动。
如下图所示,该时间序列随着阶数的递增,自相关系数先减后增,因此,可以判断该时间序列不是*稳时间序列。
统计检验
可以利用统计检验来代替目视检验:比如单位根*稳检验。单位根表名给定序列的统计特性(均值,方差和协方差)不是时间的常数,这是*稳时间序列的先决条件。
下面是它的数学解释:
假如我们有一个时间序列,\(y_t=ay_{t-1 }+ε_t\) ,其中\(y_t\)是t时刻的数据值,\(ε_t\)是误差项. 现在我们需要利用\(y_{t-1 }\)的值即:\(y_{t-1}=ay_{t-2}+ε_{t-1}\)来计算\(y_t\),如果利用所有的观察值,\(y_{t}\)的值将是:\(y_{t}=a^ny_{t-n}+ \sumε_{t-i}a^i\)
假设在上述方程中a的值为1(单位),则预测值将等于\(y_{t ? n}\)和从\(t ? n\)到\(t\)的所有误差之和,这意味着方差将随着时间的推移而增大,这就是时间序列中的单位根。众所周知,*稳时间序列的方差不能是时间的函数。单元根检验通过检查a=1的值来检查序列中是否存在单位根。最常用的单位根*稳检测方法是ADF(增补迪基-福勒)检验。
ADF(增补迪基-福勒)检验
迪基-福勒(Dickey Fuller)检验是最流行的统计检验方法之一,可以用它来确定序列中单位根的存在,从而帮助判断序列是否是*稳。ADF检验是对DF检验的扩展。这一检验的原假设与备选假设如下:
- 原假设: 序列有一个单位根(序列非*稳)
- 备选假设: 该序列没有单位根。(序列*稳)
单位根是什么呢?当一个自回归过程中: \(y_t = b y_{t ? 1} + a + ?_t\) ,如果滞后项系数b为1,就称为单位根。当单位根存在时,自变量和因变量之间的关系具有欺骗性,因为残差序列的任何误差都不会随着样本量(即时期数)增大而衰减,也就是说模型中的残差的影响是永久的。这种回归又称作伪回归。如果单位根存在,这个过程就是一个随机漫步(random walk)。ADF检验就是判断序列是否存在单位根:如果序列*稳,就不存在单位根;否则,就会存在单位根.
在Python中使用ADF检验可以在statsmodels中使用adfuller函数。在下面的代码中我们加上标题与输出值对应的名称:
#定义ADF输出格式化函数
from statsmodels.tsa.stattools import adfuller
def adf_test(timeseries):
print ('ADF检验结果:')
dftest = adfuller(timeseries, autolag='AIC')
dfoutput = pd.Series(dftest[0:4], index=['Test Statistic','p-value','Number of Lags Used','Number of Observations Used'])
for key,value in dftest[4].items():
dfoutput['Critical Value (%s)'%key] = value
print (dfoutput)
#对数据集使用ADF检验
adf_test(train['#Passengers'])
检验结果如下:
ADF检验结果:
Test Statistic 0.815369
p-value 0.991880
Number of Lags Used 13.000000
Number of Observations Used 130.000000
Critical Value (1%) -3.481682
Critical Value (5%) -2.884042
Critical Value (10%) -2.578770
dtype: float64
ADF的结果主要看以下两个方面:
- Test Statistic的值如果比Critical Value (5%)小则满足稳定性需求.
- p-value越低(理论上需要低于0.05)证明序列越稳定。
在上面的例子中,test statistic > Critical Value (5%) ,这意味着序列不是*稳的。同时p值为0.99,这证实了我们最初在目视检测中观察的结果。
随机性(白噪声)的定义与检验
随机性时间序列的定义
通过对时间序列进行*稳性检验后,我们可以将时间序列分为*稳时间序列和非*稳时间序列,对于非*稳时间序列,一般需要将其转化为*稳时间序列再进行分析,具体的转化方法随后再讲。而对于*稳时间序列,我们知道其有一个性质,即自协方差函数和自相关系数只依赖于时间间隔,而与起点无关,对于相同的时间间隔,其自协方差函数和自相关系数为一个常数,那么,就存在一种情况,当该常数为0时,照样满足*稳时间序列的条件,而此时序列之间的相关性则为0,即序列之间不相关,那么,这时我们的分析即可结束,因为对于一个毫无相关的序列,我们没法从中挖掘出可用的规律,此时的序列即为随机性时间序列,也称为白噪声序列。
对时间序列\(X_t\),如果满足:
则称该时间序列为纯随机序列或白噪声序列,简记为 $X_t ~ W N ( μ , σ^2 ) $。我们可以发现,其实白噪声序列的性质与*稳时间序列的性质一样,其均值和方差均为常数,只是自协方差函数或自相关系数为0,因此,该序列的任何两项之间不存在相关性,无法从中得到任何有用的信息,此时分析可以停止。
纯随机性(白噪声)检验
对于纯随机性序列,一般通过构建统计量的方法来检验。我们知道,白噪声序列除了0阶自相关系数外,即方差,其他阶的自相关系数应该均为0,因此,我们可以提出下面这样一个假设:
因此,围绕该假设,我们可以构建统计量进行检验,常用的统计量有Q统计量和LB统计量,其计算公式分别如下:
其中, n为序列的观察期数, m为指定延迟期数, k为延迟阶数,Box和Pierce证明这两个统计量均服从自由度为m的卡方分布,当统计量大于$χ^2 _{1 ? α} ( m ) $或者P值小于 \(α\) 时,则认为可以拒绝原假设,即认为该序列是非随机序列.
我们可以使用acorr_ljungbox函数进行数据的纯随机性检验.语法为:
acorr_ljungbox(x, lags=None, boxpierce=False) # 数据的纯随机性检验函数
lags:为延迟期数,如果为整数,则是包含在内的延迟期数,如果是一个列表或数组,那么所有时滞都包含在列表中最大的时滞中
boxpierce:为True时表示除开返回LB统计量还会返回Box和Pierce的Q统计量
返回值:
lbvalue:测试的统计量
pvalue:基于卡方分布的p统计量
bpvalue:((optionsal), float or array) – 基于 Box-Pierce 的检验的p统计量
bppvalue:((optional), float or array) – 基于卡方分布下的Box-Pierce检验的p统计量
代码实现:
from statsmodels.stats.diagnostic import acorr_ljungbox
acorr_ljungbox(train['#Passengers'])
输出检验结果中会返回两个值:
- lbvalue: 测试的统计量
- pvalue: 基于卡方分布的p统计量。
如果p-value>0.05则可判断为白噪声序列.
时间序列的*稳化
在熟悉了*稳性的概念及其不同的类型之后,接下来可以对序列进行*稳化操作。
差分法
在该方法中,计算序列中连续项的差值。执行差分操作通常是为了消除均值的变化。从数学角度,差分可以写成:\(y_t = y_t – y_{t-1}\),其中\(y_t\)是t时刻的数值。相减数值之间的间隔即为阶数。例如上述公式即为一阶差分。