心得经验总结:期权定价的BS公式

简介: 心得经验总结:期权定价的BS公式

期权定价的BS公式是指由Black-Scholes模型提出的期权定价公式,它是一种用于计算欧式期权价格的数学模型。BS公式的全称是Black-Scholes-Merton公式,它是由费希尔·布莱克(Fischer Black)、默顿·斯科尔斯(Myron Scholes)和罗伯特·默顿(Robert Merton)在1973年独立提出的。

BS公式的基本形式如下:

C=St?N(d1?)?Xe?r(T?t)N(d2?)

P=Xe?r(T?t)N(?d2?)?St?N(?d1?)

其中:

St?:当前标的资产(如股票)价格。

X:期权的行权价格。

T:期权的到期日。

t:当前时间。

r:无风险利率。

N(?):标准正态分布的累积分布函数。

d1? 和 d2? 是计算中间变量,分别为:

?其中,σ 是标的资产的波动率(年化波动率)。

BS公式的前提假设了市场是有效的,标的资产的价格服从几何布朗运动,并且不存在交易成本、无风险利率是恒定的等。这个公式在金融领域被广泛应用,为期权交易提供了重要的理论基础。

一、用VBA代码书写上述过程:

Function BlackScholes(OptionType As String, S As Double, X As Double, T As Double, r As Double, Volatility As Double) As Double

Dim d1 As Double

Dim d2 As Double

' 计算d1和d2

d1 = (Log(S / X) + (r + (Volatility ^ 2) / 2) T) / (Volatility Sqr(T))

d2 = d1 - Volatility Sqr(T)

' 根据期权类型计算期权价格

If OptionType = "Call" Then

BlackScholes = S WorksheetFunction.NormSDist(d1) - X Exp(-r T) WorksheetFunction.NormSDist(d2)

ElseIf OptionType = "Put" Then

BlackScholes = X Exp(-r T) WorksheetFunction.NormSDist(-d2) - S WorksheetFunction.NormSDist(-d1)

Else

' 如果期权类型不是"Call"或"Put",返回错误值

BlackScholes = CVErr(xlErrValue)

End If

End Function

此代码定义了一个名为BlackScholes的VBA函数,该函数接受期权类型("Call"或"Put")、标的资产价格(S)、行权价格(X)、剩余到期时间(T)、无风险利率(r)和波动率(Volatility)作为输入参数,并返回期权的理论价格。

你可以将此VBA代码添加到Excel工作簿的Visual Basic for Applications编辑器中(按ALT+F11),然后在Excel中使用BlackScholes函数来计算期权价格。例如,如果你要计算一个看涨期权的价格,可以使用以下公式:

=BlackScholes("Call", S, X, T, r, Volatility)

其中,S、X、T、r和Volatility分别是你的标的资产价格、行权价格、剩余到期时间、无风险利率和波动率的Excel单元格引用。同样,如果你要计算看跌期权的价格,只需将"Call"替换为"Put"。

二、用python写上述代码:

import numpy as np

from scipy.stats import norm

def black_scholes(option_type, S, X, T, r, volatility):

d1 = (np.log(S / X) + (r + 0.5 volatility 2) T) / (volatility np.sqrt(T))

d2 = d1 - volatility np.sqrt(T)

if option_type == "Call":

option_price = S norm.cdf(d1) - X np.exp(-r T) norm.cdf(d2)

elif option_type == "Put":

option_price = X np.exp(-r T) norm.cdf(-d2) - S norm.cdf(-d1)

else:

raise ValueError("Invalid option type")

return option_price

# 示例数据

option_type = "Call" # 期权类型,可以是"Call"或"Put"

S = 100 # 标的资产的当前价格

X = 105 # 期权的行权价格

T = 0.5 # 剩余到期时间(以年为单位)

r = 0.05 # 无风险利率

volatility = 0.2 # 波动率

# 计算期权价格

option_price = black_scholes(option_type, S, X, T, r, volatility)

print(f"Option Price: {option_price}//代码效果参考:http://www.ezhiqi.com/zx/art_2430.html ")

知道C和P的前提下,怎么计算波动率?

如果你知道期权的价格(C和P)、标的资产的当前价格(S)、行权价格(X)、剩余到期时间(T)、无风险利率(r),并且想要计算波动率(Volatility),你可以使用Black-Scholes模型的反向计算方法,通常称为隐含波动率计算。

Black-Scholes模型中的波动率是一个未知数,但可以通过反向计算来估算出来,以使模型产生已知的期权价格。以下是计算隐含波动率的一种常见方法,使用二分法或牛顿-拉普森法(Newton-Raphson method):

首先,你需要编写一个函数,该函数以波动率作为输入,并使用Black-Scholes模型来计算期权价格(C或P)。这个函数将返回期权价格与市场观察到的实际价格之间的差异(误差)。

接下来,你可以使用二分法或牛顿-拉普森法来找到使上述误差最小化的波动率值。这个波动率值就是隐含波动率。

以下是一个简化的示例,使用二分法来计算隐含波动率的过程:

用VBA代码:

Function ImpliedVolatility(OptionType As String, S As Double, X As Double, T As Double, r As Double, MarketPrice As Double) As Double

Dim lowVolatility As Double

Dim highVolatility As Double

Dim tolerance As Double

Dim currentVolatility As Double

lowVolatility = 0.01 ' 设置波动率的下限

highVolatility = 3.0 ' 设置波动率的上限

tolerance = 0.0001 ' 设置误差容忍度

Do While highVolatility - lowVolatility > tolerance

currentVolatility = (lowVolatility + highVolatility) / 2 ' 取中值作为当前波动率估计

' 使用当前波动率计算期权价格

Dim OptionPrice As Double

OptionPrice = BlackScholes(OptionType, S, X, T, r, currentVolatility)

' 检查期权价格与市场价格的差异,然后相应地调整波动率的上限或下限

If OptionPrice < MarketPrice Then

lowVolatility = currentVolatility

Else

highVolatility = currentVolatility

End If

Loop

' 返回隐含波动率

ImpliedVolatility = currentVolatility

End Function

用python代码:

import numpy as np

from scipy.stats import norm

from scipy.optimize import brentq

def black_scholes(option_type, S, X, T, r, volatility):

d1 = (np.log(S / X) + (r + 0.5 volatility 2) T) / (volatility np.sqrt(T))

d2 = d1 - volatility np.sqrt(T)

if option_type == "Call":

option_price = S norm.cdf(d1) - X np.exp(-r T) norm.cdf(d2)

elif option_type == "Put":

option_price = X np.exp(-r T) norm.cdf(-d2) - S * norm.cdf(-d1)

else:

raise ValueError("Invalid option type")

return option_price

def implied_volatility(option_type, S, X, T, r, market_price):

# Define a function to minimize (the difference between market and model prices)

def func(volatility):

return black_scholes(option_type, S, X, T, r, volatility) - market_price

# Find the implied volatility using the Brent method

implied_volatility = brentq(func, 0.01, 3.0) # You can adjust the bounds as needed

return implied_volatility

# Example data

option_type = "Call"

S = 100

X = 105

T = 0.5

r = 0.05

market_price = 10

# Calculate implied volatility

iv = implied_volatility(option_type, S, X, T, r, market_price)

print(f"Implied Volatility: {iv}//代码效果参考:http://www.ezhiqi.com/bx/art_1309.html ")

相关文章
|
11月前
|
Python
使用Python实现股票均线策略
使用Python实现股票均线策略案例的简单示例
231 2
|
PHP Python
矩阵制度三三复制直销系统模式开发详解 | 矩阵制度三三复制直销系统开发源码demo示例
矩阵制度三三复制模式是一种常见的直销模式,也被称为三三复制模式。该模式限制了前排的数量,只能填满3个位置,奖金则是按照固定的深度来进行领取的。在该模式中,每个参与者都可以推荐其他人加入,如果成功推荐,就可以获得相应的奖金。具体来说,如果推荐一个参与者,可以获得20美元的奖金;如果推荐两个参与者,可以获得10美元的奖金;如果推荐三个参与者,可以获得4美元的奖金。此外,该模式还有一些其他的奖金制度,如培育奖金、扣税等。
|
BI
运营必备 - CPA、CPS、CPC、CPM推广是什么意思?(一)
运营必备 - CPA、CPS、CPC、CPM推广是什么意思?(一)
7010 0
运营必备 - CPA、CPS、CPC、CPM推广是什么意思?(一)
|
2月前
|
Python
心得经验总结:期权定价的BS公式
心得经验总结:期权定价的BS公式
13 0
|
3月前
|
Python
python实现股票均线策略案例
此Python代码示例展示了如何运用均线策略进行股票交易模拟。它下载AAPL的股票历史数据,计算每日收益率,设置短期和长期移动平均线。当短期均线超过长期均线时,模拟买入;反之则卖出。代码遍历每一天,更新现金和股票余额,并最终计算总收益。请注意,实际交易需考虑更多因素如交易费用和风险管理。
49 2
|
3月前
|
数据可视化 Python
R语言无套利区间模型期货期现研究:正向套利和反向套利次数、收益率分析华泰柏瑞300ETF可视化
R语言无套利区间模型期货期现研究:正向套利和反向套利次数、收益率分析华泰柏瑞300ETF可视化
|
3月前
R语言Fisher检验探究地区间公寓价格的关系
R语言Fisher检验探究地区间公寓价格的关系
R语言Fisher检验探究地区间公寓价格的关系
|
3月前
非线性回归beta系数估算股票市场的风险分析亚马逊股票和构建投资组合
非线性回归beta系数估算股票市场的风险分析亚马逊股票和构建投资组合
非线性回归beta系数估算股票市场的风险分析亚马逊股票和构建投资组合
|
3月前
|
资源调度 数据挖掘
R语言收益率和波动性模拟股票价格COMP226带自测题
R语言收益率和波动性模拟股票价格COMP226带自测题
|
3月前
TMA三均线股票期货高频交易策略的R语言实现
TMA三均线股票期货高频交易策略的R语言实现