心得经验总结:期权定价的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 ")

相关文章
|
6月前
|
Python
心得经验总结:期权定价的BS公式
心得经验总结:期权定价的BS公式
42 0
|
7月前
|
Python
python实现股票均线策略案例
此Python代码示例展示了如何运用均线策略进行股票交易模拟。它下载AAPL的股票历史数据,计算每日收益率,设置短期和长期移动平均线。当短期均线超过长期均线时,模拟买入;反之则卖出。代码遍历每一天,更新现金和股票余额,并最终计算总收益。请注意,实际交易需考虑更多因素如交易费用和风险管理。
76 2
|
7月前
|
数据可视化 Python
R语言无套利区间模型期货期现研究:正向套利和反向套利次数、收益率分析华泰柏瑞300ETF可视化
R语言无套利区间模型期货期现研究:正向套利和反向套利次数、收益率分析华泰柏瑞300ETF可视化
|
7月前
R语言中进行期权定价的Heston随机波动率模型
R语言中进行期权定价的Heston随机波动率模型
|
7月前
用R语言用Nelson Siegel和线性插值模型对债券价格和收益率建模
用R语言用Nelson Siegel和线性插值模型对债券价格和收益率建模
|
7月前
R语言Black Scholes和Cox-Ross-Rubinstein期权定价模型案例
R语言Black Scholes和Cox-Ross-Rubinstein期权定价模型案例
|
7月前
|
前端开发 C++
R语言对HullWhite短期利率模型仿真
R语言对HullWhite短期利率模型仿真
|
7月前
R语言中进行期权定价的Heston模型
R语言中进行期权定价的Heston模型
|
数据建模
【美赛】2023年MCM问题Y:理解二手帆船价格(代码&思路)
【美赛】2023年MCM问题Y:理解二手帆船价格(代码&思路)
128 0
|
编译器 C语言
第二周:计算
C语言第第二周内容,计算,是开启编程世界的第一步
159 0
下一篇
DataWorks