예스스탁
예스스탁 답변
2020-06-01 15:23:27
안녕하세요
예스스탁입니다.
Input:length(12),r1(1.618),r2(2.0);;
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),
Text1(0),처리구분(""),tl2(0),tl3(0),tl4(0),tl5(0);
var : tx2(0),tx3(0),tx4(0),tx5(0);
var : tl41(0),tl51(0),tx41(0),tx51(0);
var : tl21(0),tl31(0),tx21(0),tx31(0);
Array:고점[10,2](0),저점[10,2](0); //가격,위치
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then
처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then
처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and
TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
TL_Delete(TL4);
TL_Delete(TL5);
TL_Delete(TL41);
TL_Delete(TL51);
Text_Delete(Text1);
Text_Delete(Tx4);
Text_Delete(Tx5);
Text_Delete(Tx41);
Text_Delete(Tx51);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],
sDate[eBar],sTime[eBar],고점[1,1]);
Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(고점[1,1],2)
+NewLine+"진폭"+NumToStr((고점[1,1]-저점[1,1]),2));
Text_SetStyle(Text1, 2, 1);
var2 = abs(고점[2,1]-저점[1,1]);
TL4 = TL_New(sDate,sTime,고점[1,1],NextBarSdate,NextBarStime,고점[1,1]);
TL5 = TL_New(sDate,sTime,고점[1,1]-var2,NextBarSdate,NextBarStime,고점[1,1]-var2);
TL41 = TL_New(sDate,sTime,고점[1,1]-var2*r1,NextBarSdate,NextBarStime,고점[1,1]-var2*r1);
TL51 = TL_New(sDate,sTime,고점[1,1]-var2*r2,NextBarSdate,NextBarStime,고점[1,1]-var2*r2);
tx4 = Text_New(NextBarSdate,NextBarStime,고점[1,1],NumToStr(고점[1,1],2));
tx5 = Text_New(NextBarSdate,NextBarStime,고점[1,1]-var2,NumToStr(고점[1,1]-var2,2));
tx41 = Text_New(NextBarSdate,NextBarStime,고점[1,1]-var2*r1,NumToStr(고점[1,1]-var2*r1,2));
tx51 = Text_New(NextBarSdate,NextBarStime,고점[1,1]-var2*r2,NumToStr(고점[1,1]-var2*r2,2));
}
}
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and
TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL21);
TL_Delete(TL31);
Text_Delete(Text1);
Text_Delete(Tx2);
Text_Delete(Tx3);
Text_Delete(Tx21);
Text_Delete(Tx31);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],
sDate[eBar],sTime[eBar],저점[1,1]);
Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],2)
+NewLine+"진폭"+NumToStr((고점[1,1]-저점[1,1]),2));
Text_SetStyle(Text1, 2, 0);
var1 = (고점[1,1]-저점[2,1]);
TL2 = TL_New(sDate,sTime,저점[1,1],NextBarSdate,NextBarStime,저점[1,1]);
TL3 = TL_New(sDate,sTime,저점[1,1]+var1,NextBarSdate,NextBarStime,저점[1,1]+var1);
TL21 = TL_New(sDate,sTime,저점[1,1]+var1*r1,NextBarSdate,NextBarStime,저점[1,1]+var1*r1);
TL31 = TL_New(sDate,sTime,저점[1,1]+var1*r2,NextBarSdate,NextBarStime,저점[1,1]+var1*r2);
tx2 = Text_New(NextBarSdate,NextBarStime,저점[1,1],NumToStr(저점[1,1],2));
tx3 = Text_New(NextBarSdate,NextBarStime,저점[1,1]+var1,NumToStr(저점[1,1]+var1,2));
tx21 = Text_New(NextBarSdate,NextBarStime,저점[1,1]+var1*r1,NumToStr(저점[1,1]+var1*r1,2));
tx31 = Text_New(NextBarSdate,NextBarStime,저점[1,1]+var1*r1,NumToStr(저점[1,1]+var1*r2,2));
}
}
TL_SetSize(TL1,0);
TL_SetColor(TL1,gray);
TL_SetEnd(TL2,NextBarSdate,NextBarStime,저점[1,1]);
TL_SetEnd(TL3,NextBarSdate,NextBarStime,저점[1,1]+var1);
TL_SetEnd(TL21,NextBarSdate,NextBarStime,저점[1,1]+var1*r1);
TL_SetEnd(TL31,NextBarSdate,NextBarStime,저점[1,1]+var1*r2);
TL_SetSize(TL2,2);
TL_SetColor(TL2,BLUE);
TL_SetSize(TL3,2);
TL_SetColor(TL3,yellow);
TL_SetSize(TL21,2);
TL_SetColor(TL21,yellow);
TL_SetSize(TL31,2);
TL_SetColor(TL31,yellow);
TL_SetEnd(TL4,NextBarSdate,NextBarStime,고점[1,1]);
TL_SetEnd(TL5,NextBarSdate,NextBarStime,고점[1,1]-Var2);
TL_SetEnd(TL41,NextBarSdate,NextBarStime,고점[1,1]-Var2*r1);
TL_SetEnd(TL51,NextBarSdate,NextBarStime,고점[1,1]-Var2*r2);
TL_SetSize(TL4,2);
TL_SetColor(TL4,RED);
TL_SetSize(TL5,2);
TL_SetColor(TL5,cyan);
TL_SetSize(TL41,2);
TL_SetColor(TL41,cyan);
TL_SetSize(TL51,2);
TL_SetColor(TL51,cyan);
Text_SetLocation(tx2,NextBarSdate,NextBarStime,저점[1,1]);
Text_SetLocation(tx3,NextBarSdate,NextBarStime,저점[1,1]+var1);
Text_SetLocation(tx21,NextBarSdate,NextBarStime,저점[1,1]+var1*r1);
Text_SetLocation(tx31,NextBarSdate,NextBarStime,저점[1,1]+var1*r2);
Text_SetStyle(tx2,2,1);
Text_SetStyle(tx3,2,1);
Text_SetStyle(tx21,2,1);
Text_SetStyle(tx31,2,1);
Text_SetColor(tx2,BLUE);
Text_SetColor(tx3,yellow);
Text_SetColor(tx21,yellow);
Text_SetColor(tx31,yellow);
Text_SetLocation(tx4,NextBarSdate,NextBarStime,고점[1,1]);
Text_SetLocation(tx5,NextBarSdate,NextBarStime,고점[1,1]-var2);
Text_SetLocation(tx41,NextBarSdate,NextBarStime,고점[1,1]-var2*r1);
Text_SetLocation(tx51,NextBarSdate,NextBarStime,고점[1,1]-var2*r2);
Text_SetStyle(tx4,2,1);
Text_SetStyle(tx5,2,1);
Text_SetStyle(tx41,2,1);
Text_SetStyle(tx51,2,1);
Text_SetColor(tx4,RED);
Text_SetColor(tx5,cyan);
Text_SetColor(tx41,cyan);
Text_SetColor(tx51,cyan);
즐거운 하루되세요
> 레전드 님이 쓴 글입니다.
> 제목 : 문의
> 고점 저점에서 올라갔든 폭만큼 오르거나 내리거나 햇습니다, 이것을 그폭의 0.5배,1.618배 그리고 2배만큼을 추가해서 나오도록 부탁드립니다,올라갓을때 폭에 나타났든 색깔은 올라갔을때 같게 해주시고 내려갈때 폭도 같은 색깔로 부탁드립니다 그리고 외부변수로 해서 그폭의 변동을 변수로해서 고칠수 있도록 부탁드립니다. 수식은 아래식으로 참조햇습니다
Input:length(12);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),
Text1(0),처리구분(""),tl2(0),tl3(0),tl4(0),tl5(0);
var : tx2(0),tx3(0),tx4(0),tx5(0);
Array:고점[10,2](0),저점[10,2](0); //가격,위치
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then
처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then
처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and
TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
TL_Delete(TL4);
TL_Delete(TL5);
Text_Delete(Text1);
Text_Delete(Tx4);
Text_Delete(Tx5);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],
sDate[eBar],sTime[eBar],고점[1,1]);
Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(고점[1,1],2)
+NewLine+"진폭"+NumToStr((고점[1,1]-저점[1,1]),2));
Text_SetStyle(Text1, 2, 1);
var2 = abs(고점[2,1]-저점[1,1]);
TL4 = TL_New(sDate,sTime,고점[1,1],NextBarSdate,NextBarStime,고점[1,1]);
TL5 = TL_New(sDate,sTime,고점[1,1]-var2,NextBarSdate,NextBarStime,고점[1,1]-var2);
tx4 = Text_New(NextBarSdate,NextBarStime,고점[1,1],NumToStr(고점[1,1],2));
tx5 = Text_New(NextBarSdate,NextBarStime,고점[1,1]-var2,NumToStr(고점[1,1]-var2,2));
}
}
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and
TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
TL_Delete(TL2);
TL_Delete(TL3);
Text_Delete(Text1);
Text_Delete(Tx2);
Text_Delete(Tx3);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],
sDate[eBar],sTime[eBar],저점[1,1]);
Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],2)
+NewLine+"진폭"+NumToStr((고점[1,1]-저점[1,1]),2));
Text_SetStyle(Text1, 2, 0);
var1 = (고점[1,1]-저점[2,1]);
TL2 = TL_New(sDate,sTime,저점[1,1],NextBarSdate,NextBarStime,저점[1,1]);
TL3 = TL_New(sDate,sTime,저점[1,1]+var1,NextBarSdate,NextBarStime,저점[1,1]+var1);
tx2 = Text_New(NextBarSdate,NextBarStime,저점[1,1],NumToStr(저점[1,1],2));
tx3 = Text_New(NextBarSdate,NextBarStime,저점[1,1]+var1,NumToStr(저점[1,1]+var1,2));
}
}
TL_SetSize(TL1,0);
TL_SetColor(TL1,gray);
TL_SetEnd(TL2,NextBarSdate,NextBarStime,저점[1,1]);
TL_SetEnd(TL3,NextBarSdate,NextBarStime,저점[1,1]+var1);
TL_SetSize(TL2,2);
TL_SetColor(TL2,BLUE);
TL_SetSize(TL3,2);
TL_SetColor(TL3,yellow);
TL_SetEnd(TL4,NextBarSdate,NextBarStime,고점[1,1]);
TL_SetEnd(TL5,NextBarSdate,NextBarStime,고점[1,1]-Var2);
TL_SetSize(TL4,2);
TL_SetColor(TL4,RED);
TL_SetSize(TL5,2);
TL_SetColor(TL5,cyan);
Text_SetLocation(tx2,NextBarSdate,NextBarStime,저점[1,1]);
Text_SetLocation(tx3,NextBarSdate,NextBarStime,저점[1,1]+var1);
Text_SetStyle(tx2,2,1);
Text_SetStyle(tx3,2,1);
Text_SetColor(tx2,BLUE);
Text_SetColor(tx3,yellow);
Text_SetLocation(tx4,NextBarSdate,NextBarStime,고점[1,1]);
Text_SetLocation(tx5,NextBarSdate,NextBarStime,고점[1,1]-var2);
Text_SetStyle(tx4,2,1);
Text_SetStyle(tx5,2,1);
Text_SetColor(tx4,RED);
Text_SetColor(tx5,cyan);