设为首页收藏本站

 找回密码
 注册
查看: 4000|回复: 4
打印 上一主题 下一主题

海龟交易——有止损有加仓有头寸无过滤(源码) [复制链接]

Rank: 1

精华
0
UID
113708
积分
23
帖子
2
主题
1
阅读权限
10
注册时间
2012-11-26
最后登录
2013-6-14
跳转到指定楼层
1#
发表于 2013-5-23 08:42:34 |只看该作者 |倒序浏览
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;                                       
                }
            }
                       
            // 止损指令
                        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
// 更改声明        TradeBlazer Software保留对TradeBlazer平台
//                        每一版本的TrabeBlazer公式修改和重写的权利
//------------------------------------------------------------------------

Rank: 1

精华
0
UID
119091
积分
22
帖子
1
主题
0
阅读权限
10
注册时间
2013-5-12
最后登录
2013-5-30
2#
发表于 2013-5-24 11:44:32 |只看该作者
收益很高啊

使用道具 举报

Rank: 4

精华
0
UID
113129
积分
486
帖子
363
主题
32
阅读权限
50
注册时间
2012-10-26
最后登录
2021-4-26
3#
发表于 2013-5-24 11:52:21 |只看该作者
有漏洞,只能参考

使用道具 举报

Rank: 3Rank: 3

精华
0
UID
114376
积分
237
帖子
92
主题
28
阅读权限
40
注册时间
2012-12-25
最后登录
2017-10-12
4#
发表于 2013-8-30 15:06:04 |只看该作者
貌似就是海龟的源码吧。,系统自带的好像没怎么改动吧

使用道具 举报

Rank: 1

精华
0
UID
122567
积分
29
帖子
20
主题
9
阅读权限
10
注册时间
2013-4-21
最后登录
2015-8-13
5#
发表于 2015-8-4 21:28:48 |只看该作者
yhp2012 发表于 2013-5-24 11:52
有漏洞,只能参考

什么漏洞啊 ?

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

bottom

静态版|手机版|联系我们|交易开拓者 ( 粤ICP备07044698   

GMT+8, 2024-5-2 09:36

Powered by Discuz! X2 LicensedChrome插件扩展

© 2011-2012 交易开拓者 Inc.

回顶部