海龟交易系统公式.doc_第1页
海龟交易系统公式.doc_第2页
海龟交易系统公式.doc_第3页
海龟交易系统公式.doc_第4页
海龟交易系统公式.doc_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

_这里找到了已经实现的海龟交易系统的公式完全版.虽说是著名的海龟,但不等于说用了就100%能赚钱的.该系统是比较适合于趋势型的商品行情,如大豆等期货商品.当然要是把这个系统放在振荡型的行情商品中,估计会亏得血本无归吧。其实现如今海龟已经不如当初那么神奇了,可以说是过了保质期吧。哈哈。who knows.不过要是把这个海龟系统理解透了,我相信对于提高交易者自身对系统交易的理解也能上一个台阶了。以下就是海龟系统于tradeblazer-交易开拓者软件下的实现代码,大家可慢慢琢磨一下。(每一行/后的中文字都是对每一步骤的解释,这样有助于大家慢慢地消化理解.)复制内容到剪贴板 代码:ParamsNumeric RiskRatio(1); / % Risk Per N ( 0 - 100)Numeric ATRLength(20); / 平均波动周期 ATR LengthNumeric boLength(20); / 短周期 BreakOut LengthNumeric fsLength(55); / 长周期 FailSafe LengthNumeric teLength(10); / 离市周期 Trailing Exit LengthBool LastProfitableTradeFilter(True); / 使用入市过滤条件VarsNumeric N; / N 值Numeric TotalEquity; / 按最新收盘价计算出的总资产Numeric TurtleUnits; / 交易单位NumericSeries DonchianHi; / 唐奇安通道上轨,延后1个BarNumericSeries DonchianLo; / 唐奇安通道下轨,延后1个BarNumericSeries fsDonchianHi; / 唐奇安通道上轨,延后1个Bar,长周期NumericSeries fsDonchianLo; / 唐奇安通道下轨,延后1个Bar,长周期Numeric ExitHighestPrice; / 离市时判断需要的N周期最高价Numeric ExitLowestPrice; / 离市时判断需要的N周期最低价Numeric myEntryPrice; / 开仓价格Numeric myExitPrice; / 平仓价格Bool IsEntryThisBar(False); / 当前Bar开过仓Bool IsAddThisBar(False); / 当前Bar有过增仓Bool LastBreakoutWin(False); / 最后一次突破是否盈利Numeric preEntryPrice; / 前一次开仓的价格,存放到全局变量0号位置Numeric preBreakoutType(0); / 前一次突破的方向,1 - LONG , -1 - SHORT 初始值为0,存放到全局变量1号位置Numeric preBreakOutPrice; / 前一次突破的价格,存放到全局变量2号位置BeginIf(BarStatus = 0) SetGlobalVar(0,InvalidNumeric); SetGlobalVar(1,0); SetGlobalVar(2,InvalidNumeric);Else preBreakoutType = GetGlobalVar(1); preBreakOutPrice = GetGlobalVar(2);N = AverageFC(TrueRange,ATRLength);TotalEquity = CurrentCapital()+ Abs(CurrentContracts()*Close*ContractUnit()*BigPointValue()*MarginRatio();TurtleUnits = (TotalEquity*RiskRatio/100) /(N * ContractUnit()*BigPointValue();TurtleUnits = IntPart(TurtleUnits); / 对小数取整DonchianHi = HighestFC(Close1,boLength);DonchianLo = LowestFC(Close1,boLength);/ 判断最后一次突破是否盈利If(preBreakoutType = 1) If(Close PreBreakOutPrice) LastBreakoutWin = True; Else If(preBreakoutType = -1) If(Close = 1) / 开仓价格取突破上轨+一个价位和最高价之间的较小值,这样能更接近真实情况,并能尽量保证成交 preBreakoutType = 1; preBreakOutPrice = Donchianhi; SetGlobalVar(1,preBreakoutType); SetGlobalVar(2,preBreakOutPrice); myEntryPrice = min(high,DonchianHi + PriceScale*MinMove); myEntryPrice = IIF(myEntryPrice = 1) / 开仓价格取突破下轨-一个价位和最低价之间的较大值,这样能更接近真实情况,并能尽量保证成交 preBreakoutType = -1; preBreakOutPrice = DonchianLo; SetGlobalVar(1,preBreakoutType); SetGlobalVar(2,preBreakOutPrice); myEntryPrice = max(low,DonchianLo - PriceScale*MinMove); myEntryPrice = IIF(myEntryPrice Open, Open,myEntryPrice); / 大跳空的时候用开盘价代替 If(SellShort(TurtleUnits,myEntryPrice) IsEntryThisBar = True; SetGlobalVar(0,myEntryPrice);/ 保存第一次开仓的价格 / 长周期突破开仓 Failsafe Breakout pointIf(MarketPosition = 0) fsDonchianHi = HighestFC(Close1,fsLength); fsDonchianLo = LowestFC(Close1,fsLength); If(CrossOver(High,fsDonchianHi) & TurtleUnits = 1) / 开仓价格取突破上轨+一个价位和最高价之间的较小值,这样能更接近真实情况,并能尽量保证成交 myEntryPrice = min(high,fsDonchianHi + PriceScale*MinMove); myEntryPrice = IIF(myEntryPrice = 1) / 开仓价格取突破下轨-一个价位和最低价之间的较大值,这样能更接近真实情况,并能尽量保证成交 myEntryPrice = max(low,fsDonchianLo - PriceScale*MinMove); myEntryPrice = IIF(myEntryPrice Open, Open,myEntryPrice); / 大跳空的时候用开盘价代替 If(SellShort(TurtleUnits,myEntryPrice) IsEntryThisBar = True; If(MarketPosition = 1) / 有多仓的情况 / 求出持多仓时离市的条件比较值 ExitLowestPrice = LowestFC(Low1,teLength); If(Low = myEntryPrice + 0.5 * N & TurtleUnits = 1) myEntryPrice = myEntryPrice + 0.5 * N; If(Buy(TurtleUnits,myEntryPrice) SetGlobalVar(0,myEntryPrice);/ 保存最后一次开仓的价格 / 加上止损指令 If(Close = 1) If(Open = preEntryPrice + 0.5*N) / 如果开盘就超过设定的1/2N,则直接用开盘价增仓。 myEntryPrice = Open; If(Buy(TurtleUnits,myEntryPrice) preEntryPrice = myEntryPrice; IsAddThisBar = True; SetGlobalVar(0,preEntryPrice);/ 保存最后一次开仓的价格 while(High = preEntryPrice + 0.5*N) / 以最高价为标准,判断能进行几次增仓 myEntryPrice = preEntryPrice + 0.5 * N; preEntryPrice = myEntryPrice; If(Buy(TurtleUnits,myEntryPrice) IsAddThisBar = True; SetGlobalVar(0,preEntryPrice);/ 保存最后一次开仓的价格 / 止损指令 If(IsAddThisBar) / 当前Bar有过增仓,此时不能直接按Low来判断是否止损,因为不能确定Bar的价格的走势,只按收盘价进行止损判断。 If(Close = preEntryPrice - 2 * N) myExitPrice = preEntryPrice - 2 * N; Sell(0,myExitPrice); / 数量用0的情况下将全部平仓 Else If(Low ExitHighestPrice ) myExitPrice = Min(High,ExitHighestPrice + PriceScale()*MinMove(); BuyToCover(0,ExitHighestPrice); / 数量用0的情况下将全部平仓 Else If(IsEntryThisBar) / 当前Bar开过仓的情况,如果Close比myEntryPrice小于1/2N.用收盘价加仓。 If(Close = 1) myEntryPrice = myEntryPrice - 0.5 * N; If(SellShort(TurtleUnits,myEntryPrice) SetGlobalVar(0,myEntryPrice);/ 保存最后一次开仓的价格 / 加上止损指令 If(Close = MyEntryPrice + 2 * N) myExitPrice = MyEntryPrice + 2 * N; BuyToCover(0,myExitPrice); / 数量用0的情况下将全部平仓 Else preEntryPrice = GetGlobalVar(0); / 取出上一次开仓的价格 If(preEntryPrice!=InvalidNumeric & TurtleUnits = 1) If(Open = preEntryPrice - 0.5*N) / 如果开盘就超过设定的1/2N,则直接用开盘价增仓。 myEntryPrice = Open; If(SellShort(TurtleUnits,myEntryPrice) preEntryPrice = myEntryPrice; IsAddThisBar = True; SetGlobalVar(0,preEntryPrice);/ 保存最后一次开仓的价格 while(Low = pre

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论