Python使用BS定价公式计算欧式期权标记价(MarkPrice)

2023-11-03 23:59

本文主要是介绍Python使用BS定价公式计算欧式期权标记价(MarkPrice),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      影响标记价格的几个要素是标的资产价格(即标的价格)、行权价、到期日(可以是天或秒,使用秒计算更精确)、无风险利率、隐含波动率。

        若要计算看涨(即Call)和看跌(Put)的标记价,还需要计算两个中间参数。一个参数用于计算认购(即看涨Call)期权的价格,一个参数用于计算认购或认沽(即看跌Put)价格。

用到知识点是正太分布累计概率和正太分布概率密度函数,需要引入的库是nump、scipy、norm、math,详细见实现过程。

1、导入必备的库

from math import log, sqrt, exp
from scipy.stats import norm
import numpy as np
from scipy import optimize
'''
# S 底层资产价格,即标的价格(官方为标的资产价格)
# K 期权执行价格,strike price   行权价
# T 期权的剩余期限,单位:年     合约到期时间,如果到期日不足一天需要换算成天,然后除以365(总小时/24)
# r 无风险收益率,数字货币市场一般为0,  0即可
# sigma 底层资产价格年化波动率,标记价的隐含波动率,去redis查
d1()、 d2() 说明:
这两个参数在期权定价模型中起到关键的作用,尤其在使用 Black-Scholes 期权定价模型时。
这个模型是一种用来估计欧式期权价格的数学公式。它假设市场是有效的,并且标的资产价格的变动服从几何布朗运动。
根据这个模型,可以使用 d1 和 d2 来计算认购期权和认沽期权的价格。
'''def d1(S, K, T, r, sigma):'''d1 是一个中间参数,用于计算认购期权的价格'''return (log(S / K) + (r + sigma ** 2 / 2.) * T) / (sigma * sqrt(T))def d2(S, K, T, r, sigma):'''d2 是另一个中间参数,用于计算认购期权和认沽期权的价格之间的关系'''return d1(S, K, T, r, sigma) - sigma * sqrt(T)def call_price(S, K, T, r, sigma):'''标记价计算Call'''return S * norm.cdf(d1(S, K, T, r, sigma)) - K * exp(-r * T) * norm.cdf(d2(S, K, T, r, sigma))def put_price(S, K, T, r, sigma):'''标记价计算Put'''return K * exp(-r * T) * norm.cdf(-d2(S, K, T, r, sigma)) - S * norm.cdf(-d1(S, K, T, r, sigma))

2、调用

if __name__ == '__main__':#基本参数option_name = 'BTCUSD-25AUG23-14000-C'sql = f"select end_time from t_option where name='{option_name}'"db = DB().select_fetchone(sql)end_time= int(db[0])     #db[0]#时间处理,转换为秒expiry_date = datetime.fromtimestamp(end_time / 1000)  # 将毫秒时间戳转换为datetime对象current_date = datetime.now()  # 当前日期和时间time_to_expiry = expiry_date - current_date  # 计算到期日与当前日期的时间差time_in_milliseconds = int(time_to_expiry.total_seconds() * 1000)  # 将时间差转换为毫秒buy_price = 12486.1  #买一价和卖一价sell_price = 12500  #买一价和卖一价S = 26472.1  # float(input('标的资产价格: '))K = int(option_name.split('-')[-2])T = int(time_in_milliseconds)/1000  # 一天后改为秒sigma = 1.5953 # float(input('隐含波动率: '))r = 0  # 无风险利率# S, K, T, r, sigmaprint("\n========>计算标记价MarkPrice<========")print_color('cal_price: %.8f' % call_price(S, K, T/year_second , r, sigma), fg=Color.RED.value)print_color('put_price: %.8f' % put_price(S, K, T /year_second, r, sigma), fg=Color.RED.value)

代码中在数据库中先获取改期权的到期日,然后换算成秒;输出时加了带颜色的输出。

因受隐含波动率和标的价格影响,小数点后的数值会有偏差。计算结果:

这篇关于Python使用BS定价公式计算欧式期权标记价(MarkPrice)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/341783

相关文章

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J