國信證券學習系列(8)

????????我為什么要用國信,就是這個原因,可以做期權,期貨,股票,etf,可轉債的回測。滿足了我所有的需要,我要做指數增強。通常的做法是股票和期貨。但實際上,股票和期權做組合,成本更低。

(1)認沽期權和認購期權的隱含波動率大于50etf波動率時,
以標的資產當前的價格作為行權價買入相同數量、相同標的資產和相同行權日的認購和認沽期權開倉
(2)認沽期權和認購期權的隱含波動率小于50etf波動率且有市場時,平倉
獲取數據:

import datetime
from math import (log, pow, sqrt, exp)from scipy import stats
import numpy as np
import talibcdf = stats.norm.cdf
STEP_CHANGE = 0.001
STEP_UP = 1 + STEP_CHANGE
STEP_DOWN = 1 - STEP_CHANGE
STEP_DIFF = STEP_CHANGE * 2
DX_TARGET = 0.00001
'''
變量說明
s:標的物股票價格
k:行權價
r:無風險利率
t:剩余到期時間(年)
v:隱含波動率
cp:期權類型,+1/-1對應call/put
price:期權價格
'''

初始參數:

def init(ContextInfo):ContextInfo.contract_unit = 10000#隨著時間推移該對合約可能不存了,根據需求手動修改更新ContextInfo.optOne="10001713" ContextInfo.optTwo="10001714"#上面合約的到期年月,根據需求手動修改更新ContextInfo.aa= get_week_of_month(2019, 3)ContextInfo.holdings = {ContextInfo.optOne: 0, ContextInfo.optTwo: 0}ContextInfo.accountID = '8861103625'ContextInfo.s_volatility = []

計算隱含波動率:

def calculateImpv(price, s, k, r, t, cp):"""計算隱含波動率"""# 檢查期權價格必須為正數if price <= 0:return 0# 檢查期權價格是否滿足最小價值(即到期行權價值)meet = Falseif cp == 1 and (price > (s - k) * exp(-r * t)):meet = Trueelif cp == -1 and (price > k * exp(-r * t) - s):meet = True# 若不滿足最小價值,則直接返回0if not meet:return 0# 采用Newton Raphson方法計算隱含波動率v = 0.29 # 初始波動率猜測for i in range(50):# 計算當前猜測波動率對應的期權價格和vega值p = calculatePrice(s, k, r, t, v, cp)vega = calculateOriginalVega(s, k, r, t, v, cp)# 如果vega過小接近0,則直接返回if not vega:break# 計算誤差dx = (price - p) / vega# 檢查誤差是否滿足要求,若滿足則跳出循環if abs(dx) < DX_TARGET:break# 計算新一輪猜測的波動率v += dx# 檢查波動率計算結果非負if v <= 0:return 0# 保留4位小數v = round(v, 4)return v

計算vega:

def calculateOriginalVega(s, k, r, t, v, cp):"""計算原始vega值"""    price1 = calculatePrice(s, k, r, t, v*STEP_UP, cp)price2 = calculatePrice(s, k, r, t, v*STEP_DOWN, cp)vega = (price1 - price2) / (v * STEP_DIFF)return vega

計算期權價格:

def calculatePrice(s, k, r, t, v, cp):"""計算期權價格"""# 如果波動率為0,則直接返回期權空間價值if v <= 0:return max(0, cp * (s - k))d1 = (log(s / k) + (r + 0.5 * pow(v, 2)) * t) / (v * sqrt(t))d2 = d1 - v * sqrt(t)price = cp * (s * cdf(cp * d1) - k * cdf(cp * d2) * exp(-r * t))return price

獲取日期:

def get_week_of_month(year, month):"""獲取指定的某天是某個月中的第幾周周一作為一周的開始"""begin = datetime.datetime(year, month, 1).weekday()delta = datetime.timedelta(days=21+begin)exercise_date = datetime.datetime(year, month, 1) + deltareturn  exercise_date.strftime('%Y-%m-%d')

策略代碼:

#coding:gbk
"""
跨式期權策略
回測模型示例(非實盤交易策略)(1)認沽期權和認購期權的隱含波動率大于50etf波動率時,
以標的資產當前的價格作為行權價買入相同數量、相同標的資產和相同行權日的認購和認沽期權開倉
(2)認沽期權和認購期權的隱含波動率小于50etf波動率且有市場時,平倉
"""
import datetime
from math import (log, pow, sqrt, exp)from scipy import stats
import numpy as np
import talibcdf = stats.norm.cdf
STEP_CHANGE = 0.001
STEP_UP = 1 + STEP_CHANGE
STEP_DOWN = 1 - STEP_CHANGE
STEP_DIFF = STEP_CHANGE * 2
DX_TARGET = 0.00001
'''
變量說明
s:標的物股票價格
k:行權價
r:無風險利率
t:剩余到期時間(年)
v:隱含波動率
cp:期權類型,+1/-1對應call/put
price:期權價格
'''def init(ContextInfo):ContextInfo.contract_unit = 10000#隨著時間推移該對合約可能不存了,根據需求手動修改更新ContextInfo.optOne="10001713" ContextInfo.optTwo="10001714"#上面合約的到期年月,根據需求手動修改更新ContextInfo.aa= get_week_of_month(2019, 3)ContextInfo.holdings = {ContextInfo.optOne: 0, ContextInfo.optTwo: 0}ContextInfo.accountID = '8861103625'ContextInfo.s_volatility = []
def handlebar(ContextInfo):#當前K線的對應的下標從0開始index = ContextInfo.barpos#當前K線對應的時間:毫秒realtime = ContextInfo.get_bar_timetag(index)current_time = timetag_to_datetime(realtime,'%Y-%m-%d')#當前周期period = ContextInfo.period#取當前K線圖對應的合約當前K線的當前主圖復權方式下的收盤價price_call = ContextInfo.get_market_data(['close'],period=period, stock_code = [ContextInfo.optOne+".SHO"]) price_put = ContextInfo.get_market_data(['close'],period=period, stock_code = [ContextInfo.optTwo+".SHO"])s = ContextInfo.get_market_data(["close"],stock_code = ["510050.SH"],period=period)#print price_call,price_putContextInfo.s_volatility.append(s)s_volatility = np.std(np.array(ContextInfo.s_volatility))ContextInfo.paint("s_volatility", s_volatility*10, -1, 0)k = 2.55r = ContextInfo.get_risk_free_rate(index)/100t = ((datetime.datetime.strptime(ContextInfo.aa, "%Y-%m-%d") - datetime.datetime.strptime(current_time, "%Y-%m-%d")).days) / 365.0cp_call = 1cp_put = -1implied_volatility_call = calculateImpv(price_call, s, k, r, t, cp_call)implied_volatility_put = calculateImpv(price_put, s, k, r, t, cp_put)#print "implied_volatility_call", implied_volatility_call#print "implied_volatility_put", implied_volatility_putContextInfo.paint("implied_volatility", (implied_volatility_put + implied_volatility_call), -1, 0)if (implied_volatility_put + implied_volatility_call) > s_volatility*10 :passorder(50,1101,ContextInfo.accountID ,ContextInfo.optOne,5,-1,1,ContextInfo)passorder(50,1101,ContextInfo.accountID ,ContextInfo.optTwo,5,-1,1,ContextInfo)ContextInfo.holdings[ContextInfo.optOne] = 1ContextInfo.holdings[ContextInfo.optTwo] = 1elif ContextInfo.holdings[ContextInfo.optOne] == 1 and ContextInfo.holdings[ContextInfo.optTwo] == 1 and (implied_volatility_put + implied_volatility_call) < s_volatility*10 :passorder(53,1101,ContextInfo.accountID ,ContextInfo.optOne,5,-1,1,ContextInfo)passorder(53,1101,ContextInfo.accountID ,ContextInfo.optTwo,5,-1,1,ContextInfo)ContextInfo.holdings[ContextInfo.optOne] = 0ContextInfo.holdings[ContextInfo.optTwo] = 0def calculateImpv(price, s, k, r, t, cp):"""計算隱含波動率"""# 檢查期權價格必須為正數if price <= 0:return 0# 檢查期權價格是否滿足最小價值(即到期行權價值)meet = Falseif cp == 1 and (price > (s - k) * exp(-r * t)):meet = Trueelif cp == -1 and (price > k * exp(-r * t) - s):meet = True# 若不滿足最小價值,則直接返回0if not meet:return 0# 采用Newton Raphson方法計算隱含波動率v = 0.29 # 初始波動率猜測for i in range(50):# 計算當前猜測波動率對應的期權價格和vega值p = calculatePrice(s, k, r, t, v, cp)vega = calculateOriginalVega(s, k, r, t, v, cp)# 如果vega過小接近0,則直接返回if not vega:break# 計算誤差dx = (price - p) / vega# 檢查誤差是否滿足要求,若滿足則跳出循環if abs(dx) < DX_TARGET:break# 計算新一輪猜測的波動率v += dx# 檢查波動率計算結果非負if v <= 0:return 0# 保留4位小數v = round(v, 4)return vdef calculateOriginalVega(s, k, r, t, v, cp):"""計算原始vega值"""    price1 = calculatePrice(s, k, r, t, v*STEP_UP, cp)price2 = calculatePrice(s, k, r, t, v*STEP_DOWN, cp)vega = (price1 - price2) / (v * STEP_DIFF)return vegadef calculatePrice(s, k, r, t, v, cp):"""計算期權價格"""# 如果波動率為0,則直接返回期權空間價值if v <= 0:return max(0, cp * (s - k))d1 = (log(s / k) + (r + 0.5 * pow(v, 2)) * t) / (v * sqrt(t))d2 = d1 - v * sqrt(t)price = cp * (s * cdf(cp * d1) - k * cdf(cp * d2) * exp(-r * t))return pricedef get_week_of_month(year, month):"""獲取指定的某天是某個月中的第幾周周一作為一周的開始"""begin = datetime.datetime(year, month, 1).weekday()delta = datetime.timedelta(days=21+begin)exercise_date = datetime.datetime(year, month, 1) + deltareturn  exercise_date.strftime('%Y-%m-%d')

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/449314.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/449314.shtml
英文地址,請注明出處:http://en.pswp.cn/news/449314.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Socket程序從Windows移植到Linux下的一些注意事項

關于這個話題網上流傳的是一個相同的版本&#xff0c;就是那個第一項是頭文件的區別&#xff0c;但后面列出的頭文件只有#include沒有&#xff08;估計是原版的在不斷轉載的過程中有人不小心忘了把尖括號轉義&#xff0c;讓瀏覽器當html標記解析沒了&#xff09;的那個。現在整…

邊緣控制平面Ambassador全解讀

Ambassador是由Datawire開源的一個API網關項目&#xff0c;主要在Kubernetes的容器編排框架中使用。Ambassador本質上是一個通過配置邊緣/API來管理Envoy數據面板的控制面板。而Envoy則是一個基于第7層協議的網絡代理和通信總線&#xff0c;它是一個由Lyft開源的云原生服務&…

Linux 文件編輯命令 詳細整理

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 一、vi編輯器有3種基本工作模式 首先需要知道vi編輯器有3種基本工作模式&#xff0c;分別是&#xff1a;命令模式、文本輸入模式、和末…

專訪迅雷首席工程師:迅雷的下一代互聯網底層技術構想

摘要&#xff1a;互聯網合縱連橫頻頻上演&#xff0c;迅雷與小米的聯姻也成為了熱點&#xff0c;有許多人為迅雷的上市和迅雷的未來擔憂&#xff0c;這家像工程師一樣的公司&#xff0c;命運會怎樣&#xff0c;他們未來會如何走下去&#xff1f;對此CSDN專訪了迅雷首席工程師劉…

YASnippet - emacs 的代碼片段管理工具

添加 snippet M-x 然后輸入 yas-new-snippet 回車 RET&#xff0c;會出現一個新的 buffer # -*- mode: snippet -*-# name: # key: # --在出現的 buffer 中填寫相應的數據 # -*- mode: snippet -*-# name: vard# key: vard# --echo <pre>;var_dump($0);die;c-x c…

深入vuex原理(上)

前言 vuex作為vue生態的重要組成部分&#xff0c;是對store進行管理的一柄利劍。簡而言之&#xff0c;vuex是vue的狀態管理器。使用vuex可用使數據流變得清晰、可追蹤、可預測&#xff0c;更可以簡單的實現 類似時光穿梭 等高級功能&#xff0c;對于復雜的大型應用來講&#xf…

Maven入門(含實例教程)

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 Maven這個個項目管理和構建自動化工具&#xff0c;越來越多的開發人員使用它來管理項目中的jar包。接下來小寶鴿&#xff0c;將從下面幾個…

進階正則表達式

本文同步自我的博客園&#xff1a;http://www.cnblogs.com/hustskyking/ 關于正則表達式&#xff0c;網上可以搜到一大片文章&#xff0c;我之前也搜集了一些資料&#xff0c;并做了排版整理&#xff0c;可以看這篇文章http://www.cnblogs.com/hustskyking/archive/2013/06/04/…

tkinter攔截關閉事件

import tkinter as tk from tkinter import messageboxroot tk.Tk()def on_closing():if messagebox.askokcancel("Quit", "Do you want to quit?"):root.destroy()root.protocol("WM_DELETE_WINDOW", on_closing) root.mainloop() 轉載于:htt…

阿里云服務器一分價錢一分貨,切記!

阿里云為了滿足低端市場的需求&#xff0c;會推出一些價格非常便宜的機器&#xff0c;但是這些機器是為新手練手用或者做測試用的&#xff0c;性能不行。你不要指望花每月9.5元&#xff0c;買一臺學生機&#xff0c;就可以放置流量大的網站還不卡&#xff0c;那個不現實。阿里云…

請記住:你的付出都會以該有的方式歸來(圖)

人&#xff0c;這一生就像一個耕種的農民。你不是在付出&#xff0c;就是在收獲。當然&#xff0c;有人說&#xff0c;付出并不一定有回報。這是大多數人都認同的&#xff0c;也就是付出與得到不一定成正比&#xff0c;不是付出的越多就得到的越多。但我想告訴你的是&#xff0…

c++primer plus筆記

> 第六版 操作符重載 #include<iostream> using namespace std;class Time { public:Time(){hm0;}Time(int _h,int _m){h _h;m _m;}void show(){printf("%02d:%02d \n",h,m);}Time operator(const Time &t){Time result;result.m t.m m;result.h t…

Luogu P3975 [TJOI2015]弦論

題目鏈接 \(Click\) \(Here\) 題目大意&#xff1a; 重復子串不算的第\(k\)大子串重復子串計入的第\(k\)大子串寫法&#xff1a;后綴自動機。 和\(OI\) \(Wiki\)上介紹的寫法不太一樣&#xff0c;因為要同時解決兩個問題。 把字符串每個前綴所在等價類的\(siz\)記為\(1\)&#…

《 圖解 HTTP 》讀書筆記

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1. TCP/IP 協議族按層次分為&#xff1a;應用層、傳輸層、網絡層、數據鏈路層。 2. IP 協議的作用是把各種數據包傳送給對方。 3. IP …

身體出現危險時會發出信號 這太重要了 一定收藏 !(組圖)

太重要了&#xff01;真的太重要了&#xff01; 心臟有問題時———左邊手臂會酸、麻、痛。 肝臟有問題時———小腿晚上睡覺時容易抽筋。 腎臟出現問題時———聲音就會出不來&#xff0c;就會沙啞。 脾胃出現問題時———偏頭痛。 任何試圖更改生物鐘的行為&#xff0c;都將給…

數據結構與算法-概念

計算機從解決數值計算問題到解決生活中的問題 現實生活中的問題涉及不同個體間的復雜聯系 需要在計算機程序中描述生活中個體間的聯系數據結構主要研究非數值計算程序問題中的操作對象以及它們之間的關系而不是研究復雜的算法 數據結構 基本概念 數據&#xff1a;程序的操作對象…

騰訊聯手聯通推出車聯網“網卡”,打“內容”+“流量”的組合拳

車載生態已經成為了一個兵家必爭之地了&#xff0c;于商業前景而言&#xff0c;這是一個BAT都無法忽視的掘金勝地。 從市場數據來看&#xff0c;全球車聯網市場年復合增長率達到25%&#xff0c;根據汽車之家大數據顯示&#xff1a;自2014年以來&#xff0c;車聯網上市新車型滲…

編程面試中的十個常見錯誤

本文由 伯樂在線 - darkinlight 翻譯自 thegeekstuff。歡迎加入技術翻譯小組。轉載請參見文章末尾處的要求。 身為程序員&#xff0c;你肯定知道和其他技術工作面試比起來&#xff0c;編程工作的面試流程略有不同。 這篇文章會就你在編程面試中應當避免的10個問題展開討…

費曼技巧與博客

費曼技巧與博客 什么是費曼技巧&#xff1f; 費曼技巧是一種學習方法&#xff0c;核心是以教促學。 具體實踐 以學習費曼技巧為例&#xff1a; 確定學習目標為學習費曼技巧。尋找資料&#xff08;網絡、書籍、報刊等&#xff09;學習費曼技巧&#xff0c;直到自己認為已經理解了…

阿里云服務器 CentOS 7上-- Docker 安裝 網關(API-Getway)--KONG

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 全程操作按官方文檔來就可以了。 1.將 Kong 連接到 Cassandra 或 PostgreSQL 容器 Kong支持 2 種數據庫&#xff1a;Cassandra 或 Post…