您现在的位置:程序化交易>> 期货公式>> 交易开拓者(TB)>> 开拓者知识>>正文内容

开拓者 TB 海龟交易交易策略源码—有止损有加仓有头寸无过滤(在TB范例中的进一步加持) [开拓者 TB]

  • 源码:



    //------------------------------------------------------------------------
    // 简称: TT_5
    // 名称: TT_5
    // 类别: 公式应用
    // 类型: 用户应用
    // 有止损有加仓有头寸规模无过滤条件入场出场
    //------------------------------------------------------------------------
    Params
        Numeric RiskRatio(1);                   // % Risk Per N ( 0 - 100)
        Numeric ATRLength(20);                  // 平均波动周期 ATR Length
        Numeric boLength(20);                   // 短周期 BreakOut Length
        Numeric teLength(10);                   // 离市周期 Trailing Exit Length
           
    Vars
            Numeric MinPoint;                       // 最小变动单位
            NumericSeries AvgTR;                                        // ATR
        Numeric N;                              // N 值
            Numeric VN;                             // 价值量波动性
        Numeric TotalEquity;                    // 按最新收盘价计算出的总资产
        Numeric TurtleUnits;                    // 交易单位
        NumericSeries DonchianHi;                      // 唐奇安通道上轨,延后1个Bar
        NumericSeries DonchianLo;                      // 唐奇安通道下轨,延后1个Bar

        Numeric ExitHighestPrice;               // 离市时判断需要的N周期最高价
        Numeric ExitLowestPrice;                // 离市时判断需要的N周期最低价
        Numeric myEntryPrice;                   // 开仓价格
        Numeric myExitPrice;                    // 平仓价格
        Bool SendOrderThisBar(False);                  // 当前Bar有过交易
            NumericSeries preEntryPrice(0);               // 前一次开仓的价格

    Begin
        If(BarStatus == 0)
        {
                    preEntryPrice = InvalidNumeric;
            }       
           
            DonchianHi = HighestFC(High[1],boLength);
        DonchianLo = LowestFC(Low[1],boLength);

            PlotNumeric("DonchianHi",DonchianHi);
            PlotNumeric("DonchianLo",DonchianLo);
           
            MinPoint = MinMove*PriceScale;
           
            ExitLowestPrice = LowestFC(Low[1],teLength);
            ExitHighestPrice = HighestFC(High[1],teLength);
           
        AvgTR = XAverage(TrueRange,ATRLength);
            N = AvgTR[1];       
        TotalEquity = Portfolio_CurrentCapital() + Portfolio_UsedMargin();
        TurtleUnits = (TotalEquity*RiskRatio/100) /(N * ContractUnit()*BigPointValue());
        TurtleUnits = IntPart(TurtleUnits); // 对小数取整

            Commentary("N="+Text(N));
            Commentary("preEntryPrice="+Text(preEntryPrice));
           
        //
        If(MarketPosition == 0)
        {
            // 突破开仓
            If(High > DonchianHi && TurtleUnits >= 1)
            {
                // 开仓价格取突破上轨+一个价位和最高价之间的较小值,这样能更接近真实情况,并能尽量保证成交
                myEntryPrice = min(high,DonchianHi + MinPoint);
                myEntryPrice = IIF(myEntryPrice < Open, Open,myEntryPrice); // 大跳空的时候用开盘价代替
                            preEntryPrice = myEntryPrice;
                Buy(TurtleUnits,myEntryPrice);
                            SendOrderThisBar = True;
            }

            If(Low < DonchianLo && TurtleUnits >= 1)
            {
                // 开仓价格取突破下轨-一个价位和最低价之间的较大值,这样能更接近真实情况,并能尽量保证成交
                myEntryPrice = max(low,DonchianLo - MinPoint);
                myEntryPrice = IIF(myEntryPrice > Open, Open,myEntryPrice); // 大跳空的时候用开盘价代替
                preEntryPrice = myEntryPrice;
                SendOrderThisBar = True;
                SellShort(TurtleUnits,myEntryPrice);
                            SendOrderThisBar = True;
            }
        }

        If(MarketPosition == 1) // 有多仓的情况
        {      
                    Commentary("ExitLowestPrice="+Text(ExitLowestPrice));
            If(Low < ExitLowestPrice)
            {
                myExitPrice = max(Low,ExitLowestPrice - MinPoint);
                            myExitPrice = IIF(myExitPrice > Open, Open,myExitPrice); // 大跳空的时候用开盘价代替
                Sell(0,myExitPrice);    // 数量用0的情况下将全部平仓
            }Else
            {
                If(preEntryPrice!=InvalidNumeric && TurtleUnits >= 1)
                {
                    If(Open >= preEntryPrice + 0.5*N) // 如果开盘就超过设定的1/2N,则直接用开盘价增仓。
                    {
                        myEntryPrice = Open;
                                            preEntryPrice = myEntryPrice;
                        Buy(TurtleUnits,myEntryPrice);
                                            SendOrderThisBar = True;
                    }

                    while(High >= preEntryPrice + 0.5*N) // 以最高价为标准,判断能进行几次增仓
                    {
                        myEntryPrice = preEntryPrice + 0.5 * N;
                        preEntryPrice = myEntryPrice;
                        Buy(TurtleUnits,myEntryPrice);
                                            SendOrderThisBar = True;                                       
                    }
                }
                           
                // 止损指令 CXH99.COM
                            If(Low <= preEntryPrice - 2 * N && SendOrderThisBar == false) // 加仓Bar不止损
                            {
                                    myExitPrice = preEntryPrice - 2 * N;
                                    Sell(0,myExitPrice); // 数量用0的情况下将全部平仓
                            }
            }
        }Else If(MarketPosition ==-1) // 有空仓的情况
        {
            // 求出持空仓时离市的条件比较值        
                    Commentary("ExitHighestPrice="+Text(ExitHighestPrice));
            If(High > ExitHighestPrice)
            {
                myExitPrice = Min(High,ExitHighestPrice + MinPoint);
                            myExitPrice = IIF(myExitPrice < Open, Open,myExitPrice); // 大跳空的时候用开盘价代替
                BuyToCover(0,myExitPrice);    // 数量用0的情况下将全部平仓
            }Else
            {
                If(preEntryPrice!=InvalidNumeric && TurtleUnits >= 1)
                {
                    If(Open <= preEntryPrice - 0.5*N) // 如果开盘就超过设定的1/2N,则直接用开盘价增仓。
                    {
                        myEntryPrice = Open;
                                            preEntryPrice = myEntryPrice;
                        SellShort(TurtleUnits,myEntryPrice);
                                            SendOrderThisBar = True;
                    }

                    while(Low <= preEntryPrice - 0.5*N) // 以最低价为标准,判断能进行几次增仓
                    {
                        myEntryPrice = preEntryPrice - 0.5 * N;
                        preEntryPrice = myEntryPrice;
                        SellShort(TurtleUnits,myEntryPrice);
                                            SendOrderThisBar = True;
                    }
                }

                // 止损指令
                            If(High >= preEntryPrice + 2 * N &&SendOrderThisBar==false) // 加仓Bar不止损
                            {
                                    myExitPrice = preEntryPrice + 2 * N;
                                    BuyToCover(0,myExitPrice); // 数量用0的情况下将全部平仓
                                    BuyToCover(0,myExitPrice); // 数量用0的情况下将全部平仓
                            }
            }
        }
    End


    //------------------------------------------------------------------------
    // 编译版本        GS2010.12.08
    // 用户版本        2013/05/23 08:15
    // 版权所有        gxm82wi CXH99
    // 更改声明        TradeBlazer Software保留对TradeBlazer平台
    //                        每一版本的TrabeBlazer公式修改和重写的权利
    //------------------------------------------------------------------------

 

有思路,想编写各种指标公式,程序化交易模型,选股公式,预警公式的朋友

可联系技术人员 QQ: 1145508240  有需要帮忙请点击这里留言!!!进行 有偿 编写!不贵!点击查看价格!


【字体: 】【打印文章】【查看评论

相关文章

    没有相关内容