请选择 进入手机版 | 继续访问电脑版

孕线K线组合形态测试和代码版本汇总

[复制链接]
查看312 | 回复4 | 张孟珂 | 2020-4-7 17:58:08 | 显示全部楼层 |阅读模式
孕线的形态特征

1) 定义孕线的具体形态

A. 形态条件1
文字描述:左侧是一根实体大阳线或者大阴线;
量化定义:大阳线或大阴线的实体长度>1*ATR;
(为什么用ATR:《ATR的正确使用方法-动态度量衡》)
B. 形态条件2
描述:当日开盘价和收盘价在前一日的较宽的开盘价、收盘价之间;
量化定义:当日收盘价和当日开盘价的较大值<1日前的收盘价和1日前的开盘价的较大值并且当日收盘价和当日开盘价的较小值>1日前的收盘价和1日前的开盘价的较小值;

2) 定义测试的买卖逻辑:
A. 测试的买入条件:出现孕线形态,以收盘价买入;
B. 测试的卖出条件:买入后第二天,以收盘价卖出;
回复

使用道具 举报

张孟珂 | 2020-4-7 18:00:36 | 显示全部楼层
测试一【孕线基础测试】
【测试逻辑】
A. 测试的买入条件:出现孕线形态,以收盘价买入;
B. 测试的卖出条件:买入后第二天,以收盘价卖出;

【测试代码】
//一、定义仓位
FUND:=10000000; //资金
LOTS:=INTPART(FUND*0.8/(C*MARGIN*UNIT+FEE));//INTPART(FUND*0.8/(OPEN*UNIT*0.1));//计算开仓手数
//二、定义ATR
TR:MAX(MAX((H-L),ABS(REF(C,1)-HIGH)),ABS(REF(C,1)-L));//算出(当日最高-当日最低)、(当日最高-昨日收盘)的绝对值、(昨日收盘-当日最低)的绝对值,再求这3个值中的最大值
ATR:MA(TR,N);//求N个周期内的TR的简单移动平均
//三、定义K线实体
KXST:=ABS(O-C);
//四、定义孕线
//1.定义前一根K线
REFKXIAN:REF(KXST,1)>N1*REF(ATR,1);
//2. 定义当前K线包住前一根K线
DQKXIAN_BAO_REFKXIAN:=MAX(CLOSE,OPEN)<MAX(REF(CLOSE,1),REF(OPEN,1))&&MIN(CLOSE,OPEN)>MIN(REF(CLOSE,1),REF(OPEN,1));
//3.定义孕线形态
YX:=REFKXIAN && DQKXIAN_BAO_REFKXIAN;//孕线
YX,BK(LOTS);//满足K线形态,开仓做多
BKVOL>0,SP(BKVOL);//第二天平仓

回复

使用道具 举报

张孟珂 | 2020-4-7 18:01:26 | 显示全部楼层
测试二【改变持仓周期测试】
【测试逻辑】
A. 测试的买入条件:出现孕线形态,以收盘价买入;
B. 测试的卖出条件:买入后第三天,以收盘价卖出;

【测试代码】
//一、定义仓位
FUND:=10000000; //资金
LOTS:=INTPART(FUND*0.8/(C*MARGIN*UNIT+FEE));//INTPART(FUND*0.8/(OPEN*UNIT*0.1));//计算开仓手数
//二、定义ATR
TR:MAX(MAX((H-L),ABS(REF(C,1)-HIGH)),ABS(REF(C,1)-L));//算出(当日最高-当日最低)、(当日最高-昨日收盘)的绝对值、(昨日收盘-当日最低)的绝对值,再求这3个值中的最大值
ATR:MA(TR,N);//求N个周期内的TR的简单移动平均
//三、定义K线实体
KXST:=ABS(O-C);
//四、定义孕线
//1.定义前一根K线
REFKXIAN:REF(KXST,1)>N1*REF(ATR,1);
//2.定义当前K线包住前一根K线
DQKXIAN_BAO_REFKXIAN:=MAX(CLOSE,OPEN)<MAX(REF(CLOSE,1),REF(OPEN,1))&&MIN(CLOSE,OPEN)>MIN(REF(CLOSE,1),REF(OPEN,1));
//3.定义孕线形态
YX:=REFKXIAN && DQKXIAN_BAO_REFKXIAN;//孕线
YX,BK(LOTS);//满足K线形态,开仓做多
BARSBK=3,SP(BKVOL);//第3天平仓

回复

使用道具 举报

张孟珂 | 2020-4-7 18:03:29 | 显示全部楼层
测试三【孕线形态和RSI指标结合测试】
【测试逻辑】
A. 测试的买入条件:出现孕线形态同时RSI指标大于70或者小于30时,以收盘价买入;
B. 测试的卖出条件:买入后第二天,以收盘价卖出;

【测试代码】
//一、定义仓位
FUND:=10000000; //资金
LOTS:=INTPART(FUND*0.8/(C*MARGIN*UNIT+FEE));//INTPART(FUND*0.8/(OPEN*UNIT*0.1));//计算开仓手数
//二、定义ATR
TR:MAX(MAX((H-L),ABS(REF(C,1)-HIGH)),ABS(REF(C,1)-L));//算出(当日最高-当日最低)、(当日最高-昨日收盘)的绝对值、(昨日收盘-当日最低)的绝对值,再求这3个值中的最大值
ATR:MA(TR,N);//求N个周期内的TR的简单移动平均
//三、定义RSI指标
LC := REF(CLOSE,1);//前一周期收盘价
RSI1:SMA(MAX(CLOSE-LC,0),7,1)/SMA(ABS(CLOSE-LC),7,1)*100;//当根K线收盘价与前一周期收盘价做差,在该差值与0之间取最大值,做N1周期移动平均。收盘价与前一周期收盘价做差值,取该差值的N1周期移动平均值,两平均值之间做比值。
RSI2:RSI1>70||RSI1<30;
//四、定义K线实体
KXST:=ABS(O-C);
//五、定义孕线
//1.定义前一根K线
REFKXIAN:REF(KXST,1)>N1*REF(ATR,1);
//2.定义当前K线包住前一根K线
DQKXIAN_BAO_REFKXIAN:=MAX(CLOSE,OPEN)<MAX(REF(CLOSE,1),REF(OPEN,1))&&MIN(CLOSE,OPEN)>MIN(REF(CLOSE,1),REF(OPEN,1));
//3.定义孕线形态
YX:=REFKXIAN && DQKXIAN_BAO_REFKXIAN;//孕线
YX && RSI2,BK(LOTS);//形态+RSI指标,开仓做多
BKVOL>0,SP(BKVOL);//第二天平仓

回复

使用道具 举报

张孟珂 | 2020-4-20 18:38:49 | 显示全部楼层
测试三【孕线改变K线阴阳组合的测试】
【测试逻辑】
A. 测试的买入条件:出现孕线形态时,以收盘价买入;
B. 测试的卖出条件:买入后第二天,以收盘价卖出;


【测试代码】【前后两根K线都是阴线】
//一、定义仓位
FUND:=10000000; //资金
LOTS:=INTPART(FUND*0.8/(C*MARGIN*UNIT+FEE));//INTPART(FUND*0.8/(OPEN*UNIT*0.1));//计算开仓手数
//二、定义ATR
TR:MAX(MAX((H-L),ABS(REF(C,1)-HIGH)),ABS(REF(C,1)-L));//算出(当日最高-当日最低)、(当日最高-昨日收盘)的绝对值、(昨日收盘-当日最低)的绝对值,再求这3个值中的最大值
ATR:MA(TR,N);//求N个周期内的TR的简单移动平均
//三、定义K线实体
KXST:=ABS(O-C);
//四、定义孕线
//1.定义前一根K线
REFKXIAN:REF(KXST,1)>N1*REF(ATR,1);
//2. 定义当前K线包住前一根K线
DQKXIAN_BAO_REFKXIAN:=ISDOWN && REF(ISDOWN,1) && O<REF(O,1) && C>REF(C,1);
//3.定义孕线形态
YX:=REFKXIAN && DQKXIAN_BAO_REFKXIAN;//孕线
YX,BK(LOTS);//满足K线形态,开仓做多
BKVOL>0,SP(BKVOL);//第二天平仓

【测试代码】【前一根是阴线,当前是阳线】
//一、定义仓位
FUND:=10000000; //资金
LOTS:=INTPART(FUND*0.8/(C*MARGIN*UNIT+FEE));//INTPART(FUND*0.8/(OPEN*UNIT*0.1));//计算开仓手数
//二、定义ATR
TR:MAX(MAX((H-L),ABS(REF(C,1)-HIGH)),ABS(REF(C,1)-L));//算出(当日最高-当日最低)、(当日最高-昨日收盘)的绝对值、(昨日收盘-当日最低)的绝对值,再求这3个值中的最大值
ATR:MA(TR,N);//求N个周期内的TR的简单移动平均
//三、定义K线实体
KXST:=ABS(O-C);
//四、定义孕线
//1.定义前一根K线
REFKXIAN:REF(KXST,1)>N1*REF(ATR,1);
//2. 定义当前K线包住前一根K线
DQKXIAN_BAO_REFKXIAN:=ISUP && REF(ISDOWN,1) && C<REF(O,1) && O>REF(C,1);
//3.定义孕线形态
YX:=REFKXIAN && DQKXIAN_BAO_REFKXIAN;//孕线
YX,BK(LOTS);//满足K线形态,开仓做多
BKVOL>0,SP(BKVOL);//第二天平仓

【测试代码】【前一根是阳线,当前是阴线
//一、定义仓位
FUND:=10000000; //资金
LOTS:=INTPART(FUND*0.8/(C*MARGIN*UNIT+FEE));//INTPART(FUND*0.8/(OPEN*UNIT*0.1));//计算开仓手数
//二、定义ATR
TR:MAX(MAX((H-L),ABS(REF(C,1)-HIGH)),ABS(REF(C,1)-L));//算出(当日最高-当日最低)、(当日最高-昨日收盘)的绝对值、(昨日收盘-当日最低)的绝对值,再求这3个值中的最大值
ATR:MA(TR,N);//求N个周期内的TR的简单移动平均
//三、定义K线实体
KXST:=ABS(O-C);
//四、定义孕线
//1.定义前一根K线
REFKXIAN:REF(KXST,1)>N1*REF(ATR,1);
//2. 定义当前K线包住前一根K线
DQKXIAN_BAO_REFKXIAN:=ISDOWN && REF(ISUP,1) && O<REF(C,1) && C>REF(O,1);
//3.定义孕线形态
YX:=REFKXIAN && DQKXIAN_BAO_REFKXIAN;//孕线
YX,BK(LOTS);//满足K线形态,开仓做多
BKVOL>0,SP(BKVOL);//第二天平仓

【测试代码】【前后两根K线都是阳线】
//一、定义仓位
FUND:=10000000; //资金
LOTS:=INTPART(FUND*0.8/(C*MARGIN*UNIT+FEE));//INTPART(FUND*0.8/(OPEN*UNIT*0.1));//计算开仓手数
//二、定义ATR
TR:MAX(MAX((H-L),ABS(REF(C,1)-HIGH)),ABS(REF(C,1)-L));//算出(当日最高-当日最低)、(当日最高-昨日收盘)的绝对值、(昨日收盘-当日最低)的绝对值,再求这3个值中的最大值
ATR:MA(TR,N);//求N个周期内的TR的简单移动平均
//三、定义K线实体
KXST:=ABS(O-C);
//四、定义孕线
//1.定义前一根K线
REFKXIAN:REF(KXST,1)>N1*REF(ATR,1);
//2. 定义当前K线包住前一根K线
DQKXIAN_BAO_REFKXIAN:=ISUP && REF(ISUP,1) && C<REF(C,1) && O>REF(O,1);
//3.定义孕线形态
YX:=REFKXIAN && DQKXIAN_BAO_REFKXIAN;//孕线
YX,BK(LOTS);//满足K线形态,开仓做多
BKVOL>0,SP(BKVOL);//第二天平仓


回复

使用道具 举报

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

本版积分规则

相关课程推荐
桥博士《MACD指标详解》
为什么我们只用MACD金叉死叉来进行操作效果并不好,学习课程就能在研究MACD指标上少走很多弯路
桥博士《K线形态组合解析》
从理论到实战,让您全面掌握各种K线形态及各种组合,帮您分析梳理大量K线知识让您的投资更游刃有余
桥博士《股票入门基础知识》
从理论到实战,课程包括如何买卖股票、开户流程、交易软件、k线图知识、技术指标、价值投资等新手必备知识

44

主题

242

帖子

820

积分

高级会员

Rank: 4

积分
820
  • 官方论坛

    提供最新 Discuz! 产品新闻、软件下载与技术交流