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

简介: Python随机波动模型Stochastic volatility,SV随机变分推断SVI分析标普500指数时间数据波动性可视化

全文链接:https://tecdat.cn/?p=33809


随机波动模型(Stochastic volatility models)经常被客户用来对股票价格随时间的变动性进行建模点击文末“阅读原文”获取完整代码数据


波动性(volatility)是随时间的对数收益的标准差。与假设波动性恒定不变不同,随机波动模型具有隐变量参数,可以在每个时刻对波动性进行建模。

import numpy as np

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

数据

我们将对标普500指数按日回报的波动性进行建模。让我们加载过去三年的数据。

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

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

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

image.png

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


点击标题查阅往期内容


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


01

02

03

04


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

image.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([
......)

image.png

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

plt.plot(y.T)
......

image.png

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

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

image.png

相关文章
|
4月前
|
Java 数据处理 索引
(numpy)Python做数据处理必备框架!(二):ndarray切片的使用与运算;常见的ndarray函数:平方根、正余弦、自然对数、指数、幂等运算;统计函数:方差、均值、极差;比较函数...
ndarray切片 索引从0开始 索引/切片类型 描述/用法 基本索引 通过整数索引直接访问元素。 行/列切片 使用冒号:切片语法选择行或列的子集 连续切片 从起始索引到结束索引按步长切片 使用slice函数 通过slice(start,stop,strp)定义切片规则 布尔索引 通过布尔条件筛选满足条件的元素。支持逻辑运算符 &、|。
282 0
|
5月前
|
数据可视化 搜索推荐 大数据
基于python大数据的北京旅游可视化及分析系统
本文深入探讨智慧旅游系统的背景、意义及研究现状,分析其在旅游业中的作用与发展潜力,介绍平台架构、技术创新、数据挖掘与服务优化等核心内容,并展示系统实现界面。
|
5月前
|
机器学习/深度学习 数据采集 并行计算
多步预测系列 | LSTM、CNN、Transformer、TCN、串行、并行模型集合研究(Python代码实现)
多步预测系列 | LSTM、CNN、Transformer、TCN、串行、并行模型集合研究(Python代码实现)
560 2
|
5月前
|
数据可视化 数据挖掘 大数据
基于python大数据的水文数据分析可视化系统
本研究针对水文数据分析中的整合难、分析单一和可视化不足等问题,提出构建基于Python的水文数据分析可视化系统。通过整合多源数据,结合大数据、云计算与人工智能技术,实现水文数据的高效处理、深度挖掘与直观展示,为水资源管理、防洪减灾和生态保护提供科学决策支持,具有重要的应用价值和社会意义。
|
5月前
|
算法 安全 新能源
基于DistFlow的含分布式电源配电网优化模型【IEEE39节点】(Python代码实现)
基于DistFlow的含分布式电源配电网优化模型【IEEE39节点】(Python代码实现)
438 0
|
5月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
545 102
|
5月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
402 104
|
5月前
|
人工智能 自然语言处理 算法框架/工具
Python:现代编程的首选语言
Python:现代编程的首选语言
313 103

推荐镜像

更多