Black-Scholes模型的python代码,BS期权

from math import sqrt,log,exp
print(norm.cdf(1)) # 计算累积概率密度
print(norm.ppf(0.8413)) # 计算指定cdf的分位数
from scipy.stats import norm

def option_price(S, K, r, sigma, tm):
    d1 = log(S / K) + (r + sigma ** 2 / 2) * tm / (sigma * sqrt(tm))
    d2 = d1 - sigma * sqrt(tm)
    c = S * norm.cdf(d1) - K * exp(-r * tm) * norm.cdf(d2)
    p = K * exp(-r * tm) * norm.cdf(-d2) - S * norm.cdf(-d1)
    print('call option price is {:.4f}'.format(c))
    print('put option price is {:.4f}'.format(p))
option_price(50, 50, 0.1, 0.3, 0.5)

结果如下

0.8413447460685429
0.9998150936147446
call option price is 5.4532
put option price is 3.0147

以上是第一个代码,转载自http://t.csdnimg.cn/RUxDR

第二个代码太难了,跑不动,先不跑了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Black-Scholes公式进行障碍期权定价需要对公式进行扩展,加入障碍的影响。具体来说,需要计算出在障碍期间标的资产到达障碍价时的价格和到期时标的资产价格与障碍价的关系,然后根据这个关系确定期权是否被敲出。 以下是一个使用Python实现Black-Scholes公式进行障碍期权定价的示例代码: ```python import numpy as np from scipy.stats import norm def bs_option_price(S, K, T, r, sigma, option_type): '''使用Black-Scholes公式计算欧式期权价格''' d1 = (np.log(S/K) + (r + 0.5 * sigma**2) * T) / (sigma * np.sqrt(T)) d2 = d1 - sigma * np.sqrt(T) if option_type == 'call': return S * norm.cdf(d1) - K * np.exp(-r * T) * norm.cdf(d2) else: return K * np.exp(-r * T) * norm.cdf(-d2) - S * norm.cdf(-d1) def barrier_option_price(S, K, T, r, sigma, barrier, barrier_type, option_type): '''使用Black-Scholes公式计算带障碍的期权价格''' if barrier_type == 'up_out': barrier_correction = 1 - norm.cdf(np.log(barrier/S) / (sigma * np.sqrt(T)) + (r + 0.5 * sigma**2) * np.sqrt(T) / sigma) else: barrier_correction = norm.cdf(np.log(barrier/S) / (sigma * np.sqrt(T)) - (r + 0.5 * sigma**2) * np.sqrt(T) / sigma) rebate = 0 # 如果期权被敲出,则支付的回报为0 if option_type == 'call': if barrier_type == 'up_out': S_barrier = barrier * np.exp(-r * T) / (S/K)**((r - 0.5 * sigma**2) / sigma**2 - 0.5) if S > barrier: price = bs_option_price(S, K, T, r, sigma, option_type) else: price = bs_option_price(S, K, T, r, sigma, option_type) - rebate * barrier_correction - bs_option_price(S_barrier, K, T, r, sigma, option_type) * (S/S_barrier)**(2 * (r - 0.5 * sigma**2) / sigma**2) else: S_barrier = barrier * np.exp(-r * T) / (S/K)**((r - 0.5 * sigma**2) / sigma**2 + 0.5) if S < barrier: price = bs_option_price(S, K, T, r, sigma, option_type) else: price = bs_option_price(S, K, T, r, sigma, option_type) - rebate * barrier_correction - bs_option_price(S_barrier, K, T, r, sigma, option_type) * (S/S_barrier)**(2 * (r - 0.5 * sigma**2) / sigma**2) else: if barrier_type == 'up_out': S_barrier = barrier * np.exp(-r * T) / (S/K)**((r - 0.5 * sigma**2) / sigma**2 - 0.5) if S > barrier: price = bs_option_price(S, K, T, r, sigma, option_type) else: price = bs_option_price(S, K, T, r, sigma, option_type) + rebate * barrier_correction - bs_option_price(S_barrier, K, T, r, sigma, option_type) * (S/S_barrier)**(2 * (r - 0.5 * sigma**2) / sigma**2) else: S_barrier = barrier * np.exp(-r * T) / (S/K)**((r - 0.5 * sigma**2) / sigma**2 + 0.5) if S < barrier: price = bs_option_price(S, K, T, r, sigma, option_type) else: price = bs_option_price(S, K, T, r, sigma, option_type) + rebate * barrier_correction - bs_option_price(S_barrier, K, T, r, sigma, option_type) * (S/S_barrier)**(2 * (r - 0.5 * sigma**2) / sigma**2) return price ``` 在这个示例代码中,`bs_option_price`函数用于计算欧式期权的价格,`barrier_option_price`函数用于计算带障碍的期权价格。其中,`barrier_correction`表示障碍对期权价格的修正,`rebate`表示期权被敲出时支付的回报。如果期权没有被敲出,则回报为0。 使用这个函数可以计算出带障碍的期权价格,例如: ```python price = barrier_option_price(S=100, K=100, T=1, r=0.05, sigma=0.2, barrier=110, barrier_type='up_out', option_type='call') print(price) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值