取名为幽灵交易者的系统,名字霸气,效果,大家自己测试看看了,照例还是先看策略说明吧:

策略说明:

模拟交易产生一次亏损后才启动真实下单交易。

系统要素:

1、两条指数平均线

2、RSI指标

3、唐奇安通道

入场条件:

1、模拟交易产生一次亏损、短期均线在长期均线之上、RSI低于超买值、创新高,则开多单

2、模拟交易产生一次亏损、短期均线在长期均线之下、RSI高于超卖值、创新低,则开空单

出场条件:

1、持有多单时小于唐奇安通道下轨,平多单

2、持有空单时大于唐奇安通道上轨,平空单

做多代码及解读如下:

Params

Numeric FastLength(9);// 声明数值参数FastLength,初值9,即短期指数平均线参数。//

Numeric SlowLength(19);// 声明数值参数SlowLength,初值19,即长期指数平均线参数。//

Numeric Length(9);// 声明数值参数Length,初值9,即RSI参数。//

Numeric OverSold(30);// 声明数值参数OverSold,初值30,即超卖。//

Numeric OverBought(70);// 声明数值参数OverBought,初值70,即超买。//

Numeric Lots(0);// 声明数值参数Lots,初值0,即交易手数设置。//

Vars

NumericSeries AvgValue1;// 声明数值序列变量AvgValue1,即短期指数平均线 。//

NumericSeries AvgValue2;// 声明数值序列变量AvgValue2,即长期指数平均线。//

NumericSeries NetChgAvg(0);//声明数值序列变量NetChgAvg,初值0。//

NumericSeries TotChgAvg(0);//声明数值序列变量TotChgAvg,初值0.//

Numeric SF(0);//声明数值变量SF,初值0.//

Numeric Change(0);//声明数值变量Change,初值0.//

Numeric ChgRatio(0);//声明数值变量ChgRatio,初值0.//

NumericSeries RSIValue;// 声明数值序列变量RSIValue,即RSI指标。//

NumericSeries ExitHiBand(0);// 声明数值序列变量ExitHiBand,初值0,唐奇安通道上轨。//

NumericSeries ExitLoBand(0);//声明数值序列变量ExitLoBand,初值0, 唐奇安通道下轨。//

NumericSeries myEntryPrice(0);//声明数值序列变量myEntryPrice,初值0, 进场价格。//

NumericSeries myExitPrice(0);// 声明数值序列变量myExitPrice,初值0,出场价格。//

NumericSeries myProfit(0);// 声明数值序列变量myProfit,初值0,即利润。//

NumericSeries myPosition(0);// 声明数值序列变量myPosition,初值0,即多空标志。//

Begin

If(!CallAuctionFilter()) Return;// 集合竞价和小节休息过滤。//

AvgValue1 = Xaverage(Close,FastLength);// 计算短期指数平均线,即把收盘价与周期9返回函数Xaverage求值。//

AvgValue2 = Xaverage(Close,SlowLength);//同理,计算长期指数平均线参数。//

// 计算RSI。//

If(CurrentBar <= Length - 1)//假如当前索引k线数位值小于等于周期8(9-1)的。//

{

NetChgAvg = (Close - Close[Length])/Length;//代入相应数值计算,即得NetChgAvg = (close - close[9])/ 9的。//

TotChgAvg = Average(Abs(Close - Close[1]),Length);//先算绝对值函数Abs里的,再把绝对值与周期9返回均值函数Average求均值,最后赋值给变量TotChgAvg。//

}Else//就是k线数位值大于周期8的。//

{

SF = 1/Length;//代入相应数值,即SF= 1/9 了.//

Change = Close - Close[1];//同理,代入当期k线收盘价与前一k线收盘价即可。//

NetChgAvg = NetChgAvg[1] + SF*(Change - NetChgAvg[1]);//这里也是代入上边求得的相应数值即可。//

TotChgAvg = TotChgAvg[1] + SF*(Abs(Change) - TotChgAvg[1]);//同上解读。//

}

If(TotChgAvg <> 0)//假如变量TotChgAvg不等于0.//

{

ChgRatio = NetChgAvg/TotChgAvg;//则两变量相除了。//

}Else//等于0的。//

{

ChgRatio = 0;//变量ChgRatio=0了。//

}

RSIValue = 50*(ChgRatio + 1);//指标RSI的计算结果。//

ExitHiBand = Highest(High,20);// 唐奇安通道上轨。//

ExitLoBand = Lowest(Low,20);// 唐奇安通道下轨。//

If(myPosition == 1 And myPosition[1] == 1 and Low <= ExitLoBand[1])// 持有多单时,下破唐奇安通道下轨,平多单。//

{

myExitPrice = Min(Open,ExitLoBand[1]);//出场价的计算,开盘价与前一个唐奇安通道下轨的比较,取较小值。//

Sell(0,myExitPrice);//平仓。//

myProfit = myExitPrice - MyEntryPrice;//利润算法。//

myPosition = 0;//持仓多空标志myPosition = 0.//

}

If(myPosition == 0 And myPosition[1] == 0 And AvgValue1[1] > AvgValue2[1] And RSIValue[1] < OverBought and High >= High[1])// 模拟交易产生一次亏损、短期均线在长期均线之上、RSI低于超买值、创新高,则开多单。//

{

myEntryPrice = Max(Open,High[1]);//进场价计算,即开盘价与前一个最高价的比较,取较大值。//

myPosition = 1;//持仓多空标志myPosition = 1.//

If(myProfit < 0) Buy(Lots,myEntryPrice);//假如利润myProfit <0的,以进场价开仓。//

}

End

做空代码及结果如下:

Params

Numeric FastLength(9);

Numeric SlowLength(19);

Numeric Length(9);

Numeric OverSold(30);

Numeric OverBought(70);

Numeric Lots(0);

Vars

NumericSeries AvgValue1;

NumericSeries AvgValue2;

NumericSeries NetChgAvg(0);

NumericSeries TotChgAvg(0);

Numeric SF(0);

Numeric Change(0);

Numeric ChgRatio(0);

NumericSeries RSIValue;

NumericSeries ExitHiBand(0);

NumericSeries ExitLoBand(0);

NumericSeries myEntryPrice(0);

NumericSeries myExitPrice(0);

NumericSeries myProfit(0);

NumericSeries myPosition(0);

Begin

If(!CallAuctionFilter()) Return;

AvgValue1 = Xaverage(Close,FastLength);

AvgValue2 = Xaverage(Close,SlowLength);

If(CurrentBar <= Length - 1)

{

NetChgAvg = (Close - Close[Length])/Length;

TotChgAvg = Average(Abs(Close - Close[1]),Length);

}Else

{

SF = 1/Length;

Change = Close - Close[1];

NetChgAvg = NetChgAvg[1] + SF*(Change - NetChgAvg[1]);

TotChgAvg = TotChgAvg[1] + SF*(Abs(Change) - TotChgAvg[1]);

}

If(TotChgAvg <> 0)

{

ChgRatio = NetChgAvg/TotChgAvg;

}Else

{

ChgRatio = 0;

}

RSIValue = 50*(ChgRatio + 1);

ExitHiBand = Highest(High,20);

ExitLoBand = Lowest(Low,20);

If(myPosition == -1 And myPosition[1] == -1 and High >= ExitHiBand[1])

{

myExitPrice = Max(Open,ExitHiBand[1]);

BuyToCover(0,myExitPrice);

myProfit = myEntryPrice - MyExitPrice;

myPosition = 0;

}

If(myPosition == 0 And myPosition[1] == 0 And AvgValue1[1] < AvgValue2[1] And RSIValue[1] > OverSold and Low <= Low[1])

{

myEntryPrice = Min(Open,Low[1]);

myPosition = -1;

If(myProfit < 0) SellShort(Lots,myEntryPrice);

}

End

幽灵交易策略_期货软件TB系统源代码解读系列67-幽灵交易者相关推荐

  1. 幽灵交易策略_期货软件TB系统源代码解:幽灵交易者交易策略

    策略说明: 模拟交易产生一次亏损后才启动真实下单交易. 系统要素: 1.两条指数平均线 2.RSI指标 3.唐奇安通道 入场条件: 1.模拟交易产生一次亏损.短期均线在长期均线之上.RSI低于超买值. ...

  2. 幽灵交易策略_程序化策略里,幽灵交易者策略的虚拟账户应该怎么设置?

    大作业写完了,直接把俺的大作业搬过来吧-- 基于幽灵选股者交易策略的综合分析 By S. 一.背景知识概述 幽灵选股者从"幽灵选股者"的名字可以看出,该策略的核心在于"幽 ...

  3. 幽灵交易策略_千万级 交易商 独家 策略 开盘区间 突破 PZ Stretch 指标

    千万级 交易商 独家 策略 开盘区间 突破 PZ Stretch 指标 PZ Stretch 指标 是根据成功交易者[Toby Crabel]的独特交易策略,并由著名开发公司 Point Zero 研 ...

  4. 幽灵交易策略_幽灵交易者策略(附源代码)

    NO1 . 前言 正如幽灵交易者的名字,该策略的核心思路是,在真实下单交易之前,先虚拟出一个交易,如果这个虚拟的交易是亏损的,那么下一次才启动真实的交易. NO2 . 策略简介 该策略思路源自于交易者 ...

  5. 幽灵交易策略_源码 | 幽灵交易者策略

    NO1 . 前言 正如幽灵交易者的名字,该策略的核心思路是,在真实下单交易之前,先虚拟出一个交易,如果这个虚拟的交易是亏损的,那么下一次才启动真实的交易. NO2 . 策略简介 该策略思路源自于交易者 ...

  6. 计算机专业考研电路原理,2019电子信息工程考研方向_电路与系统专业解读

    2019考研打算报考电子信息工程考研的考生你对本专业了解么?电子信息工程考研有12大方向,我们首先要清楚地了解每一个专业方向的学科概况.专业排名.培养目标.研究方向等,以此对比做出选择.下面介绍电路与 ...

  7. rc51_中国存托凭证CDR发展初期的投资交易策略_量化投资交易策略_

    中国存托凭证CDR发展初期的投资交易策略 2018-06-10 交易 一,要点 1.1,展望 1.2,简要估值 1.3,交易策略 1.4,风险因素 二,背景和假设 2.1 中国存托凭证/CDR是什么? ...

  8. 量化交易之深入理解TB系统运行机制

    首先来一张K线图,方便下面解释: 我们分3中情况解释:测试历史数据.开盘前自动交易.开盘后自动交易.在解释之前先来解释一下什么是Tick什么是Bar. (1)Tick的相关:Tick数据指的是每1秒2 ...

  9. 学生签到系统c代码_学生考勤系统源代码

    - 1 - 学生考勤系统源代码 void lace(int n)  /* 花边函数 */ { int i; for(i=0;i { putchar('*');   /* 输出 n 个 **/ } } ...

最新文章

  1. 一个非常简单的 ASP.NET MVC 示例:长轮询(又叫:反向 AJAX,英文名:Comet)实现...
  2. 简明python教程购买-简明python教程哪版(python看什么书)
  3. 【渝粤教育】国家开放大学2018年春季 7403-21T素质与思想政治教育 参考试题
  4. android java 实体类 object变量 保存_Java中的实体类--Serializable接口、transient 关键字...
  5. 黑客高手是这样上网的!Vimer是如何用快捷键浏览网页的?
  6. Linux内核套接字(Socket)的设计与实现
  7. PayPal旗下Venmo:允许信用卡用户将现金返还转换为加密币
  8. request_irq与request_threaded_irq
  9. IndexError: list index out of range coco数据集转换为voc格式出现的错误
  10. git学习(七)新建远程仓库-Gitee为例
  11. Ubuntu下多版本OpenCV共存和切换
  12. shell sort 最后一列排序_Shell 编程 排序工具 sort 和 uniq
  13. 简短的计算机病毒,最简单的电脑病毒
  14. 互联网电商都是怎么用工厂模式的?
  15. 沈阳农业大学计算机专业排名,沈阳农业大学王牌专业排名
  16. 测试音响声音啸叫软件,公共广播专业音响系统啸叫声与电流声排除方法_航天广电软件...
  17. 基于mapnik的地图符号编辑器功能介绍
  18. 惊了!这才是真正的 Windows 摸鱼神器!!!
  19. 免安装chrom浏览器
  20. Redis内存数据库的应用场景

热门文章

  1. 清楚了,为什么投简历没面试
  2. Istio组件以及架构
  3. 【课程设计】数据库C#课程设计 教务处管理系统 vs2017和sql server2014制作
  4. 计算机产品属于第几类商标,水杯在商标商品和服务区分表中属于第几类商品?...
  5. matlab SPWM产生,采用MATLAB对SPWM进行辅助设计
  6. mysql异步task_EasySwoole高性能task异步任务
  7. java入门篇(一)如何编写一个简单的程序
  8. RM机器视觉——图像处理、识别装甲板(ROBOMASTER)
  9. 计算机网络浅知识[ 2 ]:IP简史
  10. Linux中环境变量