您現(xiàn)在的位置:程序化交易>> 期貨公式>> 交易開(kāi)拓者(TB)>> 開(kāi)拓者公式>>正文內(nèi)容

TB 海龜交易系統(tǒng) 源碼[開(kāi)拓者公式]

Params
    Numeric RiskRatio(1);                   // % Risk Per N ( 0 - 100)
    Numeric ATRLength(20);                  // 平均波動(dòng)周期 ATR Length
    Numeric boLength(20);                   // 短周期 BreakOut Length
    Numeric fsLength(55);                   // 長(zhǎng)周期 FailSafe Length
    Numeric teLength(10);                   // 離市周期 Trailing Exit Length
    Bool LastProfitableTradeFilter(True);   // 使用入市過(guò)濾條件
Vars
         Numeric MinPoint;                       // 最小變動(dòng)單位
         NumericSeries AvgTR;                                          // ATR
    Numeric N;                              // N 值
    Numeric TotalEquity;                    // 按最新收盤(pán)價(jià)計(jì)算出的總資產(chǎn)
    Numeric TurtleUnits;                    // 交易單位
    NumericSeries DonchianHi;                       // 唐奇安通道上軌,延后1個(gè)Bar
    NumericSeries DonchianLo;                       // 唐奇安通道下軌,延后1個(gè)Bar
    NumericSeries fsDonchianHi;            // 唐奇安通道上軌,延后1個(gè)Bar,長(zhǎng)周期
    NumericSeries fsDonchianLo;            // 唐奇安通道下軌,延后1個(gè)Bar,長(zhǎng)周期
    Numeric ExitHighestPrice;               // 離市時(shí)判斷需要的N周期最高價(jià)
    Numeric ExitLowestPrice;                // 離市時(shí)判斷需要的N周期最低價(jià)
    Numeric myEntryPrice;                   // 開(kāi)倉(cāng)價(jià)格
    Numeric myExitPrice;                    // 平倉(cāng)價(jià)格
    Bool SendOrderThisBar(False);             // 當(dāng)前Bar有過(guò)交易
         NumericSeries preEntryPrice(0);              // 前一次開(kāi)倉(cāng)的價(jià)格
         BoolSeries PreBreakoutFailure(false);     // 前一次突破是否失敗
Begin
    If(BarStatus == 0)
    {
                   preEntryPrice = InvalidNumeric;
                   PreBreakoutFailure = false;
         }      
        
         MinPoint = MinMove*PriceScale;
    AvgTR = XAverage(TrueRange,ATRLength);
         N = AvgTR[1];
    TotalEquity = Portfolio_CurrentCapital() + Portfolio_UsedMargin();
    TurtleUnits = (TotalEquity*RiskRatio/100) /(N * ContractUnit()*BigPointValue());
    TurtleUnits = IntPart(TurtleUnits); // 對(duì)小數(shù)取整

    DonchianHi = HighestFC(High[1],boLength);
    DonchianLo = LowestFC(Low[1],boLength);

         fsDonchianHi = HighestFC(High[1],fsLength);
    fsDonchianLo = LowestFC(Low[1],fsLength);
        
         ExitLowestPrice = LowestFC(Low[1],teLength);
         ExitHighestPrice = HighestFC(High[1],teLength);

         Commentary("N="+Text(N));
         Commentary("preEntryPrice="+Text(preEntryPrice));
         Commentary("PreBreakoutFailure="+IIFString(PreBreakoutFailure,"True","False"));
        
    // 當(dāng)不使用過(guò)濾條件,或者使用過(guò)濾條件并且條件為PreBreakoutFailure為T(mén)rue進(jìn)行后續(xù)操作
    If(MarketPosition == 0 && ((!LastProfitableTradeFilter) Or (PreBreakoutFailure)))
    {
        // 突破開(kāi)倉(cāng)
        If(High > DonchianHi && TurtleUnits >= 1)
        {
            // 開(kāi)倉(cāng)價(jià)格取突破上軌+一個(gè)價(jià)位和最高價(jià)之間的較小值,這樣能更接近真實(shí)情況,并能盡量保證成交 CXH99.COM
            myEntryPrice = min(high,DonchianHi + MinPoint);
            myEntryPrice = IIF(myEntryPrice < Open, Open,myEntryPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
                            preEntryPrice = myEntryPrice;
            Buy(TurtleUnits,myEntryPrice);
                            SendOrderThisBar = True;
                            PreBreakoutFailure = False;
        }

        If(Low < DonchianLo && TurtleUnits >= 1)
        {
            // 開(kāi)倉(cāng)價(jià)格取突破下軌-一個(gè)價(jià)位和最低價(jià)之間的較大值,這樣能更接近真實(shí)情況,并能盡量保證成交
            myEntryPrice = max(low,DonchianLo - MinPoint);
            myEntryPrice = IIF(myEntryPrice > Open, Open,myEntryPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
            preEntryPrice = myEntryPrice;
            SendOrderThisBar = True;
            SellShort(TurtleUnits,myEntryPrice);
                            SendOrderThisBar = True;
                            PreBreakoutFailure = False;
        }
    }

    // 長(zhǎng)周期突破開(kāi)倉(cāng) Failsafe Breakout point
    If(MarketPosition == 0)
    {
                   Commentary("fsDonchianHi="+Text(fsDonchianHi));
        If(High > fsDonchianHi && TurtleUnits >= 1)
        {
            // 開(kāi)倉(cāng)價(jià)格取突破上軌+一個(gè)價(jià)位和最高價(jià)之間的較小值,這樣能更接近真實(shí)情況,并能盡量保證成交
            myEntryPrice = min(high,fsDonchianHi + MinPoint);
            myEntryPrice = IIF(myEntryPrice < Open, Open,myEntryPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
                            preEntryPrice = myEntryPrice;
            Buy(TurtleUnits,myEntryPrice);
                            SendOrderThisBar = True;
                            PreBreakoutFailure = False;
        }

                   Commentary("fsDonchianLo="+Text(fsDonchianLo));
        If(Low < fsDonchianLo && TurtleUnits >= 1)
        {
            // 開(kāi)倉(cāng)價(jià)格取突破下軌-一個(gè)價(jià)位和最低價(jià)之間的較大值,這樣能更接近真實(shí)情況,并能盡量保證成交
            myEntryPrice = max(low,fsDonchianLo - MinPoint);
            myEntryPrice = IIF(myEntryPrice > Open, Open,myEntryPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
            preEntryPrice = myEntryPrice;
            SellShort(TurtleUnits,myEntryPrice);
                            SendOrderThisBar = True;
                            PreBreakoutFailure = False;
        }
    }

    If(MarketPosition == 1) // 有多倉(cāng)的情況 CXH99.COM
    {      
                   Commentary("ExitLowestPrice="+Text(ExitLowestPrice));
        If(Low < ExitLowestPrice)
        {
            myExitPrice = max(Low,ExitLowestPrice - MinPoint);
                            myExitPrice = IIF(myExitPrice > Open, Open,myExitPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
            Sell(0,myExitPrice);    // 數(shù)量用0的情況下將全部平倉(cāng)
        }Else
        {
            If(preEntryPrice!=InvalidNumeric && TurtleUnits >= 1)
            {
                If(Open >= preEntryPrice + 0.5*N) // 如果開(kāi)盤(pán)就超過(guò)設(shè)定的1/2N,則直接用開(kāi)盤(pán)價(jià)增倉(cāng)。
                {
                    myEntryPrice = Open;
                                               preEntryPrice = myEntryPrice;
                    Buy(TurtleUnits,myEntryPrice);
                                               SendOrderThisBar = True;
                }

                while(High >= preEntryPrice + 0.5*N) // 以最高價(jià)為標(biāo)準(zhǔn),判斷能進(jìn)行幾次增倉(cāng)
                {
                    myEntryPrice = preEntryPrice + 0.5 * N;
                    preEntryPrice = myEntryPrice;
                    Buy(TurtleUnits,myEntryPrice);
                                               SendOrderThisBar = True;                                            
                }
            }
                           
            // 止損指令
                            If(Low <= preEntryPrice - 2 * N && SendOrderThisBar == false) // 加倉(cāng)Bar不止損
                            {
                                     myExitPrice = preEntryPrice - 2 * N;
                                     Sell(0,myExitPrice); // 數(shù)量用0的情況下將全部平倉(cāng)
                                     PreBreakoutFailure = True;
                            }
        }
    }Else If(MarketPosition ==-1) // 有空倉(cāng)的情況
    {
        // 求出持空倉(cāng)時(shí)離市的條件比較值      
                   Commentary("ExitHighestPrice="+Text(ExitHighestPrice));
        If(High > ExitHighestPrice)
        {
            myExitPrice = Min(High,ExitHighestPrice + MinPoint);
                            myExitPrice = IIF(myExitPrice < Open, Open,myExitPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
            BuyToCover(0,myExitPrice);    // 數(shù)量用0的情況下將全部平倉(cāng)
        }Else
        {
            If(preEntryPrice!=InvalidNumeric && TurtleUnits >= 1)
            {
                If(Open <= preEntryPrice - 0.5*N) // 如果開(kāi)盤(pán)就超過(guò)設(shè)定的1/2N,則直接用開(kāi)盤(pán)價(jià)增倉(cāng)。
                {
                    myEntryPrice = Open;
                                               preEntryPrice = myEntryPrice;
                    SellShort(TurtleUnits,myEntryPrice);
                                               SendOrderThisBar = True;
                }

                while(Low <= preEntryPrice - 0.5*N) // 以最低價(jià)為標(biāo)準(zhǔn),判斷能進(jìn)行幾次增倉(cāng)
                {
                    myEntryPrice = preEntryPrice - 0.5 * N;
                    preEntryPrice = myEntryPrice;
                    SellShort(TurtleUnits,myEntryPrice);
                                               SendOrderThisBar = True;
                }
            }

            // 止損指令
                            If(High >= preEntryPrice + 2 * N &&SendOrderThisBar==false) // 加倉(cāng)Bar不止損
                            {
                                     myExitPrice = preEntryPrice + 2 * N;
                                     BuyToCover(0,myExitPrice); // 數(shù)量用0的情況下將全部平倉(cāng)
                                     PreBreakoutFailure = True;
                            }
        }
    }

End
 

 

有思路,想編寫(xiě)各種指標(biāo)公式,程序化交易模型,選股公式,預(yù)警公式的朋友

可聯(lián)系技術(shù)人員 QQ: 262069696  點(diǎn)擊在線交流進(jìn)行 有償 編寫(xiě)!不貴!點(diǎn)擊查看價(jià)格!

 


【字體: 】【打印文章】【查看評(píng)論

相關(guān)文章

    沒(méi)有相關(guān)內(nèi)容
  主站蜘蛛池模板: 人人洗澡人人洗澡人人| 在线观看成年人| 亚洲一卡一卡二新区无人区| 玉蒲团之偷情宝典| 国产一区二区三区免费看| 另类欧美视频二区| 国产视频手机在线| 一本色道久久88—综合亚洲精品| 日本中文字幕一区二区有码在线| 亚洲av日韩av天堂影片精品| 翁与小莹浴室欢爱51章| 国产日韩av免费无码一区二区| 91自产拍在线观看精品| 成人综合激情另类小说| 久久精品欧美日韩精品| 欧美成人免费一区二区| 免费毛片a线观看| 色吊丝二区三区中文字幕| 国产手机精品一区二区| 999久久久免费精品国产| 成人午夜又粗又硬有大| 亚洲一区二区无码偷拍| 欧美高清精品一区二区| 免费观看理论片毛片| 老司机午夜福利视频| 国产人妖视频一区在线观看 | 欧美牲交a欧美牲交aⅴ免费真| 午夜dj在线观看神马电影中文| 荡女淫春护土bd在线观看| 国产成人精品视频一区| 非洲黑人最猛性xxxx_欧美| 国产视频一二区| jizz免费在线观看| 小次郎收藏最新地址| 中文字幕在线免费观看| 日本欧美大码aⅴ在线播放| 亚洲午夜久久久影院| 2021国产麻豆剧传媒剧情最新| 天天干在线免费视频| 亚洲av之男人的天堂| 欧美无人区码卡二三卡四卡|