커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

파동선을 만들수 있을까요?

기존에 쓰던 파동선이 있지만 파동선이 너무 크게 나오는것 같아서 새로 만들고 싶은데요. 작은파동이 모여 추세선을 만들고 추세선을 모아 추세대를 만들수 있는걸로 압니다. 제가 원하는 파동선은 그중에서도 가장 적다고 보는게 맞을거 같은데 최저점 최고점을 기준으로 올라갈땐 빨간캔들이 올라가다 파란캔들로 조금이라도 눌림을 주면 파동을 잡어서 선을 만들고 싶습니다. 최저점 기준으로 눌림주고 그 눌림목보다 무조건 높아지면 또 파동긋고 또 그 위에서 눌림주면 긋고싶은데 캔들기준으로요. 만들수 있을까요?
프로필 이미지
양정희
2019-07-22
308
글번호 130530
지표
답변완료

문의 드립니다.

수식1)을 지정된 년월일 이후에 high 수식2)를 지정된 년월일 이후에 open 값을 나태내는 함수식 으로 수정 부탁 드립니다. 미리 감사 드립니다. 수식1) Input:n(Numeric); Var:j(0); Array:MonthH[100](0); If Int(Date/100)[1] < Int(Date/100) Then { For j = 99 DownTo 1 { MonthH[j] = MonthH[j-1]; } MonthH[0] = H; } If MonthH[0] < H Then MonthH[0] = H; MonthHigh = MonthH[n]; 수식2) Input:n(Numeric); Var:j(0); Array:MonthO[100](0); If Int(Date/100)[1] < Int(Date/100) Then { For j = 99 DownTo 1 { MonthO[j] = MonthO[j-1]; } MonthO[0] = Open; } MonthOpen = MonthO[n];
프로필 이미지
뮬리
2019-07-22
197
글번호 130529
지표
답변완료

수식 여쭤봅니다~ㅎ

안녕하세요? 수식 여쭤봅니다. 거래는 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
214
글번호 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
216
글번호 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
173
글번호 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
199
글번호 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
221
글번호 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
219
글번호 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
226
글번호 130522
시스템