커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

부탁드립니다

CANDLE=sum(1); AA=highest(C(1), period); BB=valuewhen(1, crossup(C, AA), CANDLE); cloud1=( highest(high,9)+ lowest(low,9)+ highest(high,26)+ lowest(low,26) )/4; cloud2=( highest(high,52)+ lowest(low,52) )/2; condition= crossup(C, AA) and (CANDLE-BB(1)<period_max) and (period_min< CANDLE-BB(1)) and (lower<disparity(60) and disparity(60) <upper) and (C > cloud1(25) and C > cloud2(25)) and (O < cloud1(25)*1.3 and O < cloud2(25)*1.3) 지표변수 period 125 period_max 60 period_min 10 lower 90 upper 140
프로필 이미지
매치다2
2022-10-15
1444
글번호 163000
종목검색
답변완료

잔고함수 사용법

안녕하세요. getpositionquantity(종목코드,계좌번호,매수/매도구분) 이라고 메뉴얼에 나와있는데, 매수매도구분은 어떻게 구체적으로 표기하나요? 0: 매수, 1: 매도 이렇게 되나요??
프로필 이미지
건곤대
2022-10-15
1387
글번호 162999
시스템
답변완료

당일청산

안녕하세요. 아래 답변감사합니다. 아래 수식에서, 의견 주신대로 청산함수만으로 신호발생이 되지 않으니, buy,sell을 활용하면 당일분을 청산하는데 문제는 없을까요? -------------------------------------------------------- var : k(1), AccoundNum(""),Symbol(""),Quantity(0); AccoundNum = getAccount(0); Symbol = GetPositionSymbol(0,AccoundNum); Quantity = GetPositionQuantity(Symbol,AccoundNum,0); k=Quantity; if k >0 then { exitshort("잔고청산2"); } ----------------------- 안녕하세요 예스스탁입니다. 시스템은 진입신호가 있어야 청산신호가 발생합니다. 청산신호만으로 신호 발생이 가능하지 않습니다. 진입식(Buy,Sell)이 없는 시스템은 차트의 시스템 목록에는 나타나지 않아 적용자체를 할수 없습니다. 즐거운 하루되세요 > 건곤대 님이 쓴 글입니다. > 제목 : 당일청산 > 잔고함수를 활용해서 당일미청산분이 있을때는 청산해보려고 합니다. 아래와 같이 청산명령만 있는 시스템식으로 처리하려는데 문제가 있을까요? ---------------------------------------- var : k(1), AccoundNum(""),Symbol(""),Quantity(0); AccoundNum = getAccount(0); Symbol = GetPositionSymbol(0,AccoundNum); Quantity = GetPositionQuantity(Symbol,AccoundNum); k=Quantity; if k >0 then { exitlong("잔고청산1"); exitshort("잔고청산2"); }
프로필 이미지
건곤대
2022-10-15
1543
글번호 162998
시스템
답변완료

청산

30분봉 챠트에서 청산 명령을 하면, 봉완성후 청산되나요? 아니면, 명령 실행즉시 봉 완성전에라도 청산되는 건지요?
프로필 이미지
와글이
2022-10-15
1766
글번호 162997
시스템
답변완료

문의드립니다

수고에 감사드립니다 아래 두 시스템식이 같은 내용의 전략인가요? 아님 차이가 있는건지 질문드립니다 1) if stime == 100000 then { if C > O then buy(); if C < O then sell(); } if stime == 125000 then { if Marketposition == 1 then Exitlong() ; if Marketposition == -1 then Exitshort() ;} 2) Input: starttime(101500) endtime(125500) if endtime > starttime then setstopendofday(endtime); else if sDate != sDate[1] then setstopendofday(endtime); if bDate != bDate[1] then {if endtime < starttime then setstopendofday(0); if C > O then buy("b", atmarket); if C < O then sell("s", atmarket); 감사합니다
프로필 이미지
네클헌
2022-10-15
1544
글번호 162996
시스템
답변완료

시스템식 부탁드립니다.

안녕하세요. 아래의 조건에 맞는 시스템식 부탁드립니다. -------------------------------- 질문1 -------------------------------- 종목 : 나스닥 10분 매수 : 5일 이동평균선이 10일 이동평균선 보다 크거나 골드 크로스면 매수 매수청산 : 5일 이동편균선이 10일 이동평균선을 데드 크로스하면 청산 손절 : 포지션 진입가격에서 5Point 하락시 스탑로스 단, 직전 청산이 스탑로스 인경우, 5일 이동평균선이 10일 이동평균선보다 커도 매수하지 않음, 즉 매수조건이 만족 되어도 직전 청산이 손절이면 매수하지 않음 그리고 매수청산 조건이 만족되면 다시 매수 가능한 시스템식 부탁드립니다. 즉, 매수청산 조건이 만족하면 매수가 초기화 되어 다시 매수 가능한 시스템식 부탁드립니다.(실제로는 스탑로스로 청산 되었지만 매수청산 조건이 성립되지 않을 경우 재매수 금지) -------------------------------- 질문2 -------------------------------- 직전 포지션이 매수이고, 직전 청산이 setstoploss 로 청산된것을 어떻게 알수있나요? 즉 직전 포지션이 매수이고, 직전 청산이 setsoploss로 청산된경우에만 매수하고 싶습니다. 위와 같은 경우에만 매수하고자 하는 시스템식 부탁드립니다. 감사합니다.
프로필 이미지
양치기
2022-10-15
1441
글번호 162995
시스템
답변완료

문의 드립니다.

input : 익절틱수(300),손절틱수(100); var : DD(0),Year(0),V1(0),V2(0),V3(0),V4(0),summer(False); var : ST(0),ET(0),entry(0); if sDate != sDate[1] Then { DD = DayOfWeek(Sdate); Year = Floor(Sdate/10000); V1 = (10000 * Year) + (100 * 3) + 1; V2 = 15 - dayofweek(v1); v3 = (10000 * Year) + (100 * 11) + 1; v4 = 8 - dayofweek(v3); Summer = Sdate > (10000 * Year) + (100 * 3) + v2 and Sdate < (10000 * Year) + (100 * 11) + v4; if summer == true Then { ST = 70000; ET = 55000; } Else { ST = 80000; ET = 65000; } } if Year > 0 Then { IF ET > ST Then SetStopEndofday(ET); Else { if sDate != sDate[1] Then SetStopEndofday(ET); } if ((NextBarSdate != sDate and NextBarStime >= ST) or (NextBarSdate == sDate and NextBarStime >= ST and sTime < ST)) Then { if ET < ST Then SetStopEndofday(0); if NextBarOpen != c Then { Buy("b",AtStop,NextBarOpen+PriceScale*10); Sell("s",AtStop,NextBarOpen-PriceScale*10); } } Else { if h < DayOpen+PriceScale*10 Then Buy("b1",AtStop,DayOpen+PriceScale*10); if l > DayOpen-PriceScale*10 Then Sell("s1",AtStop,DayOpen-PriceScale*10); } } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); ---------------------- 위 첨부파일은 위 수식어에 매수,매도의 진입신호를 캡처한 것입니다. 여기에 조건 수식어를 첨부하고자 합니다. 그 내용은 진입신호후 체결을 바로 하는것이 아니라 신호후 그 다음 6개의 캔들중 하나라도 처음 캔들신호폭을 이탈하면 7번재 캔들싯점에서 체결이 없고 이탈이 아니면 7번재 캔들싯점에서 체결하는 수식어 입니다. 체결후 손절은 15틱으로 별도의 조건부 수식어가 가능한지도 문의 합니다. ------------------------------- 첨부파일 2번의 피보나치 수식어를 부탁드립니다. ------------------------------- input : N(5),금액(10000000); var : cnt(0),hh(0),ll(0); hh = 0; ll = 0; For cnt = 1 to N { if (hh == 0 or (hh > 0 and DayHigh(cnt) > hh)) Then hh = DayHigh(cnt); if (ll == 0 or (ll > 0 and DayLow(cnt) < ll)) Then ll = DayLow(cnt); } var1 = hh-(hh-ll)*0; var2 = hh-(hh-ll)*0.236; var3 = hh-(hh-ll)*0.382; var4 = hh-(hh-ll)*0.500; var5 = hh-(hh-ll)*0.618; var6 = hh-(hh-ll)*0.786; var7 = hh-(hh-ll)*1.000; if CrossDown(C,var2) Then Buy("b1",OnClose,DEF,Floor((금액*0.2)/C)); if CrossDown(C,var3) Then Buy("b2",OnClose,DEF,Floor((금액*0.2)/C)); if CrossDown(C,var4) Then Buy("b3",OnClose,DEF,Floor((금액*0.2)/C)); if CrossDown(C,var5) Then Buy("b4",OnClose,DEF,Floor((금액*0.2)/C)); if CrossDown(C,var6) Then Buy("b5",OnClose,DEF,Floor((금액*0.2)/C)); if MarketPosition == 1 Then { if CrossUp(c,var1) Then ExitLong("bx1",OnClose,DEF,"b1"); if CrossUp(c,Var2) Then ExitLong("bx2",OnClose,DEF,"b2"); if CrossUp(c,Var3) Then ExitLong("bx3",OnClose,DEF,"b3"); if CrossUp(c,Var4) Then ExitLong("bx4",OnClose,DEF,"b4"); if CrossUp(c,var5) Then ExitLong("bx5",OnClose,DEF,"b5"); } 위 수식어는 첨부파일3 입니다. 일봉의 10일선 위, 아래에 따라 수식어를 추가하고자 합니다. 10일선 위는 Buy로 10일선 아래는 sell 입니다. 미리 감사드립니다.
프로필 이미지
푸른
2022-10-17
1362
글번호 162994
시스템
답변완료

감사 합니다

input : Period(10); var :AA(False),VV(False); AA = crossup(C, max((highest(high,9)[25]+lowest(low,9)[25]+highest(high,26)[25]+lowest(low,26)[25])/4 , (highest(high,52)[25]+lowest(low,52)[25])/2)); VV=V>highest(V, Period)[1]; if AA and VV Then Plot1(1); Else Plot1(0); $$$$$ 강조식으로 표현 부탁드립니다 캔들이 아닌 화면 전체 로 표현하고져 합니다
프로필 이미지
매치다는
2022-10-14
1208
글번호 162993
강조
답변완료

부탁드립니다

수고하십니다 79161번 재질문입니다 차트에적용해보니 참조테이터는 나타나는데 위에있는 기본차트에 KP200선물연결(DATA1) 차트 종가에도 같은 선긋기 가 나타나지 않내요
프로필 이미지
파생돌이
2022-10-14
1028
글번호 162992
지표