编程语言
首页 > 编程语言> > 【视频】随机波动率SV模型原理和Python对标普SP500股票指数时间序列波动性预测

【视频】随机波动率SV模型原理和Python对标普SP500股票指数时间序列波动性预测

作者:互联网

全文链接:http://tecdat.cn/?p=22546 

原文出处:拓端数据部落公众号

 相关视频:

随机波动率SV模型原理和Python对标普SP500股票指数时间序列波动性预测

什么是随机波动率?

随机波动率 (SV) 是指资产价格的波动率是变化的而不是恒定的。 

“随机”一词意味着某些变量是随机确定的,无法精确预测。

在金融建模的背景下,随机建模迭代随机变量的连续值,这些值彼此不独立。非独立的意思是虽然变量的值会随机变化,但其起点将取决于其先前的值,因此取决于其先前的值,依此类推;这描述了所谓的随机游走。


随机波动率的经验证据 

在定义了波动率的含义之后,我们现在通过讨论波动率随机变化的证据来引导其余部分。我们(大体上)遵循,对现金和期权市场中观察到的价格行为进行一些实证观察。我们考虑了一些经济解释,并将它们与手头的主题联系起来:

厚尾 

现在普遍接受的是,资产收益的经验分布是尖峰的意思(大致),即关于均值的四阶矩大于具有相同方差的正态分布的相同统计量。这意味着观察到更多的极端回报和更少的中等回报,“尖峰”意味着实际分布中靠近均值的天数更多,“厚尾”表示极端收益率出现的频率高于正态分布的预测,比如出人意料的“黑天鹅事件”。 

波动性聚类和持久性

看一眼金融时间序列通常会立即发现高波动期和低波动期。 

事实上,肥尾和波动性聚类是同一枚硬币的两个方面。众所周知,分布的混合,例如根据正态分布分布的价格变化,但具有随机方差,可以复制肥尾。然而,通过直接将基础价格分布建模为具有肥尾,可以同样很好地解释肥尾和波动性聚类。另一个经验事实是波动机制的持续存在,存在高波动期和低波动期,而不仅仅是随机事件。这一观察表明了任何提议的波动率模型的某些内容。

什么是随机建模?

随机建模是一种用于帮助做出投资决策的财务模型。这种类型的建模使用随机变量预测不同条件下各种结果的概率。

随机建模呈现数据并预测结果,这些结果说明了一定程度的不可预测性或随机性。许多行业的公司都可以使用随机模型来改进他们的业务实践并提高盈利能力。在金融服务领域,规划师、分析师和投资组合经理使用随机模型来管理他们的资产和负债并优化他们的投资组合。

关键要点

了解随机建模:恒定与可变

要理解随机建模的概念,将其与相反的确定性建模进行比较会有所帮助。

确定性建模产生恒定的结果

无论您重新计算模型多少次,确定性建模都可以为特定的一组输入提供相同的精确结果。在这里,数学性质是已知的。它们都不是随机的,只有一组特定值和一个问题的答案或解决方案。对于确定性模型,不确定因素是模型外部的。

随机建模产生多变的结果

另一方面,随机建模本质上是随机的,模型中内置了不确定因素。该模型产生了许多答案、估计和结果——例如将变量添加到复杂的数学问题中——以查看它们对解决方案的不同影响。然后在各种情况下重复多次相同的过程。

波动性

资产的波动性是期权定价的关键组成部分。随机波动率模型是出于对期权定价的 Black Scholes 模型进行修改的需要而开发的,该模型未能有效地考虑到标的证券价格波动性可能发生变化的事实。Black Scholes 模型反而做了简化假设,即基础证券的波动性是恒定的。随机波动率模型通过允许基础证券的价格波动率作为随机变量波动来纠正这一点。通过允许价格变化,随机波动率模型提高了计算和预测的准确性。

随机波动的一般形式 

连续时间金融模型被写成使用随机微分方程的扩散过程。我们正在研究的模型的一般形式是 

和 

和 

这些方程意味着 S 的瞬时回报由一些确定性项加上一些随机噪声给出。本身遵循类似(但更一般)的随机动态。

Heston 随机波动率模型

Heston 模型是由金融学者 Steven Heston 在 1993 年创建的随机波动率模型。该模型使用波动率或多或少是随机的假设,并具有以下区别于其他随机波动率模型的特征:

如下图所示,观察到的股票波动率可能会飙升至高于或低于平均水平,但似乎总是在平均水平附近。高波动期之后通常是低波动期,反之亦然。使用均值回归确定波动范围并结合 预测 技术,投资者可以选择最佳交易。

Python随机波动率(SV)模型对标普500指数时间序列波动性预测

资产价格具有随时间变化的波动性(逐日收益率的方差)。在某些时期,收益率是高度变化的,而在其他时期则非常平稳。随机波动率模型用一个潜在的波动率变量来模拟这种情况,该变量被建模为随机过程。下面的模型与 No-U-Turn Sampler 论文中描述的模型相似,Hoffman (2011) p21。

这里,r是每日收益率序列,s是潜在的对数波动率过程。


建立模型

首先,我们加载标普500指数的每日收益率。

  1.   returns = (pm.get_data("SP500"))
  2.   returns\[:5\]

正如你所看到的,波动性似乎随着时间的推移有很大的变化,但集中在某些时间段。在2500-3000个时间点附近,你可以看到2009年的金融风暴。

ax.plot(returns)

指定模型。

  1.   GaussianRandomWalk('s', hape=len(returns))
  2.   nu = Exponential(  .1)
  3.   r = StudentT(  pm.math.exp(-2*s),
  4.                       obs=returns)

拟合模型

对于这个模型,最大后验(_Maximum_ A _Posteriori_,MAP)概率估计具有无限的密度。然而,NUTS给出了正确的后验。

  1.   pm.sample(tune=2000
  2.   Auto-assigning NUTS sampler...
plot(trace\['s'\]);

观察一段时间内的收益率,并叠加估计的标准差,我们可以看到该模型是如何拟合一段时间内的波动率的。

  1.   plot(returns)
  2.   plot(exp(trace\[s\]);
 np.exp(trace\[s\])

参考文献

  1. Hoffman & Gelman. (2011). The No-U-Turn Sampler: Adaptively Setting Path Lengths in Hamiltonian Monte Carlo.


点击文末“阅读原文”

获取全文完整资料。

本文选自《随机波动率SV模型原理和Python对标普SP500股票指数时间序列波动性预测》。

点击标题查阅往期内容

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

Matlab马尔可夫链蒙特卡罗法(MCMC)估计随机波动率(SV,Stochastic Volatility) 模型

R语言隐马尔可夫模型HMM连续序列重要性重抽样CSIR估计随机波动率模型SV分析股票收益率时间序列

马尔可夫Markov区制转移模型分析基金利率

马尔可夫区制转移模型Markov regime switching

时变马尔可夫区制转换MRS自回归模型分析经济时间序列

马尔可夫转换模型研究交通伤亡人数事故时间序列预测

如何实现马尔可夫链蒙特卡罗MCMC模型、Metropolis算法?

Matlab用BUGS马尔可夫区制转换Markov switching随机波动率模型、序列蒙特卡罗SMC、M H采样分析时间序列

R语言BUGS序列蒙特卡罗SMC、马尔可夫转换随机波动率SV模型、粒子滤波、Metropolis Hasting采样时间序列分析

matlab用马尔可夫链蒙特卡罗 (MCMC) 的Logistic逻辑回归模型分析汽车实验数据

stata马尔可夫Markov区制转移模型分析基金利率

PYTHON用时变马尔可夫区制转换(MRS)自回归模型分析经济时间序列

R语言使用马尔可夫链对营销中的渠道归因建模

matlab实现MCMC的马尔可夫转换ARMA - GARCH模型估计

R语言隐马尔可夫模型HMM识别不断变化的股票市场条件

R语言中的隐马尔可夫HMM模型实例

用机器学习识别不断变化的股市状况—隐马尔科夫模型(HMM)

Matlab马尔可夫链蒙特卡罗法(MCMC)估计随机波动率(SV,Stochastic Volatility) 模型

MATLAB中的马尔可夫区制转移(Markov regime switching)模型

Matlab马尔可夫区制转换动态回归模型估计GDP增长率

R语言马尔可夫区制转移模型Markov regime switching

stata马尔可夫Markov区制转移模型分析基金利率

R语言如何做马尔可夫转换模型markov switching model

R语言隐马尔可夫模型HMM识别股市变化分析报告

R语言中实现马尔可夫链蒙特卡罗MCMC模型

标签:Python,模型,波动,SV,波动性,建模,马尔可夫,随机,标普
来源: https://www.cnblogs.com/tecdat/p/16514167.html