欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

基于統(tǒng)計(jì)的交易策略簡(jiǎn)易實(shí)現(xiàn)VNPY的示例分析

這篇文章將為大家詳細(xì)講解有關(guān)基于統(tǒng)計(jì)的交易策略簡(jiǎn)易實(shí)現(xiàn)VNPY的示例分析,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了旬陽(yáng)免費(fèi)建站歡迎大家使用!

交易思維是基于歷史數(shù)據(jù)中,一組數(shù)據(jù)比如100天中,K線中最高點(diǎn)或者最低點(diǎn)相對(duì)于開始價(jià)位價(jià)差點(diǎn)差,再利用numpy的函數(shù)numpy.percentile(), 計(jì)算在比如95%機(jī)會(huì),最高點(diǎn)或者最低點(diǎn)的點(diǎn)差數(shù)字。如果點(diǎn)差是5個(gè)點(diǎn),就可以認(rèn)為下一根K線也有95%概率有5個(gè)點(diǎn)受益。

嘗試在VNPY實(shí)現(xiàn)。

思路整理:

1.入場(chǎng):如果最近N(30)個(gè)D分鐘k線,通過下面代碼計(jì)算,分析對(duì)于概率prb比如90%,如果存在一個(gè)點(diǎn)差大于TickValueLimit一個(gè)值TickValue,說(shuō)明過去N個(gè)分鐘,有P的概率,bar開始下單,在bar中有最高點(diǎn)或者最低點(diǎn)獲得TickValue。那么在下個(gè)bar開始時(shí)候,買入。

2.出場(chǎng),如果到達(dá)持有價(jià)格POSprice +/- TickValue, 則賣出;重新進(jìn)行入場(chǎng)分析。如果這個(gè)bar中間沒到達(dá)目標(biāo)價(jià)格,在bar結(jié)束時(shí)候分析是否還滿足入場(chǎng)條件,如果繼續(xù)滿足則持有,否則平倉(cāng),如果是反向,則反向開單。

3.止損,如果在持有時(shí)候,下跌到反向POSPrice +/- Multiple * TickValue 價(jià)格時(shí)候,平倉(cāng)。Multiple 隨著時(shí)間增加逐漸減少。

示例代碼如下,最后很遺憾,回測(cè)效果非常不好。

from __future__ import division
from vnpy.trader.vtConstant import EMPTY_STRING, EMPTY_FLOAT, OFFSET_OPEN,OFFSET_CLOSE
from vnpy.trader.app.ctaStrategy.ctaTemplate import (CtaTemplate,
                                                     BarGenerator,
                                                     ArrayManager)
import numpy as np
from datetime import datetime, time
########################################################################
class PercentileStrategy(CtaTemplate):
    """MACD策略Demo"""
    className = 'PercentileStrategy'
    author = u'BillyZhang'
    fixedSize = 1
    # 策略參數(shù)
    calWindow = 15
    percentile = 95
    tickValueLimit = 5
    Multiple = 0.8
    # 策略變量
    p = 0
    tickValue = 0
    tradeSign = 0
    tickValueHigh = 0
    tickValueLow = 0
    longStop = 0  # 多頭止損
    shortStop = 0  # 空頭止損
    margin = 0
    lowerLimit = 0
    upperLimit = 50000
    # 時(shí)間
    initDays = 0
    DAY_START = time(9, 10)  # 日盤啟動(dòng)和停止時(shí)間
    DAY_END = time(14, 55)
    NIGHT_START = time(21, 10)  # 夜盤啟動(dòng)和停止時(shí)間
    NIGHT_END = time(10, 55)
    # 參數(shù)列表,保存了參數(shù)的名稱
    paramList = ['name',
                 'className',
                 'author',
                 'vtSymbol',
                 'initDays',
                 'fixedSize',
                 'calWindow',
                 'percentile',
                 'tickValueLimit',
                 'Multiple'
                 ]
    # 變量列表,保存了變量的名稱
    varList = ['inited',
               'trading',
               'pos',
               'longStop',
               'shortStop',
               'posPrice',
               'lowerLimit',
               'p',
               'tickValue',
               'tradeSign',
               'tickValueHigh',
               'tickValueLow'
                ]
    # 同步列表,保存了需要保存到數(shù)據(jù)庫(kù)的變量名稱
    syncList = ['pos',
                'posPrice',
                'longStop',
                'shortStop'
                ]
    # ----------------------------------------------------------------------
    def __init__(self, ctaEngine, setting):
        """Constructor"""
        super(PercentileStrategy, self).__init__(ctaEngine, setting)
        self.am = ArrayManager(size = self.calWindow)
        # 注意策略類中的可變對(duì)象屬性(通常是list和dict等),在策略初始化時(shí)需要重新創(chuàng)建,
        # 否則會(huì)出現(xiàn)多個(gè)策略實(shí)例之間數(shù)據(jù)共享的情況,有可能導(dǎo)致潛在的策略邏輯錯(cuò)誤風(fēng)險(xiǎn),
        # 策略類中的這些可變對(duì)象屬性可以選擇不寫,全都放在__init__下面,寫主要是為了閱讀
        # 策略時(shí)方便(更多是個(gè)編程習(xí)慣的選擇)
    # ----------------------------------------------------------------------
    def onInit(self):
        """初始化策略(必須由用戶繼承實(shí)現(xiàn))"""
        self.writeCtaLog(u'%s策略初始化' % self.name)
        initData = self.loadBar(self.initDays)
        for bar in initData:
            self.onBar(bar)
        self.putEvent()
    # ----------------------------------------------------------------------
    def onStart(self):
        """啟動(dòng)策略(必須由用戶繼承實(shí)現(xiàn))"""
        if self.pos == 0:
            self.writeCtaLog(u'%s策略啟動(dòng)' % self.name)
        # 當(dāng)前無(wú)倉(cāng)位,發(fā)送開倉(cāng)委托
        # 持有多頭倉(cāng)位
        self.putEvent()
    # ----------------------------------------------------------------------
    def onStop(self):
        """停止策略(必須由用戶繼承實(shí)現(xiàn))"""
        self.writeCtaLog(u'%s策略停止' % self.name)
        self.putEvent()
    # ----------------------------------------------------------------------
    def onTick(self, tick):
        """收到行情TICK推送(必須由用戶繼承實(shí)現(xiàn))"""
        if self.lowerLimit == 0 or self.upperLimit == 0:
            self.lowerLimit = tick.lowerLimit
            self.upperLimit = tick.upperLimit
        self.bg.updateTick(tick)
    # ----------------------------------------------------------------------
    def onBar(self, bar):
        """收到Bar推送(必須由用戶繼承實(shí)現(xiàn))"""
        #如果是當(dāng)然最后5分鐘,略過
        am = self.am
        am.updateBar(bar)
        if not am.inited:
            return
        # currentTime = datetime.now().time()
        currentTime = time(9,20)
        #計(jì)算p,和tickValue
        MaxHigh = am.high / am.open
        MaxLow = am.low / am.open
        MaxClose = am.close / am.open
        lpHigh = np.percentile(MaxHigh, 100 - self.percentile)
        lpLow = np.percentile(MaxLow,  self.percentile)
        self.tickValueHigh = abs(bar.open - bar.open*lpHigh)
        self.tickValueLow = abs(bar.open - bar.open * lpLow)
        if self.tickValueHigh > self.tickValueLow and self.tickValueHigh > self.tickValueLimit:
            self.tradeSign = 1
        elif self.tickValueHigh < self.tickValueLow and self.tickValueLow > self.tickValueLimit:
            self.tradeSign = -1
        else:
            self.tradeSign = 0
        # 平當(dāng)日倉(cāng)位, 如果當(dāng)前時(shí)間是結(jié)束前日盤15點(diǎn)28分鐘,或者夜盤10點(diǎn)58分鐘,如果有持倉(cāng),平倉(cāng)。
        if ((currentTime >= self.DAY_START and currentTime <= self.DAY_END) or
            (currentTime >= self.NIGHT_START and currentTime <= self.NIGHT_END)):
            if self.pos == 0:
                if self.tradeSign == 0:
                    pass
                elif self.tradeSign == 1 and bar.close > self.lowerLimit:
                    self.buy(bar.close + 5,self.fixedSize,False)
                elif self.tradeSign == -1 and bar.close < self.upperLimit:
                    self.short(bar.close - 5,self.fixedSize,False)
            elif self.pos > 0:
                if self.tradeSign == 1 or self.tradeSign == 0:
                    pass
                elif self.tradeSign == -1:
                    self.sell(bar.close-5, abs(self.pos), False)
            elif self.pos < 0:
                if self.tradeSign == -1 or self.tradeSign == 0:
                    pass
                elif self.tradeSign ==1:
                    self.cover(bar.close+5, abs(self.pos), False)
        else:
            if self.pos > 0:
                self.sell(bar.close-5, abs(self.pos), False)
            elif self.pos < 0:
                self.cover(bar.close+5, abs(self.pos), False)
            elif self.pos == 0:
                return
    # ----------------------------------------------------------------------
    def onOrder(self, order):
        """收到委托變化推送(必須由用戶繼承實(shí)現(xiàn))"""
        # 對(duì)于無(wú)需做細(xì)粒度委托控制的策略,可以忽略onOrder
        pass
    # ----------------------------------------------------------------------
    def onTrade(self, trade):
        # 發(fā)出狀態(tài)更新事件
        """收到成交推送(必須由用戶繼承實(shí)現(xiàn))"""
        # 對(duì)于無(wú)需做細(xì)粒度委托控制的策略,可以忽略onOrder
        if trade.offset == OFFSET_OPEN:
            self.posPrice = trade.price
            if self.tradeSign == 1:
                self.sell(self.posPrice + self.tickValueHigh,abs(self.pos),False)
                self.sell(self.posPrice - self.Multiple*self.tickValueHigh, abs(self.pos), True)
            elif self.tradeSign == -1:
                self.cover(self.posPrice - self.tickValueLow, abs(self.pos), False)
                self.cover(self.posPrice + self.Multiple*self.tickValueLow, abs(self.pos),True)
        elif trade.offset == OFFSET_CLOSE:
            self.cancelAll()
            self.tradeSign = 0
            # 同步數(shù)據(jù)到數(shù)據(jù)庫(kù)
        self.saveSyncData()
    # ----------------------------------------------------------------------
    def onStopOrder(self, so):
        """停止單推送"""
        pass

關(guān)于基于統(tǒng)計(jì)的交易策略簡(jiǎn)易實(shí)現(xiàn)VNPY的示例分析就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

新聞標(biāo)題:基于統(tǒng)計(jì)的交易策略簡(jiǎn)易實(shí)現(xiàn)VNPY的示例分析
當(dāng)前鏈接:http://aaarwkj.com/article22/igodjc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)動(dòng)態(tài)網(wǎng)站、做網(wǎng)站、服務(wù)器托管、網(wǎng)站設(shè)計(jì)App開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
av在线播放网址网站| 性知音国产精品粉色视频| 日韩av大片一区二区三区| 欧美久久久久久久黑人| 亚洲成人av综合在线| 天天操天天日天天干夜夜情欢| 久久日韩精品人妻一区二区| 中文字幕日韩欧美一区| 给我搜亚洲免费播放黄色大片| 少妇高潮试看二十分钟| 热九九这里只有热九九| 午夜福利网午夜福利网| 国产精品一区二区三区日本| 亚洲一区欧美二区日韩三区| 日日干夜夜射天天操| 国产实拍之强伦奸在线观看| 人妻少妇久久中文字幕韩| 黄色亚洲一区二区三区四区| 亚洲男人av天堂东京热| 亚洲欧美精品专区极品| 免费看夫妻性生活视频| 国产精品女同久久久久久| 综合久久—本道中文字幕| 国产精品亚洲欧美中字| 日本的黄色录像一级带| 超碰97免费在线观看| 日韩欧美亚洲国产一区久久精品| 97在线亚洲欧美视频| 国产999精品在线观看| 年轻的母亲韩国三级| 高清不卡日本一区二区| 亚洲av综合色区一区| 日韩 高清 一区二区| 18禁污污网站国产| 最新91熟女九色地址| 午夜91激情福利视频| 校花出白浆视频一区二区三区| 欧美另类精品一区二区| 久久亚洲精品1区2区| 亚洲大乳大丰满中文字幕| 中文字幕一区二区三区不卡日日 |