커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

문의

아래수식과 반대인 exitshort 수식 부탁드립니다. *********************************************************************************** 안녕하세요 예스스탁입니다. 식을 수정해 드립니다. input : 시간(130000),봉갯수(100),HLRANGE(0.50); var : hh(0),ll(0),ii(0); if bdate != bdate[1] Then { hh = 0; ll = 0; ii = 0; } if stime >= 시간 then { ii = ii +1; if hh == 0 or (hh > 0 and h > hh) Then hh = h; if ll == 0 or (ll > 0 and l < ll) Then ll = l; if ii >= 봉갯수 and hh-ll >= HLRANGE Then ExitLong(); }
프로필 이미지
목마와숙녀
2019-03-22
380
글번호 127323
시스템
답변완료

차트 참조에서

차트 참조에서 코스피하락종목수/(코스피상승종목수+코스피하락종목수)*100 지표 부탁드립니다
프로필 이미지
팔보채
2019-03-22
356
글번호 127321
지표
답변완료

수식 검토

아래 buy 청산수식을 역으로 참조하여 sell 청산수식을 작성해보았는데 시뮬레이션이 되지 않습니다. 살펴주세요 input: 특정시간(130000); input : X1(20),CR(8),CF(0); var : EL(0),E1(0),H1(0),i1(0),S1(0); if stime >= 특정시간 Then { if stime[1] < 특정시간 Then { EL = L; E1 = 0; } if L < EL Then{ EL = L; E1 = 0; } if E1 == 0 and C >= EL+PriceScale*X1 Then{ E1 = 1; H1 = H; i1 = index; } if E1 == 1 and index > i1 Then{ if H > H1 Then H1 = H; if L <= H1-PriceScale*CR Then{ E1 = 2; I1 = index; S1 = H1; } } if E1 == 2 and index > i1 and C >= S1+PriceScale*CF Then{ ExitShort("sx"); E1 = 0; } } *************************************************************************************** 안녕하세요 예스스탁입니다. input: 특정시간(130000); input : X1(20),CR(8),CF(0) ; var : EH(0),E1(0),i1(0),S1(0),L1(0); if stime >= 특정시간 Then { if stime[1] < 특정시간 Then { EH = H; E1 = 0; } if H > EH Then { EH = H; E1 = 0; } if E1 == 0 and C <= EH-PriceScale*X1 Then { E1 = 1; L1 = L; i1 = index; } if E1 == 1 and index > i1 Then { if L < L1 Then L1 = L; if H >= L1+PriceScale*CR Then { E1 = 2; I1 = index; S1 = L1; } } if E1 == 2 and index > i1 and C <= S1-PriceScale*CF Then { exitlong("bx"); E1 = 0; } } 즐거운 하루되세요
프로필 이미지
목마와숙녀
2019-03-22
356
글번호 127315
시스템
답변완료

변수값

아래 수식 (가) 는 정상적으로 작동 됩니다. 그런데 수식(나) 로 변경 하였는데 변수 L 값에 관계없이 수식(가)의 진입신호와 동일하게 발생합니다 수식(나) 의 수식이 변수 L 값에 따라 진입신호가 바르게 작동 되도록 (나)의 수식을 수정하여 주십시요. 수식(가) If c > (LRLs[1] + K) Then Buy(); If c < (LRLs[1] - K) Then Sell(); 수식(나) If abs(LRLs[1] - LRLs1[2]) < L Then { If c > (LRLs[1] + K) Then Buy(); If c < (LRLs[1] - K) Then Sell(); }
프로필 이미지
너무조아
2019-03-22
356
글번호 127312
시스템
답변완료

수식문의요

수식1 sc=Stochasticsslow(sto1,sto2); valuewhen(1,crossdown(sc,hp),low) 수식2 sc=Stochasticsslow(sto1,sto2); valuewhen(1,crossup(sc,lp),high) sto1 12 sto2 5 hp 60 lp 40 키움변환 부탁드립니다 항상 감사합니다
프로필 이미지
장군777
2019-03-22
396
글번호 127310
지표
답변완료

수식 문의 드립니다....^^

수고가 많으시죠.... 1. 고가가 볼린저밴드 상단에 20일 이내에 있고 Macd 데드크로스에 매도 2. 저가가 볼린저밴드 하단에 20일 이내에 있고 Macd 골든크로스에 매수 B Bands (80, 2) MACD( 24, 52, 9) 입니다...수고하세요....^^
프로필 이미지
우섭
2019-03-22
372
글번호 127307
시스템
답변완료

함수요청

안녕하세요? 유렉스 거래소 상품 거래시간을 표현하고 싶습니다. (유럽의 일광 절약 시간제는 3월 마지막 일요일에 시작하여 10월 마지막 일요일에 해제됩니다.) 아래는 작성주신 시카고거래소 상품 거래시간입니다. (미국의 일광 절약 시간제는 3월의 두 번째 일요일에 시작하여 11월 첫 일요일해제됩니다.) Var : st(0), et(0),year(0); var : V1(0),V2(0),v99(0); Year = Floor(sDate / 10000)*10000; V1 = Dayofweek((10000 * Year) + (100 * 3) + 1); If V1 == 0 Then Value2 = 8; Else Value2 = 15 - V1; // 3월 두번째 일요일 날짜 V2 = Dayofweek((10000 * Year) + (100 * 11) + 1); If V2 == 0 Then Value4 = 1; Else value4 = 8 - V2; // 11월 첫번째 일요일 날짜 If sdate > (10000 * Year) + (100 * 3) + value2 And sdate < (10000 * Year) + (100 * 11) + value4 Then Begin st = 070000; // 써머타임 적용 시, 장시작 시간 et = 060000; // 써머타임 적용 시, 장종료 시간 End Else Begin st = 080000; // 장 시작 시간 et = 070000; // 장 종료 시간 End; condition1 = (IntPortion(stime/10000) > IntPortion(et/10000) And IntPortion(stime[1]/10000) <= IntPortion(et/10000)) Or st <> st[1];
프로필 이미지
흰둥이아빠
2019-03-22
378
글번호 127306
시스템
답변완료

문의

시뮬레이션을 통해 시간 변화값, 봉갯수 변화값, HL RANGE 변화값이 모두 나와야하는데 HL RANGE 값만 나오지 않습니다. 시간,봉갯수,HL RANGE 3개가 연동될 수 있도록 부탁드립니다. *************************************************************************** 안녕하세요 예스스탁입니다. input : 시간(130000),봉갯수(100),HLRANGE(0.50); var : hh(0),ll(0),ii(0); if bdate != bdate[1] Then { hh = 0; ll = 0; ii = 0; } if stime >= 시간 then { ii = ii +1; if h > hh Then hh = h; if l < ll Then ll = l; if ii >= 봉갯수 and hh-ll >= HLRANGE Then ExitLong(); } 즐거운 하루되세요 > 목마와숙녀 님이 쓴 글입니다. > 제목 : 수식 문의 > 청산수식을 문의드립니다. 입력한 시간부터 봉갯수를 카운트하고 고가저가를 파악합니다. 13시부터 봉개수 100개 되고 고가저가의 RANGE가 0.5이하면 청산합니다. input : 시간(130000),봉갯수(100),HL RANGE(0.50) 항상 고맙습니다.
프로필 이미지
목마와숙녀
2019-03-22
364
글번호 127305
시스템
답변완료

문의드립니다

아래 전략 3가지 에서 손절 30 익절 30 외부 변수로 추가 부탁드립니다 1 input : P1(9),P2(13); Var : cnt(0),Nth(0),tempmax(0), tempindex(0), X1(0),RCI1(0),X2(0),RCI2(0); Array : VALUE1[50](0),VALUE2[50](0),NTHVALUE[50](0); for cnt = 0 to 49{ VALUE1[cnt] = C[cnt]; VALUE2[cnt] = C[cnt]; } ############################################### For Nth = 0 to P1-1 { tempmax = -99999999; For cnt = 0 to P1-1{ if VALUE1[cnt] > tempmax then{ tempmax = VALUE1[cnt]; tempIndex = cnt; NTHVALUE[cnt] = Nth+1; } } VALUE1[tempIndex] = -99999999; } X1 = 0; for cnt = 0 to P1-1{ X1 = X1+ABS((cnt+1)-NTHVALUE[cnt])^2; } RCI1 = (1-(6*X1)/(P1*(P1^2-1)))*100; ############################################### For Nth = 0 to P2-1 { tempmax = -99999999; For cnt = 0 to P2-1{ if value2[cnt] > tempmax then{ tempmax = value2[cnt]; tempIndex = cnt; NTHVALUE[cnt] = Nth+1; } } VALUE2[tempIndex] = -99999999; } X2 = 0; for cnt = 0 to P2-1{ X2 = X2+ABS((cnt+1)-NTHVALUE[cnt])^2; } RCI2 = (1-(6*X2)/(P2*(P2^2-1)))*100; if RCI1 > 80 and RCI2 > 80 and CrossDown(RCI1,RCI2) Then sell(); if RCI1 < -80 and RCI2 < -80 and CrossUp(RCI1,RCI2) Then buy(); 2 input : P1(9),P2(13),P3(18); Var : cnt(0),Nth(0),tempmax(0), tempindex(0), X1(0),RCI1(0),X2(0),RCI2(0),X3(0),RCI3(0); Array : VALUE1[50](0),VALUE2[50](0),VALUE3[50](0),NTHVALUE[50](0); for cnt = 0 to 49{ VALUE1[cnt] = C[cnt]; VALUE2[cnt] = C[cnt]; VALUE3[cnt] = C[cnt]; } ############################################### For Nth = 0 to P1-1 { tempmax = -99999999; For cnt = 0 to P1-1{ if VALUE1[cnt] > tempmax then{ tempmax = VALUE1[cnt]; tempIndex = cnt; NTHVALUE[cnt] = Nth+1; } } VALUE1[tempIndex] = -99999999; } X1 = 0; for cnt = 0 to P1-1{ X1 = X1+ABS((cnt+1)-NTHVALUE[cnt])^2; } RCI1 = (1-(6*X1)/(P1*(P1^2-1)))*100; ############################################### For Nth = 0 to P2-1 { tempmax = -99999999; For cnt = 0 to P2-1{ if value2[cnt] > tempmax then{ tempmax = value2[cnt]; tempIndex = cnt; NTHVALUE[cnt] = Nth+1; } } VALUE2[tempIndex] = -99999999; } X2 = 0; for cnt = 0 to P2-1{ X2 = X2+ABS((cnt+1)-NTHVALUE[cnt])^2; } RCI2 = (1-(6*X2)/(P2*(P2^2-1)))*100; ############################################### For Nth = 0 to P3-1 { tempmax = -99999999; For cnt = 0 to P3-1{ if value3[cnt] > tempmax then{ tempmax = value3[cnt]; tempIndex = cnt; NTHVALUE[cnt] = Nth+1; } } VALUE3[tempIndex] = -99999999; } X3 = 0; for cnt = 0 to P3-1{ X3 = X3+ABS((cnt+1)-NTHVALUE[cnt])^2; } RCI3 = (1-(6*X3)/(P3*(P3^2-1)))*100; if RCI1 > 80 and RCI2 > 80 and RCI3 > 80 and CrossDown(RCI1,RCI3) Then sell(); if RCI1 < -80 and RCI2 < -80 and RCI2 < -80 and CrossUp(RCI1,RCI3) Then buy(); 3 input : P1(9),P2(13),P3(18); Var : cnt(0),Nth(0),tempmax(0), tempindex(0), X1(0),RCI1(0),X2(0),RCI2(0),X3(0),RCI3(0); Array : VALUE1[50](0),VALUE2[50](0),VALUE3[50](0),NTHVALUE[50](0); for cnt = 0 to 49{ VALUE1[cnt] = C[cnt]; VALUE2[cnt] = C[cnt]; VALUE3[cnt] = C[cnt]; } ############################################### For Nth = 0 to P1-1 { tempmax = -99999999; For cnt = 0 to P1-1{ if VALUE1[cnt] > tempmax then{ tempmax = VALUE1[cnt]; tempIndex = cnt; NTHVALUE[cnt] = Nth+1; } } VALUE1[tempIndex] = -99999999; } X1 = 0; for cnt = 0 to P1-1{ X1 = X1+ABS((cnt+1)-NTHVALUE[cnt])^2; } RCI1 = (1-(6*X1)/(P1*(P1^2-1)))*100; ############################################### For Nth = 0 to P2-1 { tempmax = -99999999; For cnt = 0 to P2-1{ if value2[cnt] > tempmax then{ tempmax = value2[cnt]; tempIndex = cnt; NTHVALUE[cnt] = Nth+1; } } VALUE2[tempIndex] = -99999999; } X2 = 0; for cnt = 0 to P2-1{ X2 = X2+ABS((cnt+1)-NTHVALUE[cnt])^2; } RCI2 = (1-(6*X2)/(P2*(P2^2-1)))*100; ############################################### For Nth = 0 to P3-1 { tempmax = -99999999; For cnt = 0 to P3-1{ if value3[cnt] > tempmax then{ tempmax = value3[cnt]; tempIndex = cnt; NTHVALUE[cnt] = Nth+1; } } VALUE3[tempIndex] = -99999999; } X3 = 0; for cnt = 0 to P3-1{ X3 = X3+ABS((cnt+1)-NTHVALUE[cnt])^2; } RCI3 = (1-(6*X3)/(P3*(P3^2-1)))*100; if RCI1 > 80 and RCI2 > 80 and CrossDown(RCI1,RCI2) Then sell(); if RCI1 < -80 and RCI2 < -80 and CrossUp(RCI1,RCI2) Then buy(); if RCI1 > 80 and RCI2 > 80 and RCI3 > 80 and CrossDown(RCI1,RCI3) Then sell(); if RCI1 < -80 and RCI2 < -80 and RCI2 < -80 and CrossUp(RCI1,RCI3) Then buy();
프로필 이미지
해피슈
2019-03-22
345
글번호 127302
시스템