Python随机波动模型Stochastic volatility,SV随机变分推断SVI分析标普500指数股票价格时间序列数据波动性可视化

随机波动模型(Stochastic volatility models)经常被客户用来对股票价格随时间的变动性进行建模。

波动性(volatility)是随时间的对数收益的标准差。

由Kaizong Ye,Weilong Zhang撰写

与假设波动性恒定不变不同,随机波动模型具有隐变量参数,可以在每个时刻对波动性进行建模。


import numpy as np

这个例子使用了随机变分推断(stochastic variational inference)。

数据

我们将对标普500指数按日回报的波动性进行建模。

让我们加载过去三年的数据。

pythondf = pd.read_csv('Pt.csv')

我们可以查看随时间的原始指数值:


视频

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

探索见解

去bilibili观看

探索更多视频


# 绘制原始标普500指数性能
plt.plot(df['S&P 500']) ......
output_7_1.png

但我们也可以计算对数收益的差异,然后将其建模以估计波动性。

python


# 计算对数收益
y = df['S&P 500'].values ...... # 绘图 plt.plot(y.T) ......
output_9_1.png

模型

在每个时间点 ((i)),我们将对该时间点的对数收益进行建模 ((y_i))。模型允许随时间改变波动性,因此每个时间点的波动性由该时间点的参数 ((s_i)) 控制。

然而,我们不能让每个时间点的尺度参数 ((s_i)) 完全独立,否则模型会过度拟合数据!

我们将使用正态分布作为每个 (s) 参数的变分后验分布,对于 (\nu) 和 (\sigma):

让我们使用 ProbFlow 构建这个模型。

class Stolity(pf.Model): def __init__(self, N): ......1), transform=tf.exp) def __call__(self): ...... self.add_kl_loss(s_posteriors, s_priors) return pf.StudentT(self.nu(), 0, tf.exp(self.s()))

然后我们可以实例化该模型,

model = Stocty(N)

并将其拟合到数据上!

model.fit(y, ......)

检查拟合结果

我们可以查看参数 (\sigma) 和 (\nu) 的后验分布:


model.posterior_plot([ ......)

图片

R语言随机波动模型SV:马尔可夫蒙特卡罗法MCMC、正则化广义矩估计和准最大似然估计上证指数收益时间序列

阅读文章


image.png


随时关注您喜欢的主题


但更重要的是,我们可以绘制随时间变化的波动性的 MAP 估计:

plt.plot(y.T) ......
output_19_1.png

由于这是一个贝叶斯模型,我们还可以对每个时间点的波动性量进行不确定性估计:

# 从后验分布中抽样 Ns = 50 ...... # 绘制随时间变化的后验分布 plt.plot(y.T) ...... plt.show()
output_21_0.png


可下载资源

关于作者

Kaizong Ye拓端研究室(TRL)的研究员。在此对他对本文所作的贡献表示诚挚感谢,他在上海财经大学完成了统计学专业的硕士学位,专注人工智能领域。擅长Python.Matlab仿真、视觉处理、神经网络、数据分析。

本文借鉴了作者最近为《R语言数据分析挖掘必知必会 》课堂做的准备。

​非常感谢您阅读本文,如需帮助请联系我们!

 
QQ在线咨询
售前咨询热线
15121130882
售后咨询热线
0571-63341498

关注有关新文章的微信公众号


永远不要错过任何见解。当新文章发表时,我们会通过微信公众号向您推送。

技术干货

最新洞察

This will close in 0 seconds