커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3538
글번호 230811
답변완료
수고가 많으십니다
질문 2가지 부탁드리겠습니다.
질문1)
아래 조건에서
현재 만족봉의 저가보다 "최초로" 1.5배 높거나 낮은 저가가 나올때만 조건만족봉이 나오게하려고 합니다.
비교기준은 새로운 봉이 아니라 이전 봉으로 고정을 해서 하려고 합니다
예를들어 현재만족봉 A 기준으로 다음 만족봉의 저가가 1.5배 높거나 낮지 않다면 계속 이후에 나오는 봉을 "A봉 기준"으로 비교, 최초로 조건이 만족할때를 찾아내고자 합니다.
만족봉이 나오면 그 봉을 기준으로 다시 반복을 합니다.
감사합니다
if h>l*1.08 Then
{
d1 = dd;
var1 = Index;
Var2 = var1[1];
Var3 = Var2[1];
tl=TL_NEW(sDate,sTime,100,sDate,sTime,999999);
TL_SetSize(tl,0);
TL_SetColor(tl,Red);
}
질문2)
3차원 배열에 대해서 질문드리고 싶은데요
아래와 같이 작성했을때
2차원 배열에서는
cc[x,y]
x는 조건만족봉 순서 , y에는 원하는 값 (아래 예시에서는 고가값, 저가값, ...)
처럼 y에 여러가지 변수를 저장할 수 있는데요
3차원 배열에서는 어떤것을 추가로 구현 (용도) 할 수 있는지 간단한 예시와 수식 구성법을 알려주셨으면 합니다.
감사합니다
var : cnt(0),tt(0),hh(0),ll(0);
Array : CC[50,2](0);
if h>l*1.08 Then
{
var1 = Index;
Var2 = var1[1];
hh = 0;
ll = 0;
For cnt = 1 to (var1-Var2)
{
if hh == 0 or (hh > 0 and H[cnt] > hh) Then
hh = h[cnt];
if ll == 0 or (ll > 0 and l[cnt] <= ll) Then
ll=l[cnt];
}
For cnt = 49 to 1
{
CC[cnt,0] = CC[cnt-1,0];
CC[cnt,1] = CC[cnt-1,1];
}
CC[0,0] = hh;
CC[0,1] = ll;
}
2025-04-30
252
글번호 190488
답변완료
문의드립니다,
아래수식이 매수신호가 나지 않습니다.
확인부탁드립니다.
data2 이동평균선골든크로스 and data1 rsi oscillator bull 매수시 data1 매수식
data2 이동평균선데드크로스 or data1 이동평균선데드크로스시 data1매도식
Inputs : P1(5),P2(20),RSILength(10), OverSold(30),OverBought(70);
var : m1(0,Data2),m2(0,Data2), R(0,Data1);
m1 = Data2(ma(C,P1));
m2 = Data2(ma(C,P2));
R = data1(RSI(RSILength));
If Data2(CrossUp(m1,m2)) and Crossup(R, OverSold) Then
Buy("B");
If Data2(CrossDown(m1,m2)) or data1(CrossDown(ma(c,5),ma(c,20))) Then
Sell("S");
2025-04-29
250
글번호 190487
사공하늘 님에 의해서 삭제되었습니다.
2025-04-29
86
글번호 190485
러블리 님에 의해서 삭제되었습니다.
2025-04-29
17
글번호 190483
회원 님에 의해서 삭제되었습니다.
2025-04-28
44
글번호 190482
답변완료
분봉 일봉 합치기...
아직 초보라 질문 드립니다...
아래 예시를 예스트레이더로 짜주실 수 있나요? (분봉, 일봉 혼합)
(1) 삼성전자라는 종목을
(2) 일봉상 정배열이고, (5분봉 > 20분봉 > 60분봉)
(3) 5분봉상 RSI가 30 이하일 때
(4) 매수
2025-04-28
272
글번호 190481
답변완료
식
안녕하세요 진입 청산 각각 부탁 드립니다
1 if CrossUP(A,B)
buy("B");
2 if CrossUP(C,D)
buy("BB");
1에 대한 청산과
2에 대한 청산 입니다
2025-04-28
296
글번호 190480
답변완료
시스템 진입신호시간과 스탑로스
input : short(12),long(26),sig(9);
var : S1(0),D1(0),TM(0),EP1(0),EP2(0),EP3(0);
var : macdv(0,Data1),macds(0,Data1);
var : macdv1(0,Data2),macds1(0,Data2);
var : macdv2(0,Data3),macds2(0,Data3);
macdv = data1(macd(short,long));
macds = data1(Ema(macdv,sig));
macdv1 = data2(macd(short,long));
macds1 = data2(Ema(macdv1,sig));
macdv2 = data3(macd(short,long));
macds2 = data3(Ema(macdv2,sig));
if MarketPosition <= 0 and CrossUp(MACDV,0) and MACDV1 > 0 and MACDV2 > 0 Then
Buy();
if MarketPosition >= 0 and CrossDown(MACDV,0) and MACDV1 < 0 and MACDV2 < 0 Then
Sell();
if MarketPosition == 1 and CrossDown(MACDV,0) Then
ExitLong();
if MarketPosition == -1 and CrossUp(MACDV,0) Then
ExitShort();
input : 당일청산시간(020000),익절틱수(100),손절틱수(100),최소수익틱수(30),이익보존틱수(10);
if sDate != sDate[1] Then
SetStopEndofday(055000);
if Bdate != Bdate[1] Then
SetStopEndofday(0);
if MarketPosition == 1 Then
{
if highest(H,BarsSinceEntry) >= EntryPrice+PriceScale*최소수익틱수 Then
ExitLong("bx",AtStop,EntryPrice+PriceScale*이익보존틱수);
}
if MarketPosition == -1 Then
{
if lowest(L,BarsSinceEntry) <= EntryPrice-PriceScale*최소수익틱수 Then
ExitShort("sx",AtStop,EntryPrice-PriceScale*이익보존틱수);
}
SetStopProfittarget(PriceScale*익절틱수,PointStop);
SetStopLoss(PriceScale*손절틱수,PointStop);
------------------------------------------------------------------------------------
&&&위 시스템코딩 작성에 감사드리며 변수에보면 익절틱,손절틱,최소틱,이익보존틱
총4개로 돼있어 좀어렵습니다
트레일링스탑으로 수정이 나을것 같습니다
50틱 수익을바란다면 70틱에감시를해놓고 20틱하락이런식으로
손절틱,감시틱,되돌림틱,
현재 분봉3개혼합입니다 진입분봉 데이터분봉2개 macd 0선이상이상 일치전략입니다
데이터분봉에 매수시는 macd골든크로스 상태 매도시는 데드크로스 상태 추가요
<5분봉 0선돌파 30분봉60분봉 0선위에있으나 데드크로스진행은 비추세로보고 진입시점아님
5분봉 0선돌파 30분봉60분봉 0선위에 있고 골든크로스진행은 추세로보고 진입시점
매도는 위의 내용 반대입니다>
지금 당일청산기능과 다른주기데이터조합은 유용합니다
해외선물은 23시간 횡보낮시간에 피하고자 당일청산시간같은
진입도 시작시간 추가가 가능한지 문의드립니다
감사합니다
2025-04-29
325
글번호 190479
답변완료
문의드립니다
Print( "종가.csv" , ",%.f" , C );
명령어에서
종목이름(또는 종목번호)을
자동적으로 넣어 종가를 받을때 구분하고싶습니다
차트 분할틀 6X6 콜옵션 36개를 세팅한 다음
지표 전체 적용을 하여 한번에 종가를 받고싶습니다
감사합니다
2025-04-28
300
글번호 190478