커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

변수값

아래 수식 (가) 는 정상적으로 작동 됩니다. 그런데 수식(나) 로 변경 하였는데 변수 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
370
글번호 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
417
글번호 127310
지표
답변완료

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

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

시스템문의합니다

당일 시가대비 20틱위에서 매도2계약들어가서 진입가 대비 10틱 20틱에서 1계약씩청산하고 청산이 안됐을시 50틱에서 추가로 가지고 있는 수량대비 2배로 추가매도하고 평단가 대비 10틱 20틱에서 반 반 청산하고 또 청산이 안됐을 경우 80틱에서 추가로 가지고있는 수량대비 2배로 추가매도해서 평단가 대비 10틱 20틱에서 반 반씩청산 하는시스템식을 만들고 싶습니다 그렇게 각 30틱마다 진입이 되겠끔해서 500틱까지 반복이 되겠끔 하고 싶습니다 매수도 마찬가지로요 만약 20틱에서 진입해서 다 청산이 되면 다시 20틱에 오면 매도가 되겠끔 50틱에서 추가로 들어가서 청산이 되면 다시 50틱에서도 진입이 &#46124;으면 좋겠습니다 단 진입이 되어있으면 추가 진입은 금지이고 각 진입이된 다음 30틱에서 진입이 되겠끔 부탁드립니다 만약 1계약이 청산된 상태라면 1계약은 추가로 진입가능하고요
프로필 이미지
초보트레이더11
2019-03-22
382
글번호 127300
시스템
답변완료

분할 청산 수식 부탁해요~~(국내 주식)

매수진입은 100회에 걸쳐 진입하였고 청산은 첫 신호에 전량 청산으로 요청한 식이 아래 식입니다. 여기에 추가 부탁드릴께요~~~ 청산도 해당 조건에 달성시 보유 주식에 10%씩 10회에 걸쳐 청산하는 식을 요청합니다. ==================================================================================== 안녕하세요 예스스탁입니다. Input: Period(14),LPercent(5),SPercent(80),금액(1000000),최대누적횟수(100); var : MoneyFlow(0); MoneyFlow = MFI(Period); if MoneyFlow < 5 and MaxEntries < 최대누적횟수 Then buy("b",OnClose,def,Floor(금액/c)); if MarketPosition == 1 and MoneyFlow >= SPercent Then ExitLong("bx"); 즐거운 하루되세요 > 이형지 님이 쓴 글입니다. > 제목 : MFI 매수-청산 수식 부탁해요~~ > 국내 주식 매매 30분봉 기준 MFI 저점(LPercent(5))이하에서는 신호 발생시마다 분할매수로 1회에 100만원씩 최대 100회(1억)까지 청산은 MFI 고점(SPercent)에서 일괄 청산하는 식을 만들어 주시면 감사하겠습니다.
프로필 이미지
이형지
2019-03-22
369
글번호 127298
시스템
답변완료

신규 진입 수식 부탁합니다.

해당 조건을 모두 만족할때 신규 진입 뜨는 수식 부탁해요.. 일봉 차트 - 국내 주식 CCI 일봉 > 0 && CCI 주봉 > 0 && 주봉 20일 이동평균 라인이 우상향 && 일봉이 5일이동평균(일봉)보다 아래 있을 때
프로필 이미지
이형지
2019-03-22
366
글번호 127296
시스템