커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1614
글번호 230811
회원 님에 의해서 삭제되었습니다.
2022-11-27
66
글번호 164192
답변완료
문의드립니다.
다음의 수식을 종목검색식으로 나타내고 싶습니다.
m = (highest(O, 중간기간) + lowest(O, 중간기간))/2;
m1=(avg(m*sum(1), period) - avg(sum(1), period)*avg(m, period))
/
(avg(pow(sum(1), 2), period) - (pow(avg(sum(1), period), 2)))
*(sum(1) - avg(sum(1), period))
+ avg(m, period);
A = m1 + LRS(period);
n = (highest(C, 중간기간) + lowest(C, 중간기간))/2;
n1=(avg(n*sum(1), period) - avg(sum(1), period)*avg(n, period))
/
(avg(pow(sum(1), 2), period) - (pow(avg(sum(1), period), 2)))
*(sum(1) - avg(sum(1), period))
+ avg(n, period);
B = n1 + LRS(period);
조건=CrossUp(B, A);
조건 && !조건(1)
2022-11-27
985
글번호 164191
답변완료
봉개수 카운트 2번 나타남
안녕하세요.
전략식 작성 중 진입하고 난 뒤 일수에 따라 청산을 다르게 하는 다음 프로그램에서 매일 9시05분 봉이 첨부파일과 같이 2번 카운트 되는 오류가 발생했습니다. 예스트레이더 버그 확인부탁합니다.
if sdate != sdate[1] Then
var1 = var1+1;
if var1 == var1[BarsSinceEntry]+1 Then#진입 1일 후
if var1 == var1[BarsSinceEntry]+2 Then#진입 2일 후
if var1 == var1[BarsSinceEntry]+3 Then#진입 3일 후
if var1 == var1[BarsSinceEntry]+4 Then#진입 4일 후
messagelog로 찍어보면 첨부파일과 같이 매일 9시05분 봉이 2번 나타남을 볼 수 있습니다.
2022-11-27
901
글번호 164190
회원 님에 의해서 삭제되었습니다.
2022-11-27
337
글번호 164189
답변완료
부탁 드립니다
도움에 감사 드립니다.
변환부탁 드립니다.
함수 up(n)
if(n>n(1),1,0);
m=ma(c,기간,종류);
up(m)+
up(m(1))+
up(m(2))+
up(m(3))+
up(m(4))+
up(m(5))+
up(m(6))+
up(m(7))+
up(m(8))+
up(m(9));
*추신:
변환후 m(0)에서 m(9)를 for~to문을 이용하여
0에서 n까지 부탁 드립니다.
2022-11-26
663
글번호 164188
회원 님에 의해서 삭제되었습니다.
2022-11-26
78
글번호 164187
회원 님에 의해서 삭제되었습니다.
2022-11-26
106
글번호 164186
답변완료
지표수식 변환 요청드립니다
아래지표를 타주기분(5분)으로 변환부탁드립니다.
==================
input : length(2),mult(2),useClose(true),크기(25);
var : ATrv(0),longStop(0),longStopprev(0),shortStop(0),shortStopPrev(0);
var : hsc(0),dir(1),longcolor(Crimson),shortcolor(Blue),tx(0);
var : truehighv(0),TrueLowv(0),TrueRangev(0),hsatr(0) ;
var : xClose(0),xOpen(0),xHigh(0),xLow(0);
if index == 0 then
{
xOpen = open;
xClose = (O+H+L+C)/4;
xHigh = MaxList( high, xOpen, xClose);
xLow = MinList( low, xOpen,xClose);
}
else
{
xClose = (O+H+L+C)/4;
xOpen = (xOpen [1] + xClose [1])/2 ;
xHigh = MaxList(High, xOpen, xClose) ;
xLow = MinList(Low, xOpen, xClose) ;
}
////////
If xClose[1] > xHigh then
TrueHighv = xClose[1];
else
TrueHighv = xHigh;
If xClose[1] < xLow then
TrueLowv = xClose[1];
else
TrueLowv = xLow;
TrueRangev = TrueHighv - TrueLowv;
hsatr = ma(TrueRangev,length);
hsc = xclose ;
//////////
atrv = mult * hsatr;
longStop = IFf(useClose , highest(hsc, length) , highest(h,length)) - atrv;
longStopPrev = longStop[1];
longStop = iff(hsc[1] > longStopPrev , max(longStop, longStopPrev) , longStop);
shortStop = IFf(useClose , lowest(hsc, length) , lowest(L,length)) + atrv;
shortStopPrev = shortStop[1];
shortStop = iff(hsc[1] < shortStopPrev , min(shortStop, shortStopPrev) , shortStop);
dir = iff(hsc > shortStopPrev , 1 ,iff( hsc < longStopPrev , -1 , dir));
IF dir == 1 Then
{
plot1(longStop,"Long Stop",longColor);
NoPlot(2);
}
Else
{
NoPlot(1);
plot2(shortStop,"Short Stop",shortColor);
}
////////
if dir == 1 and dir[1] == -1 and hsc > zlsma
Then
{
tx = Text_New(sDate,sTime,longStop,"▲");
Text_SetStyle(tx,2,0);
Text_SetSize(tx, 크기);
Text_SetColor(tx,longcolor);
}
if dir == -1 and dir[1] == 1 and hsc < zlsma
Then
{
tx = Text_New(sDate,sTime,shortStop,"▼");
Text_SetStyle(tx,2,1);
Text_SetSize(tx, 크기);
Text_SetColor(tx,shortcolor);
}
=========================
##ZLSMA
Input : Period(60);
var : lsma(0),lsma2(0),eq(0),zlsma(0);
lsma = LRL(C,Period);
lsma2 = LRL(lsma,Period);
eq= lsma-lsma2 ;
zlsma = lsma+eq ;
if zlsma > zlsma[1] Then
plot1(zlsma,"lsma");
2022-11-27
708
글번호 164185
졸던 님에 의해서 삭제되었습니다.
2022-11-26
50
글번호 164184