Matlab实现ADF检验,adftest函数使用详细说明
创作时间:
作者:
@小白创作中心
Matlab实现ADF检验,adftest函数使用详细说明
引用
CSDN
1.
https://blog.csdn.net/qq_62888264/article/details/129403702
本文将详细介绍如何使用Matlab中的adftest函数进行ADF(Augmented Dickey-Fuller)检验,包括函数的基本用法、参数说明以及如何通过检验结果判断时间序列的平稳性。最后,我们将通过一个实际案例(1978年到2020年中国GDP数据)来演示整个检验过程。
ADF检验简介
ADF检验全称为Augmented Dickey-Fuller test。通常在使用时间序列模型(如ARMA,ARIMA)的时候用于检验时间序列数据的平稳性。它主要通过检验数据是否有单位根来判断序列是否平稳。
adftest的使用及参数介绍
简单调用:h = adftest(y)
输入参数:
- y:进行检验的时间序列
输出参数:
- h:检验结果
- h = 0,说明序列不平稳;
- h = 1,说明序列平稳。
多参数调用:[h,pValue,stat,cValue] = adftest(y,'alpha',0.05)
输入参数:
- y:进行检验的时间序列
- 'alpha',0.05:组合起来使用可以改变假设检验的显著性水平,如果不设置则默认为0.05
输出参数:
- h:检验结果
- pValue:假设检验的P值,依据它的大小可以判断是否拒绝原假设
- stat:检验统计量,与cValue一起可以决定是否拒绝原假设
- cValue:假设检验的临界值,与stat一起可以决定是否拒绝原假设
(下文会介绍三种利用输出参数判断是否平稳的方法,他们的结果是统一的,会一种就行)
adftest如何判断是否平稳?
原假设与备择假设
- 原假设:存在单位根(时间序列不平稳)
- 备择假设:不存在单位根(时间序列平稳)
通过h判断是否平稳
- h = 0时,我们无法拒绝原假设,也就是接受原假设→序列存在单位根→时间序列不平稳
- h = 1时,我们拒绝原假设→序列不存在单位根→时间序列平稳
通过pValue判单是否平稳
- pValue>0.05(显著性水平,这里用0.05举例):我们无法拒绝原假设,也就是接受原假设→序列存在单位根→时间序列不平稳
- pValue<0.05:我们拒绝原假设→序列不存在单位根→时间序列平稳
通过stat和cValue判断是否平稳
- stat>cValue:落在接受域,我们无法拒绝原假设,也就是接受原假设→序列存在单位根→时间序列不平稳
- stat<cValue:落在拒绝域,我们拒绝原假设→序列不存在单位根→时间序列平稳
应用举例(以1978年到2020年的中国GDP为例):
原始序列的ADF检验
clc;
clear;
data = readtable("data.xlsx");
data = table2array(data);
data = data(:,2)
plot(data,'LineWidth',1.5)
[h,pValue,stat,cValue] = adftest(data,'alpha',0.05)
输出结果为:
- h = 0; (h等于0→接受原假设→有单位根→不平稳)
- pValue = 0.9990 (p大于0.05→接受原假设→有单位根→不平稳)
- stat = 13.4332 (stat>cValue→接受原假设→有单位根→不平稳)
- cValue = -1.9474
从折线图和函数返回结果看,该序列都是不平稳的。
一阶差分序列的ADF检验
%% 接上述代码
datad1 = diff(data,1)
figure
plot(datad1,'LineWidth',1.5)
[h,pValue,stat,cValue] = adftest(datad1,'alpha',0.05)
输出结果为:
- h = 0;
- pValue = 0.2810
- stat = -0.9989
- cValue = -1.9475
从折线图可见一阶差分仍然具有显著上升趋势,序列不平稳,与函数返回结果契合。
二阶差分序列
datad2 = diff(data,2)
figure
plot(datad2,'LineWidth',1.5)
[h,pValue,stat,cValue] = adftest(datad2,'alpha',0.05)
输出结果为:
- h = 1;
- pValue = 1.0000e-03
- stat = -4.3792
- cValue = -1.9476
由折线图,数据在0附近随机波动,表现为平稳序列,与函数返回值契合。
完整代码及数据
clc;
clear;
data = readtable("data.xlsx");
data = table2array(data);
data = data(:,2)
%可注释上面三行,将下一行取消注释
%data = [3678.70250000000 4100.45370000000 4587.58110000000 4935.83280000000 5373.35010000000 6020.92410000000 7278.50230000000 9098.94800000000 10376.1545000000 12174.5947000000 15180.3865000000 17179.7417000000 18872.8688000000 22005.6285000000 27194.5309000000 35673.2304000000 48637.4503000000 61339.8913000000 71813.6296000000 79715.0445000000 85195.5071000000 90564.3758000000 100280.139300000 110863.123000000 121717.424700000 137422.034900000 161840.160900000 187318.903100000 219438.474800000 270092.323700000 319244.612800000 348517.743700000 412119.255800000 487940.180500000 538579.953500000 592963.229500000 643563.104500000 688858.218000000 746395.059500000 832035.948600000 919281.129100000 990865.111300000 1015986.20000000]'
plot(data,'LineWidth',1.5)
[h,pValue,stat,cValue] = adftest(data,'alpha',0.05)
%% 一阶差分
datad1 = diff(data,1)
figure
plot(datad1,'LineWidth',1.5)
[h,pValue,stat,cValue] = adftest(datad1,'alpha',0.05)
%% 二阶差分
datad2 = diff(data,2)
figure
plot(datad2,'LineWidth',1.5)
[h,pValue,stat,cValue] = adftest(datad2,'alpha',0.05)
%adftest:原假设:存在单位根(说明这是一个非平稳的时间序列) 备择假设:不存在单位根(说明这是一个平稳时间序列)
%h = 0则不能拒绝原假设,那么接受原假设,说明时间序列不平稳
热门推荐
道家廉政思想,践行道德,铸就清廉之道
太阳能电池板电压:理解、计算和优化
电单车充电桩背后的智能秘密
佛影峡漂流:峡谷中的清凉之旅
中金:新高的美债+新低的中债,对港股意味着什么?
熟龄肌护肤指南:注重深度滋养与修复
美联储又不是先知 别把点阵图太当回事
驾照考试车辆和场地要求详解
乌里雅苏台将军:大清帝国的“漠北王”,捍卫草原的“保护神”
长孙皇后:李世民心中永远的白月光,为什么被称之为最完美的皇后
网络语“白月光”:从张爱玲到饭圈文化的流行符号
血栓溶栓的最佳时间
二甲双胍走下神坛!糖尿病新指南:两种药替代它,成为一线降糖药
心理咨询:抠门,不敢花钱,或许是内心空虚匮乏
职工医疗保险能给直系亲属报销吗?
如何处理儿童视力屈光参差或散光问题
如何使用成交量加权平均价格提升交易盈利率?
双显卡使用教程(掌握双显卡技巧,发挥双倍功效)
感冒鼻塞流鼻涕最快解决办法是什么
鸡胸肉怎么做嫩而不柴?七种实用烹饪方法详解
投资股票利润的计算:计算港股投资收益的方法
如何计算股票输赢的情况?这种计算对投资策略有何启示?
橘子是凉性还是热性为什么会上火
蜂群没蜂王会不会造王台,需要满足一定的群势和幼虫数量
重疾险包括哪些疾病及交费标准
百合莲子的功效和作用
时间飞逝的诗句,如何表达这份匆匆?
衡阳“焕新”时 | “湘见·建湘”工业文化街区:一场工业记忆与现代创意的激情碰撞
中药酒适合什么时候用
Excel中删除不可见字符的多种方法