커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

내부변수 선언위치

안녕하세요. 시스템식에서 내부변수선언부분을 수식중간에 넣는거랑, 수식제일 앞에 두는거랑 어떤차이가 있는지요? VARS: count1(0),count2(0),count3(0); 가령, 분봉차트에 일봉을 계산하는데 필요한 내부변수들이라면, 매분마다 읽을필요는 없이 일자가 변경될때만 한번 읽어주면 될거같은데, 중간에서 선언시 계속 반복될것 같기도 하구요. 실제 운용시 매매에 영향을 주는 요인인지 궁금합니다.
프로필 이미지
건곤대
2022-10-18
1345
글번호 163077
시스템
답변완료

신호타입

안녕하십니까 !! 갑자기 추위가 왔네요 감기 조심하세요^^ 항상 도움 주심에 감사합니다. 아래 항목에 의문이 있어 질의 드립니다. 기준: 일봉 주식 질의 1번. 신호타입 OnClose로 예비진입신호가 발생한 수식을 AtStop으로 바꾸었는데, 수식변환이 잘 못 된 것인지 익일 신호로 나오고 있습니다. 또한, 두 개의 신호타입 별로 전체 거래 횟수도 조금 틀리게 나옵니다. 무엇이 잘 못 된 것인지요? 질의 2번. 신호타입 OnClose로 진입시 익일시초가 수신시 시스템 성능보고서에 예비신호가 발생한 날의 종가로 진입하게 되어 있는데, 이것을 익일시초가로 바꿀 수 있는지요? 3번 . 시간이 되면 원격접속을 부탁 드립니다. 바쁘시면 QnA 게시글로 알려주십시요. ### 질의 시스템 수식 # 시스템명 : HA_Trade #------------<백테스팅 시뮬레이션 최적화변수>---------------------# input : 시스템실행구분(0) ; # 시스템실행구분(0:백테스팅&&최적화, 1:시험적용, 2:자동주문, 3:필터링, 4:전진분석) input : 분할화면번호(0) ; # 전략실행차트(가로5, 세로6)의 분할화면번호 #input : 최적화_진입청산구분(4) ; # 최적화_진입/청산구분 , <0:최적화없음>, <진입:4 청산:8>, <진입(필터채택시):5 청산(필터채택시):9> var : 백테스팅기간조건(False), 전진분석기간조건(False), Print기간조건(False), 기간평가일(20081230), 숫자증가(0) ; #기간평가일(20081230)20220929 var : 최적화_진입청산구분(4) ; # 최적화_진입/청산구분 , <0:최적화없음>, <진입:4 청산:8>, <진입(필터채택시):5 청산(필터채택시):9> #======================================================# # 초기화 처리 #---------------전체기간 조건처리----------------------------# 백테스팅기간조건 = 시스템실행구분 == 0 and ( 20030101 <= bDate and bDate <= 20081231 ) ; // 최적화, 시스템실행구분(0:백테스팅&&최적화, 1:시험적용, 2:매매일지, 3:필터링, 4:전진분석) #백테스팅기간조건 = 시스템실행구분 == 0 and ( 20000101 <= bDate and bDate <= 20220926 ) ; // 최적화, 시스템실행구분(0:백테스팅&&최적화, 1:시험적용, 2:매매일지, 3:필터링, 4:전진분석) 전진분석기간조건 = 시스템실행구분 == 4 and ( 20000101 <= bDate and bDate <= 20220429 ) ; // 전진분석, 시스템실행구분(0:백테스팅&&최적화, 1:시험적용, 2:매매일지, 3:필터링, 4:전진분석) If 전진분석기간조건 == True Then 백테스팅기간조건 = False ; If 백테스팅기간조건 == True Then 전진분석기간조건 = False ; Print기간조건 = 백테스팅기간조건 == True or 전진분석기간조건 == True or 시스템실행구분 == 1 or 시스템실행구분 == 2 or 시스템실행구분 == 3; #======================================================# Vars: ha_몸통비율(0), ha_몸통비율_진입(0), ha_몸통비율_청산(0) ; # 20221008 추가 #======================================================# # 출처 : HA_지표_Total.yin #======================================================# # Heikin Ashi Candle 계산식 # input : P0(7) ; var : P0(7) ; Vars: ha_O(0), ha_C(0), ha_H(0), ha_L(0) ; Vars: ha_MAv(0), ha_MAv기울기(0) ; #------------------------------------------------------# ha_O = (ha_O[1] + ha_C[1]) / 2 ; # 시가 = (이전 막대의 시가+이전막대의 종가)/2, 직전HA의 몸통 중간값(절반) If Index == 0 then ha_O = O ; ha_C = (O+H+L+C)/4 ; # 종가 = 캔들의 4median ha_H = MaxList(H, ha_O, ha_C) ; ha_L = MinList(L, ha_O, ha_C) ; ha_MAv = EMA(ha_C, P0) ; ha_MAv기울기 = (ha_MAv[0] - ha_MAv[1]) / ha_MAv[1] ; #======================================================# #======================================================# # HA Candle 머리길이, 꼬리길이, 몸통길이, 전체길이, 매수/도세힘 계산 Vars: ha_전체길이(0), ha_몸통길이(0), ha_머리길이(0), ha_꼬리길이(0) ; # 머리길이, 꼬리길이, 몸통길이, 전체길이 계산 Vars: ha_매수세힘(0), ha_매도세힘(0) ; #미사용변수 Vars: MA_ha전체(0), MA_ha몸통(0), MA_ha머리(0), MA_ha꼬리(0) ; #------------------------------------------------------# ha_전체길이 = ha_H - ha_L ; ha_몸통길이 = MaxList(ha_O, ha_C) - MinList(ha_O, ha_C) ; ha_머리길이 = ha_H - MaxList(ha_O, ha_C) ; ha_꼬리길이 = MinList(ha_O, ha_C) - ha_L ; If ha_O < ha_C Then ha_매수세힘 = ha_H - ha_O ; #미사용변수 If ha_O >= ha_C Then ha_매도세힘 = ha_O - ha_L ; #미사용변수 MA_ha전체 = Ma(ha_전체길이, P0) ; MA_ha몸통 = Ma(ha_몸통길이, P0) ; MA_ha머리 = Ma(ha_머리길이, P0) ; MA_ha꼬리 = Ma(ha_꼬리길이, P0) ; #======================================================# #======================================================# # Four 파라볼릭(주가:Sar,CSar , HA:ha_Sar,ha_CSar)의 구간을 비교하여 같으면 동일 색표시, 틀리면 Yellow #Input : af(0.02), maxAF(0.2); var : af(0.02), maxAF(0.2); Var : SarV(0), CSarV(0), ha_SarV(0), ha_CSarV(0) ; Var : PSar_상승cc(False), PSar_하락cc(False), PSar_횡보cc(False); #------------------------------------------------------# SarV = Sar(af,maxAF); # 주가 High Low Parabolic (S)top (A)nd (R)eversal CSarV = CSar(af,maxAF); # 주가 Close Parabolic (S)top (A)nd (R)eversal ha_SarV = ha_Sar(af,maxAF,ha_O,ha_C,ha_H,ha_L); # HA High Low Parabolic (S)top (A)nd (R)eversal ha_CSarV = ha_CSar(af,maxAF,ha_O,ha_C,ha_H,ha_L); # HA Close Parabolic (S)top (A)nd (R)eversal #나중에 4개 개별조합을 생각해야한다. PSar_상승cc = SarV < C and CSarV < C and ha_SarV < ha_C and ha_CSarV < ha_C ; # 상승추세, Red PSar_하락cc = SarV > C and CSarV > C and ha_SarV > ha_C and ha_CSarV > ha_C ; # 하락추세, Blue PSar_횡보cc = PSar_상승cc == False and PSar_하락cc == False ; # 횡보추세, Yellow #======================================================# #======================================================# # 진입/청산 var : 청산조건(False) , 진입조건(False); var : 추세점수(0) ; Array : FL[1024](False) ; # 필터조건변수, [0]번은 버리고, [1]번부터 [10]번까지 사용 2^10 = 1024 #------------------------------------------------------# # 필터 등록 #필터사용 전략식명: HA_지표_Total.yin #------------------------------------------------------# # 필터 케이스 FL[001] = ha_몸통비율 > 0 ; FL[008] = PSar_상승cc == True ; if MA_ha몸통 < ha_몸통길이 and MA_ha전체 < ha_전체길이 then { if ha_O[0] < ha_C[0] Then ha_몸통비율 = ha_몸통길이 / ha_전체길이 ; # HA양봉 if ha_O[0] > ha_C[0] Then ha_몸통비율 = (ha_몸통길이 / ha_전체길이) * -1 ; # HA음봉 } #------------------------------------------------------# # 진입 신호타입 : (0)OnClose / (1)AtStop input :신호타입(0); #------------------------------------------------------# # OnClose if 신호타입 == 0 Then { 진입조건 = FL[001] == true and FL[008] == true and 0.33 < ha_몸통비율 ; if 진입조건 == True and Print기간조건 == True and MarketPosition == 0 Then { buy("on49") ; # 속성창 비용/수량탭의 고정자산으로 사전입력 관리 } } #------------------------------------------------------# # AtStop var : imsi(0); if 신호타입 == 1 Then { 진입조건 = FL[001] == true and FL[008] == true ; if 0.33 < ha_몸통비율 Then imsi = C; Else imsi = 0; if 진입조건 == True and Print기간조건 == True and MarketPosition == 0 Then { buy("at49", AtStop, imsi) ; } } #------------------------------------------------------# # 청산 #------------------------------------------------------# If marketposition == 1 Then { ExitLong("XL",AtStop,Highest(H,BarsSinceEntry+1)-ATR(14)*2.5); SetStopLoss(5,PercentStop); } If MarketPosition == 0 Then { #무포 손절 Clear SetStopLoss(0, PercentStop); } #======================================================#
프로필 이미지
목포댁
2022-10-18
1326
글번호 163074
시스템
답변완료

수식전환 부탁

다음 수식을 예스수식으로 전환부탁드립니다. <1>강조 a=shift(close,p); b=ma(c,period); crossup(c,p1) or c>b(p2) 추가설정 p 음수 9 p1 양수 5 p2 양수 10 <2>지표 수식1 a=ma(가격,기간,이평종류); highest(a,폭,0) 수식2 a=ma(가격,기간,이평종류); lowest(a,폭,0) 이평종류 단순 가격 종가 기간 20 폭 2 <3>지표 수식1 MA(O,period,이평종류) 수식2 MA(C,period,이평종류) 수식3 MA(O,period1,이평종류) 수식4 MA(C,period1,이평종류) 설정 period 10 period1 20 이평종류 단순
프로필 이미지
임진사댁원장
2022-10-18
1308
글번호 163073
강조
답변완료

종목검색 수식 부탁드립니다

안녕하세요 고생이 많으십니다 종목검색 수식은 너무 험난하네요 수식 좀 부탁 드리겠습니다 1.1분봉 A = MA(가격,이평기간,이평방법); // 종가,240,단순 b=A + AvgIf( c - A, -1, 0.0 ) -2*StdevIf( c - A, -1, 0.0 ); crossup (c,b) 2.1분봉 거대량순위 100 기간1 1, 기간2 20,방법 단순, midPeriod 17, A=RSI(7); A1=RSI(21); d=ma(c,기간1,방법); e=ma(c,기간2,방법); f=(highest(high,midPeriod)+lowest(low,midPeriod))/2; (O<=C && L<=f && C>f ) or O<=C && L<=f && C>f && crossup(d,e) && CROSSUP(A,A1) 수고하세요.
프로필 이미지
불개미미미
2022-10-18
1402
글번호 163072
종목검색
답변완료

도움 부탁드립니다

안녕하세요 어느덧 날도 조금씩 추워지는데 건강 유의하세요 도와주심에 항상 감사드립니다 아래와 같은 식을 만들려하는데 잘 안되어서 도움 요청드립니다. 1. x 라는 조건 만족후 y라는 조건을 두번째 만족할 때 <--이런 식을 어떻게 구현할 수 있을까요? 예를 들어, 골든크로스 상태(단기 이평 > 장기이평)일 때, 주가가 단기 이평을 한번 뚫고 다시 오르다가 두번째 뚫었을때 라는 상태를 식으로 적고 싶습니다. var: 두번뚫음(0); var1 = 0; var2 = var1[1] ; If MA1> MA2 then trend=1; else trend = 0; If trend ==1 then begin { if C < ma1 then var1 == 1, } If var2 > 2 then 두번뚫음 = 1; 이런식으로 생각은 해봤는데, 도움 부탁드립니다.
프로필 이미지
이만스닥
2022-10-18
1431
글번호 163066
시스템
답변완료

수식 부탁드립니다

수고하십니다. 분봉에서 당일 첫봉의 시가/고가/저가/종가를 TL로 15시 30분까지 표시하고 싶습니다. [익일에는 전날의 TL이 표시되지 않게 해주세요..] 수고하세요...
프로필 이미지
오이도인
2022-10-18
1085
글번호 163065
지표

관리자에 의해 프로그램 사용법 QnA로 이동되었습니다

프로필 이미지
정종현
2022-10-18
13
글번호 163062
시스템

관리자에 의해 프로그램 사용법 QnA로 이동되었습니다

프로필 이미지
겐지
2022-10-18
9
글번호 163061
시스템
답변완료

중간선 세로선

input : P(10); var:t(0); var1 = highest(H,P); var2 = Lowest(L,P); var3 = (var1+var2)/2; if Var3 > Var3[1] Then T = 1; if Var3 <Var3 [1] Then T = -1; Plot1(Var3,"var3",IFF(T == 1,Red,Blue)); 1.지표 변수 24,52,9 인 macd "시그날" 선이 -0.075 이하일때 중간선이 양전환되면 세로선. 2.시스템 macd "시그날" 선이 -0.075 이하일때 중간선이 양전환되면 매수,음전환시 매수청산. 감사합니다.
프로필 이미지
고성
2022-10-18
1276
글번호 163060
지표