幽灵交易策略_期货软件TB系统源代码解读系列67-幽灵交易者
取名为幽灵交易者的系统,名字霸气,效果,大家自己测试看看了,照例还是先看策略说明吧:
策略说明:
模拟交易产生一次亏损后才启动真实下单交易。
系统要素:
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-幽灵交易者相关推荐
- 幽灵交易策略_期货软件TB系统源代码解:幽灵交易者交易策略
策略说明: 模拟交易产生一次亏损后才启动真实下单交易. 系统要素: 1.两条指数平均线 2.RSI指标 3.唐奇安通道 入场条件: 1.模拟交易产生一次亏损.短期均线在长期均线之上.RSI低于超买值. ...
- 幽灵交易策略_程序化策略里,幽灵交易者策略的虚拟账户应该怎么设置?
大作业写完了,直接把俺的大作业搬过来吧-- 基于幽灵选股者交易策略的综合分析 By S. 一.背景知识概述 幽灵选股者从"幽灵选股者"的名字可以看出,该策略的核心在于"幽 ...
- 幽灵交易策略_千万级 交易商 独家 策略 开盘区间 突破 PZ Stretch 指标
千万级 交易商 独家 策略 开盘区间 突破 PZ Stretch 指标 PZ Stretch 指标 是根据成功交易者[Toby Crabel]的独特交易策略,并由著名开发公司 Point Zero 研 ...
- 幽灵交易策略_幽灵交易者策略(附源代码)
NO1 . 前言 正如幽灵交易者的名字,该策略的核心思路是,在真实下单交易之前,先虚拟出一个交易,如果这个虚拟的交易是亏损的,那么下一次才启动真实的交易. NO2 . 策略简介 该策略思路源自于交易者 ...
- 幽灵交易策略_源码 | 幽灵交易者策略
NO1 . 前言 正如幽灵交易者的名字,该策略的核心思路是,在真实下单交易之前,先虚拟出一个交易,如果这个虚拟的交易是亏损的,那么下一次才启动真实的交易. NO2 . 策略简介 该策略思路源自于交易者 ...
- 计算机专业考研电路原理,2019电子信息工程考研方向_电路与系统专业解读
2019考研打算报考电子信息工程考研的考生你对本专业了解么?电子信息工程考研有12大方向,我们首先要清楚地了解每一个专业方向的学科概况.专业排名.培养目标.研究方向等,以此对比做出选择.下面介绍电路与 ...
- rc51_中国存托凭证CDR发展初期的投资交易策略_量化投资交易策略_
中国存托凭证CDR发展初期的投资交易策略 2018-06-10 交易 一,要点 1.1,展望 1.2,简要估值 1.3,交易策略 1.4,风险因素 二,背景和假设 2.1 中国存托凭证/CDR是什么? ...
- 量化交易之深入理解TB系统运行机制
首先来一张K线图,方便下面解释: 我们分3中情况解释:测试历史数据.开盘前自动交易.开盘后自动交易.在解释之前先来解释一下什么是Tick什么是Bar. (1)Tick的相关:Tick数据指的是每1秒2 ...
- 学生签到系统c代码_学生考勤系统源代码
- 1 - 学生考勤系统源代码 void lace(int n) /* 花边函数 */ { int i; for(i=0;i { putchar('*'); /* 输出 n 个 **/ } } ...
最新文章
- 一个非常简单的 ASP.NET MVC 示例:长轮询(又叫:反向 AJAX,英文名:Comet)实现...
- 简明python教程购买-简明python教程哪版(python看什么书)
- 【渝粤教育】国家开放大学2018年春季 7403-21T素质与思想政治教育 参考试题
- android java 实体类 object变量 保存_Java中的实体类--Serializable接口、transient 关键字...
- 黑客高手是这样上网的!Vimer是如何用快捷键浏览网页的?
- Linux内核套接字(Socket)的设计与实现
- PayPal旗下Venmo:允许信用卡用户将现金返还转换为加密币
- request_irq与request_threaded_irq
- IndexError: list index out of range coco数据集转换为voc格式出现的错误
- git学习(七)新建远程仓库-Gitee为例
- Ubuntu下多版本OpenCV共存和切换
- shell sort 最后一列排序_Shell 编程 排序工具 sort 和 uniq
- 简短的计算机病毒,最简单的电脑病毒
- 互联网电商都是怎么用工厂模式的?
- 沈阳农业大学计算机专业排名,沈阳农业大学王牌专业排名
- 测试音响声音啸叫软件,公共广播专业音响系统啸叫声与电流声排除方法_航天广电软件...
- 基于mapnik的地图符号编辑器功能介绍
- 惊了!这才是真正的 Windows 摸鱼神器!!!
- 免安装chrom浏览器
- Redis内存数据库的应用场景
热门文章
- 清楚了,为什么投简历没面试
- Istio组件以及架构
- 【课程设计】数据库C#课程设计 教务处管理系统 vs2017和sql server2014制作
- 计算机产品属于第几类商标,水杯在商标商品和服务区分表中属于第几类商品?...
- matlab SPWM产生,采用MATLAB对SPWM进行辅助设计
- mysql异步task_EasySwoole高性能task异步任务
- java入门篇(一)如何编写一个简单的程序
- RM机器视觉——图像处理、识别装甲板(ROBOMASTER)
- 计算机网络浅知识[ 2 ]:IP简史
- Linux中环境变量