设为首页收藏本站

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

历时三天编写的海龟系统 年收益91% [复制链接]

Rank: 3Rank: 3

精华
0
UID
92518
积分
164
帖子
50
主题
25
阅读权限
40
注册时间
2012-1-12
最后登录
2018-1-11
跳转到指定楼层
1#
发表于 2012-4-3 11:08:09 |只看该作者 |倒序浏览
Params
    Numeric RiskRatio(1);                   // % Risk Per N ( 0 - 100)
    Numeric ATRLength(20);                  // 平均波动周期 ATR Length
    Numeric boLength(20);                   // 短周期 BreakOut Length
    Numeric fsLength(55);                   // 长周期 FailSafe Length
    Numeric teLength(10);                   // 离市周期 Trailing Exit Length
    Bool LastProfitableTradeFilter(True);   // 使用入市过滤条件
Vars
Numeric MinPoint;                       // 最小变动单位
    Numeric N;                              // N 值
    Numeric TotalEquity;                    // 按最新收盘价计算出的总资产
    Numeric TurtleUnits;                    // 交易单位
    NumericSeries DonchianHi;              // 唐奇安通道上轨,延后1个Bar
    NumericSeries DonchianLo;              // 唐奇安通道下轨,延后1个Bar
    NumericSeries fsDonchianHi;            // 唐奇安通道上轨,延后1个Bar,长周期
    NumericSeries fsDonchianLo;            // 唐奇安通道下轨,延后1个Bar,长周期
    Numeric ExitHighestPrice;               // 离市时判断需要的N周期最高价
    Numeric ExitLowestPrice;                // 离市时判断需要的N周期最低价
    Numeric myEntryPrice;                   // 开仓价格
    Numeric myExitPrice;                    // 平仓价格
    Bool SendOrderThisBar(False);          // 当前Bar有过交易
NumericSeries preEntryPrice(0);       // 前一次开仓的价格,存放到全局变量0号位置
BoolSeries PreBreakoutFailure(false); // 前一次突破是否失败
Begin
    If(BarStatus == 0)
    {
  preEntryPrice = InvalidNumeric;
  PreBreakoutFailure = false;
}Else
{
  preEntryPrice = preEntryPrice[1];
        PreBreakoutFailure = PreBreakoutFailure[1];
    }

MinPoint = MinMove*PriceScale;
    N = XAverage(TrueRange,ATRLength);
    TotalEquity = CurrentCapital()+ Abs(CurrentContracts()*Close*ContractUnit()*BigPointValue()*MarginRatio());
    TurtleUnits = (TotalEquity*RiskRatio/100) /(N * ContractUnit()*BigPointValue());
    TurtleUnits = IntPart(TurtleUnits); // 对小数取整

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

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

Commentary("N="+Text(N));
Commentary("preEntryPrice="+Text(preEntryPrice));
Commentary("PreBreakoutFailure="+IIFString(PreBreakoutFailure,"True","False"));

    // 当不使用过滤条件,或者使用过滤条件并且条件为PreBreakoutFailure为True进行后续操作
    If(MarketPosition == 0 && ((!LastProfitableTradeFilter) Or (PreBreakoutFailure)))
    {
        // 突破开仓
        If(CrossOver(High,DonchianHi) && TurtleUnits >= 1)
        {
            // 开仓价格取突破上轨+一个价位和最高价之间的较小值,这样能更接近真实情况,并能尽量保证成交
            myEntryPrice = min(high,DonchianHi + MinPoint);
            myEntryPrice = IIF(myEntryPrice < Open, Open,myEntryPrice); // 大跳空的时候用开盘价代替
   preEntryPrice = myEntryPrice;
            Buy(TurtleUnits,myEntryPrice);
   SendOrderThisBar = True;
   PreBreakoutFailure = False;
        }

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

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

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

    If(MarketPosition == 1) // 有多仓的情况
    {
        // 求出持多仓时离市的条件比较值
        ExitLowestPrice = Lowest(Low[1],teLength);
  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的情况下将全部平仓
    PreBreakoutFailure = True;
   }
        }
    }Else If(MarketPosition ==-1) // 有空仓的情况
    {
        // 求出持空仓时离市的条件比较值
        ExitHighestPrice = Highest(High[1],teLength);
  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的情况下将全部平仓
    PreBreakoutFailure = True;
   }
        }
    }
End



测试品种白糖1101合约的年收益资金增长曲线
附件: 你需要登录才可以下载或查看附件。没有帐号?注册
恩 相互交流,因为有的群确实有策略和编程上的高手,但是群里也更多不做程序化的,他们发言的更多,使得探讨策略和编程的人不交流了,基于这个初衷我建了群280324941,希望有更多基础和研究的人进来交流

Rank: 3Rank: 3

精华
0
UID
92518
积分
164
帖子
50
主题
25
阅读权限
40
注册时间
2012-1-12
最后登录
2018-1-11
2#
发表于 2012-4-3 11:08:56 |只看该作者
是别人写的
恩 相互交流,因为有的群确实有策略和编程上的高手,但是群里也更多不做程序化的,他们发言的更多,使得探讨策略和编程的人不交流了,基于这个初衷我建了群280324941,希望有更多基础和研究的人进来交流

使用道具 举报

Rank: 1

精华
0
UID
56604
积分
23
帖子
5
主题
0
阅读权限
10
注册时间
2011-7-30
最后登录
2012-4-20
3#
发表于 2012-4-3 11:53:35 |只看该作者
回撤有点大
圣杯在手,天下我有

使用道具 举报

Rank: 5Rank: 5

精华
0
UID
73474
积分
1249
帖子
695
主题
30
阅读权限
60
注册时间
2011-10-22
最后登录
2015-11-6
4#
发表于 2012-4-3 15:43:04 |只看该作者
资金曲线不平滑,回撤有点大~~~~~~~~~~~
天崖

使用道具 举报

Rank: 3Rank: 3

精华
0
UID
104036
积分
182
帖子
26
主题
12
阅读权限
40
注册时间
2012-3-11
最后登录
2015-10-3
5#
发表于 2012-4-3 20:19:34 |只看该作者
V4里面CURRENTCAPITAL总是说没有被声明。。。

使用道具 举报

Rank: 6Rank: 6

精华
0
UID
86268
积分
2261
帖子
947
主题
67
阅读权限
70
注册时间
2011-12-13
最后登录
2021-6-6
6#
发表于 2012-4-4 17:32:36 |只看该作者
什么周期上测试?
万事无它,唯手熟尔。

使用道具 举报

Rank: 2

精华
0
UID
55971
积分
69
帖子
9
主题
2
阅读权限
30
注册时间
2011-7-27
最后登录
2013-8-5
7#
发表于 2012-4-5 09:00:52 |只看该作者
回复 5# gbgsgbgs
V4里面CURRENTCAPITAL改为Portfolio_CurrentCapital

使用道具 举报

Rank: 1

精华
0
UID
110093
积分
27
帖子
7
主题
0
阅读权限
10
注册时间
2012-4-19
最后登录
2012-5-2
8#
发表于 2012-4-19 16:19:20 |只看该作者

使用道具 举报

Rank: 4

精华
0
UID
87211
积分
340
帖子
177
主题
50
阅读权限
50
注册时间
2011-12-17
最后登录
2013-7-18
9#
发表于 2012-4-19 19:54:08 |只看该作者
扯,这个不是TB自带的吗?

使用道具 举报

Rank: 5Rank: 5

精华
0
UID
73474
积分
1249
帖子
695
主题
30
阅读权限
60
注册时间
2011-10-22
最后登录
2015-11-6
10#
发表于 2012-4-20 17:31:38 |只看该作者
这是TB自带的~~~~~~~~~~~~~~~

使用道具 举报

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

bottom

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

GMT+8, 2024-5-9 06:25

Powered by Discuz! X2 LicensedChrome插件扩展

© 2011-2012 交易开拓者 Inc.

回顶部