커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

수식 여쭤봅니다~ㅎ

안녕하세요? 수식 여쭤봅니다. 거래는 60분봉에서 하려고 합니다. 매수금액 과 이평선 설정을 변수로 조정할수 있었음 합니다. **매수) 1차매수 주가가 위에서 부터 떨어져서 분봉상 400일선 5% 까지 근접하는순간 물량의 30% 매수 2차매수 주가가 위에서 부터 떨어져서 분봉상 400일선을 데드크로스 하는 순간 물량의 30% 매수 3차매수 주가가 위에서 부터 떨어져서 분봉상 400일선에서 -5% 까지 떨어지는 순간 물량의 40% 매수 **매도) 1차 매수든 2차매수든 3차매수든 매수가 일어나고 3% 상승시 가진 물량의 30% 매도 6% 상승시 가진 물량의 50% 매도 10% 상승시 가진 물량 전부 매도 **이익보전) 1차 매수든 2차매수든 3차매수든 매수가 일어나고 3% 상승후 다시 1.5%로 떨어질시 가진물량의 50% 매도 3% 상승후 다시 1%로 떨어질시 전부 매도 6% 상승후 다시 3.5%로 떨어질시 가진 물량의 50% 매도 6% 상승후 다시 3%로 떨어질시 가진 물량 전부 매도 10% 상승후 다시 8%떨어질시 가진 물량의 50% 매도 10% 상승후 다시 7%떨어질시 가진 물량 전부 매도 **날짜 지남에 따라 매도) 매수후 +1일 09시30분에 가진 물량의 20% 매도 매수후 +2일 09시30분에 가진 물량의 20% 매도 매수후 +3일 09시30분에 가진 물량의 20% 매도 매수후 +4일 09시30분에 가진 물량 전부 매도 **손절) 현재 매수 평단가에서 -15% 하락시 가진 물량의 50% 매도 -20% 하락시 전부 매도 **어떤 식으로든 전체 물량이 매도된 날에 재매수 금지) 감사합니다~
프로필 이미지
부자청년28
2019-07-21
236
글번호 130528
시스템
답변완료

청산로직 요청 드립니다.

* 많은 도움에 항상 고맙 습니다. * 청산 때문에 머리가 아픕니다^^ * 수백번 해보지만 변수가 너무 많아서 한가지 로직 가지고는 청산이 안됨니다. <요청사항> 아래 수식 가지고 청산 로직이 가능 하도록 변형 수식 좀 하는데 잘 안됨니다. 수정 좀 부탁 드리겠습니다. *기준: 수익,손실 구간을 지정해 놓고 한구간 이상 떨어지면 자동 청산 입니다. → 주석 참고부탁 드립니다. ◈◈◈ 아래 한가지 케이스만 해 주시면 나름 공부 하면서 응용 하겠습니다. ◈◈◈ ## 구간 설정 : 10틱 단위로 상승과 하락 구간 설정 Inputs: HH1(10),HH2(20),HH3(30),HH4(40),HH5(50),HH6(60),HH7(70),HH8(80),HH9(90); Inputs: LL1(10),LL2(20),LL3(30),LL4(40),LL5(50),LL6(60),LL7(70),LL8(80),LL9(90); ## value11 = (진입가격+10틱) - 현재가 ## 수익 구간 value11 = PriceScale*HH1 - C ; ## 진입후 수익 틱수 value12 = PriceScale*HH2 - C ; value13 = PriceScale*HH3 - C ; value14 = PriceScale*HH4 - C ; value15 = PriceScale*HH5 - C ; value16 = PriceScale*HH6 - C ; value17 = PriceScale*HH7 - C ; value18 = PriceScale*HH8 - C ; value19 = PriceScale*HH9 - C ; ## value21 = 현재가 - (진입가격-10틱) ## 손실 구간 value21 = C - PriceScale*LL1 ; ## 진입후 손실 틱수 value22 = C - PriceScale*LL2 ; value23 = C - PriceScale*LL3 ; value24 = C - PriceScale*LL4 ; value25 = C - PriceScale*LL5 ; value26 = C - PriceScale*LL6 ; value27 = C - PriceScale*LL7 ; value28 = C - PriceScale*LL8 ; value29 = C - PriceScale*LL9 ; ## 수익 청산 if MarketPosition == 1 and(c > value11 OR c > value12 OR c > value13) then{ ExitLong("DD1",AtLimit, c < value12); } ## 매수 진입후 최대 수익이 value11(10틱), value12(20틱), value13(30틱) 이상 까지 계속 수익 이었는데 갑자기 하락 하여 value12 보다 작아 지면 수익 청산 (20틱 수익 청산) if MarketPosition == -1 and(c < value21 OR c < value22 OR c < value23) then{ ExitShort("SS1",AtLimit, c > value12);} ## 매도 진입후 최대 수익이 value21(10틱), value22(20틱), value23(30틱) 이상 까지 수익 이었는데 갑자기 상승(손실) 하여 value22 보다 크면 수익 청산 (20틱 수익 청산) ## 손실 청산 if MarketPosition == 1 and(c < value21 OR c < value22 OR c < value23) then{ ExitLong("DD1",AtLimit, c < value24); } ## 매수 진입후 최대 손실이 value21(10틱), value22(20틱), value33(30틱) 이상 까지 손실이고 더 하락 하여 value24 보다 더 작아 지면 손실 청산 (손실 40틱 청산) if MarketPosition == -1 and (c > value11 OR c > value12 OR c > value13) then{ ExitShort("sp",AtLimit, c < value14); } ## 매도 진입후 최대 손실이 value11(10틱), value12(20틱), value13(30틱) 이상 까지 손실이고 더 상승 하여 value14 보다 크면 손실 청산 (손실 40틱 청산) * 매번 고맙습니다. * 청산이 너무 어렵네요.... ...
프로필 이미지
요타
2019-07-23
239
글번호 130527
강조
답변완료

질문드립니다.

분할 청산식을 어떻게 작성하는지 잘 모르겠습니다.. 만약 // input : 진입금액(1000000) ; var : 손절가(0) ; if crossup(c,ma(c,20)) Then { buy("진입1",OnClose,def,floor(진입금액/c)) ; 손절가 = L ; } // 위와 같은 진입수식을 작성했다면 - 손절가 1틱 이탈시 가진 물량 전부 청산 - crossup(c,ma(c,5)) 조건 발생시 진입 물량의 30퍼 청산 ( 30만원어치) - crossup(c,ma(c,20)) 조건 발생시 진입 물량의 30퍼 청산 (30만원어치) - crossup(c,ma(c,60)) 조건 발생시 가진 물량을 전부 청산 이렇게 매수한 물량을 나눠서 청산하고 싶을 경우 어떻게 수식을 짜야 하나요?
프로필 이미지
도롱이
2019-07-21
194
글번호 130526
시스템
답변완료

지표부탁합니다.

안녕하세요. 전고전저에 수치나오게 부탁합니다. input : occur(1), left(3), right(3), period(200); var1 = SwingHigh(occur,H,left,right,period); //전고점 var2 = swinglow(occur,L,left,right,period); // 전저점 plot1(var1, "전고점"); plot2(var2, "전저점"); 고점가격은 위에 나오고 저점은 아래에 나오게 부탁드립니다. 그리고 텍스트 사이즈가 차트상 최고점 최저점 사이즈면 좋을것 같습니다. 수소하세요..
프로필 이미지
묵연히
2019-07-21
225
글번호 130525
지표
답변완료

수식수정부탁드립니다

#,안녕하세요 1,아래수식은 월간,대칭 수식인데요,이식을 날짜를 지정해서 지정한날로부터 영업일수로 25일 다음날에 초기화 되는 수식으로 수정하고 싶습니다,도움부탁드립니다, (지정날짜와 영업일수는 외부변수로 하면좋겠습니다). 2,아래식을 날짜를 지정(년월일)하여시작하고 날짜를 지정하여 종료후 초기화 되는 식으로 수정 부탁드립니다, 3,수고스럽지만 위두개(1,2)식을 별도로 작성부탁드립니다 input : Per1(9),Per2(18); Var : pivot(0),S1(0),S2(1),S3(1),S4(1),S5(0),cnt(0),t1(0),t2(0),t3(0),t4(0),t5(0); Array : oo[10](0),hh[10](0),ll[10](0),cc[10](0); if bdate > bdate[1]+30 then { oo[0] = o; hh[0] = h; ll[0] = L; for cnt = 1 to 9 { oo[cnt] = oo[cnt-1][1]; hh[cnt] = hh[cnt-1][1]; ll[cnt] = ll[cnt-1][1]; cc[cnt] = cc[cnt-1][1]; } } if h > hh[0] Then hh[0] = h; if l < ll[0] Then ll[0] = l; cc[0] = c; if hh[1] > 0 and ll[1] > 0 then { S1 = (hh[0]+ll[0])/2; S2 = (hh[1]+ll[1])/2; S3 = hh[1]; S4 = ll[1]; s5 = oo[0]; plot1(10^(LOG10(oo[0]))); plot2(10^(LOG10(cc[1])+(LOG10(S3)-LOG10(S4))*(Per1/100))); plot3(10^(LOG10(cc[1])-(LOG10(S3)-LOG10(S4))*(Per1/100))); plot4(10^(LOG10(cc[1])+(LOG10(S3)-LOG10(S4))*(Per2/100))); plot5(10^(LOG10(cc[1])-(LOG10(S3)-LOG10(S4))*(Per2/100))); } Text_Delete(t1); Text_Delete(t2); Text_Delete(t3); Text_Delete(t4); Text_Delete(t5); t1 = Text_New(sdate,stime,10^(LOG10(cc[1])+(Log10(S3)-log10(S4))*(Per1/100))," mb:"+NumToStr(10^(LOG10(cc[1])+(Log10(S3)-log10(S4))*(Per1/100)),2)); t2 = Text_New(sdate,stime,10^(LOG10(cc[1])-(Log10(S3)-log10(S4))*(Per1/100))," ms:"+NumToStr(10^(LOG10(cc[1])-(Log10(S3)-log10(S4))*(Per1/100)),2)); t3 = Text_New(sdate,stime,10^(LOG10(cc[1])+(Log10(S3)-log10(S4))*(Per2/100))," MB:"+NumToStr(10^(LOG10(cc[1])+(Log10(S3)-log10(S4))*(Per2/100)),2)); t4 = Text_New(sdate,stime,10^(LOG10(cc[1])-(Log10(S3)-log10(S4))*(Per2/100))," MS:"+NumToStr(10^(LOG10(cc[1])-(Log10(S3)-log10(S4))*(Per2/100)),2)); t5 = Text_New(sdate,stime,s5," MO:"+NumToStr(s5,2)); Text_SetStyle(t1,5,2); Text_SetStyle(t2,5,2); Text_SetStyle(t3,5,2); Text_SetStyle(t4,5,2); Text_SetStyle(t5,5,2); Text_SetColor(t1,RED); Text_SetColor(t2,BLUE); Text_SetColor(t3,RED); Text_SetColor(t4,BLUE); Text_SetColor(t5,RED); $$$,언제나 늘 고맙습니다.
프로필 이미지
회원
2019-07-23
244
글번호 130524
지표
답변완료

수식 수정 부탁드립니다~

안녕하세요? 1분봉에 적용하는 식이구요~ 아래의 식은 조건만족시 3시10분에 매수가되도록 되어 있는데요. 아래 1) 2) 3) 조건을 추가하고 싶습니다~ 1) 3시10분에 [일봉상 캔들이] [도지] 캔들일때는 매수가 안되게 하고 싶습니다. 예를들어) 일봉 캔들의 시가 ~ 현재가 범위가 음봉 양봉 상관없이 0.5% 이내일때 매수 금지 2) 가지고 있던 전체물량이 매도되어 물량이 0 이 되는 그 당일날은 재매수가 안일어나게 하고 싶습니다. 감사합니다 input : 금액(3000000); var : 상한가(0), UpLimit(0),count(0),entry(0); var : up1(0), up2(0), up3(0), up4(0), up5(0),up6(0),Up7(0); if date >= 19981207 then { if date < 20050328 && CodeCategory() == 2 then UpLimit = (BP[0] * 1.12); Else if date >= 20050328 and date < 20150615 Then UpLimit = (BP[0] * 1.15); Else UpLimit = (BP[0] * 1.30); if CodeCategory() == 2 then { if date >= 20030721 then { up1 = int(UpLimit/100+0.00001)*100; up2 = int(UpLimit/100+0.00001)*100; up3 = int(UpLimit/100+0.00001)*100; up4 = int(UpLimit/50+0.00001)*50; up5 = int(UpLimit/10+0.00001)*10; up6 = int(UpLimit/5+0.00001)*5; up7 = int(UpLimit/1+0.00001)*1; } else { up1 = int(UpLimit/1000+0.00001)*1000; up2 = int(UpLimit/500+0.00001)*500; up3 = int(UpLimit/100+0.00001)*100; up4 = int(UpLimit/50+0.00001)*50; up5 = int(UpLimit/10+0.00001)*10; up6 = int(UpLimit/10+0.00001)*10; up7 = int(UpLimit/1+0.00001)*1; } } Else { up1 = int(UpLimit/1000+0.00001)*1000; up2 = int(UpLimit/500+0.00001)*500; up3 = int(UpLimit/100+0.00001)*100; up4 = int(UpLimit/50+0.00001)*50; up5 = int(UpLimit/10+0.00001)*10; up6 = int(UpLimit/5+0.00001)*5; up7 = int(UpLimit/1+0.00001)*1; } if CodeCategory() == 1 || CodeCategory() == 2 then { if sdate < 20101004 Then { If BP >= 500000 Then 상한가 = up1; Else If BP >= 100000 Then 상한가 = iff(up2>=500000, up1, up2); Else If BP >= 50000 Then 상한가 = iff(up3>=100000, up2, up3); Else If BP >= 10000 Then 상한가 = iff(up4>=50000, up3, up4); Else If BP >= 5000 Then 상한가 = iff(up5>=10000, up4, up5); Else If BP >= 1000 Then 상한가 = iff(up5>=5000, up5, up6); Else 상한가 = iff(up6>=1000, up6, up6); } Else { If BP >= 500000 Then 상한가 = up1; Else If BP >= 100000 Then 상한가 = iff(up2>=500000, up1, up2); Else If BP >= 50000 Then 상한가 = iff(up3>=100000, up2, up3); Else If BP >= 10000 Then 상한가 = iff(up4>=50000, up3, up4); Else If BP >= 5000 Then 상한가 = iff(up5>=10000, up4, up5); Else If BP >= 1000 Then 상한가 = iff(up5>=5000, up5, up6); Else 상한가 = iff(up6>=1000, up6, up7); } } else if CodeCategory() == 8 || CodeCategory() == 9 then { // ETF 상한가 = up6; } } if bdate != bdate[1] Then entry = 0; if MarketPosition(0) != 0 and MarketPosition(0) != MarketPosition(0)[1] Then entry = entry+1; if entry < 1 and MarketPosition == 0 and stime >= 151000 and stime[1] < 151000 and dayhigh < Dayclose(1)*1.12 and DayClose(1) > dayopen(1) and DayClose(0) > dayopen(0) and DayHigh < 상한가 then buy("매수☆",OnClose,def,Floor(금액/c)); if MarketPosition == 1 Then { if sdate > EntryDate and stime >= 92000 and stime[1] < 92000 Then { count = count+1; if count == 1 Then ExitLong("1일",OnClose,def,"",floor(CurrentContracts*0.25),1); if count == 2 Then ExitLong("2일",OnClose,def,"",floor(CurrentContracts*0.33),1); if count == 3 Then ExitLong("3일",OnClose,def,"",floor(CurrentContracts*0.50),1); if count == 4 Then ExitLong("4일"); } ExitLong("3%",atlimit,EntryPrice*1.03,"",Floor(CurrentContracts*0.50),1); ExitLong("12%",atlimit,EntryPrice*1.12,"",Floor(CurrentContracts*0.50),1); ExitLong("15%",atlimit,EntryPrice*1.15); ExitLong("5%손",AtStop,EntryPrice*0.95); } Else count = 0;
프로필 이미지
부자청년28
2019-07-21
253
글번호 130523
시스템
답변완료

수식 추가부탁드립니다.

안녕하세요? 아래와 같은 답변 감사히 받았습니다. 추가하고싶은것 한가지가 있어서 질문드렸구요, 아래의 수식에서 하루 매매횟수를 변수로 지정하였으면 합니다. 감사합니다. 수고하세요~!!! input : 매수틱(5),매도틱(5); input : 익절틱수(20),손절틱수(20); if C == O+PriceScale*매수틱 Then#지정한 틱수의 몸통이면 == buy("b"); if C == O-PriceScale*매도틱 Then#지정한 틱수의 몸통이면 == sell("s"); SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop);
프로필 이미지
대구어린울프
2019-07-22
248
글번호 130522
시스템
답변완료

지표 수식으로 변환부탁

다음 수식을 지표 수식으로 변환부탁드립니다. <1> t1=tema(c,period); x=valuewhen(1,crossdown(c,t1), highestsince(1,crossup(c,t1),t1)); period 20 지표색깔 빨강 <2> t1=tema(c,period); y=valuewhen(1,crossup(c,t1), lowestsince(1,crossdown(c,t1),t1)); period 20 지표색깔 검정
프로필 이미지
이대표
2019-07-20
422
글번호 130521
지표
답변완료

매수후 일정가격에 매도하는법

수고하십니다 input : P1(5),P2(20),P3(60); var1 = ma(C,P1); var2 = ma(C,P2); var3 = ma(C,P3); var4 = 0; Condition1 = var1 > var2; // and var2 > var3; if Condition1 == true and Condition1[1] == false Then buy("bbbbb"); // 매수진입후 종가기준 최고가에서 10% 하락시 청산 if marketposition == 1 Then { if Highest(H,BarsSinceEntry) Then ExitLong("sssss"); } 지난번 질문(63378)에 대한 답변으로 메크로를 작성하여 주신걸 시뮬에이션해보니 결과가 제가 생각하는 바와 너무 달라서 이거저거 변행해가며 확인중에 질문을 드립니다 1. 제일 좌측(14일자)에서 신호가 나와 매수했는데, 저의 예상으로는 2번재 기호(2월 25일)에 매도 신호가 나오면 최적이겠다 싶은데,,,이외로 바로 다음날 매도신호가 나오네요 물론 3번째 신호도 그렇고,,,왜 그런가요??? 2. Highest(H,BarsSinceEntry) ==> 설명서에 보면은 이 식같은경우 진입후 최고가라고 나오는데,, 실시간에서는 진행중이므로 미리 예측할수는 없을테니 제 생각데로 안나올수도 있겠다 싶은데,, 시뮬에이션차트에서는 2월 25일자 값이 나와야 할것 같은데,,, 3. 실시간챠트(시뮬레이션챠트도)에서 현재가를 알수있는 변수나 방법이 뭔가요.. 나의 매수가격이 현재가 보다 150%이상이면 매도한다 라는 식으론 구현 못하나요??? 주가가 8000원에 매수했는데 9500원이면 매도하라,,,,,식으로, 이에 더블어 7천원이면 손절하라,,, 추가로 1. YesLanguage에 들어가 보면 명령이나 랭귀지 사용법등이 나오는데 함수, 예약어등에서 어떤함수는 시스템에서만 사용가능하고 어떤 함수는 검색에서만 가능하고 하는데 이걸 구분하는 방법은 있나요?? 아님 하나씩 구현해가며 터득해야하나요(검증하다보면 Error로 나오던데,,) 2. 예스랭귀지 편집기 화면(화일관리자)에서 "검색"과 "종목검색"의 차이점은 뭔가요??? 즐거운 주말되시길바랍니다,,
프로필 이미지
atmskill
2019-07-20
428
글번호 130520
시스템