國信證券學習系列(5)

????????網格策略,號稱勝率100%的策略,只要扛得住回撤,怎么說呢,它包含了最簡單的思想,大道至簡,真的是沒有什么復雜的,原理清晰,思路簡單。可以明確知道我掙的是那筆錢,為什么獲利?為什么虧損?可能唯一要關注的就是滑點問題,還有成交及時性的問題。

核心思想:

本策略首先計算了過去300個價格數據的均值和標準差
并根據均值加減標準差得到網格的區間分界線,
并分別配以0.3和0.5的倉位權重
然后根據價格所在的區間來配置倉位(+/-40為上下界,無實際意義):
(-40,-3],(-3,-2],(-2,2],(2,3],(3,40](具體價格等于均值+數字倍標準差)
[0.25, 0.15, 0.0, 0.15, 0.25](資金比例)

策略代碼:

#coding:gbk#在期貨的1min線下運行
'''
回測模型示例(非實盤交易策略)本策略首先計算了過去300個價格數據的均值和標準差
并根據均值加減標準差得到網格的區間分界線,
并分別配以0.3和0.5的倉位權重
然后根據價格所在的區間來配置倉位(+/-40為上下界,無實際意義):
(-40,-3],(-3,-2],(-2,2],(2,3],(3,40](具體價格等于均值+數字倍標準差)
[0.25, 0.15, 0.0, 0.15, 0.25](資金比例)
'''import numpy as np
import pandas as pd
import time
import datetime
def init(ContextInfo):#設置圖為標的ContextInfo.tradefuture = ContextInfo.stockcode+"."+ContextInfo.marketContextInfo.set_universe([ContextInfo.tradefuture])print(ContextInfo.get_universe())ContextInfo.timeseries = pd.DataFrame()ContextInfo.band = np.zeros(5)#print 'ContextInfo.band',ContextInfo.band# 設置網格的倉位ContextInfo.weight = [0.25, 0.15, 0.0, 0.15, 0.25]# 獲取多倉倉位ContextInfo.position_long = 0# 獲取孔倉倉位ContextInfo.position_short = 0#剩余資金ContextInfo.surpluscapital = ContextInfo.capital#保證金比率comdict = ContextInfo.get_commission()ContextInfo.marginratio = comdict['margin_ratio']#合約乘數ContextInfo.multiplier = ContextInfo.get_contract_multiplier(ContextInfo.tradefuture)#賬號ContextInfo.accountid='testF'ContextInfo.now_timestamp = time.time()
def handlebar(ContextInfo):index = ContextInfo.barposrealtimetag  = ContextInfo.get_bar_timetag(index)lasttimetag = ContextInfo.get_bar_timetag(index - 1)print(timetag_to_datetime(realtimetag, '%Y-%m-%d %H:%M:%S'))if ContextInfo.period in ['1m','3m','5m','15m','30m'] and not ContextInfo.do_back_test:if (datetime.datetime.fromtimestamp(ContextInfo.now_timestamp) - datetime.datetime.fromtimestamp(realtimetag / 1000)).days > 7:returnstarttime = timetag_to_datetime(realtimetag-86400000 * 10, '%Y%m%d%H%M%S')endtime = timetag_to_datetime(realtimetag-86400000, '%Y%m%d%H%M%S')#print 'starttime,endtime',starttime,endtimeResult=ContextInfo.get_market_data(['close'],stock_code=[ContextInfo.tradefuture],start_time=starttime,end_time=endtime,skip_paused=False,period=ContextInfo.period,dividend_type='front')close_sort = Result['close'].sort_index(axis = 0,ascending = True)#print close_sort,starttime,endtime#過去300個價格數據的均值和標準差Result_mean = close_sort.tail(300).mean()Result_std = close_sort.tail(300).std()ContextInfo.band = Result_mean + np.array([-40, -3, -2, 2, 3, 40]) * Result_std#print 'ContextInfo.band',ContextInfo.bandif np.isnan(ContextInfo.band).any() or Result_std==0:returnif index > 0:lasttimetag = ContextInfo.get_bar_timetag(index - 1)#前一根bar收盤價close_lastbar = ContextInfo.get_market_data (['close'],stock_code=[ContextInfo.tradefuture],period=ContextInfo.period,dividend_type='front')#當前開盤價open_currentbar = ContextInfo.get_market_data (['open'],stock_code=[ContextInfo.tradefuture],period=ContextInfo.period,dividend_type='front')#劃分網格#print close_lastbar,ContextInfo.bandgrid = pd.cut([close_lastbar], ContextInfo.band, labels=[0, 1, 2, 3, 4])[0]#print 'grid ',gridif not ContextInfo.do_back_test:ContextInfo.paint('grid',float(grid),-1,0)# 若無倉位且價格突破則按照設置好的區間開倉if ContextInfo.position_long == 0 and ContextInfo.position_short == 0 and grid != 2:# 大于3為在中間網格的上方,做多if grid >= 3 and ContextInfo.surpluscapital > 0 :long_num = int(ContextInfo.weight[grid]*ContextInfo.surpluscapital/(ContextInfo.marginratio*close_lastbar*ContextInfo.multiplier))ContextInfo.position_long = long_numbuy_open(ContextInfo.tradefuture,long_num,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital -= long_num * ContextInfo.marginratio * close_lastbar * ContextInfo.multiplier#print '開多' elif grid <= 1 and ContextInfo.surpluscapital > 0 :short_num = int(ContextInfo.weight[grid]*ContextInfo.surpluscapital/(ContextInfo.marginratio*close_lastbar*ContextInfo.multiplier))ContextInfo.position_short = short_numsell_open(ContextInfo.tradefuture,short_num,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital -= short_num * ContextInfo.marginratio * close_lastbar * ContextInfo.multiplier#print '開空'# 持有多倉的處理elif ContextInfo.position_long > 0 :if grid >= 3 and ContextInfo.surpluscapital > 0 :targetlong_num = int(ContextInfo.weight[grid] * (ContextInfo.surpluscapital + ContextInfo.multiplier * close_lastbar * ContextInfo.position_long*ContextInfo.marginratio)/ (ContextInfo.marginratio*close_lastbar * ContextInfo.multiplier))if targetlong_num > ContextInfo.position_long : trade_num = targetlong_num - ContextInfo.position_long ContextInfo.position_long = targetlong_numbuy_open(ContextInfo.tradefuture,trade_num,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital -= trade_num * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplierelif targetlong_num < ContextInfo.position_long:trade_num = ContextInfo.position_long - targetlong_numContextInfo.position_long = targetlong_numsell_close_tdayfirst(ContextInfo.tradefuture,trade_num,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital += trade_num * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplier#print '調多倉到倉位'# 等于2為在中間網格,平倉elif grid == 2:sell_close_tdayfirst(ContextInfo.tradefuture,ContextInfo.position_long,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital += ContextInfo.position_long * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplierContextInfo.position_long = 0#print '平多'# 小于1為在中間網格的下方,做空elif grid <= 1:sell_close_tdayfirst(ContextInfo.tradefuture,ContextInfo.position_long,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital += ContextInfo.position_long * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplierContextInfo.position_long = 0#print '全平多倉'if ContextInfo.surpluscapital > 0 :short_num = int(ContextInfo.weight[grid]*ContextInfo.surpluscapital/(ContextInfo.multiplier * ContextInfo.marginratio * close_lastbar))ContextInfo.position_short = short_numsell_open(ContextInfo.tradefuture,short_num,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital -= short_num * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplier#print '開空倉到倉位'# 持有空倉的處理elif ContextInfo.position_short> 0 :# 小于1為在中間網格的下方,做空if grid <= 1:targetlshort_num = int(ContextInfo.weight[grid]*(ContextInfo.surpluscapital + ContextInfo.multiplier*close_lastbar*ContextInfo.position_short*ContextInfo.marginratio)/(ContextInfo.multiplier * ContextInfo.marginratio * close_lastbar))if targetlshort_num > ContextInfo.position_short:trade_num = targetlshort_num - ContextInfo.position_short ContextInfo.position_short = targetlshort_numsell_open(ContextInfo.tradefuture,trade_num,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital -= trade_num * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplier#print '開空倉到倉位' ,targetlshort_numelif targetlshort_num < ContextInfo.position_short:trade_num = ContextInfo.position_short -  targetlshort_num ContextInfo.position_short = targetlshort_numbuy_close_tdayfirst(ContextInfo.tradefuture,trade_num,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital += trade_num * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplier#print  '平空倉到倉位' ,targetlshort_num# 等于2為在中間網格,平倉elif grid == 2:buy_close_tdayfirst(ContextInfo.tradefuture,ContextInfo.position_short,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital += ContextInfo.position_short * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplierContextInfo.position_short = 0#print '全平空倉' # 大于3為在中間網格的上方,做多elif grid >= 3:buy_close_tdayfirst(ContextInfo.tradefuture,ContextInfo.position_short,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital += ContextInfo.position_short * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplierContextInfo.position_short = 0#print  '全平空倉' if ContextInfo.surpluscapital > 0 :trade_num = int(ContextInfo.weight[grid]*ContextInfo.surpluscapital / (ContextInfo.marginratio * close_lastbar * ContextInfo.multiplier))ContextInfo.position_long = trade_numbuy_open(ContextInfo.tradefuture,trade_num,'fix',close_lastbar,ContextInfo,ContextInfo.accountid)ContextInfo.surpluscapital -= trade_num * close_lastbar * ContextInfo.marginratio * ContextInfo.multiplier#print ' 開多倉到倉位' # 獲取多倉倉位#print 'ContextInfo.position_long',ContextInfo.position_long# 獲取空倉倉位#print 'ContextInfo.position_short',ContextInfo.position_short# 獲取剩余資金#print 'ContextInfo.surpluscapital',ContextInfo.surpluscapital

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

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

相關文章

promise

## 前言 今天來分享下promise的用法&#xff0c;es6偉大發明之一&#xff0c;當初我學習的時候也是蠻頭大的&#xff0c;不知道為啥&#xff0c;整個腦子就是&#xff0c;我在哪&#xff0c;我要干啥的懵圈&#xff0c;后面認真學習之后&#xff0c;覺得真是十分好用&#xff0…

計算機集群 解說

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 計算機集群簡稱集群是一種計算機系統&#xff0c;它通過一組松散集成的計算機軟件和/或硬件連接起來高度緊密地協作完成計算工作。 在某…

同時尋找最大數和最小數的最優算法 第二大數

我們知道&#xff0c;在一個容量為n的數據集合中尋找一個最大數&#xff0c;不管用什么樣的比較算法&#xff0c;至少要比較n-1次&#xff0c;就算是用競標賽排序也得比較n-1次&#xff0c;否則你找到的就不能保證是最大的數。那么&#xff0c;在一個容量為n的數據集合中同時尋…

淺談mpvue項目目錄和文件結構

2019獨角獸企業重金招聘Python工程師標準>>> 在Visual Studio Code里面打開項目文件夾&#xff0c;我們可以看到類似如下的文件結構&#xff1a; 1、package.json文件 package.json是項目的主配置文件&#xff0c;里面包含了mpvue項目的基本描述信息、項目所依賴的各…

[AHOI2009]最小割(最大流+tarjan)

繼續填坑了&#xff0c;啦啦啦 這道題本來是準備枚舉每個邊&#xff0c;暫時去除它&#xff0c;但發現時間會爆炸的 于是決定另辟蹊徑 于是這篇題解就應運而生 首先還是網絡流跑一邊 畢竟題目叫最小割嘛&#xff0c;給個面子 然后跑一邊tarjan對滿流的邊處理掉&#xff0c;即不…

進程間通信---信號

什么是信號&#xff1f; 】 信號處理流程 信號類型 發送信號的函數 參數sig&#xff1a;代表 信號 接收信號的函數 參數 handle 的處理方式有幾種&#xff1f; 實例代碼 實例邏輯 圖中的等待操作使用&#xff1a;pause&#xff08;&#xff09;函數 代碼 在這里插入代碼片…

大白話解說,半分鐘就懂 --- 分布式與集群是什么 ? 區別是什么?

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 PS&#xff1a;這篇文章算是筆記&#xff0c;僅部分文字是原創&#xff0c;相當內容只是收集、整理、提煉、總結別人寫的。 沒有標為原創…

國信證券學習系列(6)

行業輪動策略&#xff1a; 本策略每隔1個月定時觸發計算1000能源&#xff08;399381.SZ&#xff09;、1000材料&#xff08;399382.SZ&#xff09;、1000工業&#xff08;399383.SZ&#xff09;、1000可選&#xff08;399384.SZ&#xff09;、1000消費&#xff08;399385.SZ&a…

用Linux命令行修圖——縮放、編輯、轉換格式——一切皆有可能

本文由 極客范 - 八卦愛好者 翻譯自 How-To Geek。歡迎加入極客翻譯小組&#xff0c;同我們一道翻譯與分享。轉載請參見文章末尾處的要求。ImageMagick是一系列的用于修改、加工圖像的命令行工具。ImageMagick能夠快速地使用命令行對圖片進行操作&#xff0c;對大量的圖片進行…

劍指offer:二維數組中的查找

目錄 題目解題思路具體代碼題目 題目鏈接劍指offer&#xff1a;二維數組中的查找題目描述 在一個二維數組中&#xff08;每個一維數組的長度相同&#xff09;&#xff0c;每一行都按照從左到右遞增的順序排序&#xff0c;每一列都按照從上到下遞增的順序排序。請完成一個函數&a…

函數對象 函數嵌套 名稱空間與作用域

函數對象&#xff1a; 函數是第一類對象&#xff0c;即函數可以當做數據傳遞 1 可以被引用 2 可以當做參數傳遞 3 返回值可以是函數 &#xff08;函數名 不帶&#xff08;&#xff09; 就是函數名的內存地址&#xff0c;帶括號就是執行函數&#xff09; 4 可以當做容器類型的…

國信證券學習系列(7)

跨品種套利策略&#xff1a; 本策略根據計算滾動的.過去的30個bar的均值正負0.5個標準差得到布林線 并在最新價差上穿上軌來做空價差,下穿下軌來做多價差 并在回歸至上下軌水平內的時候平倉 獲取數據&#xff1a; # 獲取兩個品種的收盤價時間序列closesContextInfo.get_ma…

dubbo-admin管理平臺搭建

一、前言 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 dubbo的使用&#xff0c;其實只需要有注冊中心&#xff0c;消費者&#xff0c;提供者這三個就可以使用了&#xff0c;但是并不能…

不朽傳奇-云計算技術背后的那些天才程序員:Qemu的作者法布里斯貝拉

作者&#xff1a;Liu Guo Hui&#xff0c;OpenStack中國社區&#xff0c;轉載請注明出處 眾所周知&#xff0c;虛擬化技術是構建云基礎架構不可或缺的關鍵技術之一&#xff0c;而在眾多虛擬化技術實現當中&#xff0c;KVM&#xff08;Kernel Virtual Machine&#xff09;因為L…

C學習筆記-字符串

對于C語言來說&#xff0c;字符串其實就是最后一個元素為’\0’的char數組 字符數組的初始化 字符數組常見的有兩種初始化方式 char str[] "hello";或者 char str[] {h, e, l, l, o};當使用sizeof&#xff08;str&#xff09;時&#xff0c;得到的大小為6&#xff…

Shiro安全框架入門篇(登錄驗證實例詳解與源碼)

一、Shiro框架簡單介紹 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 Apache Shiro是Java的一個安全框架&#xff0c;旨在簡化身份驗證和授權。Shiro在JavaSE和JavaEE項目中都可以使用…

國信證券學習系列(8)

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

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;命令模式、文本輸入模式、和末…