커뮤니티

부탁드림니다

프로필 이미지
djhsfg
2017-02-23 14:46:38
206
글번호 107198
답변완료

첨부 이미지

그림과같이 파란추세선환성에 고점에 빨강추세선완성에 저점에 번호를 넣고 싶습니다 미리 감사드림니다 ---------------------- Input:length(3); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),처리구분(""),T(0),Color(0); var:tx1(0),tx2(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); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL_SetSize(TL1,2); if 고점[2,1] == 0 or (고점[2,1] > 0 and 고점[2,1] < 고점[1,1]) Then color = red; TL_SetColor(TL1,color); if TL_SetColor(TL1,color)>1 then { } } } 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); } TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL_SetSize(TL1,2); if 저점[2,1] == 0 or (저점[2,1] > 0 and 저점[2,1] > 저점[1,1]) Then color = blue; TL_SetColor(TL1,color); } }
지표
답변 1
프로필 이미지

예스스탁 예스스탁 답변

2017-02-23 19:12:27

안녕하세요 예스스탁입니다. Input:length(3); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),처리구분(""),T(0),Color(0); var:tx1(0),tx2(0),x(0),y(0),tx11(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); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL_SetSize(TL1,2); if 고점[2,1] == 0 or (고점[2,1] > 0 and 고점[2,1] < 고점[1,1]) Then{ color = red; } TL_SetColor(TL1,color); } } 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); } TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL_SetSize(TL1,2); if 저점[2,1] == 0 or (저점[2,1] > 0 and 저점[2,1] > 저점[1,1]) Then{ color = blue; } TL_SetColor(TL1,color); } } if TL1 != TL1[1] and (color == red or color[1] ==red) and 처리구분 == "저점처리" Then{ X = X+1; tx11 = Text_New(TL_GetBeginDate(TL1[1]),TL_GetBeginTime(TL1[1]),TL_GetBeginVal(TL1[1]),NumToStr(X,0)); Text_SetColor(tx11,RED); } if TL1 != TL1[1] and (color == blue or color[1] == blue) and 처리구분 == "고점처리" Then{ Y = Y+1; tx11 = Text_New(TL_GetBeginDate(TL1[1]),TL_GetBeginTime(TL1[1]),TL_GetBeginVal(TL1[1]),NumToStr(Y,0)); Text_SetColor(tx11,blue); } if color == blue Then X = 0; if color == red Then Y = 0; 즐거운 하루되세요 > djhsfg 님이 쓴 글입니다. > 제목 : 부탁드림니다 > 그림과같이 파란추세선환성에 고점에 빨강추세선완성에 저점에 번호를 넣고 싶습니다 미리 감사드림니다 ---------------------- Input:length(3); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),처리구분(""),T(0),Color(0); var:tx1(0),tx2(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); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL_SetSize(TL1,2); if 고점[2,1] == 0 or (고점[2,1] > 0 and 고점[2,1] < 고점[1,1]) Then color = red; TL_SetColor(TL1,color); if TL_SetColor(TL1,color)>1 then { } } } 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); } TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL_SetSize(TL1,2); if 저점[2,1] == 0 or (저점[2,1] > 0 and 저점[2,1] > 저점[1,1]) Then color = blue; TL_SetColor(TL1,color); } }