커뮤니티

수정부탁드립니다

프로필 이미지
외국인
2023-04-06 15:32:32
1092
글번호 167972
답변완료
수직 표현위치 다름니다 수정(하락 상승 연장시) 및 지그재그선 상승시 red 하락시 blue 부탁드립니다.. Input:barCnt(5),tjs(0.5),tjs1(1); Var:aj(0),turBit(""),kaaTL1(0),aaTL1(0),kkaaTL1(0); Array:vaArr[10](0),baArr[10](0),tuPntrr[10](""); // 봉이 새로 생겼으므로 봉개수 관리하는 변수들의 봉개수 값 1씩 증가 For aj = 0 To 9 { baArr[aj] = baArr[aj] + 1; } // 고점조건 = 5-1-5에서 가운데 고가가 좌측 5봉과 우측 5봉 고가보다 높다 // 저점조건 = 5-1-5에서 가운데 저가가 좌측 5봉과 우측 5봉 저가보다 낮다 Condition1 = Highest(H,barCnt)[barCnt+1] <= H[barCnt] and H[barCnt] > Highest(H,barCnt); Condition2 = Lowest(L,barCnt)[barCnt+1] >= L[barCnt] and L[barCnt] < Lowest(L,barCnt); // 전환점구분 null값으로 초기화; // if 고점조건, 저점조건 동시 만족시 then // if 이전 고점,저점 범위를 모두 벗어났을 때 // 전환점구분 = 고저점; // else if 이전 고점을 갱신했다면 전환점구분 = 고점; // else if 이전 저점을 갱신했다면 전환점구분 = 저점; // else if 전환점배열의 현재(배열상 1번째)값이 고점이면 전환점구분 = 저점; // else if 전환점배열의 현재 값이 저점이면 전환점구분 = 고점; // else if 고점조건 만족하면 전환점구분 = 고점; // else if 저점조건 만족하면 전환전구분 = 저점; turBit = ""; If Condition1 and Condition2 Then { If Max(vaArr[1],vaArr[2]) < H[barCnt] and Min(vaArr[1],vaArr[2]) > L[barCnt] Then turBit = "HiLo"; Else If Max(vaArr[1],vaArr[2]) < H[barCnt] Then turBit = "Hi"; Else If Min(vaArr[1],vaArr[2]) > L[barCnt] Then turBit = "Lo"; Else If tuPntrr[1] == "Hi" Then turBit = "Lo"; Else If tuPntrr[1] == "Lo" Then turBit = "Hi"; } Else If Condition1 Then turBit = "Hi"; Else If Condition2 Then turBit = "Lo"; // if 전환점구분에 값이 있을 때만 아래 실행, 없으면 통과 If turBit <> "" Then { // if 전환점구분이 고저점이면 then // 이전 파동은 연장시키고 아래에서 새로이 파동선을 추가토록 한다. If turBit == "HiLo" Then { vaArr[1] = IFF(tuPntrr[1] == "Hi",H[barCnt],L[barCnt]); baArr[1] = barCnt; TL_SetEnd(aaTL1,sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); If tuPntrr[1] == "Hi" Then turBit = "Lo"; Else turBit = "Hi"; } // if 신규 전환점구분이 현재(전환점배열 1번째)와 다르면 then // 배열값들을 이전값으로 Move; If turBit <> tuPntrr[1] Then { for aj = 8 downto 1 { vaArr[aj+1] = vaArr[aj]; baArr[aj+1] = baArr[aj]; tuPntrr[aj+1] = tuPntrr[aj]; } } // if 전환점구분이 바뀌었거나 또는 // (전환점구분은 안바뀌었는데 // (이전 고점보다 높은 고점이 발생했거나 또는 // 이전 저점보다 낮은 저점이 발생했으면)) then If turBit <> tuPntrr[1] or (turBit == tuPntrr[1] and ((turBit == "Hi" and vaArr[1] < H[barCnt]) or (turBit == "Lo" and vaArr[1] > L[barCnt]))) Then { // 값 배열에는 고점 또는 저점을 대입; // 봉개수 배열에는 입력변수의 봉개수 대입; // 전환점 배열에 전환점구분값을 대입; vaArr[1] = IFF(turBit == "Hi",H[barCnt],L[barCnt]); baArr[1] = barCnt; tuPntrr[1] = turBit; // if 이전봉대비 전환점구분이 바뀌었다면 추세선 새로 그리고; // else 전환점구분이 안바뀌었으면 값만 바뀐거므로 추세선 연장; If tuPntrr[1][1] <> tuPntrr[1][0] Then aaTL1 = TL_New(sDate[baArr[2]],sTime[baArr[2]],vaArr[2],sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); Else TL_SetEnd(aaTL1,sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); } TL_SetSize(aaTL1,tjs1); TL_SetColor(aaTL1,Green); //TL_Delete(kkaaTL1); If tuPntrr[1][1] < tuPntrr[1][0] Then kkaaTL1 = TL_New(sDate[baArr[1]],sTime[baArr[1]],0,sDate[baArr[1]],sTime[baArr[1]],999999999);//수직선 TL_SetColor(kkaaTL1,Magenta); TL_SetSize(kkaaTL1,1); //TL_Delete(kkaaTL1); If tuPntrr[1][1] > tuPntrr[1][0] Then kkaaTL1 = TL_New(sDate[baArr[1]],sTime[baArr[1]],0,sDate[baArr[1]],sTime[baArr[1]],99999999); //수직선 TL_SetColor(kkaaTL1,Lime); TL_SetSize(kkaaTL1,1); }
지표
답변 1
프로필 이미지

예스스탁 예스스탁 답변

2023-04-07 08:46:06

안녕하세요 예스스탁입니다. Input:barCnt(5),tjs(0.5),tjs1(1); Var:aj(0),turBit(""),kaaTL1(0),aaTL1(0),kkaaTL1(0); Array:vaArr[10](0),baArr[10](0),tuPntrr[10](""); // 봉이 새로 생겼으므로 봉개수 관리하는 변수들의 봉개수 값 1씩 증가 For aj = 0 To 9 { baArr[aj] = baArr[aj] + 1; } // 고점조건 = 5-1-5에서 가운데 고가가 좌측 5봉과 우측 5봉 고가보다 높다 // 저점조건 = 5-1-5에서 가운데 저가가 좌측 5봉과 우측 5봉 저가보다 낮다 Condition1 = Highest(H,barCnt)[barCnt+1] <= H[barCnt] and H[barCnt] > Highest(H,barCnt); Condition2 = Lowest(L,barCnt)[barCnt+1] >= L[barCnt] and L[barCnt] < Lowest(L,barCnt); // 전환점구분 null값으로 초기화; // if 고점조건, 저점조건 동시 만족시 then // if 이전 고점,저점 범위를 모두 벗어났을 때 // 전환점구분 = 고저점; // else if 이전 고점을 갱신했다면 전환점구분 = 고점; // else if 이전 저점을 갱신했다면 전환점구분 = 저점; // else if 전환점배열의 현재(배열상 1번째)값이 고점이면 전환점구분 = 저점; // else if 전환점배열의 현재 값이 저점이면 전환점구분 = 고점; // else if 고점조건 만족하면 전환점구분 = 고점; // else if 저점조건 만족하면 전환전구분 = 저점; turBit = ""; If Condition1 and Condition2 Then { If Max(vaArr[1],vaArr[2]) < H[barCnt] and Min(vaArr[1],vaArr[2]) > L[barCnt] Then turBit = "HiLo"; Else If Max(vaArr[1],vaArr[2]) < H[barCnt] Then turBit = "Hi"; Else If Min(vaArr[1],vaArr[2]) > L[barCnt] Then turBit = "Lo"; Else If tuPntrr[1] == "Hi" Then turBit = "Lo"; Else If tuPntrr[1] == "Lo" Then turBit = "Hi"; } Else If Condition1 Then turBit = "Hi"; Else If Condition2 Then turBit = "Lo"; // if 전환점구분에 값이 있을 때만 아래 실행, 없으면 통과 If turBit <> "" Then { // if 전환점구분이 고저점이면 then // 이전 파동은 연장시키고 아래에서 새로이 파동선을 추가토록 한다. If turBit == "HiLo" Then { vaArr[1] = IFF(tuPntrr[1] == "Hi",H[barCnt],L[barCnt]); baArr[1] = barCnt; TL_SetEnd(aaTL1,sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); If tuPntrr[1] == "Hi" Then turBit = "Lo"; Else turBit = "Hi"; } // if 신규 전환점구분이 현재(전환점배열 1번째)와 다르면 then // 배열값들을 이전값으로 Move; If turBit <> tuPntrr[1] Then { for aj = 8 downto 1 { vaArr[aj+1] = vaArr[aj]; baArr[aj+1] = baArr[aj]; tuPntrr[aj+1] = tuPntrr[aj]; } } // if 전환점구분이 바뀌었거나 또는 // (전환점구분은 안바뀌었는데 // (이전 고점보다 높은 고점이 발생했거나 또는 // 이전 저점보다 낮은 저점이 발생했으면)) then If turBit <> tuPntrr[1] or (turBit == tuPntrr[1] and ((turBit == "Hi" and vaArr[1] < H[barCnt]) or (turBit == "Lo" and vaArr[1] > L[barCnt]))) Then { // 값 배열에는 고점 또는 저점을 대입; // 봉개수 배열에는 입력변수의 봉개수 대입; // 전환점 배열에 전환점구분값을 대입; vaArr[1] = IFF(turBit == "Hi",H[barCnt],L[barCnt]); baArr[1] = barCnt; tuPntrr[1] = turBit; // if 이전봉대비 전환점구분이 바뀌었다면 추세선 새로 그리고; // else 전환점구분이 안바뀌었으면 값만 바뀐거므로 추세선 연장; If tuPntrr[1][1] <> tuPntrr[1][0] Then { aaTL1 = TL_New(sDate[baArr[2]],sTime[baArr[2]],vaArr[2],sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); TL_SetColor(aaTL1,iff(tuPntrr[1][0] == "Hi",red,blue)); TL_SetSize(aaTL1,tjs1); kkaaTL1 = TL_New(sDate[baArr[1]],sTime[baArr[1]],0,sDate[baArr[1]],sTime[baArr[1]],999999999); TL_SetColor(kkaaTL1,iff(tuPntrr[1][0] == "Hi",Lime,Magenta)); TL_SetSize(kkaaTL1,1); } Else { TL_SetEnd(aaTL1,sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); TL_SetBegin(kkaaTL1,sDate[baArr[1]],sTime[baArr[1]],0); TL_SetEnd(kkaaTL1,sDate[baArr[1]],sTime[baArr[1]],999999999); } } } 즐거운 하루되세요 > 외국인 님이 쓴 글입니다. > 제목 : 수정부탁드립니다 > 수직 표현위치 다름니다 수정(하락 상승 연장시) 및 지그재그선 상승시 red 하락시 blue 부탁드립니다.. Input:barCnt(5),tjs(0.5),tjs1(1); Var:aj(0),turBit(""),kaaTL1(0),aaTL1(0),kkaaTL1(0); Array:vaArr[10](0),baArr[10](0),tuPntrr[10](""); // 봉이 새로 생겼으므로 봉개수 관리하는 변수들의 봉개수 값 1씩 증가 For aj = 0 To 9 { baArr[aj] = baArr[aj] + 1; } // 고점조건 = 5-1-5에서 가운데 고가가 좌측 5봉과 우측 5봉 고가보다 높다 // 저점조건 = 5-1-5에서 가운데 저가가 좌측 5봉과 우측 5봉 저가보다 낮다 Condition1 = Highest(H,barCnt)[barCnt+1] <= H[barCnt] and H[barCnt] > Highest(H,barCnt); Condition2 = Lowest(L,barCnt)[barCnt+1] >= L[barCnt] and L[barCnt] < Lowest(L,barCnt); // 전환점구분 null값으로 초기화; // if 고점조건, 저점조건 동시 만족시 then // if 이전 고점,저점 범위를 모두 벗어났을 때 // 전환점구분 = 고저점; // else if 이전 고점을 갱신했다면 전환점구분 = 고점; // else if 이전 저점을 갱신했다면 전환점구분 = 저점; // else if 전환점배열의 현재(배열상 1번째)값이 고점이면 전환점구분 = 저점; // else if 전환점배열의 현재 값이 저점이면 전환점구분 = 고점; // else if 고점조건 만족하면 전환점구분 = 고점; // else if 저점조건 만족하면 전환전구분 = 저점; turBit = ""; If Condition1 and Condition2 Then { If Max(vaArr[1],vaArr[2]) < H[barCnt] and Min(vaArr[1],vaArr[2]) > L[barCnt] Then turBit = "HiLo"; Else If Max(vaArr[1],vaArr[2]) < H[barCnt] Then turBit = "Hi"; Else If Min(vaArr[1],vaArr[2]) > L[barCnt] Then turBit = "Lo"; Else If tuPntrr[1] == "Hi" Then turBit = "Lo"; Else If tuPntrr[1] == "Lo" Then turBit = "Hi"; } Else If Condition1 Then turBit = "Hi"; Else If Condition2 Then turBit = "Lo"; // if 전환점구분에 값이 있을 때만 아래 실행, 없으면 통과 If turBit <> "" Then { // if 전환점구분이 고저점이면 then // 이전 파동은 연장시키고 아래에서 새로이 파동선을 추가토록 한다. If turBit == "HiLo" Then { vaArr[1] = IFF(tuPntrr[1] == "Hi",H[barCnt],L[barCnt]); baArr[1] = barCnt; TL_SetEnd(aaTL1,sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); If tuPntrr[1] == "Hi" Then turBit = "Lo"; Else turBit = "Hi"; } // if 신규 전환점구분이 현재(전환점배열 1번째)와 다르면 then // 배열값들을 이전값으로 Move; If turBit <> tuPntrr[1] Then { for aj = 8 downto 1 { vaArr[aj+1] = vaArr[aj]; baArr[aj+1] = baArr[aj]; tuPntrr[aj+1] = tuPntrr[aj]; } } // if 전환점구분이 바뀌었거나 또는 // (전환점구분은 안바뀌었는데 // (이전 고점보다 높은 고점이 발생했거나 또는 // 이전 저점보다 낮은 저점이 발생했으면)) then If turBit <> tuPntrr[1] or (turBit == tuPntrr[1] and ((turBit == "Hi" and vaArr[1] < H[barCnt]) or (turBit == "Lo" and vaArr[1] > L[barCnt]))) Then { // 값 배열에는 고점 또는 저점을 대입; // 봉개수 배열에는 입력변수의 봉개수 대입; // 전환점 배열에 전환점구분값을 대입; vaArr[1] = IFF(turBit == "Hi",H[barCnt],L[barCnt]); baArr[1] = barCnt; tuPntrr[1] = turBit; // if 이전봉대비 전환점구분이 바뀌었다면 추세선 새로 그리고; // else 전환점구분이 안바뀌었으면 값만 바뀐거므로 추세선 연장; If tuPntrr[1][1] <> tuPntrr[1][0] Then aaTL1 = TL_New(sDate[baArr[2]],sTime[baArr[2]],vaArr[2],sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); Else TL_SetEnd(aaTL1,sDate[baArr[1]],sTime[baArr[1]],vaArr[1]); } TL_SetSize(aaTL1,tjs1); TL_SetColor(aaTL1,Green); //TL_Delete(kkaaTL1); If tuPntrr[1][1] < tuPntrr[1][0] Then kkaaTL1 = TL_New(sDate[baArr[1]],sTime[baArr[1]],0,sDate[baArr[1]],sTime[baArr[1]],999999999);//수직선 TL_SetColor(kkaaTL1,Magenta); TL_SetSize(kkaaTL1,1); //TL_Delete(kkaaTL1); If tuPntrr[1][1] > tuPntrr[1][0] Then kkaaTL1 = TL_New(sDate[baArr[1]],sTime[baArr[1]],0,sDate[baArr[1]],sTime[baArr[1]],99999999); //수직선 TL_SetColor(kkaaTL1,Lime); TL_SetSize(kkaaTL1,1); }