首页 > 编程语言 >Python随机波动模型Stochastic volatility,SV随机变分推断SVI分析标普500指数股票价格时间数据波动性可视化

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

时间:2023-10-08 22:44:07浏览次数:35  
标签:SVI Python ...... 建模 波动性 时间 随机 模型 500

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

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

随机波动模型(Stochastic volatility models)经常被客户用来对股票价格随时间的变动性进行建模。波动性(volatility)是随时间的对数收益的标准差。与假设波动性恒定不变不同,随机波动模型具有隐变量参数,可以在每个时刻对波动性进行建模。

   
import numpy as np

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

数据

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

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

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

  python
# 绘制原始标普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([
......)

image.png

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

   
plt.plot(y.T)

......

output_19_1.png

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

   
# 从后验分布中抽样
Ns = 50

......

# 绘制随时间变化的后验分布
plt.plot(y.T)

......
plt.show()

output_21_0.png


A-decade-after-the-global-financial-crisis-1536x1536-250.jpg

最受欢迎的见解

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

2.R语言GARCH-DCC模型和DCC(MVT)建模估计

3.R语言实现 Copula 算法建模依赖性案例分析报告

4.R语言COPULAS和金融时间序列数据VaR分析

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

6.用R语言实现神经网络预测股票实例

7.r语言预测波动率的实现:ARCH模型与HAR-RV模型

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

9.matlab使用Copula仿真优化市场风险

标签:SVI,Python,......,建模,波动性,时间,随机,模型,500
From: https://www.cnblogs.com/tecdat/p/17750379.html

相关文章

  • 机器学习之旅-从Python 开始
    你想知道如何开始机器学习吗?在这篇文章中,我将简要概括一下使用Python来开始机器学习的一些步骤。Python是一门流行的开源程序设计语言,也是在人工智能及其它相关科学领域中最常用的语言之一。机器学习简称ML,是人工智能的一个分支,它是利用算法从数据中进行学习,然后作出预测。......
  • python xml(ElementTree)
    pythonxml处理(ElementTree)1.模块导入fromxml.etree.ElementTreeimportElementTree,Element,SubElement2.对象概述ElementTree:表示整个xml层级结构Element:表示树形结构中的父节点SubElement:表示树形结构中的所有子节点,有些节点既可以是父节点,也可以是子节点3.Elem......
  • Python 内部类,内部类调用外部类属性,方法
     一Python中内部类classMyOuter:age=18def__init__(self,name):self.name=nameclassMyInner:def__init__(self,inner_name):self.inner_name=inner_nameout=MyOuter('lqz')inner=out.MyInner('lqz_inner�......
  • Python检测Windows剩余磁盘空间
    设计模块包:wmi  #pipinstallwmiwindows1064位,安装成功;windows200864位,安装失败。 WindowsManagementInstrumentation(WMI)AlightweightwrapperaroundtheWMIclassesavailableforallWin32platforms.Theseprovideastandardwaytoaccesssystem-leveli......
  • Python 压缩文件解压文件
    安装zipfilepip3installzipfile38pip3installzipfile37 f=zipfile.ZipFile("test.zip",mode="")//mode解压是r,压缩是w,追加压缩是a  压缩文件importzipfiledefzip_files(files,zip_name):zip=zipfile.ZipFile(zip_name,'w',zipfi......
  • python29days
    绑定方法绑定给对象绑定给类非绑定方法(静态static)封装隐藏属性property装饰器(内置的,用来把函数伪装成属性)封装————————————————————————————————————————————————————————  该方法就......
  • 【Python】数独游戏
    StartimportrandomclassSudokuGenerator:BOARD_SIZE=9SUBGRID_SIZE=3def__init__(self)->None:self.board=[[0for_inrange(self.BOARD_SIZE)]for_inrange(self.BOARD_SIZE)]defgenerate(self):self.fill_va......
  • Python入门示例系列10 字符串(初级)
     字符串(string)Python中的字符串用单引号'或双引号"括起来,同时使用反斜杠\转义特殊字符。'ABC' 与"ABC"完全等价。示例:s1="hello"#双引号"括起来s2='hello'#单引号'括起来s3=''#空字符串s4=""#空字符串s5='''......
  • Python入门示例系列07 Python注释
     Python中的注释有单行注释(linecomment)和多行注释(paragraphcomment,blockcomment):Python中单行注释以#(hash,pound)开头,例如:#这是一个单行注释acommentlineprint("Hello!")#这是一个单行注释acommentline示例:#thisisthefirstcommentspam=1#andthisist......
  • Python入门示例系列06 使用PyCharm单步调试
    摘要: 使用PyCharm单步调试视频演示(0分52秒)启动PyCharm#新建Project#输入项目位置#注意:选定解释器新建py文件输入文件名,按回车输入代码a=1b=2c=3print("helloworld")左侧点击设置断点调试(代码区域,右键,调试)查看Variable结果 系列目录Python入门示例系列0......