19,在资本市场我们求的是大概率,求大概率,错了也是对的,求小概率对了也是错的。
20,要坚持独立思考,并将你的聪明降三档,不要偏执的坚持自己错误的想法。
21,我的理念是:
严控风险,稳健增值;剑指复利,永求复利,积累一切为复利;永远把多空力量对比作为研究的重点;坚定不移的执行我的“强势理论”作为买卖的依据;不与大势对抗,不求战胜市场,只愿能客观的学习它、适应它。
22,风险控制体系在整个体系中应处于至高无上的地位,本金的安全永远是第一位。
九稳量化交易系统 是一套高胜率策略趋势跟踪系统,系统最大优势就是开仓位置精确,信号不漂移 不延迟 同步行情信号 拒绝马后面!www.gao998.cn 微信 fxfx668998
============================================
缠论线开关:=1;//笔中枢;
MA8:=1;
展F:=10;
HH展BDD:=(H>HV(H,展F))*缠论线开关*MA8;
NH展BDD:=(BARSLAST(HH展BDD)+1)*缠论线开关*MA8;
LL展BDD:=(L<LV(L,展F))*缠论线开关*MA8;
NL展BDD:=(BARSLAST(LL展BDD)+1)*缠论线开关*MA8;
AH展BDD:=(BACKSET(COUNT(LL展BDD,NH展BDD)&&LL展BDD,NH展BDD))*缠论线开关*MA8;
////
MX:=5;//M值需要大于等于5
G:=MA(C,5);
D:=MA(C,10);
NNHX:=BARSLAST(H=HHV(H,MX)) ,NODRAW;
NNLX:=BARSLAST(L=LLV(L,MX)) ,NODRAW;
NNX:=IF(REF(G,NNHX)>REF(D,NNHX) AND NNHX<=MX-3,NNHX,IF(REF(G,NNLX)<REF(D,NNLX) AND NNLX<=MX-3,NNLX,MX-2)) ,NODRAW;
NNNX:=IF(ISLASTBAR AND NNX>0,NNX,MX-2) ,NODRAW;
H1:=REF(H,NNNX)=HHV(H,MX-1);
L1:=REF(L,NNNX)=LLV(L,MX-1);
FG01X:=BACKSET(H1,NNNX+1)>BACKSET(H1,NNNX),NODRAW;//只设置前面第M-1个
FD01X:=BACKSET(L1,NNNX+1)>BACKSET(L1,NNNX) ,NODRAW;
FG02X:=FG01X=FD01X AND G>D,NODRAW;
FD02X:=FG01X=FD01X AND G<D,NODRAW;
TTTTX:=BARSLAST(FD01X),NODRAW;
FG0X:=FG01X AND IF(FG02X=1,H=HHV(H,BARSLAST(REF(FD01X,1))+1),H=HHV(H,IF(BARSLAST(L=LLV(L,MX))>=MX-2,MX-2,BARSLAST(FD01X)))) AND FD02X=0 ,NODRAW;
FD0X:=FD01X AND IF(FD02X=1,L=LLV(L,BARSLAST(REF(FG01X,1))+1),L=LLV(L,IF(BARSLAST(H=HHV(L,MX))>=MX-2,MX-2,BARSLAST(FG01X)))) AND FG02X=0 ,NODRAW;
//高低点间周期
GTX:=BARSLAST(FG0X),NODRAW;
DTX:=BARSLAST(FD0X),NODRAW;
//第一次处理高低点间多余的点
LLLLX:=DTX=0 AND REF(DTX,1)<GTX AND L>REF(L,REF(DTX,1)+1),NODRAW;
FG1X:=BACKSET(REFX(GTX,1)=0 AND GTX<DTX AND REFX(H,1)>=REF(H,GTX),GTX+1),NODRAW;
FD1X:=BACKSET(REFX(DTX,1)=0 AND DTX<GTX AND REFX(L,1)<=REF(L,DTX),DTX+1),NODRAW;
FG11X:=IF(GTX=0 AND REF(GTX,1)<DTX AND IF(REF(G,BARSLAST(L=LLV(L,MX)))>REF(D,BARSLAST(L=LLV(L,MX))),BARSLAST(L=LLV(L,MX))<MX-2,1) AND H<REF(H,REF(GTX,1)+1),1,0),NODRAW;
FD11X:=IF(DTX=0 AND REF(DTX,1)<GTX AND IF(REF(G,BARSLAST(H=HHV(H,MX)))<REF(D,BARSLAST(H=HHV(H,MX))),BARSLAST(H=HHV(H,MX))<MX-2,1) AND L>REF(L,REF(DTX,1)+1),1,0),NODRAW;
//再次周期X
GT1X:=BARSLAST(FG11X<>1 AND FG1X<>1 AND FG0X),NODRAW;
DT1X:=BARSLAST(FD11X<>1 AND FD1X<>1 AND FD0X),NODRAW;
FD2X:=BACKSET(REFX(GT1X,1)=0 AND DT1X<3 AND GT1X-DT1X<4 AND REF(L,DT1X)>LLV(L,GT1X+MX-2),DT1X+1),NODRAW;
FG2AX:=BACKSET(REFX(GT1X,1)=0 AND DT1X<3 AND GT1X-DT1X<4 AND REF(L,DT1X)<=LLV(L,GT1X+MX-2) AND REF(H,GT1X)>HHV(H,GT1X+MX-2),GT1X+1),NODRAW;
FG2BX:=IF(GT1X=0 AND DT1X<4 AND REF(GT1X,1)-DT1X<4 AND REF(L,DT1X)<=LLV(L,REF(GT1X,1)+MX-1) AND H>HHV(H,REF(GT1X,1)+MX-1),1,0),NODRAW;
FG2X:=BACKSET(REFX(DT1X,1)=0 AND GT1X<3 AND DT1X-GT1X<4 AND REF(H,GT1X)<HHV(H,DT1X+MX-2),GT1X+1),NODRAW;
FD2AX:=BACKSET(REFX(DT1X,1)=0 AND GT1X<3 AND DT1X-GT1X<4 AND REF(H,GT1X)>=HHV(L,DT1X+MX-2) AND REF(L,DT1X)>LLV(L,DT1X+MX-2),DT1X+1),NODRAW;
FD2BX:=IF(DT1X=0 AND GT1X<4 AND REF(DT1X,1)-GT1X<4 AND REF(H,GT1X)>=HHV(H,REF(DT1X,1)+6) AND L>LLV(L,REF(DT1X,1)+MX-1),1,0),NODRAW;
TTTTTTX:= H<REF(H,REF(GT1X,1)+1) AND DT1X<4,NODRAW;
HHHHHHX:=REF(LLV(L,10),DT1X),NODRAW;
//前长后短;
FG21X:=IF(GT1X=0 AND DT1X<4 AND H<=REF(H,REF(GT1X,1)+1) ,1,0),NODRAW;
FD21X:=IF(DT1X=0 AND GT1X<4 AND L>=REF(L,REF(DT1X,1)+1) ,1,0),NODRAW;
//前短后长,前低后高(去低);
FD231X:=BACKSET(REFX(GT1X,1)=0 AND DT1X>3 AND GT1X>DT1X AND GT1X-DT1X<4 AND REFX(H,1)>REF(H,GT1X) AND REF(L,DT1X)>REF(LLV(L,10),DT1X),DT1X+1),NODRAW;
FG23X:=BACKSET(REFX(GT1X,1)=0 AND DT1X>3 AND GT1X>DT1X AND GT1X-DT1X<4 AND REFX(H,1)>REF(H,GT1X) AND (REF(H,GT1X)<REF(HHV(H,13),GT1X) OR REF(FD231X,DT1X)=0),GT1X+1),NODRAW;
//前短后长,去2;
FG231X:=BACKSET(REFX(DT1X,1)=0 AND GT1X>3 AND DT1X>GT1X AND DT1X-GT1X<4 AND REFX(L,1)<REF(L,DT1X) AND REF(H,GT1X)<REF(HHV(H,10),GT1X) ,GT1X+1),NODRAW;
FD23X:=BACKSET(REFX(DT1X,1)=0 AND GT1X>3 AND DT1X>GT1X AND DT1X-GT1X<4 AND REFX(L,1)<REF(L,DT1X) AND ( REF(L,DT1X)>REF(LLV(L,13),DT1X) OR REF(FG231X,GT1X)=0),DT1X+1),NODRAW;
//前短后长,去3;
FDD23X:=REF(H,GT1X)<REF(HHV(H,10),GT1X) OR REF(FD23X,DT1X)=0,NODRAW;
FD24X:=BACKSET(REFX(GT1X,1)=0 AND DT1X>3 AND GT1X>DT1X AND GT1X-DT1X<4 AND REFX(H,1)<HHV(H,GT1X+3) AND REF(L,DT1X)>LLV(L,DT1X+5),DT1X+1),NODRAW;
FG24X:=BACKSET(REFX(DT1X,1)=0 AND GT1X>3 AND DT1X>GT1X AND DT1X-GT1X<4 AND REFX(L,1)>LLV(L,DT1X+3) AND REF(H,GT1X)<HHV(H,GT1X+5),GT1X+1),NODRAW;
//做两次高低点间多余的点
GT2X:=BARSLAST(FG21X<>1 AND FG23X<>1 AND FG231X<>1 AND FG24X<>1 AND FG2X<>1 AND FG2AX<>1 AND FG2BX<>1 AND GT1X=0),NODRAW;
DT2X:=BARSLAST(FD21X<>1 AND FD23X<>1 AND FD231X<>1 AND FD24X<>1 AND FD2X<>1 AND FD2AX<>1 AND FD2BX<>1 AND DT1X=0),NODRAW;
FG3X:=BACKSET(REFX(GT2X,1)=0 AND GT2X<DT2X AND REFX(H,1)>=REF(H,GT2X),GT2X+1),NODRAW;
FD3X:=BACKSET(REFX(DT2X,1)=0 AND DT2X<GT2X AND REFX(L,1)<=REF(L,DT2X),DT2X+1),NODRAW;
FG31X:=IF(GT2X=0 AND REF(GT2X,1)<DT2X AND H<REF(H,REF(GT2X,1)+1),1,0),NODRAW;
FD31X:=IF(DT2X=0 AND REF(DT2X,1)<GT2X AND L>REF(L,REF(DT2X,1)+1),1,0),NODRAW;
GT3X:=BARSLAST(GT2X=0 AND FG3X<>1 AND FG31X<>1 ),NODRAW;
DT3X:=BARSLAST(DT2X=0 AND FD3X<>1 AND FD31X<>1),NODRAW;
FG4X:=BACKSET(REFX(GT3X,1)=0 AND GT3X<DT3X AND REFX(H,1)>=REF(H,GT3X),GT3X+1),NODRAW;
FD4X:=BACKSET(REFX(DT3X,1)=0 AND DT3X<GT3X AND REFX(L,1)<=REF(L,DT3X),DT3X+1),NODRAW;
FG41X:=IF(GT3X=0 AND REF(GT3X,1)<DT3X AND H<REF(H,REF(GT3X,1)+1),1,0),NODRAW;
FD41X:=IF(DT3X=0 AND REF(DT3X,1)<GT3X AND L>REF(L,REF(DT3X,1)+1),1,0),NODRAW;
HHHX:=GT3X=0 AND FG31X<>1 AND FG3X<>1,NODRAW;
LLLX:=DT3X=0 AND FD31X<>1 AND FD3X<>1,NODRAW;
DRAWLINE1(HHHX ,H,LLLX,L,0),RGB(0,128,255),LINETHICK2;//绿色
DRAWLINE1(LLLX,L,HHHX ,H,0),RGB(255,255,255),LINETHICK2;//红色
//最后一段画线
N1X:=BARSLAST(HHHX)+1;
N2X:=BARSLAST(LLLX)+1;
DRAWTEXT(HHHX,H,'顶'),FONTSIZE25,RGB(255,0,255);
DRAWTEXT(LLLX,L,'底'),FONTSIZE25,RGB(255,255,255),VALIGN0;
DRAWNUMBER(HHHX,H*1.001,H,1,DOT),RGB(255,255,255);
DRAWNUMBER(LLLX,L*0.999,L,1,DOT),VALIGN0;
DRAWHORIZONTALLINE(HHHX,H,DOT),LINETHICK1,RGB(255,255,255);
DRAWHORIZONTALLINE(LLLX,L,DOT),RGB(255,255,255);
DRAWLINE3(ISLASTBAR&&MIN(N1X,N2X)=N2X&&L>REF(L,N2X-1),REF(L,N2X-1),N2X-1,ISLASTBAR,H,0,0),COLORRED,LINETHICK3;//红色
DRAWLINE3(ISLASTBAR&&MIN(N1X,N2X)=N1X&&H<REF(H,N1X-1),REF(H,N1X-1),N1X-1,ISLASTBAR,L,0,0),COLORGREEN,LINETHICK3;//绿色
MA1:=EMA(C,8);
S:=MA1>REF(MA1,1);
XX:=MA1<=REF(MA1,1);
WS:=BARSLAST(S)+1,LINETHICK2;
WX:=BARSLAST(XX)+1,LINETHICK2;
H12:=REFX1(CROSSDOWN(SUM(S,WX),0.5),1)&&ISLASTBAR=0,ICON(1,'ICO1');
L12:=REFX1(CROSSDOWN(SUM(XX,WS),0.5),1)&&ISLASTBAR=0,ICON(1,'ICO2');
HH1X:BACKSET(H12,IF(VALUEWHEN(CROSS(SUM(S,WX),0.5),H)=HHV(H,BARSLAST(CROSS(SUM(S,WX),0.5) )+1),BARSLAST(CROSS(SUM(S,WX),0.5) )+1, BARSLAST(H>HV(H,BARSLAST(CROSS(SUM(S,WX),0.5))))+1)),NODRAW;
LL1X:BACKSET(L12,IF(VALUEWHEN(CROSS(SUM(XX,WS),0.5),L)=LLV(L,BARSLAST(CROSS(SUM(XX,WS),0.5) )+1),BARSLAST(CROSS(SUM(XX,WS),0.5) )+1, BARSLAST(L<LV(L,BARSLAST(CROSS(SUM(XX,WS),0.5))))+1)),NODRAW;
HHZZ:=CROSS(HH1X=1,0.5)||HH1X=1&&REF(H12,1);
LLZZ:=CROSS(LL1X=1,0.5)||LL1X=1&&REF(L12,1),ICON(1,'ICO1');
HX1:=HHZZ&&H>=REF(VALUEWHEN(HHZZ,H),1)&&VALUEWHEN(LLZZ,L>=REF(VALUEWHEN(LLZZ,L),1)),ICON(1,'ICO1');
HX2:=(HHZZ||ISLASTBAR)&&(H<REF(VALUEWHEN(HHZZ,H),1)||IF(ISLASTBAR,1, H>REF(VALUEWHEN(HHZZ,H),1)&&VALUEWHEN(LLZZ,L<REF(VALUEWHEN(LLZZ,L),1))))&&REF(VALUEWHEN(HHZZ,HX1),1),ICON(0,'ICO2'),VALIGN0;
HX3:=HX1&&REF(VALUEWHEN(HHZZ,NOT(HX1)),1),ICON(0,'ICO3'),VALIGN0;
LX1:=LLZZ&&L<=REF(VALUEWHEN(LLZZ,L),1)&&VALUEWHEN(HHZZ,H<=REF(VALUEWHEN(HHZZ,H),1)),ICON(1,'ICO1');
LX2:=(LLZZ||ISLASTBAR)&&(L>REF(VALUEWHEN(LLZZ,L),1)||IF(ISLASTBAR,1,L<REF(VALUEWHEN(LLZZ,L),1)&&VALUEWHEN(HHZZ,H>REF(VALUEWHEN(HHZZ,H),1))))&&REF(VALUEWHEN(LLZZ,LX1),1),ICON(0,'ICO2'),VALIGN0;
LX3:=LX1&&REF(VALUEWHEN(LLZZ,NOT(LX1)),1),ICON(0,'ICO3'),VALIGN0;
L0:=CROSS(BACKSET(HX2,REF(SUMBARS(HHZZ,1),1)+1),0.5);
L2:=CROSS(BACKSET(L0,BARSLAST(LLZZ)+1),0.5),ICON(1,'ICO2');
L3:=CROSS(BACKSET(HX3,SUMBARS(LLZZ,2)),0.5),ICON(1,'ICO2');
H0:=CROSS(BACKSET(LX2,REF(SUMBARS(LLZZ,1),1)+1),0.5);
H2:=CROSS(BACKSET(H0,BARSLAST(HHZZ)+1),0.5),ICON(1,'ICO2');
H3:=CROSS(BACKSET(LX3,SUMBARS(HHZZ,2)),0.5),ICON(1,'ICO2');
PP:=BACKSET(ISLASTBAR,SUMBARS(L3||H3,1));
P2:=BACKSET(ISLASTBAR,SUMBARS(L2&&COUNT(L2,BARSLAST(L3))=1||H2&&COUNT(H2,BARSLAST(H3))=1,1));
DRAWLINE1(PP&&L3,L,L2,L,1),RGB(255,0,255),DASH;
DRAWLINE1(PP&&H3,H,H2,H,1),RGB(255,0,255),DASH;
DRAWSL(P2&&L2||CROSS(BACKSET(P2&&H2,BARSLAST(LLZZ)+1),0.5) ,L,0,10000,0,RGB(128,0,255)),LINETHICK2;
DRAWSL(P2&&H2||CROSS(BACKSET(P2&&L2,BARSLAST(HHZZ)+1),0.5),H,0,10000,0,RGB(128,0,255)),LINETHICK2;
DRAWICON(CROSS(BACKSET(P2&&H2,BARSLAST(LLZZ)+1),0.5),L,4),VALIGN0;
DRAWICON(CROSS(BACKSET(P2&&L2,BARSLAST(HHZZ)+1),0.5),H,4),VALIGN2;
DRAWSHIFTNUMBER(ISLASTBAR,VALUEWHEN(P2&&L2,L),VALUEWHEN(P2&&L2,L),1,RGB(255,255,0),1,10);
DRAWSHIFTNUMBER(ISLASTBAR,VALUEWHEN(P2&&H2,H),VALUEWHEN(P2&&H2,H),1,RGB(128,0,255),1,10);
X_6:=LOW<REF(LOW,1) AND HIGH<REF(HIGH,1);//2K低低形态
X_7:=LOW>REF(LOW,1) AND HIGH>REF(HIGH,1);//2K高高形态
X_8:=LOW<REF(LOW,1) AND HIGH>=REF(HIGH,1) AND REF(LOW,1)>=REF(LOW,2) AND REF(HIGH,1)<=REF(HIGH,2) AND HIGH<REF(HIGH,2) AND COUNT(X_6,BARSLAST(X_7))=0;//高高形态+3K左包右、左最高
X_9:=HIGH>REF(HIGH,1) AND LOW<=REF(LOW,1) AND REF(HIGH,1)<=REF(HIGH,2) AND REF(LOW,1)>=REF(LOW,2) AND LOW>REF(LOW,2) AND COUNT(X_7,BARSLAST(X_6))=0;//低低形态+3K左包右、左最低
X_10:=HIGH<REF(HIGH,1) AND REF(LOW,1)<=REF(LOW,2) AND REF(HIGH,1)>=REF(HIGH,2) AND LOW<REF(LOW,2) AND COUNT(X_6,BARSLAST(X_7))=0;//高高形态+3K中包左右、中间最高
X_11:=LOW>REF(LOW,1) AND REF(HIGH,1)>=REF(HIGH,2) AND REF(LOW,1)<=REF(LOW,2) AND HIGH>REF(HIGH,2) AND COUNT(X_7,BARSLAST(X_6))=0;//低低形态+3K中包左右、中间最低
X_12:=X_6 OR X_8 OR X_10;//包含处理后低低形态
X_13:=X_7 OR X_9 OR X_11;//包含处理后高高形态
X_14:=X_13 AND COUNT(X_13,BARSLAST(X_12))=1;//低低+高高=底分型(第3元素完成)
X_15:=X_12 AND COUNT(X_12,BARSLAST(X_13))=1;//高高+低低=顶分型(第3元素完成)
X_16:=IF(X_14,LLV(LOW,1+BARSLAST(X_15)),0);//底分型第三元素
X_17:=IF(X_16,X_16,REF(X_16,BARSLAST(X_16)));//下一个最低点形成前,一直最低
X_18:=IF(X_15,HHV(HIGH,1+BARSLAST(X_14)),0);//顶分型第三元素
X_19:=IF(X_18,X_18,REF(X_18,BARSLAST(X_18)));//下一个最高点形成前,一直最高
//以上源码实现顶底分型识别
X_20:=HIGH>=REF(HIGH,1) AND LOW<=REF(LOW,1);//右包含左
X_21:=HIGH<=REF(HIGH,1) AND LOW>=REF(LOW,1);//左包含右
X_22:=X_20 OR X_21;//2K包含
X_23:=HIGH>=REF(HIGH,1) AND LOW<=REF(LOW,1) AND REF(LOW,1)>=REF(LOW,2) AND REF(HIGH,1)<=REF(HIGH,2) AND HIGH>=REF(HIGH,2);//左右包含中间
X_24:=HIGH<=REF(HIGH,1) AND LOW>=REF(LOW,1) AND REF(HIGH,1)>=REF(HIGH,2) AND REF(LOW,1)<=REF(LOW,2) AND LOW<=REF(LOW,2);//中间包含左右
X_25:=X_23 OR X_24 AND (COUNT(X_15,BARSLAST(X_14))=0 OR X_15);//包含处理后底分型延续??
X_26:=HIGH>=REF(HIGH,1) AND LOW<=REF(LOW,1) AND REF(HIGH,1)<=REF(HIGH,2) AND REF(LOW,1)>=REF(LOW,2) AND LOW>=REF(LOW,2);//左右包含中间
X_27:=HIGH<=REF(HIGH,1) AND LOW>=REF(LOW,2) AND REF(LOW,1)<=REF(LOW,2) AND REF(HIGH,1)>=REF(HIGH,2) AND HIGH>=REF(HIGH,2);//中间包含左右
X_28:=X_26 OR X_27 AND (COUNT(X_14,BARSLAST(X_15))=0 OR X_14);//包含处理后顶分型延续
X_29:=X_25 OR X_28;//顶底分型延续
X_30:=BARSLAST(X_17<>REF(X_17,1))-COUNT(X_22,BARSLAST(X_17<>REF(X_17,1)))+COUNT(X_29,BARSLAST(X_17<>REF(X_17,1)))>2 AND HIGH=HHV(HIGH,1+BARSLAST(X_17<>REF(X_17,1))) AND COUNT(LOW<REF(X_17,BARSLAST(X_17<>REF(X_17,1))),BARSLAST(X_17<>REF(X_17,1)))=0 AND BARSLAST(X_17<>REF(X_17,1))>0;
X_31:=SUMBARS(X_17<>REF(X_17,1),2)-COUNT(X_22,SUMBARS(X_17<>REF(X_17,1),2))+COUNT(X_29,SUMBARS(X_17<>REF(X_17,1),2))>3 AND HIGH=HHV(HIGH,SUMBARS(X_17<>REF(X_17,1),2)) AND REF(X_17,SUMBARS(X_17<>REF(X_17,1),2)-1)<=LLV(LOW,SUMBARS(X_17<>REF(X_17,1),2));
X_32:=SUMBARS(X_17<>REF(X_17,1),3)-COUNT(X_22,SUMBARS(X_17<>REF(X_17,1),3))+COUNT(X_29,SUMBARS(X_17<>REF(X_17,1),3))>3 AND HIGH=HHV(HIGH,SUMBARS(X_17<>REF(X_17,1),3)) AND REF(X_17,SUMBARS(X_17<>REF(X_17,1),3)-1)<=LLV(LOW,SUMBARS(X_17<>REF(X_17,1),3));
X_33:=SUMBARS(X_17<>REF(X_17,1),4)-COUNT(X_22,SUMBARS(X_17<>REF(X_17,1),4))+COUNT(X_29,SUMBARS(X_17<>REF(X_17,1),4))>3 AND HIGH=HHV(HIGH,SUMBARS(X_17<>REF(X_17,1),4)) AND REF(X_17,SUMBARS(X_17<>REF(X_17,1),4)-1)<=LLV(LOW,SUMBARS(X_17<>REF(X_17,1),4));
X_34:=SUMBARS(X_17<>REF(X_17,1),5)-COUNT(X_22,SUMBARS(X_17<>REF(X_17,1),5))+COUNT(X_29,SUMBARS(X_17<>REF(X_17,1),5))>3 AND HIGH=HHV(HIGH,SUMBARS(X_17<>REF(X_17,1),5)) AND REF(X_17,SUMBARS(X_17<>REF(X_17,1),5)-1)<=LLV(LOW,SUMBARS(X_17<>REF(X_17,1),5));
X_35:=SUMBARS(X_17<>REF(X_17,1),6)-COUNT(X_22,SUMBARS(X_17<>REF(X_17,1),6))+COUNT(X_29,SUMBARS(X_17<>REF(X_17,1),6))>3 AND HIGH=HHV(HIGH,SUMBARS(X_17<>REF(X_17,1),6)) AND REF(X_17,SUMBARS(X_17<>REF(X_17,1),6)-1)<=LLV(LOW,SUMBARS(X_17<>REF(X_17,1),6));
X_36:=BARSLAST(X_19<>REF(X_19,1))-COUNT(X_22,BARSLAST(X_19<>REF(X_19,1)))+COUNT(X_29,BARSLAST(X_19<>REF(X_19,1)))>2 AND COUNT(HIGH>REF(X_19,BARSLAST(X_19<>REF(X_19,1))),BARSLAST(X_19<>REF(X_19,1)))=0 AND LOW=LLV(LOW,BARSLAST(X_19<>REF(X_19,1))) AND BARSLAST(X_19<>REF(X_19,1))>0;
X_37:=SUMBARS(X_19<>REF(X_19,1),2)-COUNT(X_22,SUMBARS(X_19<>REF(X_19,1),2))+COUNT(X_29,SUMBARS(X_19<>REF(X_19,1),2))>3 AND LOW=LLV(LOW,SUMBARS(X_19<>REF(X_19,1),2)) AND REF(X_19,SUMBARS(X_19<>REF(X_19,1),2)-1)>=HHV(HIGH,SUMBARS(X_19<>REF(X_19,1),2));
X_38:=SUMBARS(X_19<>REF(X_19,1),3)-COUNT(X_22,SUMBARS(X_19<>REF(X_19,1),3))+COUNT(X_29,SUMBARS(X_19<>REF(X_19,1),3))>3 AND LOW=LLV(LOW,SUMBARS(X_19<>REF(X_19,1),3)) AND REF(X_19,SUMBARS(X_19<>REF(X_19,1),3)-1)>=HHV(HIGH,SUMBARS(X_19<>REF(X_19,1),3));
X_39:=SUMBARS(X_19<>REF(X_19,1),4)-COUNT(X_22,SUMBARS(X_19<>REF(X_19,1),4))+COUNT(X_29,SUMBARS(X_19<>REF(X_19,1),4))>3 AND LOW=LLV(LOW,SUMBARS(X_19<>REF(X_19,1),4)) AND REF(X_19,SUMBARS(X_19<>REF(X_19,1),4)-1)>=HHV(HIGH,SUMBARS(X_19<>REF(X_19,1),4));
X_40:=SUMBARS(X_19<>REF(X_19,1),5)-COUNT(X_22,SUMBARS(X_19<>REF(X_19,1),5))+COUNT(X_29,SUMBARS(X_19<>REF(X_19,1),5))>3 AND LOW=LLV(LOW,SUMBARS(X_19<>REF(X_19,1),5)) AND REF(X_19,SUMBARS(X_19<>REF(X_19,1),5)-1)>=HHV(HIGH,SUMBARS(X_19<>REF(X_19,1),5));
X_41:=SUMBARS(X_19<>REF(X_19,1),6)-COUNT(X_22,SUMBARS(X_19<>REF(X_19,1),6))+COUNT(X_29,SUMBARS(X_19<>REF(X_19,1),6))>3 AND LOW=LLV(LOW,SUMBARS(X_19<>REF(X_19,1),6)) AND REF(X_19,SUMBARS(X_19<>REF(X_19,1),6)-1)>=HHV(HIGH,SUMBARS(X_19<>REF(X_19,1),6));
X_42:=X_30 OR X_31 OR X_32 OR X_33 OR X_34 OR X_35;
X_43:=X_36 OR X_37 OR X_38 OR X_39 OR X_40 OR X_41;
X_44:=X_42 AND COUNT(X_42,1+BARSLAST(X_43))=1;
X_45:=X_43 AND COUNT(X_43,1+BARSLAST(X_42))=1;
X_46:=IF(X_44,LLV(LOW,1+BARSLAST(X_45)),0);
X_47:=IF(X_46,X_46,REF(X_46,BARSLAST(X_46)));
X_48:=IF(X_45,HHV(HIGH,1+BARSLAST(X_44)),0);
X_49:=IF(X_48,X_48,REF(X_48,BARSLAST(X_48)));
X_50:=HHV(HIGH,1+BARSLAST(X_46))=HIGH;
X_51:=LLV(LOW,1+BARSLAST(X_48))=LOW;
X_52:=CROSS(BACKSET(X_51||BARSLAST(X_50)<BARSLAST(X_51)&&ISLASTBAR,BARSLAST(X_50)+1)=1,0.5);// FILTERX(X_50,BARSLAST(X_51));
X_53:=CROSS(BACKSET(X_50||BARSLAST(X_50)>BARSLAST(X_51)&&ISLASTBAR,BARSLAST(X_51)+1)=1,0.5);// FILTERX(X_51,BARSLAST(X_50));
X_54:=IF(X_53,LOW,0);
X_55:=IF(X_52,HIGH,0);
X_56:=IF(X_54>0,X_54,REF(X_54,BARSLAST(X_54>0)));
X_57:=IF(X_55>0,X_55,REF(X_55,BARSLAST(X_55>0)));
X_58:=BARSLAST(X_53)-COUNT(X_22,BARSLAST(X_53))+COUNT(X_29,BARSLAST(X_53))>3 AND COUNT(LOW<REF(X_56,BARSLAST(X_53)),BARSLAST(X_53))=0 AND HIGH=HHV(HIGH,1+BARSLAST(X_53)) AND BARSLAST(X_53)>0;
X_59:=BARSLAST(X_52)-COUNT(X_22,BARSLAST(X_52))+COUNT(X_29,BARSLAST(X_52))>3 AND COUNT(HIGH>REF(X_57,BARSLAST(X_52)),BARSLAST(X_52))=0 AND LOW=LLV(LOW,BARSLAST(X_52)) AND BARSLAST(X_52)>0;
X_60:=CROSS(BACKSET(X_59||ISLASTBAR&&BARSLAST(X_58)<BARSLAST(X_59),BARSLAST(X_58)+1)=1,0.5);// FILTERX(X_58,BARSLAST(X_59));
X_61:=CROSS(BACKSET(X_58||ISLASTBAR&&BARSLAST(X_58)>BARSLAST(X_59),BARSLAST(X_59)+1)=1,0.5);// FILTERX(X_59,BARSLAST(X_58));
X_62:=IF(X_61,LOW,0);
X_63:=IF(X_60,HIGH,0);
X_64:=IF(X_62>0,X_62,REF(X_62,BARSLAST(X_62>0)));
X_65:=IF(X_63>0,X_63,REF(X_63,BARSLAST(X_63>0)));
X_66:=LLV(LOW,1+BARSLAST(X_64<>REF(X_64,1) OR (X_62>0 AND X_64=REF(X_64,1))))=LOW AND COUNT(X_65<>REF(X_65,1),BARSLAST(X_64<>REF(X_64,1) OR (X_62>0 AND X_64=REF(X_64,1)))+1)=0;
X_67:=HHV(HIGH,1+BARSLAST(X_65<>REF(X_65,1) OR (X_63>0 AND X_65=REF(X_65,1))))=HIGH AND COUNT(X_64<>REF(X_64,1),BARSLAST(X_65<>REF(X_65,1) OR (X_63>0 AND X_65=REF(X_65,1)))+1)=0;//1
X_68:=CROSS(BACKSET(X_66||ISLASTBAR&&BARSLAST(X_67)<BARSLAST(X_66),BARSLAST(X_67)+1)=1,0.5);// FILTERX(X_67,BARSLAST(X_66));
X_69:=CROSS(BACKSET(X_67||ISLASTBAR&&BARSLAST(X_67)>BARSLAST(X_66),BARSLAST(X_66)+1)=1,0.5);// FILTERX(X_66,BARSLAST(X_67));
X_70:=IF(X_69,LOW,0),NODRAW;
X_71:=IF(X_68,HIGH,0),NODRAW;
//精准笔
DRAWSL(REFX(X_68,1),L,0,6,0,COLORRED);
DRAWSL(REFX(X_69,1),H,0,6,0,COLORGREEN);
DRAWSHIFTNUMBER(REFX(X_68,1),L,L,1,COLORYELLOW,1,5);
DRAWSHIFTNUMBER(REFX(X_69,1),H,H,1,COLORYELLOW,1,5);
//DRAWICON(X_68,H,5);
//DRAWICON(X_69,L,4),VALIGN0;
DRAWTEXT(X_68,H,'顶');
DRAWTEXT(X_69,L,'底'),VALIGN0;
KK:=ISDOWN&&C<VALUEWHEN(X_68,REF(L,1))&&COUNT(ISDOWN&&C<VALUEWHEN(X_68,REF(L,1)),BARSLAST(X_68))=1;
DD:=ISUP&&C>VALUEWHEN(X_69,REF(H,1))&&COUNT(ISUP&&C>VALUEWHEN(X_69,REF(H,1)),BARSLAST(X_69))=1;
DRAWTEXT(KK,H,'卖'),COLORGREEN,FONTSIZE20;
DRAWTEXT(DD,L,'买'),COLORRED,VALIGN0,FONTSIZE20;
KK,SOUND('A');
DD,SOUND('A');
DRAWCOLORKLINE(BARSLAST(KK)<BARSLAST(DD)&&ISDOWN&&NOT(ISLASTBAR),RGB(255,255,255),0);
DRAWCOLORKLINE(BARSLAST(KK)<BARSLAST(DD)&&ISDOWN=0&&NOT(ISLASTBAR),COLORCYAN,1);
DRAWCOLORKLINE(BARSLAST(KK)>BARSLAST(DD)&&ISDOWN&&NOT(ISLASTBAR),COLORRED,0);
DRAWCOLORKLINE(BARSLAST(KK)>BARSLAST(DD)&&ISDOWN=0&&NOT(ISLASTBAR),COLORRED,1);
DRAWCOLORKLINE(CROSS(BARSLAST(KK)<BARSLAST(DD),0.5)&&ISDOWN&&NOT(ISLASTBAR),COLORYELLOW,0);
DRAWCOLORKLINE(CROSS(BARSLAST(KK)<BARSLAST(DD),0.5)&&ISDOWN=0&&NOT(ISLASTBAR),COLORYELLOW,1);
DRAWCOLORKLINE(CROSS(BARSLAST(KK)>BARSLAST(DD),0.5)&&NOT(ISLASTBAR),COLORBLUE,0);
AL展BDD:=(BACKSET(COUNT(HH展BDD,NL展BDD)&&HH展BDD,NL展BDD))*缠论线开关*MA8;
//DRAWLINE1(CROSS(AH展BDD=1,0.5),H,CROSS(AL展BDD=1,0.5),L,0),DASHDOTDOT,LINETHICK1,RGB(146,99,1);
//DRAWLINE1(CROSS(AL展BDD=1,0.5),L,CROSS(AH展BDD=1,0.5),H,0),DASHDOTDOT,LINETHICK1,RGB(143,32,255);
//DRAWNUMBER(CROSS(AH展BDD=1,0.5),H+0*MINPRICE,H-VALUEWHEN(CROSS(AL展BDD=1,0.5),L),1,COLORYELLOW),ALIGN0,VALIGN2,FONTSIZE16;
//DRAWNUMBER(CROSS(AL展BDD=1,0.5),L-0*MINPRICE,L-VALUEWHEN(CROSS(AH展BDD=1,0.5),H),1,COLORGREEN),ALIGN0,VALIGN0,FONTSIZE16;
LX:=AL展BDD, NOTEXT;
HX:=AH展BDD, NOTEXT;
笔:=1;
//1、本级别 (BOLL26)笔:
XZ:BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12)),NODRAW;
X8:CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),8)),0.5),NODRAW;
X9:CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),9)),0.5),NODRAW;
X12:CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12)),0.5),NODRAW;
X13:CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),13)),0.5),NODRAW;
//BOLL26最后一笔(未完成);
//HH:=CROSS(HX=1,0.5);
//LL:=CROSS(LX=1,0.5);
HH:CROSS(AH展BDD=1,0.5), NOTEXT;
LL:CROSS(AL展BDD=1,0.5), NOTEXT;
////////2、画倒数1234的笔;
//2.1、倒数第4笔(已完成);
BADS4:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4));
BBDS4:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),5));
//2.2、倒数第2笔(已完成);
BADS2:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),2));
BBDS2:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),3));
//2.3、倒数第3笔(已完成);
BADS3:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),3));
BBDS3:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4));
//2.4、倒数第1笔(已完成);
BADS1:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),1));
BBDS1:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),2));
////////3、计算笔的长度;
//3.1、BOLL26笔(已完成)的每笔长度;
DRAWNUMBER1(笔*REFX(CROSS(LX=1,0.5),5),REFX(L,5),REFX((L-VALUEWHEN(CROSS(HX=1,0.5),H)),5),2),ALIGN2,VALIGN0,RGB(0,67,100);//向下笔(已完成)长度,保留2位小数;
DRAWNUMBER1(笔*REFX(CROSS(HX=1,0.5),5),REFX(H,5),REFX((H-VALUEWHEN(CROSS(LX=1,0.5),L)),5),2),ALIGN2,VALIGN2,RGB(0,67,100);//向上笔(已完成)长度,保留2位小数;
//BOLL26最后一笔(未完成)长度;
BX1:=CROSS(BACKSET(ISLASTBAR&&BARSLAST(HH)<BARSLAST(LL),LLVBARS(L,BARSLAST(HH))+1),0.5);
BX2:=CROSS(BACKSET(ISLASTBAR&&BARSLAST(HH)>BARSLAST(LL),HHVBARS(H,BARSLAST(LL))+1),0.5);
DRAWNUMBER1(笔*REFX(BX1,5),REFX(L,5),REFX((L-VALUEWHEN(CROSS(HX=1,0.5),H)),5),2),ALIGN2,VALIGN0,RGB(0,67,100);//向下笔(未完成)长度,保留2位小数;
DRAWNUMBER1(笔*REFX(BX2,5),REFX(H,5),REFX((H-VALUEWHEN(CROSS(LX=1,0.5),L)),5),2),ALIGN2,VALIGN0,RGB(0,67,100);//向上笔(未完成)长度,保留2位小数;
////////4、笔终点标注文字记号;
//4.1、笔(已完成)终点标注文字;
BAA:=IF(CROSS(LX=1,0.5),L,H);
BBB:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4));
DRAWTEXT(笔*BBB&&CROSS(HX=1,0.5)&&COUNT(CROSS(HX=1,0.5),BARSLASTCOUNT(BBB))=1,H,'H2 '),ALIGN2,FONTSIZE18,RGB(128,128,255),COLORRED;//倒数第2个高点标注文字;
DRAWTEXT(笔*BBB&&CROSS(HX=1,0.5)&&COUNT(CROSS(HX=1,0.5),BARSLASTCOUNT(BBB))=2,H,'H1 '),ALIGN2,FONTSIZE18,RGB(128,128,255),COLORRED;//倒数第1个高点标注文字;
DRAWTEXT(笔*BBB&&CROSS(LX=1,0.5)&&COUNT(CROSS(LX=1,0.5),BARSLASTCOUNT(BBB))=1,L,'L2 '),ALIGN2,VALIGN0,FONTSIZE18,RGB(128,128,255),COLORGREEN;//倒数第2个低点标注文字;
DRAWTEXT(笔*BBB&&CROSS(LX=1,0.5)&&COUNT(CROSS(LX=1,0.5),BARSLASTCOUNT(BBB))=2,L,'L1 '),ALIGN2,VALIGN0,FONTSIZE18,RGB(128,128,255),COLORGREEN;//倒数第1个低点标注文字;
BAA0:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),5));
DRAWTEXT(笔*CROSS(BAA0>=1,0.5) && CROSS(LX=1,0.5),L,'L3 '),ALIGN2,VALIGN0,FONTSIZE18,RGB(155,155,155),COLORGREEN;//倒数第3个低点标注文字;
DRAWTEXT(笔*CROSS(BAA0>=1,0.5) && CROSS(HX=1,0.5),H,'H3 '),ALIGN2,FONTSIZE18,RGB(155,155,155),COLORRED;//倒数第3个高点标注文字;
BAA1:=BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),6));
DRAWTEXT(笔*CROSS(BAA1>=1,0.5) && CROSS(LX=1,0.5),L,'L4 '),ALIGN2,VALIGN0,FONTSIZE18,RGB(155,155,155),COLORGREEN;//倒数第4个低点标注文字;
DRAWTEXT(笔*CROSS(BAA1>=1,0.5) && CROSS(HX=1,0.5),H,'H4 '),ALIGN2,FONTSIZE18,RGB(155,155,155),COLORRED;//倒数第4个高点标注文字;
//4.2、笔(未完成)的最后1笔标注文字;
AM26:=BACKSET(ISLASTBAR&&BARSLAST(HH)>BARSLAST(LL),HHVBARS(H,BARSLAST(LL))+1);
BM26:=BACKSET(ISLASTBAR&&BARSLAST(HH)<BARSLAST(LL),LLVBARS(L,BARSLAST(HH))+1);
DRAWTEXT(笔*CROSS(AM26,0.5),H,' H0 ? '),FONTSIZE18,RGB(200,200,0);//最后一笔(未完成)标注文字;
DRAWTEXT(笔*CROSS(BM26,0.5),L,' L0 ? '),VALIGN0,FONTSIZE18,RGB(200,200,0);//最后一笔(未完成)标注文字;
笔中枢:=1;
//////////画笔中枢框;
HH2:=VALUEWHEN(BBB&&CROSS(HX=1,0.5)&&COUNT(CROSS(HX=1,0.5),BARSLASTCOUNT(BBB))=1,H);
HH1:=VALUEWHEN(BBB&&CROSS(HX=1,0.5)&&COUNT(CROSS(HX=1,0.5),BARSLASTCOUNT(BBB))=2,H);
LL2:=VALUEWHEN(BBB&&CROSS(LX=1,0.5)&&COUNT(CROSS(LX=1,0.5),BARSLASTCOUNT(BBB))=1,L);
LL1:=VALUEWHEN(BBB&&CROSS(LX=1,0.5)&&COUNT(CROSS(LX=1,0.5),BARSLASTCOUNT(BBB))=2,L);
//画笔中枢框;
NG:=BARSLASTCOUNT(HH2>0 || HH1>0 || LL2>0 || LL1>0)=1;
NGG:=BARSLASTCOUNT(HH2>0 && HH1>0 && LL2>0 && LL1>0)=1;
DRAWSL(笔中枢*NGG,MIN(HH2,HH1),0,-SUMBARS(NG,1)+1,0,RGB(128,128,255)),DOT;//中枢上轨;
DRAWSL(笔中枢*NGG,MAX(LL2,LL1),0,-SUMBARS(NG,1)+1,0,RGB(128,128,255)),DOT;//中枢下轨;
DRAWLINE(笔中枢*NGG,MIN(HH2,HH1),NGG,MAX(LL2,LL1),RGB(128,128,255)),DOT;//中枢右边垂线;
DRAWLINE3(笔中枢*NGG,MIN(HH2,HH1),SUMBARS(NG,1)-1,NGG,MAX(LL2,LL1),SUMBARS(NG,1)-1,0),RGB(128,128,255),DOT;//中枢左边垂线;
//画笔中枢框延伸部分;
L1缠:=CROSS(BACKSET(ISLASTBAR,BARSLAST(CROSS(LX=1,0.5))+1),0.5);
L2缠:=CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5),2)),0.5);
L3缠:=CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5),3)),0.5);
L4缠:=CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5),4)),0.5),ICON(1,'●');
L5缠:=CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(LX=1,0.5),5)),0.5),ICON(1,'●');
H1缠:=CROSS(BACKSET(ISLASTBAR,BARSLAST(CROSS(HX=1,0.5))+1),0.5);
H2缠:=CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(HX=1,0.5),2)),0.5);
H3缠:=CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(HX=1,0.5),3)),0.5);
H4缠:=CROSS(BACKSET(ISLASTBAR,SUMBARS(CROSS(HX=1,0.5),4)),0.5),ICON(1,'●');
周期:=BARSLAST(CROSS(BBB,0.5)),RGB(255,0,255);
DRAWLINE3(ISLASTBAR&&VALUEWHEN(L1缠,L)>=VALUEWHEN(L2缠,L),VALUEWHEN(L1缠,L),0,1,VALUEWHEN(L1缠,L),BARSLAST(CROSS(BBB,0.5)),0),RGB(128,128,255),LINETHICK1;
DRAWLINE3(ISLASTBAR&&VALUEWHEN(L1缠,L)<=VALUEWHEN(L2缠,L),VALUEWHEN(L2缠,L),0,1,VALUEWHEN(L2缠,L),BARSLAST(CROSS(BBB,0.5)),0),RGB(128,128,255),LINETHICK1;
DRAWTEXT(ISLASTBAR&&VALUEWHEN(L1缠,L)>=VALUEWHEN(L2缠,L),VALUEWHEN(L1缠,L),' 笔枢下沿'),RGB(128,128,255);
DRAWTEXT(ISLASTBAR&&VALUEWHEN(L1缠,L)<=VALUEWHEN(L2缠,L),VALUEWHEN(L2缠,L),' 笔枢下沿'),RGB(128,128,255);
DRAWNUMBER(ISLASTBAR&&VALUEWHEN(L1缠,L)>=VALUEWHEN(L2缠,L),VALUEWHEN(L1缠,L),VALUEWHEN(L1缠,L)*(-1),2,RGB(128,128,255)),ALIGN0;
DRAWNUMBER(ISLASTBAR&&VALUEWHEN(L1缠,L)<=VALUEWHEN(L2缠,L),VALUEWHEN(L2缠,L),VALUEWHEN(L2缠,L)*(-1),2,RGB(128,128,255)),ALIGN0;
DRAWLINE3(ISLASTBAR&&VALUEWHEN(H1缠,H)>=VALUEWHEN(H2缠,H),VALUEWHEN(H2缠,H),0,1,VALUEWHEN(H2缠,H),BARSLAST(CROSS(BBB,0.5)),0),RGB(128,128,255),DOT;
DRAWLINE3(ISLASTBAR&&VALUEWHEN(H1缠,H)<=VALUEWHEN(H2缠,H),VALUEWHEN(H1缠,H),0,1,VALUEWHEN(H1缠,H),BARSLAST(CROSS(BBB,0.5)),0),RGB(128,128,255),DOT;
DRAWNUMBER(ISLASTBAR&&VALUEWHEN(H1缠,H)>=VALUEWHEN(H2缠,H),VALUEWHEN(H2缠,H),VALUEWHEN(H2缠,H)*(-1),2,RGB(128,128,255)),ALIGN0;
DRAWNUMBER(ISLASTBAR&&VALUEWHEN(H1缠,H)<=VALUEWHEN(H2缠,H),VALUEWHEN(H1缠,H),VALUEWHEN(H1缠,H)*(-1),2,RGB(128,128,255)),ALIGN0;
DRAWTEXT(ISLASTBAR&&VALUEWHEN(H1缠,H)>=VALUEWHEN(H2缠,H),VALUEWHEN(H2缠,H),' 笔枢上沿'),RGB(128,128,255);
DRAWTEXT(ISLASTBAR&&VALUEWHEN(H1缠,H)<=VALUEWHEN(H2缠,H),VALUEWHEN(H1缠,H),' 笔枢上沿'),RGB(128,128,255);
//填充中枢;
HHH2:=REFX1(VALUEWHEN(BBB&&CROSS(HX=1,0.5)&&COUNT(CROSS(HX=1,0.5),BARSLASTCOUNT(BBB))=1,H),99999);
HHH1:=REFX1(VALUEWHEN(BBB&&CROSS(HX=1,0.5)&&COUNT(CROSS(HX=1,0.5),BARSLASTCOUNT(BBB))=2,H),99999);
LLL2:=REFX1(VALUEWHEN(BBB&&CROSS(LX=1,0.5)&&COUNT(CROSS(LX=1,0.5),BARSLASTCOUNT(BBB))=1,L),99999);
LLL1:=REFX1(VALUEWHEN(BBB&&CROSS(LX=1,0.5)&&COUNT(CROSS(LX=1,0.5),BARSLASTCOUNT(BBB))=2,L),99999);
AA:=BACKSET(ISLASTBAR,MAX(BARSLAST(H2缠),BARSLAST(L2缠))+1),NODRAW;
BB:=BACKSET(ISLASTBAR,MIN(BARSLAST(H1缠),BARSLAST(L1缠))+1),NODRAW;
ZXZ:=(IF(ISNULL( AA),0,AA)+IF(ISNULL( BB),0,BB))=1|| REF((IF(ISNULL( AA),0,AA)+IF(ISNULL( BB),0,BB))=1,1),NODRAW;
FILLRGN(ZXZ&&笔中枢*BARSLASTCOUNT(HH2>0 || HH1>0 || LL2>0 || LL1>0)>=1 && ((HH2>0 && HH1>0 && LL2>0 && LL1>0)=0 || BARSLASTCOUNT(HH2>0 && HH1>0 && LL2>0 && LL1>0)=1),MAX(LLL1,LLL2),MIN(HHH1,HHH2),RGB(0,0,100));//填充中枢;
AAX:CROSS(BACKSET(ISLASTBAR,BARSLAST(CROSS(LX=1,0.5)||CROSS(HX=1,0.5))+1),0.5),ICON(1,'ICO1');
DRAWSL(AAX, REF(HHV(IF(CROSS(LX=1,0.5),L,0) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4)) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5) , 8)),0,-SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12),0,COLORYELLOW);
DRAWSL(AAX, REF(LLV(IF(CROSS(HX=1,0.5),H,999999) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4)) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5) , 8)),0,-SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12),0,COLORYELLOW);
DRAWLINE(AAX,REF(HHV(IF(CROSS(LX=1,0.5),L,0) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4)) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5) , 8)),1,REF(LLV(IF(CROSS(HX=1,0.5),H,999999) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4)) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5) , 8)),COLORYELLOW);
DRAWLINE3(AAX,REF(HHV(IF(CROSS(LX=1,0.5),L,0) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4)) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5) , 8)),SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12),AAX,REF(LLV(IF(CROSS(HX=1,0.5),H,999999) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4)) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5) , 8)),SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12),0),COLORYELLOW;
HHX:REFX1(VALUEWHEN(AAX,REF(HHV(IF(CROSS(LX=1,0.5),L,0) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4)) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5) , 8))),10000),NODRAW;
LLX:REFX1(VALUEWHEN(AAX,REF(LLV(IF(CROSS(HX=1,0.5),H,999999) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),4)) ,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5) , 8))),10000),NODRAW;
/////6.2填充中枢区间;
//扩张型中枢,G1>G2,D2>D1, G2>D2,填充区间G2D2;
FILLRGN(ZXZ&&笔中枢*REFX1(ISLASTBAR&&VALUEWHEN(H1缠,H)>=VALUEWHEN(H2缠,H)&&ISLASTBAR&&VALUEWHEN(L2缠,L)>=VALUEWHEN(L1缠,L) &&ISLASTBAR&&VALUEWHEN(H2缠,H)>VALUEWHEN(L2缠,L),10000), REFX1(VALUEWHEN(L2缠,L),10000), REFX1(VALUEWHEN(H2缠,H),10000), RGB(0,0,100));
//收敛型中枢,G2>G1,D1>D2, G1>D1,填充区间G1D1;
FILLRGN(ZXZ&&笔中枢*REFX1(ISLASTBAR&&VALUEWHEN(H2缠,H)>=VALUEWHEN(H1缠,H)&&ISLASTBAR&&VALUEWHEN(L1缠,L)>=VALUEWHEN(L2缠,L) &&ISLASTBAR&&VALUEWHEN(H1缠,H)>VALUEWHEN(L1缠,L),10000), REFX1(VALUEWHEN(H1缠,H),10000), REFX1(VALUEWHEN(L1缠,L),10000),RGB(33,33,33));
//奔走向上型,向上之字型中枢,G1>G2,D1>D2, G2>D1,填充区间G2D1;
FILLRGN(ZXZ&&笔中枢*REFX1(ISLASTBAR&&VALUEWHEN(H1缠,H)>=VALUEWHEN(H2缠,H)&&ISLASTBAR&&VALUEWHEN(L1缠,L)>=VALUEWHEN(L2缠,L) &&ISLASTBAR&&VALUEWHEN(H2缠,H)>VALUEWHEN(L1缠,L),10000) , REFX1(VALUEWHEN(H2缠,H),10000), REFX1(VALUEWHEN(L1缠,L),10000),RGB(99,80,0));
//奔走向下型,向下之字型中枢,G2>SG1,D2>D1, G1>D2,填充区间G1D2;
FILLRGN(ZXZ&&笔中枢*REFX1(ISLASTBAR&&VALUEWHEN(H2缠,H)>=VALUEWHEN(H1缠,H)&&ISLASTBAR&&VALUEWHEN(L2缠,L)>=VALUEWHEN(L1缠,L) &&ISLASTBAR&&VALUEWHEN(H1缠,H)>VALUEWHEN(L2缠,L),10000), REFX1(VALUEWHEN(H1缠,H),10000), REFX1(VALUEWHEN(L2缠,L),10000), RGB(0,27,0));
//上涨3买型,G1>G2,D1>D2, G2<D1,填充区间G2D1;
FILLRGN(ZXZ&&笔中枢*REFX1(ISLASTBAR&&VALUEWHEN(H1缠,H)>VALUEWHEN(H2缠,H)&&ISLASTBAR&&VALUEWHEN(L1缠,L)>VALUEWHEN(L2缠,L) &&ISLASTBAR&&VALUEWHEN(H2缠,H)<VALUEWHEN(L1缠,L),10000) , REFX1(VALUEWHEN(H2缠,H),10000), REFX1(VALUEWHEN(L1缠,L),10000), RGB(88,0,0));
//下跌3卖型,G2>G1,D2>D1, G1<D2,填充区间G1D2;
FILLRGN(ZXZ&&笔中枢*REFX1(ISLASTBAR&&VALUEWHEN(H2缠,H)>VALUEWHEN(H1缠,H)&&ISLASTBAR&&VALUEWHEN(L2缠,L)>VALUEWHEN(L1缠,L) &&ISLASTBAR&&VALUEWHEN(H1缠,H)<VALUEWHEN(L2缠,L),10000), REFX1(VALUEWHEN(H1缠,H),10000), REFX1(VALUEWHEN(L2缠,L),10000), RGB(0,68,0));
DO1:REFX1(VALUEWHEN(AAX,VALUEWHEN(CROSS(HX=1,0.5),H>REF(VALUEWHEN(CROSS(HX=1,0.5),H),1)))&& VALUEWHEN(AAX,VALUEWHEN(CROSS(LX=1,0.5),L>REF(VALUEWHEN(CROSS(LX=1,0.5),L),1)))&&REF(REF(H,SUMBARS(CROSS(HX=1,0.5),2)-1),1)<VALUEWHEN(CROSS(LX=1,0.5),L) ,10000),NODRAW;//H1>H2&&L1>L2&&H2<L1
FILLRGN(BACKSET(AAX,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12))&&DO1,HHX,LLX,RGB(88,0,0));
DO2:REFX1(VALUEWHEN(AAX,VALUEWHEN(CROSS(HX=1,0.5),H<REF(VALUEWHEN(CROSS(HX=1,0.5),H),1)))&& VALUEWHEN(AAX,VALUEWHEN(CROSS(LX=1,0.5),L<REF(VALUEWHEN(CROSS(LX=1,0.5),L),1)))&&REF(REF(L,SUMBARS(CROSS(LX=1,0.5),2)-1),1)>VALUEWHEN(CROSS(HX=1,0.5),H) ,10000),NODRAW;//H1<H2&&L1<L2 &&H1<L2
FILLRGN(BACKSET(AAX,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12))&&DO2,HHX,LLX,RGB(0,68,0));
//H1>H2&&L2>L1&&H2>L2 RGB(0,0,100)
DO3:REFX1(VALUEWHEN(AAX,VALUEWHEN(CROSS(HX=1,0.5),H>REF(VALUEWHEN(CROSS(HX=1,0.5),H),1)))&& VALUEWHEN(AAX,VALUEWHEN(CROSS(LX=1,0.5),L<REF(VALUEWHEN(CROSS(LX=1,0.5),L),1)))&&REF(REF(H,SUMBARS(CROSS(HX=1,0.5),2)-1),1)>REF(REF(L,SUMBARS(CROSS(LX=1,0.5),2)-1),1) ,10000),NODRAW;//H1>H2&&L1>L2&&H2<L1
FILLRGN(BACKSET(AAX,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12))&&DO3,HHX,LLX,RGB(0,0,100));
//H2>H1&&L1>L2&&H1>L1 RGB(33,33,33)
DO4:REFX1(VALUEWHEN(AAX,VALUEWHEN(CROSS(HX=1,0.5),H<REF(VALUEWHEN(CROSS(HX=1,0.5),H),1)))&& VALUEWHEN(AAX,VALUEWHEN(CROSS(LX=1,0.5),L>REF(VALUEWHEN(CROSS(LX=1,0.5),L),1)))&&REF(REF(H,SUMBARS(CROSS(HX=1,0.5),1)-1),1)>REF(REF(L,SUMBARS(CROSS(LX=1,0.5),1)-1),1) ,10000),NODRAW;//H1>H2&&L1>L2&&H2<L1
FILLRGN(BACKSET(AAX,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12))&&DO4,HHX,LLX,RGB(33,33,33));
//H1>H2&&L1>L2&&H2>L1 RGB(99,80,0)
DO5:REFX1(VALUEWHEN(AAX,VALUEWHEN(CROSS(HX=1,0.5),H>REF(VALUEWHEN(CROSS(HX=1,0.5),H),1)))&& VALUEWHEN(AAX,VALUEWHEN(CROSS(LX=1,0.5),L>REF(VALUEWHEN(CROSS(LX=1,0.5),L),1)))&&REF(REF(H,SUMBARS(CROSS(HX=1,0.5),2)-1),1)>REF(REF(L,SUMBARS(CROSS(LX=1,0.5),1)-1),1) ,10000),NODRAW;//H1>H2&&L1>L2&&H2<L1
FILLRGN(BACKSET(AAX,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12))&&DO5,HHX,LLX,RGB(99,80,0));
//H2>H1&&L2>L1&&H1>L2 RGB(0,27,0)
DO6:REFX1(VALUEWHEN(AAX,VALUEWHEN(CROSS(HX=1,0.5),H<REF(VALUEWHEN(CROSS(HX=1,0.5),H),1)))&& VALUEWHEN(AAX,VALUEWHEN(CROSS(LX=1,0.5),L<REF(VALUEWHEN(CROSS(LX=1,0.5),L),1)))&&REF(REF(H,SUMBARS(CROSS(HX=1,0.5),1)-1),1)>REF(REF(L,SUMBARS(CROSS(LX=1,0.5),2)-1),1) ,10000),NODRAW;//H1>H2&&L1>L2&&H2<L1
FILLRGN(BACKSET(AAX,SUMBARS(CROSS(LX=1,0.5)||CROSS(HX=1,0.5),12))&&DO6,HHX,LLX,RGB(0,27,0) );
DRAWKLINE1(H,O,L,C);
M:=0;
N1:=3;
N2:=6;
NC3:=12;
NC4:=24;
BBI:=(MA(CLOSE,N1)+MA(CLOSE,N2)+MA(CLOSE,NC3)+MA(CLOSE,NC4))/4;
顶:=BBI+3*STD(BBI,13),COLOR004AFF;
底:=BBI-3*STD(BBI,13),COLOR67FF00;
X:=3;
HN:=HHV(HIGH,5);
LLY:=LLV(LOW,5);
HH3:=BARSLAST((HN>REF(HN,1)));
LL3:=BARSLAST((LLY<REF(LLY,1)));
A:=IF((HH3 < LL3),1,IF((HH3 > LL3),-1,0));
HM:=HHV(HIGH,3);
LM:=LLV(LOW,3);
HM1:=IF(H<REF(H,1)&&H<REF(H,2)&&H<REF(H,4)&&L<REF(L,1)&&L<REF(L,3)&&L<REF(L,5)&&OPEN>CLOSE&&(HHV(OPEN,0)-CLOSE)>0,REF(H,4),0);
LM1:=IF(L>REF(L,1)&&L>REF(L,3)&&L>REF(L,5)&&H>REF(H,1)&&H>REF(H,2)&&H>REF(H,4)&&OPEN<CLOSE&&(CLOSE-LLV(OPEN,0))>0,REF(L,4),0);
HM2:=VALUEWHEN(HM1>0,HM1);
LM2:=VALUEWHEN(LM1>0,LM1);
KM1:=IF(CLOSE>HM2,-3,IF(CLOSE<LM2,1,0));
KM2:=VALUEWHEN(KM1<>0,KM1);
GM:=IF(KM2=1,HM2,LM2);
GM1:=VALUEWHEN(ISLASTBAR,GM);
BL:=2;
TMPM:=KM2;
WM1:=KM2;
WM2:=OPEN-CLOSE;
HTM:=IF(OPEN>CLOSE,OPEN,CLOSE);
LTM:=IF(OPEN<CLOSE,OPEN,CLOSE);
HJ:=2;
//均线,0
QZS:=(EMA(CLOSE,3)+EMA(CLOSE,6))/2;
MA5:MA(C,8),COLORWHITE,LINETHICK3,NODRAW;
MA10:MA(C,20),COLORBLUE,LINETHICK3,NODRAW;
//改良布林
ZX:=MA(CLOSE,26),NODRAW;
TMP2:=STD(C,26),NODRAW;
SA:=ZX+2*TMP2;
BBIBOLL:=(MA(C,3)+MA(C,6)+MA(C,12)+MA(C,24))/4;
多空线:=BBIBOLL, COLORWHITE,LINETHICK1;
牛17:=IF(X=2 OR X=3,MA(C,17),NULL),COLORRED,LINETHICK1;
中布:=IF(BL>0 ,ZX,NULL), COLORYELLOW,LINETHICK2;
布上:=IF(BL>1,SA,NULL), COLORCYAN,LINETHICK1;
XA:= ZX-2*TMP2;
布下:=IF(BL>1,XA,NULL),COLORCYAN,LINETHICK1;
熊26:IF( BL>1 OR X=2 OR X=3,MA(C,89),NULL),COLORRED,LINETHICK3,NODRAW;
//缠论
局部低点预选A:=BACKSET(LLV(L,5)<REF(LLV(L,4),1),4);
局部低点预选B:=BACKSET(局部低点预选A=0 AND REF(局部低点预选A,1)=1,2);
局部低点预选C:=IF(局部低点预选B=1 AND REF(局部低点预选B,1)=0,-1,0);
局部高点预选A:=BACKSET(HHV(H,5)>REF(HHV(H,4),1),4);
局部高点预选B:=BACKSET(局部高点预选A=0 AND REF(局部高点预选A,1)=1,2);
局部高点预选C:=IF(局部高点预选B=1 AND REF(局部高点预选B,1)=0,1,0);
缺口判断:=IF(L>REF(H,1),1,IF(H<REF(L,1),-1,0));
距前高天:=BARSLAST(局部高点预选C=1);
距前低天:=BARSLAST(局部低点预选C=-1);
小值周期:=20;
大值周期:=20;
低保留AA:=IF(局部低点预选C=-1 AND REF(距前高天,1)>REF(距前低天,1) AND LLV(L,距前高天+1)<REF(LLV(L,距前高天+1),1),-1,0);
低保留AB:=IF(局部低点预选C=-1 AND REF(距前高天,1)<=REF(距前低天,1) AND (距前高天>=4 OR LLV(缺口判断,距前高天)=-1 OR LLV(L,距前低天+2)<REF(LLV(L,距前低天+1),1)),-1,0);
低保留S:=IF((低保留AA=-1 OR 低保留AB=-1) AND L<REF(H,距前高天+1),-1,0);
预判:=IF((距前低天<4 AND HHV(缺口判断,距前低天)<>1) OR REF(低保留S,距前低天)=0,1,0);
判断:=IF(局部高点预选C=1 AND REF(距前低天,1)<=REF(距前高天,1) AND 预判=1 AND 大值周期>REF(小值周期,距前低天+1) AND 大值周期>REF(小值周期,距前低天) AND 大值周期>REF(大值周期,距前高天),1,0);
高保留A:=IF(局部高点预选C=1 AND REF(距前低天,1)>REF(距前高天,1) AND HHV(H,距前低天+1)>REF(HHV(H,距前低天+1),1),1,0);
高保留B:=IF(局部高点预选C=1 AND REF(距前低天,1)<=REF(距前高天,1) AND REF(低保留S,距前低天)=-1 AND (距前低天>=4 OR HHV(缺口判断,距前低天)=1),1,0);
高保留:=IF((高保留A=1 OR 高保留B=1 OR 判断=1) AND H>REF(L,距前低天+1),1,0);
预判A:=IF((距前高天<4 AND HHV(缺口判断,距前高天)<>1) OR REF(高保留,距前高天)=0,1,0);
判断A:=IF(局部低点预选C=-1 AND REF(距前高天,1)<=REF(距前低天,1) AND 预判A=1 AND 小值周期>REF(大值周期,距前高天+1) AND 小值周期>REF(大值周期,距前高天) AND 小值周期>REF(小值周期,距前低天),-1,0);
低保留A:=IF(局部低点预选C=-1 AND REF(距前高天,1)>REF(距前低天,1) AND LLV(L,距前高天+1)<REF(LLV(L,距前高天+1),1),-1,0);
低保留B:=IF(局部低点预选C=-1 AND REF(距前高天,1)<=REF(距前低天,1) AND (距前高天>=4 OR LLV(缺口判断,距前高天)=-1 OR 判断A=-1),-1,0);
低保留:=IF((低保留A=-1 OR 低保留B=-1) AND L<REF(H,距前高天+1),-1,0);
距前高天A:=BARSLAST(高保留=1);
距前低天A:=BARSLAST(低保留=-1);
预判X:=IF((距前低天A<4 AND HHV(缺口判断,距前低天A)<>1) OR REF(低保留,距前低天A)=0,1,0);
判断X:=IF(局部高点预选C=1 AND REF(距前低天A,1)<=REF(距前高天A,1) AND 预判X=1 AND 大值周期>REF(小值周期,距前低天A+1) AND 大值周期>REF(小值周期,距前低天A) AND 大值周期>REF(大值周期,距前高天A),1,0);
高保留XA:=IF(局部高点预选C=1 AND REF(距前低天A,1)>REF(距前高天A,1) AND HHV(H,距前低天A+1)>REF(HHV(H,距前低天A+1),1),1,0);
高保留XB:=IF(局部高点预选C=1 AND REF(距前低天A,1)<=REF(距前高天A,1) AND REF(低保留,距前低天A)=-1 AND (距前低天A>=4 OR HHV(缺口判断,距前低天A)=1),1,0);
高保留X:=IF((高保留XA=1 OR 高保留XB=1 OR 判断X=1) AND H>REF(L,距前低天A+1),1,0);
预判XA:=IF((距前高天A<4 AND HHV(缺口判断,距前高天A)<>1) OR REF(高保留XA,距前高天A)=0,1,0);
判断XA:=IF(局部低点预选C=-1 AND REF(距前高天A,1)<=REF(距前低天A,1) AND 预判XA=1 AND 小值周期>REF(大值周期,距前高天A+1) AND 小值周期>REF(大值周期,距前高天A) AND 小值周期>REF(小值周期,距前低天A),-1,0);
低保留XA:=IF(局部低点预选C=-1 AND REF(距前高天A,1)>REF(距前低天A,1) AND LLV(L,距前高天A+1)<REF(LLV(L,距前高天A+1),1),-1,0);
低保留XB:=IF(局部低点预选C=-1 AND REF(距前高天A,1)<=REF(距前低天A,1) AND (距前高天A>=4 OR LLV(缺口判断,距前高天A)=-1 OR 判断XA=-1),-1,0);
低保留X:=IF((低保留XA=-1 OR 低保留XB=-1) AND L<REF(H,距前高天A+1),-1,0);
距前高天YA:=BARSLAST(高保留X=1);
距前低天YA:=BARSLAST(低保留X=-1);
预判YX:=IF((距前低天YA<4 AND HHV(缺口判断,距前低天YA)<>1) OR REF(低保留X,距前低天YA)=0,1,0);
判断YX:=IF(局部高点预选C=1 AND REF(距前低天YA,1)<=REF(距前高天YA,1) AND 预判YX=1 AND 大值周期>REF(小值周期,距前低天YA+1) AND 大值周期>REF(小值周期,距前低天YA) AND 大值周期>REF(大值周期,距前高天YA),1,0);
高保留YXA:=IF(局部高点预选C=1 AND REF(距前低天YA,1)>REF(距前高天YA,1) AND HHV(H,距前低天YA+1)>REF(HHV(H,距前低天YA+1),1),1,0);
高保留YXB:=IF(局部高点预选C=1 AND REF(距前低天YA,1)<=REF(距前高天YA,1) AND REF(低保留X,距前低天YA)=-1 AND (距前低天YA>=4 OR HHV(缺口判断,距前低天YA)=1),1,0);
高保留YX:=IF((高保留YXA=1 OR 高保留YXB=1 OR 判断YX=1) AND H>REF(L,距前低天YA+1),1,0);
预判YXA:=IF((距前高天YA<4 AND HHV(缺口判断,距前高天YA)<>1) OR REF(高保留YXA,距前高天YA)=0,1,0);
判断YXA:=IF(局部低点预选C=-1 AND REF(距前高天YA,1)<=REF(距前低天YA,1) AND 预判YXA=1 AND 小值周期>REF(大值周期,距前高天YA+1) AND 小值周期>REF(大值周期,距前高天YA) AND 小值周期>REF(小值周期,距前低天YA),-1,0);
低保留YXA:=IF(局部低点预选C=-1 AND REF(距前高天YA,1)>REF(距前低天YA,1) AND LLV(L,距前高天YA+1)<REF(LLV(L,距前高天YA+1),1),-1,0);
低保留YXB:=IF(局部低点预选C=-1 AND REF(距前高天YA,1)<=REF(距前低天YA,1) AND (距前高天YA>=4 OR LLV(缺口判断,距前高天YA)=-1 OR 判断YXA=-1),-1,0);
低保留YX:=IF((低保留YXA=-1 OR 低保留YXB=-1) AND L<REF(H,距前高天YA+1),-1,0);
AAAD:=IF(高保留YX=1 AND 低保留YX=-1 AND H>REF(H,REF(距前高天YA,1)+2),1,IF(高保留YX=1 AND 低保留YX=-1 AND L<REF(L,REF(距前低天YA,1)+2),-1,0));
极点保留:=IF(AAAD=0,高保留YX+低保留YX,AAAD);
NNH:=BARSLAST(H=HHV(H,7)) ,NODRAW;
NNL:=BARSLAST(L=LLV(L,7)) ,NODRAW;
PD:=REF(G,NNH)>REF(D,NNH) ,NODRAW;
NN:=IF(REF(G,NNH)>REF(D,NNH) AND NNH<=4,NNH,IF(REF(G,NNL)<REF(D,NNL) AND NNL<=4,NNL,5)) ,NODRAW;
N:=IF(ISLASTBAR AND NN>0,NN,5) ,NODRAW;
FG01:=BACKSET(HH,N+1)>BACKSET(HH,N),NODRAW;//只设置前面第6个
FD01:=BACKSET(LL,N+1)>BACKSET(LL,N) ,NODRAW;
FG02:=FG01=FD01 AND G>D,NODRAW;
FD02:=FG01=FD01 AND G<D,NODRAW;
//高底是同一K看均线位置//
FG001:=IF(BARSLAST(FD01)>BARSLAST(FG01),FG01,0),NODRAW;
//高点处
FD001:=IF(BARSLAST(FG001)=0 AND BARSLAST(FG01)=BARSLAST(FD01) AND D>G,FD01,NULL);
FD003:=IF(BARSLAST(FG001)=0 AND BARSLAST(FG01)>BARSLAST(FD01),FD01,0),NODRAW;
TTTT:=BARSLAST(FD01),NODRAW;
FG0:=FG01 AND H=HHV(H,IF(FG02=1,BARSLAST(REF(FD01,1))+1,BARSLAST(FD01))) AND FD02=0 ,NODRAW;
FD0:=FD01 AND L=LLV(L,IF(FD02=1,BARSLAST(REF(FG01,1))+1,BARSLAST(FG01))) AND FG02=0 ,NODRAW;
FG00:=FG01 AND IF(FG02=1,H=HHV(H,BARSLAST(REF(FD01,1))+1),H=HHV(H,IF(BARSLAST(L=LLV(L,7))>=5,5,BARSLAST(FD01)))) AND FD02=0 ,NODRAW;
FD00:=FD01 AND IF(FD02=1,L=LLV(L,BARSLAST(REF(FG01,1))+1),L=LLV(L,IF(BARSLAST(H=HHV(L,7))>=5,5,BARSLAST(FG01)))) AND FG02=0 ,NODRAW;
//高低点间周期
GT:=BARSLAST(FG00),NODRAW;
DT:=BARSLAST(FD00),NODRAW;
//第一次处理高低点间多余的点
LLLL:=DT=0 AND REF(DT,1)<GT AND L>REF(L,REF(DT,1)+1),NODRAW;
FG1:=BACKSET(REFX(GT,1)=0 AND GT<DT AND REFX(H,1)>=REF(H,GT),GT+1),NODRAW;
FD1:=BACKSET(REFX(DT,1)=0 AND DT<GT AND REFX(L,1)<=REF(L,DT),DT+1),NODRAW;
FG11:=IF(GT=0 AND REF(GT,1)<DT AND IF(REF(G,BARSLAST(L=LLV(L,7)))>REF(D,BARSLAST(L=LLV(L,7))),BARSLAST(L=LLV(L,7))<5,1) AND H<REF(H,REF(GT,1)+1),1,0),NODRAW;
FD11:=IF(DT=0 AND REF(DT,1)<GT AND IF(REF(G,BARSLAST(H=HHV(H,7)))<REF(D,BARSLAST(H=HHV(H,7))),BARSLAST(H=HHV(H,7))<5,1) AND L>REF(L,REF(DT,1)+1),1,0),NODRAW;
//再次周期
GT1:=BARSLAST(FG11<>1 AND FG1<>1 AND FG0),NODRAW;
DT1:=BARSLAST(FD11<>1 AND FD1<>1 AND FD0),NODRAW;
GGT1:=REF(GT1,1),NODRAW;//处理两边都少于3根的笔
HHHH:=REF(H,GT1),NODRAW;
HHHHH:=HHV(H,GT1+5),NODRAW;
FD2:=BACKSET(REFX(GT1,1)=0 AND DT1<3 AND GT1-DT1<4 AND REF(L,DT1)>LLV(L,GT1+5),DT1+1),NODRAW;
//加两句,低是最低,去两边;
NL:=GT1=0 AND DT1<4 AND REF(GT1,1)-DT1<4 ,NODRAW;
LLLLLLLL:=LLV(L,GT1+5),NODRAW;
FG2A:=BACKSET(REFX(GT1,1)=0 AND DT1<3 AND GT1-DT1<4 AND REF(L,DT1)<=LLV(L,GT1+5) AND REF(H,GT1)>HHV(H,GT1+5),GT1+1),NODRAW;
FG2B:=IF(GT1=0 AND DT1<4 AND REF(GT1,1)-DT1<4 AND REF(L,DT1)<=LLV(L,REF(GT1,1)+6) AND H>HHV(H,REF(GT1,1)+6),1,0),NODRAW;
FG2:=BACKSET(REFX(DT1,1)=0 AND GT1<3 AND DT1-GT1<4 AND REF(H,GT1)<HHV(H,DT1+5),GT1+1),NODRAW;
FD2A:=BACKSET(REFX(DT1,1)=0 AND GT1<3 AND DT1-GT1<4 AND REF(H,GT1)>=HHV(L,DT1+5) AND REF(L,DT1)>LLV(L,DT1+5),DT1+1),NODRAW;
FD2B:=IF(DT1=0 AND GT1<4 AND REF(DT1,1)-GT1<4 AND REF(H,GT1)>=HHV(H,REF(DT1,1)+6) AND L>LLV(L,REF(DT1,1)+6),1,0),NODRAW;//
GGG:=IF(HHV(H,GT1+1)<HHV(H,GT1+15),HHV(H,GT1+1),NULL),NODRAW;
DDD:=IF(HHV(H,GT1+1)<HHV(H,GT1+15),HHV(H,GT1+15),NULL),NODRAW;
//处理单边都少于3根的笔
GT11:=BARSLAST(GT1=0 AND FG2<>1),NODRAW;
DT11:=BARSLAST(DT1=0 AND FD2<>1 AND FD02<>1),NODRAW;
//FG21:IF(GT1=0 AND DT1<4 AND H<HHV(H,REF(GT1,1)+3),1,0),NODRAW;
//FD21:IF(DT1=0 AND GT1<4 AND L>LLV(L,REF(DT1,1)+3) ,1,0),NODRAW;
FD22:=BACKSET(REFX(GT1,1)=0 AND DT1<3 AND REFX(H,1)>REF(H,GT1) AND REF(L,DT1)>LLV(L,GT1+5),DT1+1),NODRAW;
G22:=BACKSET(REFX(DT1,1)=0 AND GT1<3 AND REFX(L,1)<REF(L,DT1) AND REF(H,GT1)<HHV(H,DT1+5),GT1+1),NODRAW;
TTTTTT:=H<REF(H,REF(GT1,1)+1) AND DT1<4,NODRAW;
HHHHHH:=REF(LLV(L,10),DT1),NODRAW;//前长后短;
//FG21:IF(GT1=0 AND DT1<4 AND H<=REF(H,REF(GT1,1)+1) ,1,0),NODRAW;
//FD21:IF(DT1=0 AND GT1<4 AND L>=REF(L,REF(DT1,1)+1) ,1,0),NODRAW;
//前短后长,前低后高(去低);
FD231:=BACKSET(REFX(GT1,1)=0 AND DT1>3 AND GT1>DT1 AND GT1-DT1<4 AND REFX(H,1)>REF(H,GT1) AND REF(L,DT1)>REF(LLV(L,10),DT1),DT1+1),NODRAW;
FG23:=BACKSET(REFX(GT1,1)=0 AND DT1>3 AND GT1>DT1 AND GT1-DT1<4 AND REFX(H,1)>REF(H,GT1) AND (REF(H,GT1)<REF(HHV(H,13),GT1) OR REF(FD231,DT1)=0),GT1+1),NODRAW;
//前短后长,前高后低(去高);
NNN:=REF(H,GT1)>=REF(HHV(H,8),GT1),NODRAW;
//前短后长,去2;
FG231:=BACKSET(REFX(DT1,1)=0 AND GT1>3 AND DT1>GT1 AND DT1-GT1<4 AND REFX(L,1)<REF(L,DT1) AND REF(H,GT1)<REF(HHV(H,10),GT1) ,GT1+1),NODRAW;
FD23:=BACKSET(REFX(DT1,1)=0 AND GT1>3 AND DT1>GT1 AND DT1-GT1<4 AND REFX(L,1)<REF(L,DT1) AND ( REF(L,DT1)>REF(LLV(L,13),DT1) OR REF(FG231,GT1)=0),DT1+1),NODRAW;///前短后长,去3;
FDD23:=REF(H,GT1)<REF(HHV(H,10),GT1) OR REF(FD23,DT1)=0,NODRAW;
FD24:=BACKSET(REFX(GT1,1)=0 AND DT1>3 AND GT1>DT1 AND GT1-DT1<4 AND REFX(H,1)<HHV(H,GT1+3) AND REF(L,DT1)>LLV(L,DT1+5),DT1+1),NODRAW;
FG24:=BACKSET(REFX(DT1,1)=0 AND GT1>3 AND DT1>GT1 AND DT1-GT1<4 AND REFX(L,1)>LLV(L,DT1+3) AND REF(H,GT1)<HHV(H,GT1+5),GT1+1),NODRAW;
FG241:=IF(GT1=0 AND DT1>4 AND REF(GT1,1)-DT1<3 AND H<HHV(H,REF(GT1,1)+3) AND REF(FD24,DT1+2)<>1,1,0),NODRAW;
FD241:=IF(DT1=0 AND GT1>4 AND REF(DT1,1)-GT1<3 AND L>LLV(L,REF(DT1,1)+3) AND REF(FG24,GT1+2)<>1,1,0),NODRAW;
FGE:=BACKSET(ISLASTBAR AND DT1-GT1<3 AND DT1>GT1, GT1+1),NODRAW;//FDE:BACKSET(ISLASTBAR AND GT1-DT1<3 AND GT1>DT1, DT1+1),NODRAW;
FG21:=IF(GT1=0 AND DT1<4 AND REF(GT1,1)<4,1,0),NODRAW;
FD21:=IF(DT1=0 AND GT1<4 AND REF(DT1,1)<4 ,1,0),NODRAW;
//做两次高低点间多余的点
GT2:=BARSLAST(FG21<>1 AND FG23<>1 AND FG231<>1 AND FG24<>1 AND FG2<>1 AND FG2A<>1 AND FG2B<>1 AND GT1=0),NODRAW;
DT2:=BARSLAST(FD21<>1 AND FD23<>1 AND FD231<>1 AND FD24<>1 AND FD2<>1 AND FD2A<>1 AND FD2B<>1 AND DT1=0),NODRAW;
FG3:=BACKSET(REFX(GT2,1)=0 AND GT2<DT2 AND REFX(H,1)>=REF(H,GT2),GT2+1),NODRAW;
//HHX:REF(H,GT2),NODRAW;
FD3:=BACKSET(REFX(DT2,1)=0 AND DT2<GT2 AND REFX(L,1)<=REF(L,DT2),DT2+1),NODRAW;
FG31:=IF(GT2=0 AND REF(GT2,1)<DT2 AND H<REF(H,REF(GT2,1)+1),1,0),NODRAW;
FD31:=IF(DT2=0 AND REF(DT2,1)<GT2 AND L>REF(L,REF(DT2,1)+1),1,0),NODRAW;
GT3:=BARSLAST(GT2=0 AND FG3<>1 AND FG31<>1 ),NODRAW;
DT3:=BARSLAST(DT2=0 AND FD3<>1 AND FD31<>1),NODRAW;
FG4:=BACKSET(REFX(GT3,1)=0 AND GT3<DT3 AND REFX(H,1)>=REF(H,GT3),GT3+1),NODRAW;
FD4:=BACKSET(REFX(DT3,1)=0 AND DT3<GT3 AND REFX(L,1)<=REF(L,DT3),DT3+1),NODRAW;
FG41:=IF(GT3=0 AND REF(GT3,1)<DT3 AND H<REF(H,REF(GT3,1)+1),1,0),NODRAW;
FD41:=IF(DT3=0 AND REF(DT3,1)<GT3 AND L>REF(L,REF(DT3,1)+1),1,0),NODRAW;
LLL:=DT3=0 AND FD31<>1 AND FD3<>1,NODRAW;
HHH:=FG0 AND FG11<>1 AND FG1<>1 AND FG2<>1 AND FG21<>1 AND FG31<>1 AND FG3<>1;
PARTLINE(FG0 AND FG41<>1 AND FG4<>1 AND FG31<>1 AND FG3<>1 AND FG2<>1 AND FG11<>1 AND FG1<>1,H,COLORYELLOW),CIRCLEDOT,LINETHICK5;
PARTLINE(FD0 AND FD41<>1 AND FD4<>1 AND FD31<>1 AND FD3<>1 AND FD2<>1 AND FD11<>1 AND FD1<>1,L,COLORYELLOW),CIRCLEDOT,LINETHICK5;
//PARTLINE(FD01 ,L,COLORRED),CIRCLEDOT,LINETHICK2;
//PARTLINE(FG0 ,H,COLORYELLOW),POINTDOT,LINETHICK2;
//PARTLINE(FD0 ,L,COLORCYAN),CIRCLEDOT,LINETHICK2;
BD:=IF(FD0 AND FD41<>1 AND FD4<>1 AND FD31<>1 AND FD3<>1 AND FD2<>1 AND FD11<>1 AND FD1<>1,L,0);
笔低:=IF(BD<>0,BD,NULL),COLORYELLOW,NODRAW;
BG:=IF(FG0 AND FG41<>1 AND FG4<>1 AND FG31<>1 AND FG3<>1 AND FG2<>1 AND FG11<>1 AND FG1<>1,H,0);
笔高:IF(BG<>0,BG,NULL),COLORYELLOW,NODRAW;
老笔:=1;
GB:=MA(C,5);
DB:=MA(C,10);
HHB:=REF(H,5)=HHV(H,11);
FGB01:=BACKSET(HHB,6)>BACKSET(HHB,5) ;
FDB01:=BACKSET(LL1,6)>BACKSET(LL1,5) ;
FGB02:=IF(BARSLAST(FGB01)=BARSLAST(FDB01) AND GB>DB,FGB01,IF(BARSLAST(FDB01)>BARSLAST(FGB01),FGB01,0));
FDB02:=IF(BARSLAST(FGB01)=BARSLAST(FDB01) AND DB>GB,FDB01,IF(BARSLAST(FGB01)>BARSLAST(FDB01),FDB01,0));
FGB0:=FGB02 AND H=HHV(H,BARSLAST(FDB02));
FDB0:=FDB02 AND L=LLV(L,BARSLAST(FGB02));
JG:=IF(FGB0 AND BG=0,H,1) ;
局高:=IF(JG<>1,JG,NULL),COLORGREEN,NODRAW;
JD:=IF(FDB0 AND BD=0,L,-1),COLORGREEN;
局低:IF(JD<>-1,JD,NULL),COLORGREEN,NODRAW;
短极点:IF(PERIOD>2,IF(极点保留=-1 AND BD=0 AND JD=-1,L,IF(极点保留=1 AND BG=0 AND JG=1,H,NULL)) ,NULL),COLORMAGENTA,NODRAW;
//中枢分割线
HIGH1:=REF(HHV(H,90),3);//3周期前的90周期的最高价
LOW1:=REF(LLV(L,90),3);//3周期前的90周期的最低价
J1:=HIGH1-(HIGH1-LOW1)*0.191;
J0:=HIGH1-(HIGH1-J1)/2;
J2:=HIGH1-(HIGH1-LOW1)*0.382;
J3:=HIGH1-(HIGH1-LOW1)*0.5;
J4:=HIGH1-(HIGH1-LOW1)*0.618;
J5:=HIGH1-(HIGH1-LOW1)*0.809;
J6:=HIGH1-(HIGH1-LOW1)*1.191;
JZ:=J0-(J0-LOW1)/2;
HIGHB1:=REF(HHV(H,60),3);
LOW2:=REF(LLV(L,60),3);
HIGHB2:=IF(HIGHB1<=J4,J4,IF(HIGHB1<=J3,J3-(J3-J4)/2,IF(HIGHB1<=J2,J2-(J2-J3)/2,IF(HIGHB1<=J1,J1-(J1-J2)/2,IF(HIGHB1<=HIGH1 ,HIGH1-(HIGH1-J1)/2,NULL)))));
HIGH2:=IF(HIGHB1<HIGHB2,HIGHB2,IF(HIGHB1>=HIGHB2 AND C<HIGHB2,HIGHB2,HIGHB1-(HIGHB1-HIGHB2)/2));
J22:=HIGH2+(HIGH2-LOW2)*0.191;
J12:=HIGH2-(HIGH2-LOW2)*0.191;
J42:=HIGH2-(HIGH2-LOW2)*0.618;
JZ2:=HIGH2-(HIGH2-J42)/2;
J52:=HIGH2-(HIGH2-LOW2)*0.809;
J02:=J52;
CL:=1;
AD:=REFX1(DATE<=200601,9999);//指标到期日
YYD:=HHV(H,60),COLORWHITE;
空损:=IF( HJ=2,MA(YYD,5),NULL),COLORGREEN,DOT;
YY3:=HHV(H,60)-(HHV(H,60)-LLV(L,30))*0.191,COLORGRAY;
做空:=IF( HJ=2,MA(YY3,5),NULL),COLORYELLOW;
YYC3:=HHV(H,30)-(HHV(H,30)-LLV(L,30))*0.382,COLORLIGHTGREY;
强:=IF( HJ=2,MA(YYC3,5),NULL),COLORLIGHTGREY;
YYC3CD:=HHV(H,30)-(HHV(H,30)-LLV(L,30))*0.618,COLORGREEN;
弱:=MA(YYC3CD,5),COLORGREEN;
YYC3D:=HHV(H,30)-(HHV(H,30)-LLV(L,30))*0.809,COLORRED;
做多:=IF( HJ=2,MA(YYC3D,5),NULL),COLORRED;
ZZ:=LLV(L,30);
多损:=IF( HJ=2,MA(ZZ,5),NULL),COLORGREEN,DOT;
/*DRAWTEXT(ISLASTBAR,做空,'空'),COLORCYAN,FONTSIZE16,ALIGN0;
DRAWTEXT(ISLASTBAR,强,'强'),COLORLIGHTGREY,FONTSIZE16,ALIGN0;
DRAWTEXT(ISLASTBAR,做多,'多'),COLORRED,FONTSIZE16,ALIGN0;
DRAWTEXT(ISLASTBAR,空损,'损'),COLORGREEN,FONTSIZE16,ALIGN0,NOTEXT;
DRAWTEXT(ISLASTBAR,多损,'损'),COLORGREEN,FONTSIZE16,ALIGN0,NOTEXT;
*/
DRAWSL(ISLASTBAR,空损,0,1,3,COLORGREEN),LINETHICK3;
DRAWSL(ISLASTBAR,多损,0,1,3,COLORGREEN),LINETHICK3;
NC:=8;
KKC:=0;
TYP := IF(PERIOD>7&&AD,(HIGH + LOW + CLOSE)/3,NULL);
CCI1:=(TYP-MA(TYP,6))/(0.015*AVEDEV(TYP,6));
CCI2:=(TYP-MA(TYP,10))/(0.015*AVEDEV(TYP,10));
CCI3:=(TYP-MA(TYP,20))/(0.015*AVEDEV(TYP,20));
CCI4:=(TYP-MA(TYP,30))/(0.015*AVEDEV(TYP,30));
CCI5:=(TYP-MA(TYP,60))/(0.015*AVEDEV(TYP,60));
CCI:=CCI1+CCI2+CCI3+CCI4+CCI5;
AAAB:=IF(PERIOD>2&&AD,(3*C+H+L+O)/6,NULL);
VVAR1:=(8*AAAB+7*REF(AAAB,1)+6*REF(AAAB,2)+5*REF(AAAB,3)+4*REF(AAAB,4)+3*REF(AAAB,5)+2*REF(AAAB,6)+REF(AAAB,8))/36;
VVAR6:=(LLV(VVAR1,2)+LLV(VVAR1,4)+LLV(VVAR1,6))/3;
短线:=IF(X=1 , QZS,NULL),COLORCYAN,LINETHICK1;
强线:=IF( X=1 , VVAR1, NULL),COLORWHITE,LINETHICK1;
中线:=IF( X=1 ,VVAR6, NULL),COLORLIGHTGREEN,LINETHICK2;
FILLRGN1(短线>强线 ,短线,强线),RGB(150,10,50);
FILLRGN1( 短线<强线,短线,强线),RGB(10,100,10);
//未来函数预测波段顶底,通用程序
DRAWTEXT(PERIOD>=8 AND ISLASTBAR<>1 AND TROUGHBARS(L,20,1,1)=0 AND CL<3,L-6*M*MINPRICE,'底'),COLORYELLOW,FONTSIZE26;
DRAWTEXT(PERIOD>=8 AND ISLASTBAR<>1 AND PEAKBARS(H,20,1,1)=0 AND CL<3,H+6*M*MINPRICE,'顶'),COLORMAGENTA,FONTSIZE26;
DDMS:=IF(PERIOD>=8 AND ISLASTBAR<>1 AND TROUGHBARS(L,20,1,1)=0,1,0);
DMS:=IF(PERIOD>=8 AND ISLASTBAR<>1 AND PEAKBARS(H,20,1,1)=0,1,0);
DRAWTEXT(ISLASTBAR<>1 AND TROUGHBARS(L,8,1,1)=0 AND DDMS<>1 AND CL<3,L-7*M*MINPRICE,'小底'),COLORLIGHTGREY,FONTSIZE16,VALIGN0;
DRAWTEXT(ISLASTBAR<>1 AND PEAKBARS(H,8,1,1)=0 AND DMS<>1 AND CL<3,H+7*M*MINPRICE,'小底'),COLORLIGHTGREY,FONTSIZE16;
DTS:=IF(ISLASTBAR<>1 AND PEAKBARS(H,8,1,1)=0,1,0);
JDTS:=IF(ISLASTBAR<>1 AND TROUGHBARS(L,8,1,1)=0,1,0),COLORWHITE;
DRAWTEXT((PERIOD<=13 AND ZIGZAG(C,3,1)<REF(ZIGZAG(C,3,1),1)) AND (REF(ZIGZAG(C,3,1),1)>=REF(ZIGZAG(C,3,1),2)) AND REF(ZIGZAG(C,3,1),2)>=REF(ZIGZAG(C,3,1),3) AND DTS<>1 AND CL<3,HIGH+5*M*MINPRICE,'小顶'),COLORCYAN,FONTSIZE16;
DRAWTEXT((PERIOD<=13 AND ZIGZAG(C,3,1)>REF(ZIGZAG(C,3,1),1)) AND (REF(ZIGZAG(C,3,1),1)<=REF(ZIGZAG(C,3,1),2)) AND (REF(ZIGZAG(C,3,1),2)<=REF(ZIGZAG(C,3,1),3)) AND JDTS<>1 AND CL<3,LOW-5*M*MINPRICE,'小底'),COLORWHITE,FONTSIZE16,VALIGN0;
XZDZ:=IF((PERIOD<=13 AND ZIGZAG(C,3,1)>REF(ZIGZAG(C,3,1),1)) AND (REF(ZIGZAG(C,3,1),1)<=REF(ZIGZAG(C,3,1),2)) AND (REF(ZIGZAG(C,3,1),2)<=REF(ZIGZAG(C,3,1),3)) AND JDTS<>1,1,0);
XZDD:=IF((PERIOD<=13 AND ZIGZAG(C,3,1)<REF(ZIGZAG(C,3,1),1)) AND (REF(ZIGZAG(C,3,1),1)>=REF(ZIGZAG(C,3,1),2)) AND REF(ZIGZAG(C,3,1),2)>=REF(ZIGZAG(C,3,1),3) AND DTS<>1,1,0);
DRAWTEXT(ISLASTBAR<>1 AND PEAKBARS(H,3,1,1)=0 AND XZDD<>1 AND DMS<>1 AND DTS<>1 AND CL<3,HIGH+4*M*MINPRICE,'小顶'),COLORGREEN,FONTSIZE16;
DRAWTEXT(ISLASTBAR<>1 AND TROUGHBARS(L,3,1,1)=0 AND XZDZ<>1 AND DDMS<>1 AND JDTS<>1 AND CL<3,LOW-4*M*MINPRICE,'小底'),COLORRED,FONTSIZE16,VALIGN0;
TY:=(CLOSE+HIGH+LOW)/3;
CCIB:=(TY-MA(TY,14))/(0.015*AVEDEV(TY,14));
YY:=IF(BG<>0 AND CCIB<100 AND CCIB>0,1,0);
DRAWTEXT(YY=1 AND XZDD<>1,H+3*M*MINPRICE,'●');
P:=2;
MID:=MA(C,20);
UPPER:= MID+P*STD(C,20);
LOWER:= MID - P*STD(C,20);
AT:=MA(C,20),COLORBLUE;
通道限宽:=(C-LOWER)/(UPPER-LOWER),COLORRED;
通道极限:=100*(C-AT)/STD(C,26),COLORWHITE;
通道趋势:=EMA(通道极限,3),COLORMAGENTA;
DRAWTEXT(BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限>-100 AND XZDZ<>1,L-1*M*MINPRICE,'●'),COLORWHITE,VALIGN0;
GLQD2:=IF(BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限>-100,1,0);
DRAWTEXT(GLQD2<>1 AND BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限>-170 AND XZDZ<>1,L-2*M*MINPRICE,'●'),COLORMAGENTA,VALIGN0;
XJ:=IF(BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限<-170,LLV(L,60),0);
//DRAWTEXT(BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限<-170 AND JDTS<>1 AND L<XJ,L,'※'),COLORRED;
DRAWTEXT(BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限<-170 AND L>=XJ AND JDTS<>1 AND XZDZ<>1,L-3*M*MINPRICE,'●'),COLORYELLOW,VALIGN0;
XJGL:=IF(BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限<-170 AND L>=XJ AND JDTS<>1 AND XZDZ<>1,1,0);
DRAWTEXT(((BD<>0 AND FDB0=1) OR (BD<>0 AND 极点保留=-1)) AND CCIB<0 AND CCIB>-100 AND 通道极限<0 AND 通道极限>-100 AND JDTS<>1 AND XJGL<>1 ,L-2*M*MINPRICE,'●'),COLORCYAN,VALIGN0;
XX1:=IF(BD<>0 AND CCIB>0 OR 通道极限>0,1,NULL);
DRAWTEXT(XX1=1 AND BD<>0,L-1*M*MINPRICE,'●'),VALIGN0;
ZDG1:=REF(HHV(H,5),8) ,NODRAW;
ZDG2:=REF(HHV(H,5),16) ,NODRAW;
ZDG3:=REF(HHV(H,5),24) ,NODRAW;
ZDG4:=REF(HHV(H,5),32) ,NODRAW;
ZDG5:=REF(HHV(H,5),40) ,NODRAW;
ZDG6:=REF(HHV(H,5),48) ,NODRAW;
ZDG7:=REF(HHV(H,5),56) ,NODRAW;
DPD:=IF(BG<>0 AND FGB0=1 AND H<=ZDG1 ,1,0);
PD1:=IF(BG<>0 AND FGB0=1 AND H<=ZDG2,DPD+1,DPD);
PD2:=IF(BG<>0 AND FGB0=1 AND H<=ZDG3,PD1+1,PD1);
PD3:=IF(BG<>0 AND FGB0=1 AND H<=ZDG4,PD2+1,PD2);
PD4:=IF(BG<>0 AND FGB0=1 AND H<=ZDG5,PD3+1,PD3);
PD5:=IF(BG<>0 AND FGB0=1 AND H<=ZDG6,PD4+1,PD4);
PD6:=IF(BG<>0 AND FGB0=1 AND H<=ZDG7,PD5+1,PD5);
背离次数:=PD6,NODRAW;
GLQD:=IF(BG<>0 AND FGB0=1 AND 极点保留=1 AND CCIB>100 AND 通道极限<170,1,0);
GLQD1:=IF(BG<>0 AND FGB0=1 AND 极点保留=1 AND CCIB>100 AND 通道极限>170 AND DTS<>1,1,0);
DRAWTEXT(GLQD<>1 AND GLQD1<>1 AND YY<>1 AND ( PD6>=4) AND ((CCIB>100 AND 通道极限>170) OR (CCIB<100 AND 通道极限<170 )) ,H+2*M*MINPRICE,'起跌'),COLORGREEN;
DRAWTEXT(BG<>0 AND FGB0=1 AND 极点保留=1 AND CCIB>100 AND 通道极限<170 AND XZDD<>1,H+2*M*MINPRICE,'超买跌'),COLORCYAN;
DRAWTEXT(BG<>0 AND FGB0=1 AND 极点保留=1 AND CCIB>100 AND 通道极限>170 AND DTS<>1 AND XZDD<>1,H+2*M*MINPRICE,'超买跌'),COLORCYAN;
CMGL:=IF(BG<>0 AND FGB0=1 AND 极点保留=1 AND CCIB>100 AND 通道极限<170 AND XZDD<>1,1,0);
CMGL1:=IF(BG<>0 AND FGB0=1 AND 极点保留=1 AND CCIB>100 AND 通道极限>170 AND DTS<>1 AND XZDD<>1,1,0);
DRAWTEXT(((BG<>0 AND FGB0=1) OR (FGB0=1 AND 极点保留=1) OR (BG<>0 AND 极点保留=1) OR FGB0=1) AND CCIB>100 AND 通道极限>100 AND DTS<>1 AND XZDD<>1 AND CMGL<>1 AND CMGL1<>1,H+1*M*MINPRICE,'●'),COLORCYAN;
JS:=IF(ISLASTBAR=1,1,0);
//价格上涨彩色K(趋势)多增红多减绿,通用程序
NNC:=BARSLAST(DATE<>REF(DATE,1))+1;
仓1:=OPI-REF(OPI,NNC);
VARL:=VOL/((HIGH-LOW)*2-ABS(CLOSE-OPEN));
成交:VOL,COLORMAGENTA,NODRAW;
持仓量:OPI,NODRAW;
主动买盘:=IF(CLOSE>OPEN,VARL*(HIGH-LOW),IF(CLOSE<OPEN,VARL*((HIGH-OPEN)+(CLOSE-LOW)),VOL/2)),COLORRED,NODRAW;
主动卖盘:=IF(CLOSE>OPEN,VARL*((HIGH-CLOSE)+(OPEN-LOW)),IF(CLOSE<OPEN,VARL*(HIGH-LOW),VOL/2)),COLORCYAN,NODRAW;
DRAWTEXT(ISLASTBAR=1 AND 通道极限>170 ,L,'※'),COLORYELLOW,FONTSIZE16,VALIGN0;
DRAWTEXT(ISLASTBAR=1 AND 通道极限<-170 ,H,'超卖'),COLORYELLOW,FONTSIZE16;
DRAWKLINE1(H,O,L,C);
PERIOD<>3&&CL<2||YY=1 AND XZDD<>1||BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限>-100 AND XZDZ<>1,SOUND('A');
GLQD2<>1 AND BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限>-170 AND XZDZ<>1||BD<>0 AND FDB0=1 AND 极点保留=-1 AND CCIB<-100 AND 通道极限<-170 AND L>=XJ AND JDTS<>1 AND XZDZ<>1,SOUND('A');
((BD<>0 AND FDB0=1) OR (BD<>0 AND 极点保留=-1)) AND CCIB<0 AND CCIB>-100 AND 通道极限<0 AND 通道极限>-100 AND JDTS<>1 AND XJGL<>1||XX1=1 AND BD<>0,SOUND('A');
GLQD<>1 AND GLQD1<>1 AND YY<>1 AND ( PD6>=4) AND ((CCIB>100 AND 通道极限>170) OR (CCIB<100 AND 通道极限<170 )),SOUND('A');
BG<>0 AND FGB0=1 AND 极点保留=1 AND CCIB>100 AND 通道极限<170 AND XZDD<>1,SOUND('A');
BG<>0 AND FGB0=1 AND 极点保留=1 AND CCIB>100 AND 通道极限>170 AND DTS<>1 AND XZDD<>1,SOUND('A');
((BG<>0 AND FGB0=1) OR (FGB0=1 AND 极点保留=1) OR (BG<>0 AND 极点保留=1) OR FGB0=1) AND CCIB>100 AND 通道极限>100 AND DTS<>1 AND XZDD<>1 AND CMGL<>1 AND CMGL1<>1,SOUND('A');
通道极限>170||通道极限<-170,SOUND('A');