답변완료
파라볼릭 쓰리바닥 쓰리봉 분리
Input : af(0.02), maxAF(0.2),상(1),하(1);
Var : Sarv(0),tl(0),T(0);
Sarv = sar(af,maxAF);
If crossup(c,Sarv) Then
{
T = 1;
var1 = Sarv;
Var2 = var1[1];
Var3 = var2[1];
Condition1 = False;
if var1 <= var2+PriceScale*상 and var1 >= var2-PriceScale*하 and
var2 <= var3+PriceScale*상 and var2 >= var3-PriceScale*하 and var3 > 0 Then
{
Condition1 = true;
TL = TL_New(sDate,sTime,0,sDate,sTime,99999999);
TL_SetColor(TL,Red);
TL_SetSize(TL,0.5);
}
}
if CrossDown(C,sarv) Then
{
T = -1;
value1 = Sarv;
value2 = value1[1];
value3 = value2[1];
Condition2 = False;
if value1 <= value2+PriceScale*상 and value1 >= value2-PriceScale*하 and
value2 <= value3+PriceScale*상 and value2 >= value3-PriceScale*하 and value3 > 0 Then
{
Condition2 = true;
TL = TL_New(sDate,sTime,0,sDate,sTime,99999999);
TL_SetColor(TL,Blue);
TL_SetSize(TL,0.5);
}
}
Else
{
if T == 1 Then
{
if sarv < var1 Then
{
var1 = sarv;
if Condition1 == False and var1 <= var2+PriceScale*상 and var1 >= var2-PriceScale*하 and
var2 <= var3+PriceScale*상 and var2 >= var3-PriceScale*하 and var3 > 0 Then
{
Condition1 = true;
TL = TL_New(sDate,sTime,0,sDate,sTime,99999999);
TL_SetColor(TL,Red);
TL_SetSize(TL,0.5);
}
}
}
if T == -1 Then
{
if sarv > value1 Then
{
value1 = sarv;
if Condition2 == False and value1 <= value2+PriceScale*상 and value1 >= value2-PriceScale*하 and
value2 <= value3+PriceScale*상 and value2 >= value3-PriceScale*하 and value3 > 0 Then
{
Condition2 = true;
TL = TL_New(sDate,sTime,0,sDate,sTime,99999999);
TL_SetColor(TL,Blue);
TL_SetSize(TL,0.5);
}
}
}
}
쓰리바닥과 쓰리봉을 각기 다른 두개의 수식으로 분리. 감사합니다.
2022-11-07
749
글번호 163574
지표
답변완료
수식부탁드립니다^^) 볼밴인데 색으로도 표현하고싶습니다
1밴드상단(일목균형표)
(
avg((C+H+L)/3,20)+2*stdev((C+H+L)/3,20)+
avg((C+H+L)/3,33)+2*stdev((C+H+L)/3,33)+
avg((C+H+L)/3,40)+2*stdev((C+H+L)/3,40)+
avg((C+H+L)/3,73)+2*stdev((C+H+L)/3,73)
)/4
밴드 하단
(
avg((C+H+L)/3,20) - 2*stdev((C+H+L)/3,20)+
avg((C+H+L)/3,33) - 2*stdev((C+H+L)/3,33)+
avg((C+H+L)/3,40) - 2*stdev((C+H+L)/3,40)+
avg((C+H+L)/3,73) - 2*stdev((C+H+L)/3,73)
상단저항
Max(
avg((C+H+L)/3,20)+2*stdev((C+H+L)/3,20),
avg((C+H+L)/3,33)+2*stdev((C+H+L)/3,33),
avg((C+H+L)/3,40)+2*stdev((C+H+L)/3,40),
avg((C+H+L)/3,73)+2*stdev((C+H+L)/3,73)
)
상단지지
Min(
avg((C+H+L)/3,20)+2*stdev((C+H+L)/3,20),
avg((C+H+L)/3,33)+2*stdev((C+H+L)/3,33),
avg((C+H+L)/3,40)+2*stdev((C+H+L)/3,40),
avg((C+H+L)/3,73)+2*stdev((C+H+L)/3,73)
)
)/4
조건
Period 20
D1 2
2밴드하단 (일목균형표)
하단 저항
Max(
avg((C+H+L)/3,20)-2*stdev((C+H+L)/3,20),
avg((C+H+L)/3,33)-2*stdev((C+H+L)/3,33),
avg((C+H+L)/3,40)-2*stdev((C+H+L)/3,40),
avg((C+H+L)/3,73)-2*stdev((C+H+L)/3,73)
)
하단지지
Min(
avg((C+H+L)/3,20)-2*stdev((C+H+L)/3,20),
avg((C+H+L)/3,33)-2*stdev((C+H+L)/3,33),
avg((C+H+L)/3,40)-2*stdev((C+H+L)/3,40),
avg((C+H+L)/3,73)-2*stdev((C+H+L)/3,73)
)
조건
Period 20
D1 2
2022-11-06
995
글번호 163558
지표
답변완료
추세선 실시간
input : Period(10),선두께(1),pt(0.35);
Var:상승색(Red), 하락색(Blue);
Var:j(0),T(0);
Var: date11(0),date12(0),time11(0),time12(0),TL1(0),TL(0),
date21(0),date22(0),time21(0),time22(0),
date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0),tl4(0);
Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0);
Array:r[7](0),fr[7](0),TL2[7](0),TL3[7](0),TX2[7](0),TX3[7](0);
var : txx(0);
r[0] = 0;
r[1] = 2;
r[2] = 3.;
r[3] = -1;
r[4] = -2.;
r[5] = 1;
r[6] = 0.5;
For j = 0 To 19
{
HiBar[j] = HiBar[j] + 1;
LoBar[j] = LoBar[j] + 1;
}
if crossup(c,highest(H,Period)[1]) Then
T = 1;
if CrossDown(c,Lowest(L,Period)[1]) Then
T = -1;
If T == -1 Then
{
If T[1] != -1 Then
{
For j = 18 DownTo 0
{
LoVal[j+1] = LoVal[j];
LoBar[j+1] = LoBar[j];
}
LoVal[0] = L;
LoBar[0] = 0;
date11 = date[HiBar[0]];
time11 = stime[HiBar[0]];
Value11 = HiVal[0];
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
TL_Delete(tl);
TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen);
TL1 = TL_New(date11,time11,Value11,date12,time12,Value12);
TL_SetColor(TL1,하락색);
date21 = date[HiBar[0]];
time21 = stime[HiBar[0]];
date22 = date[0];
time22 = stime[0];
for j = 0 to 6
{
fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]);
}
Condition1 = False;
if max(LoVal[1],LoVal[2]) <= min(LoVal[1],LoVal[2])+pt Then
{
txx = Text_New(sdate[HiBar[0]],sTime[HiBar[0]],Hival[0],"●");
Text_SetColor(txx,Green);
Text_SetSize(txx,30);
Text_SetStyle(txx,2,1);
Condition1 = true;
}
}
If LoVal[0] > L Then
{
LoVal[0] = L;
LoBar[0] = 0;
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
TL_SetEnd(TL1, date12,time12,Value12);
date22 = date[0];
time22 = stime[0];
TL_SetEnd(TL2[0],date22,time22,fr[0]);
TL_SetEnd(TL2[1],date22,time22,fr[1]);
TL_SetEnd(TL2[2],date22,time22,fr[2]);
Text_SetLocation(TX2[2],date22,time22,fr[2]);
TL_SetEnd(TL2[3],date22,time22,fr[3]);
TL_SetEnd(TL2[4],date22,time22,fr[4]);
Text_SetLocation(TX2[4],date22,time22,fr[4]);
TL_SetEnd(TL2[5],date22,time22,fr[5]);
TL_SetEnd(TL2[6],date22,time22,fr[6]);
TL_Delete(tl);
TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen);
}
if Condition1 == true and LoVal[0] < max(LoVal[1],LoVal[2])-pt Then
{
Condition1 = False;
Text_Delete(txx);
}
}
If T == 1 Then
{
If T[1] != 1 Then
{
text_Delete(txx);
For j = 18 DownTo 0
{
HiVal[j+1] = HiVal[j];
HiBar[j+1] = HiBar[j];
}
HiVal[0] = H;
HiBar[0] = 0;
date11 = date[LoBar[0]];
time11 = stime[LoBar[0]];
Value11 = LoVal[0];
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
TL_Delete(tl);
TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen);
TL1 = TL_New(date11,time11,Value11,date12,time12,Value12);
TL_SetColor(TL1,상승색);
date31 = date[LoBar[0]];
time31 = stime[LoBar[0]];
date32 = date[0];
time32 = stime[0];
for j = 0 to 5
{
fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]);
}
}
If HiVal[0] < H Then
{
HiVal[0] = H;
HiBar[0] = 0;
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
TL_SetEnd(TL1, date12,time12,Value12);
date32 = date[0];
time32 = stime[0];
TL_SetEnd(TL3[0],date32,time32,fr[0]);
TL_SetEnd(TL3[1],date32,time32,fr[1]);
TL_SetEnd(TL3[2],date32,time32,fr[2]);
Text_SetLocation(TX3[2],date32,time32,fr[2]);
TL_SetEnd(TL3[3],date32,time32,fr[3]);
TL_SetEnd(TL3[4],date32,time32,fr[4]);
Text_SetLocation(TX3[4],date32,time32,fr[4]);
TL_SetEnd(TL3[5],date32,time32,fr[5]);
TL_SetEnd(TL3[6],date32,time32,fr[6]);
TL_Delete(tl);
TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen);
}
}
TL_SetSize(TL1,선두께);
79311에서 알려주신 수식을 여기에 일부 추가. 직전저점 깨지는지 실시간 보기위한 지표입니다.
1.추세선이 음전환되면 그 상단에 동그라미 표시.
2.동그라미 삭제시점.
a.직전저점을 안깨고 양전환되면 삭제.
b.직전저점 깨지면 직저 -1틱 도달시 삭제.(동그라미는 생성과 삭제 반복) 감사합니다.
2022-11-06
1230
글번호 163553
지표