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

相关文章
|
1月前
|
机器学习/深度学习 数据可视化 TensorFlow
使用Python实现深度学习模型的分布式训练
使用Python实现深度学习模型的分布式训练
173 73
|
1月前
|
机器学习/深度学习 数据采集 供应链
使用Python实现智能食品消费需求分析的深度学习模型
使用Python实现智能食品消费需求分析的深度学习模型
82 21
|
1月前
|
机器学习/深度学习 数据采集 搜索推荐
使用Python实现智能食品消费偏好预测的深度学习模型
使用Python实现智能食品消费偏好预测的深度学习模型
81 23
|
20天前
|
数据采集 Web App开发 监控
Python爬虫:爱奇艺榜单数据的实时监控
Python爬虫:爱奇艺榜单数据的实时监控
|
1月前
|
机器学习/深度学习 数据采集 数据挖掘
使用Python实现智能食品消费习惯预测的深度学习模型
使用Python实现智能食品消费习惯预测的深度学习模型
117 19
|
1月前
|
机器学习/深度学习 数据采集 数据挖掘
使用Python实现智能食品消费模式预测的深度学习模型
使用Python实现智能食品消费模式预测的深度学习模型
59 2
|
1月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
1月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
29天前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
108 80
|
18天前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
35 14

热门文章

最新文章