热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Delta对冲:模拟实验

文章目录期权Delta对冲:模拟实验1.模拟参数设定2.MonteCarlo模拟标的价格路径3.利用BS计算delta和期权理论价值4.结果呈现4.1使用实际波动率进


文章目录

  • 期权Delta对冲:模拟实验
    • 1. 模拟参数设定
    • 2. Monte Carlo模拟标的价格路径
    • 3. 利用BS计算delta和期权理论价值
    • 4. 结果呈现
      • 4.1 使用实际波动率进行对冲
      • 4.2 使用隐含波动率进行对冲
    • 5. 完整代码


期权Delta对冲:模拟实验


1. 模拟参数设定

假定买入一个欧式平值认购期权,一年后到期,行权价为100,隐含波动率为20%,实际波动率为30%,无风险利率为5%。本文将对冲1000次,根据不同的价格路径模拟标准delta对冲过程十次。本实验基于BS公式与其假设条件(波动率是固定不变的)。


2. Monte Carlo模拟标的价格路径

假设标的资产价格服从几何布朗运动:
dS=μSdt+σSdz,dz=ϵdtdS = \mu S dt +\sigma S dz, dz = \epsilon \sqrt{dt}dS=μSdt+σSdz,dz=ϵdt


由于风险中性的假设存在,其中μ=r\mu = rμ=r,μ\muμ是标的资产价格收益的均值,σ\sigmaσ是标的资产价格收益的年化标准差,ϵ\epsilonϵ服从N(0,1)N(0,1)N(0,1)的正态分布。
根据伊藤引理:
有伊藤过程dx=a(t,x)dt+b(t,x)dzdx = a(t,x)dt+b(t,x)dzdx=a(t,x)dt+b(t,x)dz,其中dz服从维纳过程
G(x,t)服从以下过程 :
dG=(∂G∂xa+∂G∂t+12∂2G∂x2b2)dt+∂G∂zbdzdG = (\frac{\partial G}{\partial x}a +\frac{\partial G}{\partial t} +\frac{1}{2} \frac{\partial^2 G}{\partial x^2}b^2)dt+\frac{\partial G}{\partial z}bdzdG=(xGa+tG+21x22Gb2)dt+zGbdz
G=ln⁡SG=\ln SG=lnS,则∂G∂x=1S,∂2G∂x2=−1S2,∂G∂t=0\frac{\partial G}{\partial x} =\frac{1}{S}, \frac{\partial^2 G}{\partial x^2}=-\frac{1}{S^2}, \frac{\partial G}{\partial t}=0xG=S1,x22G=S21,tG=0,可以推出:
dG=d(ln⁡S)=(μ−σ22)dt+σdzST=S0exp((μ−σ22)T+σϵT)dG =d(\ln S)=(\mu - \frac{\sigma^2}{2})dt + \sigma dz \\ S_T = S_0 exp((\mu - \frac{\sigma^2}{2})T + \sigma \epsilon \sqrt{T}) dG=d(lnS)=(μ2σ2)dt+σdzST=S0exp((μ2σ2)T+σϵT

)
模拟标的价格的代码如下:

stock_price_paths = init_stock_price * np.exp(np.cumsum((risk_free_rate - 0.5 * actual_volatility ** 2) * dt + actual_volatility * sqrt(dt) * random_seed,axis=0))

3. 利用BS计算delta和期权理论价值

Black-sholes公式如下所示:
计算公式

def get_delta(S, T, K, sigma, rf, option_type):if option_type == "Call":n = 1else:n = -1d1 = (np.log(S / K) + (rf + 0.5 * sigma ** 2) * T) / (sigma * np.sqrt(T))delta = n * si.norm.cdf(n * d1)return deltadef get_option_price(S, T, K, sigma, rf, option_type):d1 = (np.log(S / K) + (rf + 0.5 * sigma ** 2) * T) / (sigma * np.sqrt(T))d2 = d1 - sigma * np.sqrt(T)if option_type == "Call":option_price = S * norm.cdf(d1) - K * np.exp(-rf * T) * norm.cdf(d2)else:option_price = K * np.exp(-rf * T) * norm.cdf(-d2) - S * norm.cdf(-d1)return option_price

4. 结果呈现


4.1 使用实际波动率进行对冲

使用实际波动率进行对冲,最终的收益是确定的,即V(S,t,σ)−V(S,t,σ~)V(S,t,\sigma) - V(S,t,\tilde{\sigma})V(S,t,σ)V(S,t,σ~),其中S代表标的资产的价格,t代表剩余到期时间,σ\sigmaσ代表实际波动率,σ~\tilde{\sigma}σ~代表隐含波动率。对冲收益取决于隐含波动率和实际波动率的差。

此外,可以看出每次对冲的收益是不确定的,具有较大的波动性。
实际波动率


4.2 使用隐含波动率进行对冲

使用隐含波动率进行对冲,最终的收益是不确定的,总收益为12(σ2−σ~2)∫t0Te−r(t−t0)S2Γidt\frac{1}{2}(\sigma^2 - \tilde{\sigma}^2) \int_{t_0}^{T} e^{-r(t-t_0)} S^2 \Gamma^i dt21(σ2σ~2)t0Ter(tt0)S2Γidt, 在本次实验中的实际波动率为30%,高于隐含波动率20%,且期权的Gamma值一定为正,对冲的收益一定为正,但收益的值是不确定的。

但是每次对冲的收益是确定的,没有较大的波动。每次对冲的收益为12(σ2−σ~2)S2Γidt\frac{1}{2}(\sigma^2 - \tilde{\sigma}^2) S^2 \Gamma^i dt21(σ2σ~2)S2Γidt

隐含波动率


5. 完整代码

# -*- coding: utf-8 -*-
"""
@time:2021/6/24 9:58@author: Hu Yue
@email: hhhuyue@gmail.com
@file: hedge.py
Note:
"""

from math import sqrt
import scipy.stats as si
import numpy as np
from matplotlib import pyplot as plt
from scipy.stats import norm# 1.对冲场景设定(无分红)
risk_free_rate = 0.05
implied_volatility = 0.2
actual_volatility = 0.3init_stock_price = 100
strike_price = 100strike_style = "European"
option_type = "Call"T = 1
simulation_steps = 1000 # 每次模拟有1000步
simulation_times = 10 # 模拟10次
dt = 1 / 1000
random_seed = np.random.standard_normal((simulation_steps, simulation_times))# 2.Monte Carlo模拟标的价格路径 S_t = S_0 * exp((u-0.5*sigma**2)dt+sigma*dz)
stock_price_paths = init_stock_price * np.exp(np.cumsum((risk_free_rate - 0.5 * actual_volatility ** 2) * dt + actual_volatility * sqrt(dt) * random_seed,axis=0))# 制作模拟价格走势图表
# plt.plot(stock_price_paths[:, :], lw=1.5)
# plt.rcParams['font.sans-serif'] = ['SimHei']
# plt.xlabel('时间')
# plt.ylabel('价格')
# plt.title('模拟价格走势')
# plt.show()# 3.delta对冲
def get_delta(S, T, K, sigma, rf, option_type):if option_type == "Call":n = 1else:n = -1d1 = (np.log(S / K) + (rf + 0.5 * sigma ** 2) * T) / (sigma * np.sqrt(T))delta = n * si.norm.cdf(n * d1)return deltadef get_option_price(S, T, K, sigma, rf, option_type):d1 = (np.log(S / K) + (rf + 0.5 * sigma ** 2) * T) / (sigma * np.sqrt(T))d2 = d1 - sigma * np.sqrt(T)if option_type == "Call":option_price = S * norm.cdf(d1) - K * np.exp(-rf * T) * norm.cdf(d2)else:option_price = K * np.exp(-rf * T) * norm.cdf(-d2) - S * norm.cdf(-d1)return option_price# 计算每次对冲的delta值
expire_time = (np.ones((simulation_steps, 1)) * dt).cumsum()[::-1] # 倒序
pnl = np.zeros((simulation_steps - 1, simulation_times))
for simulation in range(simulation_times):# 股票价格stock_price = stock_price_paths[:, simulation].reshape((simulation_steps, 1))delta = np.zeros((simulation_steps, 1))option_price = np.zeros((simulation_steps, 1))for step in range(simulation_steps):# 基于实际波动率计算的delta值delta[step] = get_delta(stock_price[step], expire_time[step], strike_price, actual_volatility, risk_free_rate,option_type)# 基于隐含波动率计算的delta值# delta[step] = get_delta(stock_price[step], expire_time[step], strike_price, implied_volatility, risk_free_rate,option_type)# 基于implied volatility计算出的期权理论价值,也就是市场上期权的价值。option_price[step] = get_option_price(stock_price[step], expire_time[step], strike_price, implied_volatility,risk_free_rate,option_type)pnl_path = np.diff(option_price, axis=0) - delta[:-1] * np.diff(stock_price, axis=0) - \risk_free_rate * dt * (option_price[:-1] - delta[:-1] * stock_price[:-1])pnl[:, simulation] = pnl_path.reshape(simulation_steps - 1)
cum_pnl = pnl.cumsum(axis=0)# 4.不同价格路径下期权对冲累积收益图plt.plot(cum_pnl[:, :], lw=1.5)
plt.rcParams['font.sans-serif'] = ['KaiTi', 'SimHei', 'FangSong'] # 汉字字体,优先使用楷体,如果找不到楷体,则使用黑体
plt.rcParams['font.size'] = 12 # 字体大小
plt.rcParams['axes.unicode_minus'] = False # 正常显示负号
plt.xlabel('时间')
plt.ylabel('收益')
plt.title('期权对冲累积收益图')
plt.show()

推荐阅读
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • Givenasinglylinkedlist,returnarandomnode'svaluefromthelinkedlist.Eachnodemusthavethe s ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
author-avatar
依然-狠幸福
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有