커뮤니티

종목검색기능 관련 다시 여쭈어봅니다.

프로필 이미지
일프로
2019-01-28 16:43:36
248
글번호 125672
답변완료

첨부 이미지

전일에도 문의 드렸는데요. 말씀하신대로 파워종목검색에서 검색에 필요한 최소기간값과 차트의 조회건수를 동일 하게 하여도 종목검색을 하면 조건에 해당되지 않는 종목들이 간헐적으로 발생합니다. 예스의 기본장착된 이동평균선정배열 지표와 제가 만든 adx 강세 지표를 파워종목검색에서 A and B 라고하여도 안되어 수식을 통합해서 아래와 같이 만들었는데도 문제가 검출됩니다. 이동평균선 정배열과 adx 강세를 이용하여 종목검색을 했습니다. 이평 5,20,60 정배열 adx 20이상 and 조건으로 검색. Input : shortPeriod(5), midPeriod(20), longPeriod(60); value1 = ma(C,shortPeriod); value2 = ma(C,midPeriod); value3 = ma(C,longPeriod); If value1 > value2 && value2 > value3 Then { value4=100; } Else value4 = 0; INPUT:기간(14),mx(20); vars:var1(0); if (ADX(기간))>mx Then var1=100; else var1=0; if var1==100 && value4==100 then var5=1; else var5=0; find(var5); 과 같이 수식을 작성하고 첨부와 같이 차트 띄우고 파워종목검색에서 검색을 해보았습니다. 조건에 해당되지 않는 종목들이 간혹 검출됩니다. 이틀동안 고생중입니다. 부탁드립니다.
종목검색
답변 2
프로필 이미지

예스스탁 예스스탁 답변

2019-01-29 09:53:31

안녕하세요 예스스탁입니다. Input : shortPeriod(5), midPeriod(20), longPeriod(60); value1 = ma(C,shortPeriod); value2 = ma(C,midPeriod); value3 = ma(C,longPeriod); If value1 > value2 && value2 > value3 Then { value4=100; } Else value4 = 0; INPUT:기간(14),mx(20); vars:var1(0); if (ADX(기간))>mx Then var1=100; else var1=0; if var1==100 && value4==100 then var5=1; else var5=0; plot1(adx(기간)); 위 지표를 그대로 적용해 보시면 adx값이 차트에서 보시는 것과 다른것을 확인하실수 있습니다. adx는 사용자함수를 열어보시면 CurrentBar >= 1이라는 내용이 있습니다. 수식에서 필요한 최소 봉수 이후부터 계산한다는 내용입니다. 즉 차트를 120봉을 열었지만 해당 수식이 60이평이 사용되므로 해당 수식의 계산에 필요한 최소봉수인 60봉이후 부터 계산을 하게 됩니다. 수식은 하나의 수식에서 요구되는 봉수 이후부터 계산되고 검색하실때 과거 값에 영향받는 지표등은 최대한 검색봉을 많이 지정하고 검색하시기 바랍니다. 봉이 경과할수록 과거의 영향이 줄어들게 됩니다. 즐거운 하루되세요 > 일프로 님이 쓴 글입니다. > 제목 : 종목검색기능 관련 다시 여쭈어봅니다. > 전일에도 문의 드렸는데요. 말씀하신대로 파워종목검색에서 검색에 필요한 최소기간값과 차트의 조회건수를 동일 하게 하여도 종목검색을 하면 조건에 해당되지 않는 종목들이 간헐적으로 발생합니다. 예스의 기본장착된 이동평균선정배열 지표와 제가 만든 adx 강세 지표를 파워종목검색에서 A and B 라고하여도 안되어 수식을 통합해서 아래와 같이 만들었는데도 문제가 검출됩니다. 이동평균선 정배열과 adx 강세를 이용하여 종목검색을 했습니다. 이평 5,20,60 정배열 adx 20이상 and 조건으로 검색. Input : shortPeriod(5), midPeriod(20), longPeriod(60); value1 = ma(C,shortPeriod); value2 = ma(C,midPeriod); value3 = ma(C,longPeriod); If value1 > value2 && value2 > value3 Then { value4=100; } Else value4 = 0; INPUT:기간(14),mx(20); vars:var1(0); if (ADX(기간))>mx Then var1=100; else var1=0; if var1==100 && value4==100 then var5=1; else var5=0; find(var5); 과 같이 수식을 작성하고 첨부와 같이 차트 띄우고 파워종목검색에서 검색을 해보았습니다. 조건에 해당되지 않는 종목들이 간혹 검출됩니다. 이틀동안 고생중입니다. 부탁드립니다.
프로필 이미지

일프로

2019-01-29 18:27:16

오늘 CurrentBar와 지표계산에 필요한 기간값을 어떻게 이용해서 지표가 출력되는지 알게 되었습니다.감사합니다. 그런데 알려주신 수식을 좀더 수정해서 adx(14)<mx 이면 녹색막대로 출력하도록(수식1,검출수식참조) 하고 검색결과를 비교한 결과도 동일하게 오류검출이 이루어 지고 있습니다. 말씀하신 내용에서 " 검색하실때 과거 값에 영향받는 지표등은 최대한 검색봉을 많이 지정하고 검색하시기 바랍니다. 봉이 경과할수록 과거의 영향이 줄어들게 됩니다." 라는 내용을 납득이 안되고 저를 너무 힘들게하는 말씀이네요.^^ 최대한 검색봉을 많이 지정이라 종목검색에서 사용하는 기간값이 얼마인가요? 재귀함수를 사용하든 안하든 수정한 지표값을 기준으로 종목검색결과와 비교하여 모두 결과가 참으로 나와야 정상이라고 생각하는데요. 지표를 이용해서 파워종목검색에서 수행한다면 또 그 결과만 받아서 충실하게 검색이 이루어진다면 수정한 지표와 동일한 결과가 검색결과로 나와야하고 검색조건과 동일하게 차트의 기간설정만 이루진다면 결과가 일치해야 한다고 생각하기 때문입니다. 제가 어떻게 하면 종목검색결과와 지표출력결과를 일치시킬 수 있을까요? 또 하나는 그림2는 adx 조건을 빼고 보시는 바와같이 단순이동평균선만 사용해서 기본종목 검색식 이동평균선 정배열을 수정하여 종목검색을 하였을 때도 오류가 발생됩니다. (수식2 참조) 오늘도 5시간 동안 이 문제로 검토하고 또 어떻게 질문드려야 할 지 고민에 고민을 거듭하고 다시 여쭈어봅니다. 육안으로 모두 확인해야 한다면 얼마나 사용자들이 얼마나 피곤하겠습니까? 잠재적인 문제로 검색결과를 신뢰하지도 자신이 만든 지표식에 대해서도 신뢰하지도 못할 것 같습니다. 제가 정말 뭘 몰라서 사용을 그릇되게 이해하는 것인지 아니면 파워종목검색에 문제가 있어서 그런것인지 자신감이 뚝 떨어집니다. &#4447;&#4466;&#4466; 이 단계를 넘어서야 다음 단계로 나아갈수 있는데 말입니다. 수식1 [검출수식] Input : shortPeriod(5), midPeriod(20), longPeriod(60); value1 = ma(C,shortPeriod); value2 = ma(C,midPeriod); value3 = ma(C,longPeriod); If value1 > value2 && value2 > value3 Then { value4=100; } Else value4 = 0; INPUT:기간(14),mx(20); vars:var1(0); if (ADX(기간))>mx Then var1=100; else var1=0; if var1==100 && value4==100 then var5=1; else var5=0; plot1(adx(기간)); plot2(mx); if adx(기간)<mx Then plot3(adx(기간)); // 녹색막대 수식2 종목검색검증_이동평균선 정배열 Input : shortPeriod(5), midPeriod(20), longPeriod(60),기준봉(0); value1 = ma(C,shortPeriod); value2 = ma(C,midPeriod); value3 = ma(C,longPeriod); If value1 > value2 && value2 > value3 Then { value4=100; } Else value4 = 0; plot1(value1,"단기"); plot2(value2,"중기"); plot3(value3,"장기"); if value4[기준봉]==0 then plot4(min(value1,value2,value3,L),"정배열 아님"); > 예스스탁 님이 쓴 글입니다. > 제목 : Re : 종목검색기능 관련 다시 여쭈어봅니다. > 안녕하세요 예스스탁입니다. Input : shortPeriod(5), midPeriod(20), longPeriod(60); value1 = ma(C,shortPeriod); value2 = ma(C,midPeriod); value3 = ma(C,longPeriod); If value1 > value2 && value2 > value3 Then { value4=100; } Else value4 = 0; INPUT:기간(14),mx(20); vars:var1(0); if (ADX(기간))>mx Then var1=100; else var1=0; if var1==100 && value4==100 then var5=1; else var5=0; plot1(adx(기간)); 위 지표를 그대로 적용해 보시면 adx값이 차트에서 보시는 것과 다른것을 확인하실수 있습니다. adx는 사용자함수를 열어보시면 CurrentBar >= 1이라는 내용이 있습니다. 수식에서 필요한 최소 봉수 이후부터 계산한다는 내용입니다. 즉 차트를 120봉을 열었지만 해당 수식이 60이평이 사용되므로 해당 수식의 계산에 필요한 최소봉수인 60봉이후 부터 계산을 하게 됩니다. 수식은 하나의 수식에서 요구되는 봉수 이후부터 계산되고 검색하실때 과거 값에 영향받는 지표등은 최대한 검색봉을 많이 지정하고 검색하시기 바랍니다. 봉이 경과할수록 과거의 영향이 줄어들게 됩니다. 즐거운 하루되세요 > 일프로 님이 쓴 글입니다. > 제목 : 종목검색기능 관련 다시 여쭈어봅니다. > 전일에도 문의 드렸는데요. 말씀하신대로 파워종목검색에서 검색에 필요한 최소기간값과 차트의 조회건수를 동일 하게 하여도 종목검색을 하면 조건에 해당되지 않는 종목들이 간헐적으로 발생합니다. 예스의 기본장착된 이동평균선정배열 지표와 제가 만든 adx 강세 지표를 파워종목검색에서 A and B 라고하여도 안되어 수식을 통합해서 아래와 같이 만들었는데도 문제가 검출됩니다. 이동평균선 정배열과 adx 강세를 이용하여 종목검색을 했습니다. 이평 5,20,60 정배열 adx 20이상 and 조건으로 검색. Input : shortPeriod(5), midPeriod(20), longPeriod(60); value1 = ma(C,shortPeriod); value2 = ma(C,midPeriod); value3 = ma(C,longPeriod); If value1 > value2 && value2 > value3 Then { value4=100; } Else value4 = 0; INPUT:기간(14),mx(20); vars:var1(0); if (ADX(기간))>mx Then var1=100; else var1=0; if var1==100 && value4==100 then var5=1; else var5=0; find(var5); 과 같이 수식을 작성하고 첨부와 같이 차트 띄우고 파워종목검색에서 검색을 해보았습니다. 조건에 해당되지 않는 종목들이 간혹 검출됩니다. 이틀동안 고생중입니다. 부탁드립니다.