python 隐含波动率_【BSM模型】用实际市场数据计算隐含波动率并验证波动率微笑...

在Black-Scholes期权定价模型中,不能直接观察到的参数只有股票价格的波动率。波动率可以由历史数据进行估计,这是历史波动率。隐含波动率也是交易员非常关心的,隐含波动率是期权的市场价格中所包含的波动率,即由期权价格和期权定价公式反推的波动率。隐含波动率和历史波动率作比较,可以指导投资者的操作。投资者可以直接买卖波动率,或者参考波动率确定买卖时机。

我们可以通过期权定价公式写出隐含波动率的方程,但是直接解方程非常困难,因为这个方程不存在闭合解。既然是用程序求解,当然可以用计算机求方程解的神器-数值计算。牛顿迭代法和二分法是求隐含波动率常用的两个方法。相比二分法,牛顿迭代法是更通用的近似求解方程的方法。

由于国内没有场内个股期权,曲曲菜用上证50ETF期权做分析。首先从新浪财经的网站获得期权的行情信息,并存入csv文件。到期时间我选了16天,51天,76天三种,分别存成三个文件。

新浪财经的期权行情数据(16天到期)

期权数据文件(16天到期)

然后就可以计算隐含波动率了,计算隐含波动率的python程序如下。

一.BSM模型

1.引入所用到的库

2. 定价公式的程序实现

二.牛顿迭代法

1.介绍

设r是f(x)=0的根,选取x0作为r的初始近似值,过点(x0,f(x0))做曲线y=f(x)

的切线L ,

,则L与x轴交点的横坐标

,称x1为r的一次近似值。过点(x1,f(x1))做曲线y=f(x)的切线,并求该切线与x轴交点的横坐标

,称x2为r的二次近似值。重复以上程,得r的近似值序列,其中,

称为r的n+1次近似值,上式称为牛顿迭代公式。

隐含波动率的计算中,f(x)是BSM定价公式得到的价格和实际价格的差,x是隐含波动率,f(x)中只有隐含波动率是未知数,其他是已知数。由定义可知,x的导数是vega。

2.程序实现

三.二分法

1.介绍

二分法求根的思想和二分查找相同,只不过二分查找比较的是未知数和目标,而二分法比较的是未知数的函数和目标函数值。二分法求根需要知道根所在的区间,将上下限分别设为区间的上下边界点,初始值设为上下限的均值。通过迭代不断更新并逼近方程的解。

2.程序实现

四.读取行情数据并初始化参数

1.程序实现

五.计算隐含波动率

1.程序实现

2.隐含波动率打印结果

imp_vol_newton_16:[0.3638689603157307, 0.3647065048442553, 0.33796965226626546, 0.3087508280418194, 0.29010352112059345, 0.27704783086782625, 0.2678504434116786, 0.27958298121452063, 0.2815159982582914, 0.2892477867510613, 0.2948778490238011, 0.3001603015476018, 0.3079952199130588]

imp_vol_dichotomy_16:[0.3638690114021301, 0.3647065758705139, 0.33796969056129456, 0.3087505102157593, 0.290103480219841, 0.2770475149154663, 0.2678511142730713, 0.2795829623937607, 0.28151603043079376, 0.2892477214336395, 0.29487812519073486, 0.3001604676246643, 0.30799537897109985]

-------------------------------------------------------------------------------------------------------------------------------------

imp_vol_newton_51:[0.2663830055838, 0.2623349770104388, 0.25886692974504383, 0.25514765329363565, 0.25388257585478174, 0.25112748137747243, 0.25311127192458244, 0.25282431711916714, 0.25334527303228827]

imp_vol_dichotomy_51:[0.26638298481702805, 0.26233501732349396, 0.25886694341897964, 0.2551477253437042, 0.25388259440660477, 0.2511274963617325, 0.25311121344566345, 0.2528250217437744, 0.25334523618221283]

-------------------------------------------------------------------------------------------------------------------------------------imp_vol_newton_79:[0.30525607059637466, 0.2900199629942286, 0.29426758619557364, 0.26917014044939297, 0.2708636644397624, 0.25993171220348904, 0.2610946078237793, 0.2527101923035752, 0.2523987108427234, 0.24752459839396573, 0.2483057133362068, 0.24353321749378323, 0.24308705976680656, 0.23851008170784155, 0.2406859629151288, 0.24016117575185575]

imp_vol_dichotomy_79:[0.30525608360767365, 0.29002001881599426, 0.29426760971546173, 0.2691701799631119, 0.2708636373281479, 0.25993166863918304, 0.261094618588686, 0.2527102008461952, 0.25239837169647217, 0.2475244402885437, 0.24830570071935654, 0.2435331791639328, 0.243087038397789, 0.2385101616382599, 0.24068592488765717, 0.24016119539737701]

-------------------------------------------------------------------------------------------------------------------------------------

六.绘制波动率曲线

1.绘制牛顿法曲线的程序实现

2.上一步绘制出的图形

3.绘制二分法曲线的程序实现

4.上一步绘制出的图形

从图形可以看出,51天到期和79天到期的隐含波动率随执行价格的递增,呈现递减趋势,这就是股票期权的波动率微笑(volatility smile)。16天到期的隐含波动率是随执行价格递增先是递减,至标的价格附近后,开始缓慢递增,这也是波动率微笑,虽然对股票期权来说,这个微笑不是很标准。从图形还可以看出,距离到期时间越近,隐含波动率越大。

波动率微笑反映了隐含波动率和执行价格的关系。外汇期权的波动率是对称的微笑, 股票期权的波动率微笑是不对称的,更准确的叫法是volatility skew(波动率倾斜),或者volatility smirk(波动率假笑)。反映到图形上,就是左高有低,隐含波动率随执行价格的递增而递减。

股票期权波动率微笑的原因,常见的解释是杠杆效应和恐慌情绪,但是也有人认为这就是一个市场的反应,没有特别的原因。(如需要本文的源代码和数据文件可以联系我)

代码在我的GitHub:https://github.com/ququcai/volatility_smile

参考资料

[1] 约翰 赫尔.期权、期货及其他衍生品

[2] Yves Hilpsch. Python for Finance: Analyze Big Financial Data

本文作者:曲曲菜(微信公众号:曲曲菜)

原创作品,未标明作者不得转载。

作者公众号

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/507163.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php获得指定目录文件,PHP遍历指定文件夹获取路径及大小(包含子文件夹)

PHP获取指定文件夹下(包含子文件夹)所有文件路径 及 大小代码如下:// 获取指定文件夹 所有文件及大小 (包含子文件夹) By 【简爱】function JA_files2arr($dirpath){if($dirpath[strlen($dirpath)-1]!"/"){$dirpath."/";} //static $result_arr…

winform判断线程有没有完成_并发编程系列1:线程池的架构实现、大小配置、及四种线程池使用...

△ 公众号回复关键词“架构” 即可领取《1500BAT架构及面试专题合集》本篇为线程池系列文章之一,不经常使用线程池的童鞋,还有对几种线程的使用不甚了解的童鞋,可以读一下此文,并关注后续线程池相关文章连载。 本篇内容大纲&#…

python枚举是什么意思,什么是枚举python

枚举类型可以看作是一种标签或是一系列常量的集合,通常用于表示某些特定的有限集合,例如星期、月份、状态等。Python 的原生类型(Built-in types)里并没有专门的枚举类型,但是我们可以通过很多方法来实现它,例如字典、类等&#x…

php 10060,远程连接mysql 10060错误

远程连接mysql 10060错误Could not connect: Cant connect to MySQL server on ***.***.***.*** (10060)代码是$con mysql_connect("***.***.***.***","user","Password");if (!$con){die(Could not connect: . mysql_error());}用户名和密码正…

python包含多个元组的元组_Python数据结构(元组,列表,字典)

Python内置了 几种数据结构,元组,列表 字典1.元组元组可以由不同的元素组成,所有元素通过圆括号( )包含起来,并通过逗号","隔开.如变量名 (元素1,元素2,...),如果a 1,3,56,abc,aoe,也默认a是元组每个元素也可以是不同的数据类型,字符串,数字,元组,列表,字典元组的元…

vscode 导入python库_vscode 如何导入python库

vscode 如何导入python库首先,我们要知道,VScode和本地运行的并不是同一个python,反正我的是这样,所以导致了在本地下载好库后,在VScode运行时还是报错。那么如何在VScode中导入python库呢?1.已经在vscode中…

docker部署php站点,docker部署php

## **Docker部署php**操作系统:Ubuntu16.04 / Ubuntu18.04~~~//查看可用的php版本$ docker search php//这里安装php7.1版$ docker pull php:7.1-fpm//启动挂载$ docker run -p 9000:9000 -d --name myphp-fpm -v /docker/www:/usr/share/nginx/www php:7.1-fpm//这…

python怎么退出调试模式_python – 在验尸调试时如何退出ipdb?

我喜欢使用以下方式检查Python脚本中的错误:$python3 -m pdb my_script.py这会让我进入一个pdb提示,从那里我可以继续执行,当它遇到错误,我可以检查变量,然后q退出脚本执行以回到我的shell.我尝试与iPython调试器模块相同,因为它更加丰富多彩:$python3 -…

oracle捕捉所有异常,如何捕获和处理特定的Oracle异常?

你有两个选择:直接通过编号参考例外:BEGINEXECUTE IMMEDIATE CREATE SEQUENCE S_TEST START WITH 1 INCREMENT BY 1;EXCEPTIONWHEN OTHERS THENIF SQLCODE -955 THENNULL; -- suppresses ORA-00955 exceptionELSERAISE;END IF;END;其他选项是使用EXCEPT…

拖拽批量上传图片如何保证 顺序_图片压缩神器和图片分割工具,美工设计和运营终于得救了...

想要快速互联网干货技巧?请(置顶)星标我们好不容易写好文案,设计好长图海报,上传到微信公众号,竟然提示上传图片体积不得超过5M,怎么办?怎么办?不得已,只好又返回Ps里降低…

php将word转txt,PHP如何将将word文件转为pdf

PHP将word文件转为pdf的方法:首先修改【php.ini】,并重启环境;然后安装微软office套件;最后配置office组件服务即可。PHP将word文件转为pdf的方法:1、修改php.ini添加:extensionphp_com_dotnet.dll去除注释…

redis一般缓存什么样数据_SpringBoot+Redis轻松实现数据缓存

1.为什么需要缓存为什么需要缓存,我相信搞开发的都能回答出来,无非就是为了降低数据库压力,节约资源,提升系统性能。而事实上也确实是,归根结底就是降压,高并发,高性能。不过,大厂里…

python里面的import provide_Python importorror:没有名为wmi的模块

我按照说明在这里下载了用于Python的WMI当我试图运行代码时import wmic wmi.WMI ()for s in c.Win32_Service (StartMode"Auto", State"Stopped"):if raw_input ("Restart %s? " % s.Caption).upper () "Y":s.StartService ()我收到…

php 微信消息解密,thinkphp微信开发(消息加密解密)

使用thinkphp官方的WeChat包,使用不同模式可以成功,但是安全模式就是不行,现将分析解决结果做下记录。分析问题:解密微信服务器消息老是不成功,下载下微信公众平台官方给出的解密文件和WechatCrypt.class.php进行比对发…

模型预测控制_模型预测控制(MPC)算法之一MAC算法

引言随着自动驾驶技术以及机器人控制技术的不断发展及逐渐火热,模型预测控制(MPC)算法作为一种先进的控制算法,其应用范围与领域得到了进一步拓展与延伸。目前提出的模型预测控制算法主要有基于非参数模型的模型算法控制(MAC)和动态矩阵控制(DMC)&#x…

基于dde的vb和matlab,基于VB和DDE技术的组态王通信协议转换

组态王是一种通用的工业监控上位机软件,它界面友好、易学易用、即便是不懂编程的工程人员也能在短时时间内开发出界面精美,符合行业标准且高效的上位机监控程序,因此深受工程师们的喜爱,然而组态王软件的上下位机通信协议是固定的切不可改变,这就给一些使用“自拟定协议”和“非…

pythonjava解释xml_Python解析XML文档

解析XML主要用到pytohn自带的XML库,其次还是lxml库XML结构,先以一个相对简单但功能比较全的XML文档为例dive into markcurrently between addictionstag:diveintomark.org,2001-07-29:/2009-03-27T21:56:07ZMarkhttp://diveintomark.org/Dive into histo…

红旗linux安装oracle,Redflag Linux安装Oracle 10gR2 RAC记事

Redflag Linux安装Oracle 10gR2 RAC记事Kamus遇到过:SQL> startup nomountORA-27102: out of memoryLinux-x86_64 Error: 28: No space LEFT ON device这和内核参数 shmall 有关,修改设置 kernel.shmall 16475728 。后来离开没多久,客户打…

springboot开启debug日志_SpringBoot 如何优雅的打印日志?

一、打印日志注意事项1、使用 Slf4j 注解这个代码相信大家都很熟悉,你是否曾经看到或者自己因 copy 而 没有改变“当前类名”?如果你们项目用到 lombok ,可以在类上使用 Slf4j 注解,省去手动写这行代码。2、不建议使用的输出为什么…

oracle导出表中某天数据命令,Oracle数据库使用命令行导入导出数据表及数据内容(本地、远程)...

一、本机导入导出1、数据库导出命令,导出用户userA下的表结构和数据:exp 用户名/密码服务名 owner用户名 file导出文件指定存储路径 fully2、数据库导入命令,将userA用户下的表结构和数据导入到用户userB下:imp 用户名/密码服务名 fromuser导…