自回归条件异方差(ARCH)模型涉及具有时变异方差的时间序列,其中方差是以特定时间点的现有信息为条件的。
ARCH模型假设时间序列模型中误差项的条件均值是常数(零),与我们迄今为止讨论的非平稳序列不同),但其条件方差不是。
ARCH模型
这样一个模型可以用公式1、2和3来描述。
data:image/s3,"s3://crabby-images/baf79/baf79214b1ad17f6ec2c3e9074c4ec8f5b3f8c1c" alt=""
可下载资源
方程4和5给出了测试模型和假设,以测试时间序列中的ARCH效应,其中残差e^t来自于将变量yt回归一个常数,如1,或回归一个常数加上其他回归因子;方程4中的测试可能包括几个滞后项,在这种情况下,无效假设(方程5)是所有这些项都不显著。
data:image/s3,"s3://crabby-images/75080/75080753cebbb37b081c40c820d303af299a3a89" alt=""
无效假设是不存在ARCH效应。检验统计量为
data:image/s3,"s3://crabby-images/5475a/5475aabcc9857e201a304be6927390a9f73bc490" alt=""
下面的例子使用了数据集,它包含了500个股票收益率的生成观测值。图显示了数据的时间序列图和柱状图。
plot.ts(r)
hist(r)
data:image/s3,"s3://crabby-images/a0984/a0984f432991fb5321d063d71aa2173962d32c4f" alt=""
图: 变量 的水平和柱状图
让我们首先对数据集中的变量r一步一步地进行公式4和5中描述的ARCH检验。
summary(yd)
data:image/s3,"s3://crabby-images/f95fc/f95fc19c57b13d45da6609b95b9f79601d7ef91f" alt=""
ehsq <- ts(resid(mean)^2)
summary(ARCH)
data:image/s3,"s3://crabby-images/86649/86649bce055ae4fbf90d859fbe42ef88ab572527" alt=""
Rsq <- glance(ARCH)\[\[1\]\]
LM <- (T-q)*Rsq
Chicr <- qchisq(1-alpha, q)
data:image/s3,"s3://crabby-images/ea28b/ea28bbdb4fcdbc674a320090d2ab5aac7a6ece84" alt=""
结果是LM统计量,等于62.16,与α=0.05和q=1自由度的临界卡方值进行比较;这个值是χ2(0.95,1)=3.84;这表明拒绝了无效假设,结论是该序列具有ARCH效应。
如果我们不使用一步步的程序,而是使用R的ARCH检验功能之一,也可以得出同样的结论。
ArchTest
data:image/s3,"s3://crabby-images/d22e0/d22e0ee3030b5d94e9037670184ec8b1bec31f2b" alt=""
函数garch(),当使用order=参数等于c(0,1)时,成为一个ARCH模型。这个函数可以用来估计和绘制方程3中定义的方差ht,如以下代码和图所示。
garch(r,c(0,1))
data:image/s3,"s3://crabby-images/0ee49/0ee494cafba16138a0d5c9c981534594010513a3" alt=""
随时关注您喜欢的主题
summary(arch)
data:image/s3,"s3://crabby-images/585c2/585c2fd5a61d47bdeac8d69fe4c3fcc242f48f61" alt=""
ts(2*fitted.values^2)
plot.ts(hhat)
data:image/s3,"s3://crabby-images/44651/446516afa539e3ce01c895d3582d69f6a8622247" alt=""
图 对数据集的ARCH(1)方差的估计
GARCH模型
# 使用软件包\`garch\`来建立GARCH模型
fit(spec=garch, data=r)
coef(Fit)
data:image/s3,"s3://crabby-images/d5084/d508469d113f15b30d082c18afd4efb7038b14dc" alt=""
fitted.values
fit$sigma^2)
plot.ts(hhat)
图: 使用数据集的标准GARCH模型(sGARCH)。
data:image/s3,"s3://crabby-images/00f8c/00f8c72b7373a00e5157ea0ae53e694189fecfe7" alt=""
# tGARCH
garchfit(spec, data=r, submodel="TGARCH")
coef(garchfit)
data:image/s3,"s3://crabby-images/748fe/748fe108524791ee7c251ca20aa246665e621904" alt=""
fitted.values
fit$sigma^2)
plot.ts(hhat)
data:image/s3,"s3://crabby-images/f48bd/f48bd8e61b72466e85a59e5557e790f7d567f13f" alt=""
图: 数据集的tGARCH模型
# GARCH-IN-MEAN模型
fit( data=r,
distribution="std",variance=list(model="fGARCH")
coef(garchFit)
data:image/s3,"s3://crabby-images/b3750/b37503228144bd54854d5789135d83032e643677" alt=""
fit$fitted.values
fit$sigma^2)
plot.ts(hhat)
data:image/s3,"s3://crabby-images/29cbe/29cbe2476f7d4b445da83c5997ba1dbab0474dbe" alt=""
图:使用数据集的GARCH-in-mean模型的一个版本
图显示了GARCH模型的几个版本。预测结果可以通过ugarchboot()来获得。
可下载资源
关于作者
Kaizong Ye是拓端研究室(TRL)的研究员。在此对他对本文所作的贡献表示诚挚感谢,他在上海财经大学完成了统计学专业的硕士学位,专注人工智能领域。擅长Python.Matlab仿真、视觉处理、神经网络、数据分析。
本文借鉴了作者最近为《R语言数据分析挖掘必知必会 》课堂做的准备。
非常感谢您阅读本文,如需帮助请联系我们!