커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

2개 전략

안녕하세요~~^^ 동일 종목에서 2개 전략 사용시(buy, sell) 같은 변수명이 있으면 에러가 발생하나요?
프로필 이미지
코퍼
2022-09-07
1215
글번호 162073
시스템
답변완료

안녕하세요

안녕하세요 1. 아래 수식은 진입가 대비 10% 수익시 1계약 청산식입니다. 진입한(보유) 수량의 % 비율로 청산수식을 수정부탁드립니다. 예시는 보유 수량의 50%씩 두번 분할청산 되는 수식으로 부탁드려요. ExitLong("bp1",AtLimit,EntryPrice*1.1,def,10); 2. 아래 수식으로 손절을 하는데요 분할진입시 익절,손절이 개별 진입시점기준으로 분산됨니다. ex) 손절 1%예시 1차 진입가 100 일때 99 손절 , 2차 진입가 200 일때 198 손절 손절도 분할로 익절도 동일하게 분할 처리 됨니다. 익절,손절을 평균가로 하는 예제수식 부탁드립니다. LC(손절변수) SetStopLoss(LC,PercentStop); ----------------------------------------------------------------- If MarketPosition <= 0 and value1 == 1 and Condition1 == true Then Buy("B1",AtStop,고[2,1]-PriceScale*a,1); if MarketPosition == 1 Then { if L > EntryPrice*0.99 Then Buy("bb2",AtLimit,EntryPrice*0.99,1); if L > EntryPrice*0.98 Then Buy("bb3",AtLimit,EntryPrice*0.98,1); if L > EntryPrice*0.97 Then Buy("bb4",AtLimit,EntryPrice*EntryPrice*0.97,1); if L > EntryPrice*0.96 Then Buy("bb5",AtLimit,EntryPrice*EntryPrice*0.96,1); } if MarketPosition == 1 Then { if H < EntryPrice*1.02 Then ExitLong("bp1",AtLimit,EntryPrice*1.02,def,1); if H < EntryPrice*1.04 Then ExitLong("bp2",AtLimit,EntryPrice*1.04,def,1); if H < EntryPrice*1.06 Then ExitLong("bp3",AtLimit,EntryPrice*1.06,def,1); if H < EntryPrice*1.08 Then ExitLong("bp4",AtLimit,EntryPrice*1.08,def,1); if H < EntryPrice*1.10 Then ExitLong("bp5",AtLimit,EntryPrice*1.10,def,1); } SetStopLoss(LC,PercentStop); 감사합니다.
프로필 이미지
상중하
2022-09-07
1255
글번호 162051
시스템
답변완료

문의드립니다

var11=var11+Upticks; var12=var12+Downticks; var13=var11-var12; 이런식으로 업틱과 다운틱의 차이를 구하려고 합니다. 틱챠트에서 최초 10개 봉의 var13 평균값을 구하는 수식 부탁드립니다
프로필 이미지
고스트
2022-09-07
1023
글번호 162050
시스템
답변완료

문의 드립니다

input : 익절틱수(160),손절틱수(30); var1 = ma(C,10); Var2 = ma(C,1); if NextBarSdate != sDate and var1 > Var2 Then { if NextBarOpen > C Then Buy("b",AtStop,NextBarOpen+PriceScale*-20); if NextBarOpen < C Then Buy("bx",AtStop,NextBarOpen-PriceScale*-20); } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); var1 = ma(C,5); Var2 = ma(C,1); if NextBarSdate != sDate and var1 > Var2 Then { if NextBarOpen > C Then Buy("b1",AtStop,NextBarOpen+PriceScale*-20); if NextBarOpen < C Then Buy("bx1",AtStop,NextBarOpen-PriceScale*-20); } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); var1 = ma(C,4); Var2 = ma(C,1); if NextBarSdate != sDate and var1 > Var2 Then { if NextBarOpen > C Then Buy("b2",AtStop,NextBarOpen+PriceScale*-20); if NextBarOpen < C Then Buy("bx2",AtStop,NextBarOpen-PriceScale*-20); } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); var1 = ma(C,1); Var2 = ma(C,5); if NextBarSdate != sDate and var1 > Var2 Then { if NextBarOpen > C Then Buy("b3",AtStop,NextBarOpen+PriceScale*-20); if NextBarOpen < C Then Buy("bx3",AtStop,NextBarOpen-PriceScale*-20); } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); --------------- 위 수식어에 60선 아래 진입신호금지를 추가 부탁드립니다. ------------------------------------------------------------------- input : 익절틱수(120),손절틱수(30); var1 = ma(C,1); Var2 = ma(C,5); if NextBarSdate != sDate and var1 < Var2 Then { if NextBarOpen > C Then Sell("s",AtStop,NextBarOpen+PriceScale*-18); if NextBarOpen < C Then Sell("sx",AtStop,NextBarOpen-PriceScale*-18); } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); var1 = ma(C,3); Var2 = ma(C,7); if NextBarSdate != sDate and var1 < Var2 Then { if NextBarOpen > C Then Sell("s1",AtStop,NextBarOpen+PriceScale*-18); if NextBarOpen < C Then Sell("sx1",AtStop,NextBarOpen-PriceScale*-18); } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); var1 = ma(C,5); Var2 = ma(C,10); if NextBarSdate != sDate and var1 < Var2 Then { if NextBarOpen > C Then Sell("s2",AtStop,NextBarOpen+PriceScale*-18); if NextBarOpen < C Then Sell("sx2",AtStop,NextBarOpen-PriceScale*-18); } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); var1 = ma(C,7); Var2 = ma(C,1); if NextBarSdate != sDate and var1 < Var2 Then { if NextBarOpen > C Then Sell("s3",AtStop,NextBarOpen+PriceScale*-18); if NextBarOpen < C Then Sell("sx3",AtStop,NextBarOpen-PriceScale*-18); } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); --------------------- 위 수식어에 60선 위 진입신호금지를 추가 부탁드립니다.
프로필 이미지
푸른
2022-09-07
982
글번호 162049
시스템
답변완료

변수배치, 에러

안녕세요~ -Inputs 과 Vars를 문장 최상단에 배치하지 않고 변수 사용문장 상단에 각각 배치해도 되는지요?? 예시> Inputs Vars 문장1 Inputs Vars 문장2 Inputs Vars 문장3
프로필 이미지
코퍼
2022-09-07
979
글번호 162048
시스템
답변완료

해외선물 자금관리 (계약수 조절) 수식 문의좀 드립니다.

안녕하세요 항상 고생이 많으십니다. 예스글로벌 해외선물 시스템 트레이딩 수식 문의드립니다. 매수매도 진입전략만 운용하다가 계약수를 매번 손으로 조정하기가 어려워서 수식으로 자동화시키려고 하는데요, 쓰려고하는 자금관리기법은 흔히 알려진 윌리엄스 자금관리 방식입니다. 계좌 총 잔고가 늘어날수록 계약수를 늘이고 계좌 잔고가 줄어들수록 계약수를 줄이는 방식인데요 (최소 1계약은 유지) 안전마진 = MDD + Micro e-mini나스닥 현재 증거금 가 되어서 Netprofit이 안전마진만큼 쌓이면 1계약을 추가하는 방식입니다. 반대로 운용중에 안전마진만큼 손해가 발생하면 1계약을 줄입니다. 이 내용을 토대로 수식을 작성하려고하는데, 1. MDD는 MaxIDDrawDown으로 불러올 수 있던데, 이건 포인트 기준으로 불러와지는 건가요? 아니면 거래통화인 USD기준으로 불러와 지는건지 헷갈립니다. 2. GetUnclearedDeposits 함수는 예탁총액을 불러온다고 하는데, 이것도 usd기준인지 원화 기준인지 궁금합니다. 또한 netprofit은 포인트 기준인가요? 3. 위의 윌리엄스 자금관리 기법을 적용하려면 수식을 어떤식으로 작성해야할지.. 예제한번만 부탁드립니다. 예시가 있으면 그 이후에는 응용해서 할 수 있을 것 같은데 조금 막연하네요 바쁘신데 감사드립니다!
프로필 이미지
911gt3rs
2022-09-07
1117
글번호 162047
시스템
답변완료

수식

안녕하세요. 지표 파일은 YesLang -> indication 넣어서 챠트에 구동 시키면 됩니다. 강조 파일은 어디에 넣어서 챠트에 구동 시켜야하느지 질문드립니다. 감사합니다.
프로필 이미지
한국사람73
2022-09-07
1383
글번호 162045
강조
답변완료

쌍바닥 plot 색상

Input : af(0.02), maxAF(0.2),상(1),하(1); Var : Sarv(0),tl(0),T(0); Sarv = sar(af,maxAF); Plot1(0); If crossup(c,Sarv) Then { T = 1; var1 = Sarv; Var2 = var1[1]; Condition1 = False; if var1 <= var2+PriceScale*상 and var1 >= var2-PriceScale*하 and var2 > 0 Then { Condition1 = true; Plot1(1); PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav"); } } if CrossDown(C,sarv) Then T = -1; Else { if T == 1 Then { if sarv < var1 Then { var1 = sarv; if Condition1 == False and var1 <= var2+PriceScale*상 and var1 >= var2-PriceScale*하 and var2 > 0 Then { Condition1 = true; Plot1(1); PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav"); } } } } "직전 저점"보다 낮아진 쌍바닥은 파랑,같은 쌍바닥은 그린,높아진 쌍바닥은 빨강, 이런식으로 각기 다른 세가지 색으로 출력.알람은 있어도 되고 없어도 무관. 감사합니다.
프로필 이미지
고성
2022-09-07
1483
글번호 162044
지표
답변완료

분봉에서 일봉이평값을 만들어 사용하고자 합니다. 도움 부탁드립니다.

안녕하세요. 늘 도움 주셔서 항상 감사드립니다. 첨부한 그림과 같이 분봉에서 일봉의 5일선 값을 만들어 사용하고자 합니다. 그런데, 일봉에서는 4/26일의 값을 4/25일의 종가를 사용하여 분봉을 만들고 있는데, 분봉에서는 4/26일의 데이터가 없어서, 4/27일부터 분봉의 일봉이평값과 일봉의 5일선 값이 서로 다른 결과가 나와서 애를 먹고 있습니다. 이러한 문제를 어떻게 해결할 수 있을까요? 도움 부탁드립니다. 고맙습니다.
프로필 이미지
영화사랑
2022-09-06
1737
글번호 162043
지표