커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내

안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
프로필 이미지
예스스탁
2026-02-27
6180
글번호 230811
지표

eiger 님에 의해서 삭제되었습니다.

프로필 이미지
eiger
2018-02-27
0
글번호 116949
시스템
답변완료

수식문의 합니다

수고하십니다 56841 답변 감사합니다 개별종목 data1의 10분봉 현재시점(오후 2시라고 가정)에서 10분봉 종가가 1) data2의 오늘현재 일봉기준 5 이평보다 크면 1, 아니면 0 20 이평보다 크면 1, 아니면 0 60 이평보다 크면 1, 아니면 0 의 합산점수 구하는 수식과 2) data2의 n일전 일봉기준 5 이평보다 크면 1, 아니면 0 20 이평보다 크면 1, 아니면 0 60 이평보다 크면 1, 아니면 0 의 합산점수 구하는 수식 부탁합니다.
프로필 이미지
dk3113
2018-02-26
196
글번호 116948
시스템
답변완료

data2

data2에 p1값을 불러올려고할때 dayclose는 for문에서 안된다는 글을 보았습니다. 그래서, var = dayv(0,data2); dayv = data2(closeD(0)); for count = 0 to P5{ if count < P1 Then sumV1 = sumV1+dayv(count); 이렇게하면 dayclose오류를 해결할 줄 알았는데 함수만이 입력값을 가질 수 있다고 나오네요. 저 로직은 data2차트에 일봉이평값을 가져오려고하는 것입니다. 왜 안되는지.. 2. data2에 있는 값을 가져오려면 현재 var로 선언된 내부변수에 모두 x(0,data2)처럼 다 적어야하나요? 3. sig = false; if 매매조건 then{ SIG = TRUE;} if sig then buy(); 이런식의 로직인데요. 이렇게했을때 sig = data2(false); if data2(매매조건) then{ data2(sig) = data2(TRUE);} if data2(sig) then buy(); 이렇게 덮어씌우면 되는지요. 너무 비효율적인데.. 응용되는 보조지표도 마찬가지입니다. var : x(0,data2); x = data2(n); if data2(x and n and a) then 이렇게가야하는지.. 4. 청산질문입니다. 이렇게하면되는지요. 모든걸 이렇게 data2로 진창도배해야하나요?? If data2(MarketPosition == 1) Then{ If data2(CrossUp(Close,openD(0))) Then ExitLong("시가매도청산"); 5. 진입횟수도 이렇게하면되나요? var : BLcnt(0),SLcnt(0),추격횟수(0); if Bdate != Bdate[1] Then{ BLcnt = 0; SLcnt = 0; 추격횟수 = 0; } if data2(TotalTrades > TotalTrades[1] and MarketPosition(1) == 1 and IsExitName("StopLoss",1) == true) Then BLcnt = BLcnt+1; if data2(TotalTrades > TotalTrades[1] and MarketPosition(1) == -1 and IsExitName("StopLoss",1) == true) Then SLcnt = SLcnt+1; 6. 사용자함수질문입니다. 제가만든 i라는 함수가 있습니다. 이것 역시 if data2(조건and i) then 하면 크게 상관은 없는거죠? 물론 함수의 경우 dayclose와같은 함수를 사용하는 구문은 없습니다. 7. 사진 첨부합니다. 오늘 하루동안 5이평을 3번 돌파하면 로직 부탁드립니다. 혹은 for 문으로 하는 방법이있는지요? 몇캔들이내에.. 라는 조건이야countif를 쓰면된다지만, 조건만족캔들범위가 제한적이다보니.. 8. 제가짠 이평하강 로직인데요. 작동이 안되네요. cnt = 0; cnt2 = 0; for cnt = 1 to 10{ if open[cnt] > ma(c,5)[cnt] and close[cnt] < ma(c,5)[cnt] then cnt2 + 1; } if cnt2 < 1 then { plotpaintbar} 이렇게 하면 이전에 나오는 5이평하강된곳에 페인트바가 나오지않습니다. 왜그런건가요? for문을 돌려 cnt2에 for문 조건만족을 하면 cnt2에 1씩 저장하고 if cnt2 < 1 then하면 조건값 저장으로 출력되야하는게 아니었는지요.
프로필 이미지
stockric
2018-02-27
237
글번호 116947
시스템
답변완료

문의드립니다.

Input : 매수가격(60.30),매도가격(60.00),당일수익틱수(100); Var : N1(0),dayPl(0),당일수익(0),Xcond(false),Tcond(false); var : T1(0),count(0); 당일수익 = PriceScale*당일수익틱수; if (sdate != sdate[1] and stime >= 80000) or (sdate == sdate[1] and stime >= 80000 and stime[1] < 80000) Then{ Tcond = true; Xcond = false; N1 = NetProfit; T1 = TotalTrades; } if MarketPosition == 0 Then count = TotalTrades-T1; Else count = TotalTrades-T1+1; if (sdate != sdate[1] and stime >= 055000) or (sdate == sdate[1] and stime >= 055000 and stime[1] < 055000) Then{ Tcond = false; if MarketPosition == 1 Then exitlong(); if MarketPosition == -1 Then ExitShort(); } daypl = NetProfit-N1; if TotalTrades > TotalTrades[1] and (IsExitName("dbp",1) == true or IsExitName("dsp",1) == true) then Xcond = true; if Tcond == true and Xcond == false then{ if H < 매수가격 Then{ buy("b",AtStop,매수가격+PriceScale*1,1+count*2); } if L > 매도가격 Then{ sell("s",AtStop,매도가격-PriceScale*1,1+count*2); } } if MarketPosition == 1 then{ ExitLong("dbp",atlimit,EntryPrice+((당일수익-daypl)/CurrentContracts)); } if MarketPosition == -1 then{ ExitShort("dsp",atlimit,EntryPrice-((당일수익-daypl)/CurrentContracts)); } 시작시간과 끝나는 시간을 빼고 싶습니다. 다른건 다 똑같고요. 제가 시간 뺄라고 해보니까 잘 안되네요. 부탁드리겠습니다. 그럼 수고하세요.
프로필 이미지
아침한때비51
2018-02-26
198
글번호 116946
시스템
답변완료

수식 문의합니다

안녕하세요 고점과 저점의 중심값을 선으로 나타내고 싶습니다 중심선0 .... 당일 고점과 저점의 중심선 중심선1 ... 1일전 과 당일의 고점과 저점의 중심선 중심선2 ... 2일전 과 당일의 고점과 저점의 중심선 중심선3 ... 3일전 과 당일의 고점과 저점의 중심선 중심선3 ... 4일전 과 당일의 고점과 저점의 중심선 1. 각각의 중심선 끝에 글자표시( 중심선0, 중심선1, 중심선2.....) 2. 중심선의 굵기는 제일 가늘게... 3. 글자크기는 8 정도 4. 중심선에 색을 넣어주세요 가능할가요? 부탁드립니다 수고하세요
프로필 이미지
정상에서야
2018-02-26
218
글번호 116945
지표
답변완료

부탁드립니다

수고하십니다(아래수식에서) *지그재그 파동마다, *상승시일때 1.저점에서부터오른쪽으로 검정색수평선 긋기 2.저점에서 다음첫번째양봉시가부터 오른쪽 빨강색수평선긋기 *((단 양봉으로 저점을 찌을때는 그양봉에 저가와시가에 수평선긋기))* *하락시일때 1.고점에서부터오른쪽으로 검정색수평선 긋기 2.고점에서 전첫번째 양봉종가부터 오른쪽 청색수평선긋기 *((단 양봉으로 고점을 찌을때는 그양봉에 고가와종가에 수평선긋기))* Input:length(6); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0), Text1(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); Text_Delete(Text1); } 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)); #Text_SetStyle(Text1, 2, 1); } } 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); Text_Delete(Text1); } 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)); #Text_SetStyle(Text1, 2, 0); } } TL_SetSize(TL1,3); TL_SetColor(TL1,CYAN);
프로필 이미지
파생돌이
2018-02-26
244
글번호 116944
지표
답변완료

수식 부탁드립니다

### 당일 제외한 과거 n일동안(변수조절) 최대거래량을 가진 캔들중에서 수식 구합니다 1) n일동안 가장 큰 양봉의 종가선을 현재까지 오른쪽 그리기 하고 꼬리제외한 양봉 몸통의 중심선을 현재까지 오른쪽 그리기 하면 좋겠습니다. $,단,1)의 값이 당일시가보다 위에(클때)있을 때에만 현재까지 오른쪽 그리기하고 종가,중심값을 출력하며,(만일 그 값이 시가보다 아래있을때는 생략하면 됩니다) 2) n일동안 가장 큰 음봉의 종가선을 현재까지 오른쪽 그리기 하고 꼬리제외한 음봉 몸통의 중심선을 현재까지 오른쪽 그리기 하면 좋겠습니다. $,단,2))의 값이 당일시가보다 아래에(작을때)있을 때에만 현재까지 오른쪽 그리기하고 종가,중심값을 출력하며,(만일 그 값이 시가보다 위에 있을때는 생략하면 됩니다) $$$ 도움주심에 미리감사드립니다.
프로필 이미지
회원
2018-02-26
235
글번호 116943
지표
답변완료

부탁 드립니다.

도움주심에 깊이 감사 드립니다. 1) 해선시작 시간(08:00)에 계산을 zero로 시작하여 익일(07:00)에 계산을 마치고 또 08:00에 zero로 계산을 시작하고 익일(07:00)에 계산을 마치는 수식 부탁 드립니다. 미리 경배의 마음으로 감사 드립니다. input : sig(10); var : g1(0),g2(0),x(0),b(0),y(0),b2(0); g1=iff(c>o,v,0); g2=iff(c<o,v,0); x=g1-g2; b=b+x; if date != date[1] Then b2 = b[1]; y=b-b2; var1 = ema(y,sig); plot1(var1); 2)다음 수식은 해선 당일의 진폭을 표시하고 있습니다만, 지나간날도 매일의 진폭을 표시 하도록 부탁 드리오며 , 아울러 틱정수화로 표시 된것도 pricescale(?)을 사용하도록 부탁 드립니다. input:시작시간(080010),끝시간(070000),틱정수화(10000); var:cond5(false),hh5(0),ll5(0),a5(0),b5(0),k5(0); var1=시작시간; var2=끝시간; if stime == var1 or (stime > var1 and stime[1] < var1) then{ cond5 = true; HH5 = H; LL5 = L; } if stime == var2 or (stime > var2 and stime[1] < var2 ) Then Cond5 = false; if cond5 == true then{ if H > HH5 Then HH5 = H; if L < LL5 Then LL5 = L; a5 = HH5; b5 = LL5; k5 =a5-b5; VAR:TX27(0); Text_Delete(tx27); Tx27 = Text_New(sdate[2],stime[2],b5,NumToStr(((a5-b5)*틱정수화),0)); Text_SetColor(tx27,MAGENTA); Text_SetStyle(tx27,2,1);}
프로필 이미지
yes
2018-02-27
228
글번호 116942
지표
답변완료

지표에관한 재질문

1. 거래정지에 관한 관련 재질문 1-1. 일봉값을 리턴한다는것이 무엇을 뜻하는건가요?? /그리고 closeD,highD,lowD,openD -> 지표의 뜻을 모르겟네요 끝에 D가 무엇을 뜻하는지 1-2. 밑의 리턴? 수식-> 5일이평선을 나타내고자할때, 수식지표내에 하루라도 거래정지가 있다면 밑에있는 수식을 그대로 쓴다면 된다는건가요? 수식기간내에 거래정지가 하루있든,이틀있든 상관없이 없다는건지.. var4 = (C + CloseD(1) + CloseD(2) + CloseD(3) + CloseD(4))/5; 1-3. 만약 위의 말이 아니라면 EX) 12월 11일 네이처셀 기준으로 5일의 이동평균선을 나타내려고한다고하면 12월 6일 - 거래정지 -> 12월 11일 기준으로 4일전 거래정지입니다] var4 = (C (당일) + dayclose(1) (전일) + dayClose(2) (2일전) +여기부분이 거래정지일+ dayclose(3) + dayClose(4))/5; -> 거래정지일에 closed를 넣으면 되는건지요??/ 1-4. 케이스2로 ex) 우리기술투자 9월 18일 기준으로 9월 22일까지 3거래일 [1일거래일 + 1일 거래정지 + 1일 거래일 +1일 거래정지 +1일 거래일] 이렇게 2일 거래정지인 경우에 분봉 3일 이평을 넣고 싶으면 어떻게 하면될까요 위와 비슷하지만 2거래일 경우 다를까해서 물어봅니다 2. 차트에 그림(추세선, 피보등등 그려넣은거)을 저장하려면 설정에서 어느부분을 체크하면되나요? 어쩔때는 저장이 되는데 이게 다시 hts를 켜면 리셋이 되는건지, 종목을 바꿀때마다 지워지는건지, 지표를 계속 추가해서그런건지... 이전에 그려놓앗던게 깨끗하게 지워져버려서 ㅜㅜ 설정법을 모르겟네요 + [피보나치를 그리면 시가에 정확히 맞출수없어서 입력에서 시작값 을 바꿔도 바뀌지가 않는데 오류가 있는건지 확인좀요.. 2월달 호텔신라우를 피보로 분석하려고하는데 입력으로 되지를 않아서 20분동안 겨우겨우해서 맞췃네요 ㅠㅠ 3. 6101, 6102 차트의 차이점은 날짜,건수는 알겠는데 그 외의 차이점은 무엇이 있나요 4. 키움수식인데 변환좀 부탁드릴게요!! -과열예고발동- A = sum(avg(c, 40, 1) * 1.3 <= C and avg(거래대금/C, 40, 1) * 6 <= avg(거래대금/C, 2) and avg(((h-l)/((h+l)/2)), 40, 1) * 1.5 <= avg(((h-l)/((h+l)/2)), 2) and C(1) < C); B = valuewhen(1, A(1) != A, C); if(A(1) - A(10) >= 1, B(1) < C and A(1) != A, A(1) != A) -과열예고적출- A = avg(c, 40, 1) * 1.3 <= C and avg(거래대금/C, 40, 1) * 6 <= avg(거래대금/C, 2) and avg(((h-l)/((h+l)/2)), 40, 1) * 1.5 <= avg(((h-l)/((h+l)/2)), 2) and C(1) < C; B = sum(A); B(1) - B(10) == 0 and A == 1 -선- ( ((DayHigh()+Daylow())/2)+((predayhigh()+predaylow())/2)+((npredayhigh(2)+npredaylow(2))/2)+((npredayhigh(3)+npredaylow(3))/2)+((npredayhigh(4)+npredaylow(4))/2) +((npredayhigh(5)+npredaylow(5))/2)+((npredayhigh(6)+npredaylow(6))/2)+((npredayhigh(7)+npredaylow(7))/2)+((npredayhigh(8)+npredaylow(8))/2) )/9 -또다른선- (Daylow()+predaylow()+npredaylow(2)+npredaylow(3)+npredaylow(4)+npredaylow(5))/6
프로필 이미지
sdsadsa
2018-02-26
352
글번호 116932
지표