R语言时间序列GARCH模型分析股市波动率
首页 专栏 算法 文章详情
0

R语言时间序列GARCH模型分析股市波动率

拓端tecdat 发布于 4 月 29 日

原文链接:http://tecdat.cn/?p=22360 

在这篇文章中,我们将学习一种在价格序列中建立波动性模型的标准方法,即广义自回归条件异方差(GARCH)模型。

价格波动的 GARCH 模型的思想是利用误差结构的近期实现来预测误差结构的未来实现。更简单地说,我们经常看到在高波动性或低波动性时期的聚类,因此我们可以利用近期的波动性来预测近期的波动性。

我们将使用SPY价格来说明波动率的模型。下面的图显示了SPY收益率。

colnames(SPYRet) <- c('SPY') SPYRet           <- tidy(SPYRet) ggplot(SPYRet) +    geom_line() +    labs(title = "SPY收益率"

这篇文章的首要目标是对价格收益序列的变化的平均值和方差进行建模。

接下来,我们将通过两种常用的方式来显示收益率的变化方差。这些是绘制价格收益的绝对值。

或价格收益的平方

这两种情况都是有意义的,因为方差总是一个正数,并且受到偏离平均值的影响。当然这是在我们知道收益序列的平均值为0的情况下。

在价格数据中,百分比回报率的平均值几乎都非常接近于0。 如果平均回报率非零,那么我们可以直接绘制

add_column( value^2,  abs(value)) ggplot(SPYRet) +    geom_line() +    labs(title = "SPY绝对收益值"

ggplot(Ret, aes(y = SquaredReturns) +    geom_line() +    labs(title = "SPY平方收益率"

波动率的GARCH模型

普通的(GARCH模型有很多变体)GARCH模型如下。

第一行是为均值建模的方程。这里没有ARMA效应,但如果你发现它们很重要,可以很容易地把它们放进去。只有一个截距和一个误差项。接下来的三行将更多的结构放在误差项上,
第二行为什么我们要把两个项相乘来得到ϵt?
要看到这一点,重要的是要牢记这里的目标。我们正在寻找一个能给我们带来rSPYt变化方差的模型

因此,如果基本收益模型是

接下来的步骤依赖于随机变量方差的属性。具体来说,如果

因此,如果我们得到一个εt的模型
考虑GARCH模型中的第二行。

请注意 σtσ2ϵ2

最后一行是由于

估计GARCH模型

下面的代码使用rugarch R包来估计GARCH(p = 1, q = 1)模型。请注意,p和q表示σ2tϵ2t的滞后数。
第一条命令要求它用model = "sGARCH "指定一个普通的GARCH。它要求它使用ARMA(1, 1)作为收益模型,即armaOrder = c(1, 1), include.mean = TRUE。我们要求它使用N(0,1),distribution.model="norm",模型输出显示在 "最优参数 "下。mu、ar1和ma1系数来自均值模型(ARMA(1,1)),omega、alpha1和beta1是来自 

garchspec(variance.m = list(model = "sGARCH", mean.m= list(armaOrder = c(1, 1)                             dist = "norm") garchfit

现在让我们用这个估计的模型来产生滚动预测,即

forecast(spec, n.ahead = 1, n.roll = 2499, out = 2500) plot(forecast)

可以看到,这个模型很好的预测了波动率峰值将保持多长时间,或者说是模拟了波动率峰值回落到长期平均水平的路径。由于所有的计量经济学模型都是用过去的数值来预测当前的数值,所以它无法预见波动率最初上升的情况。

最受欢迎的见解

1.HAR-RV-J与递归神经网络(RNN)混合模型预测和交易大型股票指数的高频波动率

2.R语言中基于混合数据抽样(MIDAS)回归的HAR-RV模型预测GDP增长

3.波动率的实现:ARCH模型与HAR-RV模型

4.R语言ARMA-EGARCH模型、集成预测算法对SPX实际波动率进行预测

5.GARCH(1,1),MA以及历史模拟法的VaR比较

6.R语言多元COPULA GARCH 模型时间序列预测

7.R语言基于ARMA-GARCH过程的VAR拟合和预测

8.matlab预测ARMA-GARCH 条件均值和方差模型

9.R语言对S&P500股票指数进行ARIMA + GARCH交易策略

算法 机器学习 人工智能 深度学习 数据挖掘
阅读 83 更新于 4 月 29 日
收藏
分享
本作品系原创, 采用《署名-非商业性使用-禁止演绎 4.0 国际》许可协议
拓端数据
拓端tecdat分享最in的大数据资讯,提供“一站式”的数据分析学习和咨询体验,让我们一起做有态度的数据人...
关注专栏
avatar
拓端tecdat

拓端(http://tecdat.cn )创立于2016年,自成立以来,就定位为提供专业的数据分析与数据挖掘服务的提供商,致力于充分挖掘数据的价值,为客户定制个性化的数据解决方案与行业报告等。

169 声望
27 粉丝
关注作者
0 条评论
得票数 最新
提交评论
你知道吗?

注册登录
avatar
拓端tecdat

拓端(http://tecdat.cn )创立于2016年,自成立以来,就定位为提供专业的数据分析与数据挖掘服务的提供商,致力于充分挖掘数据的价值,为客户定制个性化的数据解决方案与行业报告等。

169 声望
27 粉丝
关注作者
宣传栏
目录

原文链接:http://tecdat.cn/?p=22360 

在这篇文章中,我们将学习一种在价格序列中建立波动性模型的标准方法,即广义自回归条件异方差(GARCH)模型。

价格波动的 GARCH 模型的思想是利用误差结构的近期实现来预测误差结构的未来实现。更简单地说,我们经常看到在高波动性或低波动性时期的聚类,因此我们可以利用近期的波动性来预测近期的波动性。

我们将使用SPY价格来说明波动率的模型。下面的图显示了SPY收益率。

colnames(SPYRet) <- c('SPY') SPYRet           <- tidy(SPYRet) ggplot(SPYRet) +    geom_line() +    labs(title = "SPY收益率"

这篇文章的首要目标是对价格收益序列的变化的平均值和方差进行建模。

接下来,我们将通过两种常用的方式来显示收益率的变化方差。这些是绘制价格收益的绝对值。

或价格收益的平方

这两种情况都是有意义的,因为方差总是一个正数,并且受到偏离平均值的影响。当然这是在我们知道收益序列的平均值为0的情况下。

在价格数据中,百分比回报率的平均值几乎都非常接近于0。 如果平均回报率非零,那么我们可以直接绘制

add_column( value^2,  abs(value)) ggplot(SPYRet) +    geom_line() +    labs(title = "SPY绝对收益值"

ggplot(Ret, aes(y = SquaredReturns) +    geom_line() +    labs(title = "SPY平方收益率"

波动率的GARCH模型

普通的(GARCH模型有很多变体)GARCH模型如下。

第一行是为均值建模的方程。这里没有ARMA效应,但如果你发现它们很重要,可以很容易地把它们放进去。只有一个截距和一个误差项。接下来的三行将更多的结构放在误差项上,
第二行为什么我们要把两个项相乘来得到ϵt?
要看到这一点,重要的是要牢记这里的目标。我们正在寻找一个能给我们带来rSPYt变化方差的模型

因此,如果基本收益模型是

接下来的步骤依赖于随机变量方差的属性。具体来说,如果

因此,如果我们得到一个εt的模型
考虑GARCH模型中的第二行。

请注意 σtσ2ϵ2

最后一行是由于

估计GARCH模型

下面的代码使用rugarch R包来估计GARCH(p = 1, q = 1)模型。请注意,p和q表示σ2tϵ2t的滞后数。
第一条命令要求它用model = "sGARCH "指定一个普通的GARCH。它要求它使用ARMA(1, 1)作为收益模型,即armaOrder = c(1, 1), include.mean = TRUE。我们要求它使用N(0,1),distribution.model="norm",模型输出显示在 "最优参数 "下。mu、ar1和ma1系数来自均值模型(ARMA(1,1)),omega、alpha1和beta1是来自 

garchspec(variance.m = list(model = "sGARCH", mean.m= list(armaOrder = c(1, 1)                             dist = "norm") garchfit

现在让我们用这个估计的模型来产生滚动预测,即

forecast(spec, n.ahead = 1, n.roll = 2499, out = 2500) plot(forecast)

可以看到,这个模型很好的预测了波动率峰值将保持多长时间,或者说是模拟了波动率峰值回落到长期平均水平的路径。由于所有的计量经济学模型都是用过去的数值来预测当前的数值,所以它无法预见波动率最初上升的情况。

最受欢迎的见解

1.HAR-RV-J与递归神经网络(RNN)混合模型预测和交易大型股票指数的高频波动率

2.R语言中基于混合数据抽样(MIDAS)回归的HAR-RV模型预测GDP增长

3.波动率的实现:ARCH模型与HAR-RV模型

4.R语言ARMA-EGARCH模型、集成预测算法对SPX实际波动率进行预测

5.GARCH(1,1),MA以及历史模拟法的VaR比较

6.R语言多元COPULA GARCH 模型时间序列预测

7.R语言基于ARMA-GARCH过程的VAR拟合和预测

8.matlab预测ARMA-GARCH 条件均值和方差模型

9.R语言对S&P500股票指数进行ARIMA + GARCH交易策略