커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4427
글번호 230811
답변완료
문의 드립니다.
항상 감사 드립니다.
질문 드릴께요..
질문,
Input : Period(1);
var : kk(0),aa(0);
aa = data2(ma(bids,Period));
kk = data2(ma(asks,Period));
var1 = aa - kk;
var2 = ma(var1, 5);
var3 = ma(var1, 10);
var4 = ma(var1, 15);
var5 = ma(var1, 20);
Plot1(var2);
Plot2(var3);
Plot3(var4);
Plot4(var5);
위와같이 수식을 작성했는데
전일데이터와 합쳐지니 제대로 나오지 않네요..
날짜가 바뀌면 데이터가 초기화 되게 부탁드립니다.
커뮤니티 보고 혼자해보려 했는데 도저히 제대로 나오지 않네요.. 부탁드립니다.
지표가 초기화되면 var5 같은경우 시간이 9시 20분이 되기 전에는 출력되지 않게 해 주세요
2017-03-08
107
글번호 107603
태양같이 님에 의해서 삭제되었습니다.
2017-03-09
52
글번호 107601
답변완료
수식부탁드림니다=================
장시작시 var1,var2가 100에서시작하게되있는데
이걸
지금으로부터 10봉전에둘다 100에서시작하게 바꿔주시면 감사하겠슴니다
실시간으로 10봉전부터 현재까지 var1,var2의 변화를보려고 합니다
if Bdate != Bdate[1] Then{
idx = 0;
var1 = 100;
var2 = 100;
plot10(var1);
plot11(var2);
plot51(var2 +호가더하기/1000 );
}
Else{
idx = idx+1;
var1 = var1+(var1*(va91/100));
if abs(va96[3]-va96) <= 보정치/10000 Then
var2 = var1;
else
2017-03-08
105
글번호 107600
답변완료
수식 작성 요청드립니다.
안녕하세요.
언제나 도움 주셔서 감사합니다.
간단한 수식 부탁드립니다.
매수조건 : 20 이동평균선이 우하향하다가 우상향으로 반전 시
매도조건 : 20 이동평균선이 우상향하다가 우하향으로 반전 시
수고하세요.
2017-03-08
94
글번호 107599
바나 님에 의해서 삭제되었습니다.
2017-03-08
3
글번호 107598
아트정 님에 의해서 삭제되었습니다.
2017-03-08
55
글번호 107596
답변완료
문의드립니다
mav9 = ma(c, Period9);
mav10 = ma(c, Period10);
mav11 = ma(c, Period11);
mav12 = ma(c, Period12);
mav13 = ma(c, Period13);
mav14 = ma(c, Period14);
mav15 = ma(c, Period15);
mav16 = ma(c, Period16);
mav17 = ma(c, Period17);
mav18 = ma(c, Period18);
SROC = ema(C,Period1)/ema(c,Period1)[Period2]*100;
SROCsig = ema(SROC,signal);
if MarketPosition <= 0 and
(mav11 > mav11[1] and mav10 > mav11 and mav11 > mav12 and mav12 > mav13 and mav13 > mav14 and mav14 > mav15 and mav15 > mav16 and mav16 > mav17 and crossup(mav9,mav10)) or (mav12 < mav13 and mav13 < mav15 and mav15 < mav16 and mav16 < mav17 and crossup(mav11,mav13)) or (mav18 > mav18[1] and CrossUP(SROC,SROCsig)) or (mav11 < mav12 and mav12 < mav13 and mav13 < mav14 and mav14 < mav15 and mav15 < mav16 and mav12 < mav17 and mav17 < mav16 and crossup(mav10,mav11)) Then
buy("b",OnClose,def,1);
if MarketPosition == 1 Then{
if mav11 > mav11[1] and CurrentContracts < 5 Then
buy("bb",OnClose,def,1);
if (mav11 > mav11[1] and mav12 > mav13 and mav13 > mav14 and mav14 > mav15 and mav15 > mav16 and mav16 > mav17 and CrossDown(mav9,mav11)) or (CrossDown(SROC,SROCsig)) or (mav12 < mav13 and mav13 < mav14 and mav14 < mav15 and mav15 < mav16 and mav12 < mav17 and mav17 < mav16 and CrossDown(mav10,mav11)) Then{
ExitLong("bx");
}
ExitLong("bp",atlimit,AvgEntryPrice+PriceScale*익절틱수);
ExitLong("bl",AtStop,AvgEntryPrice-PriceScale*손절틱수);
}
if MarketPosition >= 0 and
(mav11 < mav11[1] and mav10 < mav11 and mav11 < mav12 and mav12 < mav13 and mav13 < mav14 and mav14 < mav15 and mav15 < mav16 and mav16 < mav17 and CrossDown(mav9,mav10)) or (mav12 > mav13 and mav13 > mav15 and mav15 > mav16 and mav16 > mav17 and CrossDown(mav11,mav13)) or (mav18 < mav18[1] and CrossDown(SROC,SROCsig)) or (mav11 > mav12 and mav12 > mav13 and mav13 > mav14 and mav14 > mav15 and mav15 > mav16 and mav12 > mav17 and mav17 > mav16 and CrossDown(mav10,mav11)) Then
sell("s",OnClose,def,1);
if MarketPosition == -1 then{
if mav11 < mav11[1] and CurrentContracts < 5 Then
sell("ss",OnClose,def,1);
if (mav11 < mav11[1] and mav12 < mav13 and mav13 < mav14 and mav14 < mav15 and mav15 < mav16 and mav16 < mav17 and crossup(mav9,mav11)) or (crossup(SROC,SROCsig)) or (mav12 > mav13 and mav13 > mav14 and mav14 > mav15 and mav15 > mav16 and mav12 > mav17 and mav17 > mav16 and crossup(mav10,mav11)) Then
ExitShort("sx");
ExitShort("sp",atlimit,AvgEntryPrice-PriceScale*익절틱수);
ExitShort("sl",AtStop,AvgEntryPrice+PriceScale*손절틱수);
}
2번 수식
mav9 = ma(c, Period9);
mav10 = ma(c, Period10);
mav11 = ma(c, Period11);
mav12 = ma(c, Period12);
mav13 = ma(c, Period13);
mav14 = ma(c, Period14);
mav15 = ma(c, Period15);
mav16 = ma(c, Period16);
mav17 = ma(c, Period17);
mav18 = ma(c, Period18);
if (mav12 < mav13 and mav13 < mav15 and mav15 < mav16 and mav16 < mav17 and crossup(mav11,mav13)) or (mav11 < mav12 and mav12 < mav13 and mav13 < mav14 and mav14 < mav15 and mav15 < mav16 and mav12 < mav17 and mav17 < mav16 and crossup(mav10,mav11)) Then
T = 1;
if (mav12 > mav13 and mav13 > mav15 and mav15 > mav16 and mav16 > mav17 and CrossDown(mav11,mav13)) or (mav11 > mav12 and mav12 > mav13 and mav13 > mav14 and mav14 > mav15 and mav15 > mav16 and mav12 > mav17 and mav17 > mav16 and CrossDown(mav10,mav11)) Then
T = -1;
if T == 1 then{
if crossuP(mav10,mav11) Then
buy();
if CrossDown(mav9,mav10) Then
ExitLong();
}
if T == -1 then{
if CrossDown(mav10,mav11) Then
sell();
if Crossup(mav9,mav10) Then
ExitShort();
}
1번질문
1번 수식을 운영하다보면 5개가 아닌 6개계약으로도 진입을 하는 것 같습니다
1번 수식이 6계약 이상 진입은 에러 인가요(대부분은 5계약으로 진입하다가 가끔 6계약이상이 진입합니다)
2번 질문
1번 수식 기준으로 2번 수식을 함계 운영하고자 합니다
즉 1번 수식에 2번 수식도 시스템수식이 동작할 수 있도록 넣어 주세요
감사합니다
2017-03-08
95
글번호 107588
답변완료
수식 부탁 드립니다
//시간보정된때를 plot으로표시하고싶슴니다 부탁드립니다
if stime == 시간보정*100 then {
PLOT62(100,"시간보정");
}
위의식이 맞나요?표시가안되네요
Input: 시간보정(0),호가더하기(0),지수더하기(0),보정치(0),폭보정(1.5),지수호가테마LENGTH1(10),순매수LENGTH2(10),급변(0.05)
,순매수테마보정한계(0.3),순매수테마급증보정(0.5),순매수테마급감보정(0.5)
,지수테마보정한계(0.3),지수테마급증보정(0.5),지수테마급감보정(0.5) ;
var : AsksMA(0),BidsMA(0), Period(1),idx(0),EP(0),E11(0),E12(0),E13(0),E21(0),E22(0),E23(0);
Var : value(0);
Var : valuec(0);
var : va61(0);
var : va71(0);
var : va80(0);
var : va81(0);
var : va90(0);
var : va91(0);
var : va92(0);
var : va93(0);
var : va94(0);
var : va95(0);
var : va96(0);
VAR : TEMA1(0);
VAR : TEMA2(0);
VAR : TEMA3(0);
VAR : vmin(0);
VAR : vmax(0);
BidsMa = ma(bids,Period);
AsksMA = ma(asks,Period);
value = ma(bids,period)-ma(asks,period)+29000;
Plot2(BidsMA, "매수잔량이평");
Plot3(AsksMA, "매도잔량이평");
Plot4(value, "차");
//**************************************************************
//*************************************************************
va91=((c-c[1])/c[1]*100)*20000/20000;
va93=((value-value[1])/value[1]*70)*125/2900;
if stime == 시간보정*100 or (stime > 시간보정*100 and stime[1] < 시간보정*100) Then{
idx = 0;
var1 = 100;
var2 = 100;
plot10(var1);
plot11(var2);
plot51(var2 +호가더하기/1000 );
}
Else{
idx = idx+1;
var1 = var1+(var1*(va91/100));
if abs(va96[10]-va96) <= 보정치 Then
var2 = var1;
else
var2 = var2+(var2*(va93/95));
plot10(var1+지수더하기/1000 );
plot11(var2+호가더하기/1000 );
plot51(var2+호가더하기/1000 );
TEMA3 = (3 * Ema(var2+호가더하기/1000 ,순매수LENGTH2)) - (3 * Ema(Ema(var2+호가더하기/1000 ,순매수LENGTH2),순매수LENGTH2)) +
(Ema(Ema(Ema(var2+호가더하기/1000 ,순매수LENGTH2),순매수LENGTH2),순매수LENGTH2));
if TEMA3 >TEMA3[1]+순매수테마보정한계 then TEMA3 = ((TEMA3 -TEMA3[1])*순매수테마급증보정)+TEMA3[1];
if TEMA3 <TEMA3[1]-순매수테마보정한계 then TEMA3 = TEMA3[1]-((TEMA3[1] -TEMA3)*순매수테마급감보정);
if TEMA3 >TEMA3[1]+50 then TEMA3 = ((TEMA3 -TEMA3[1])*0.9)+TEMA3[1];
if TEMA3 <TEMA3[1]-50 then TEMA3 = TEMA3[1]-((TEMA3[1] -TEMA3)*0.9);
plot52(TEMA3,"순매수테마");
}
if var2-var1 > 폭보정 Then var2=var1;
if var1-var2 > 폭보정 Then var2=var1;
//if va71[1] < va71 and va71[1] + 0.05 > va71 then var2=var1;
//if va71[1] > va71 and va71[1] - 0.05 > va71 then var2=var1;
EP = 2/(지수호가테마LENGTH1+1);
if idx == 0 Then{
E11 = var1;
E21 = var2;
}
Else{
E11 = var1 * EP + E11 * (1-EP);
E21 = var2 * EP + E21 * (1-EP);
}
if idx <= 1 Then{
E12 = E11;
E22 = E21;
}
Else{
E12 = E11 * EP + E12 * (1-EP);
E22 = E21 * EP + E22 * (1-EP);
}
if idx <= 2 Then{
E13 = E12;
E23 = E22;
}
Else{
E13 = E12 * EP + E13 * (1-EP);
E23 = E22 * EP + E23 * (1-EP);
}
TEMA1 = (3 * E11) - (3 * E12) + (E13);
if TEMA1 >TEMA1[1]+지수테마보정한계 then TEMA1 = ((TEMA1 -TEMA1[1])*지수테마급증보정)+TEMA1[1];
if TEMA1 <TEMA1[1]-지수테마보정한계 then TEMA1 = TEMA1[1]-((TEMA1[1] -TEMA1)*지수테마급감보정);
if TEMA2 >TEMA2[1]+지수테마보정한계 then TEMA2 = ((TEMA2 -TEMA2[1])*지수테마급증보정)+TEMA2[1];
if TEMA2 <TEMA2[1]-지수테마보정한계 then TEMA2 = TEMA2[1]-((TEMA2[1] -TEMA2)*지수테마급감보정);
TEMA2 = (3 * E21) - (3 * E22) + (E23);
PLOT30(TEMA1+지수더하기/1000 ,"지수테마",iff((TEMA1 +지수더하기/1000 )>(TEMA1 +지수더하기/1000)[1]+00,BLACK,iff((TEMA1 +지수더하기/1000 )<(TEMA1 +지수더하기/1000 )[1]-00,BLACK,BLACK)));
PLOT31(TEMA2 +호가더하기/1000,"호가테마");
vmin = min(TEMA1+지수더하기/1000 ,TEMA2+호가더하기/1000 );
vmax = max(TEMA1+지수더하기/1000 ,TEMA2+호가더하기/1000 );
if TEMA1+지수더하기/1000> TEMA2+호가더하기/1000 Then{
var80 = (TEMA1+지수더하기/1000- TEMA2 +호가더하기/1000 )*0.5+TEMA2+호가더하기/1000 ;
}
if TEMA1 < TEMA2+호가더하기/1000 Then{
var80 = (TEMA2+호가더하기/1000 -TEMA1+지수더하기/1000)*0.5+TEMA1+지수더하기/1000 ;
}
PLOT17(var80,"지호평균");
//테마합 일정 수량차이상의 급등락 표시
if TEMA3 > TEMA3[1]+ 급변 Then{plot21(vmin-0.05,"급등");}
if TEMA3 < TEMA3[1]- 급변 Then{plot22(vmin-0.05,"급락");}
va71 =( TEMA2+호가더하기/1000 - TEMA1+지수더하기/1000 )+100;
if ( TEMA2+호가더하기/1000 )[1] < ( TEMA2+호가더하기/1000 ) and (TEMA1+지수더하기/1000)[1] < (TEMA1+지수더하기/1000) Then{
PLOT25((vmin )-0.02,"매수예비");
//PlaySound("C:₩예스트레이더₩data₩Sound₩pp.wav");
}
if ( TEMA2+호가더하기/1000 )[1] > ( TEMA2+호가더하기/1000 ) and (TEMA1+지수더하기/1000)[1] > (TEMA1+지수더하기/1000) Then{
PLOT26((vmin )-0.02,"매도예비");
// PlaySound("C:₩예스트레이더₩data₩Sound₩dingdong.wav");
}
PLOT60(va71,"55");
if CrossUp (( TEMA2+호가더하기/1000 ),(TEMA1+지수더하기/1000)) Then{
//if (TEMA1[1]+지수더하기/1000 )< (TEMA1+지수더하기/1000) and (va71[1] )< (va71)then {
PLOT45((vmin )-0.02,"매수막대");
PlaySound("C:₩예스트레이더₩data₩Sound₩up.wav");
}
if CrossDown (( TEMA2+호가더하기/1000 ),(TEMA1+지수더하기/1000)) Then{
// if (TEMA1[1]+지수더하기/1000 )> (TEMA1+지수더하기/1000) and (va71[1] )> (va71) Then{
PLOT46((vmin )-0.02,"매도막대");
PlaySound("C:₩예스트레이더₩data₩Sound₩dingdong.wav");
}
if va71[1]+급변 < va71 Then {
PLOT18((va71 )+0.01,"매도");
}
if va71[1]-급변 > va71 Then {
PLOT19((va71 )+0.01,"매수");
}
va96 = (tema1 - tema2)*1000;
PLOT61(va96,"66",iff(va96 > 0,RED,iff(va96 < 0,BLACK,BLACK)));
PlotBaseLine1(100,"기준선100");
2017-03-09
101
글번호 107587
답변완료
시스템식 부탁드립니다.
항상 도움 주셔서 감사합니다.
문1) 아래와 같이 추세선을 그리고
특정 A라인을 돌파시 포지션 진입, 다음 B라인 터치시 청산하는 경우
현재시점이 특정 A라인을 돌파한 이후일 경우(다음 B라인 터치 이전인 경우)
실제 매매에서는 포지션이 진입 안될것으로 예상되는데
만약 특정 A라인 돌파 이후 포지션을 진입하려면 어떻게 해야 하나요?
예를 들면
특정 A라인 돌파이후 5봉이 지났다거나,
특정 A라인 돌파 이후 10분이 경과했다든가
아니면 특정 A라인 돌파 이후 다음 B라인까지 거래가 50% 남았다거나 할경우
포지션을 진입하고 싶습니다.(3가지 모두 부탁드립니다.)
문2) 실계좌 매매에서 문)1과 같이 현재 시점이 특정 A라인 돌파 이후라면
포지션(매수라고 가정) 진입이 안될것이라고 생각되는데
이런 경우 다음 B라인 터치시 매도 진입을 해서 다시 특정 A라인에서 매도청산을
하려면 어떻게 해야 하나요?
문3) 아래와 같이 매매시
특정 A라인 돌파 이후 포지션 진입 및 다음 B라인에서 청산이후
다시 반대 방향으로 포지션 진입을 하고 싶습니다.
첫번째 매매: 특정 A라인 돌파시 매수 다음 B라인 터치시 매도 청산
두번째 매매: 매도 청산후 다시 특정 A라인 방향으로 매도 진입
두번재 청산조건 :
1 - 진입 B라인에서 특정 A라인 터치시
2 - 진입 B라인에서 특정 A라인까지 거래의 50% 지점에서 청산
문4) 위와 같은 경우 스탑로스를 포함하여 3번만 매매하고 싶습니다.
어떻게 해야 하나요?
문5) 특정 A라인과 다음 B라인 추세선을 아래와 같이 작성시
A라인과 B라인의 차이(A라인-B라인의 값)를 어떻게 구할수 있나요?
문6) 차트 오른쪽 상단에 뉴욕시간 테스트함수로 실시간 표시 가능한가요?
문7) 5분 차트에서 5분동안의 남은 시간을 그래프로 표시할수 있나요?
질문 많이 드려 죄송합니다.
도움 부탁드립니다.
// 시스템식 - 오일 4월물 5분봉
input : 추세선시작일1(20170303),추세선시작시간1(220000); //추세선1-저가
input : 추세선종료일1(20170306),추세선종료시간1(171000); //추세선1-저가2
input : 추세선시작일2(20170306),추세선시작시간2(081000); //추세선2-고가
input : 추세선종료일2(20170306),추세선종료시간2(185000); //추세선2-고가2
input : X1(0.72),X11(-0.72),X2(0.42),X22(-0.42) ;// 추세선 이동
input : loss(10),profit(30),Tp(10),Ts(5); // 수익,손절,트레일링스탑
var : TL1(0),TLL1(0),TLLL1(0),T1(0); //추세선1-지지
var : TL2(0),TLL2(0),TLLL2(0),T2(0); //추세선2-저항
##### 추세선 그리기 #####
// 추세선1 - 저가
if sdate == 추세선시작일1 and time == 추세선시작시간1 Then{
T1 = 1;
var1 = L;
}
if T1 == 1 and sdate == 추세선종료일1 and time == 추세선종료시간1 Then{
var2 = L;
TL1 = TL_New(추세선시작일1,추세선시작시간1,var1,추세선종료일1,추세선종료시간1,var2);
TL_SetExtLeft(TL1,true);
TL_SetExtRight(TL1,true);
TL_SetColor(TL1,BLUE) ;
T1 = 2;
TLL1 = TL_New(추세선시작일1,추세선시작시간1,var1+x1,추세선종료일1,추세선종료시간1,var2+x1); //추세선 복사
TL_SetExtLeft(TLL1,true);
TL_SetExtRight(TLL1,true);
TL_SetColor(TLL1,BLUE) ;
TLLL1 = TL_New(추세선시작일1,추세선시작시간1,var1+x11,추세선종료일1,추세선종료시간1,var2+x11); //추세선 복사
TL_SetExtLeft(TLLL1,true);
TL_SetExtRight(TLLL1,true);
TL_SetColor(TLLL1,BLUE) ;
}
// 추세선2 - 고가
if sdate == 추세선시작일2 and time == 추세선시작시간2 Then{
T2 = 1;
var3 = H;
}
if T2 == 1 and sdate == 추세선종료일2 and time == 추세선종료시간2 Then{
var4 = H;
TL2 = TL_New(추세선시작일2,추세선시작시간2,var3,추세선종료일2,추세선종료시간2,var4);
TL_SetExtLeft(TL2,true);
TL_SetExtRight(TL2,true);
TL_SetColor(TL2,RED) ;
T2 = 2;
TLL2 = TL_New(추세선시작일2,추세선시작시간2,var3+x2,추세선종료일2,추세선종료시간2,var4+x2);
TL_SetExtLeft(TLL2,true);
TL_SetExtRight(TLL2,true);
TL_SetColor(TLL2,RED) ;
TLLL2 = TL_New(추세선시작일2,추세선시작시간2,var3+x22,추세선종료일2,추세선종료시간2,var4+x22);
TL_SetExtLeft(TLLL2,true);
TL_SetExtRight(TLLL2,true);
TL_SetColor(TLLL2,RED) ;
}
##### 시스템매매 #####
// 진입 시스템
// 매매시간 시작
if T1 == 2 then {
// 하락
if T1 == 2 and MarketPosition == 0 then { //and s_line1 > -1 and s_line4 < 0 then{
if C < TL_GetValue(TL1,sdate,stime) and C[1] > TL_GetValue(TL1,sdate[1],stime[1]) Then
sell("S");
}
// 상승
if T2 == 2 and MarketPosition == 0 then { //and s_line1 < 1 and s_line4 > 0 then{
if C > TL_GetValue(TL2,sdate,stime) and C[1] < TL_GetValue(TL2,sdate[1],stime[1]) Then
Buy("B");
}
// 청산 시스템
// 매도청산
// X1,X2에 닿을 경우
if MarketPosition == -1 then{
if (L <= TL_GetValue(TLLL1,sdate,stime) and L[1] > TL_GetValue(TLLL1,sdate[1],stime[1]))
or (L <= TL_GetValue(TLLL2,sdate,stime) and L[1] > TL_GetValue(TLLL2,sdate[1],stime[1])) Then
ExitShort("SX");
}
// 매수청산
// // X11,X22에 닿을 경우
if MarketPosition == 1 then{
if (H >= TL_GetValue(TLL1,sdate,stime) and H[1] < TL_GetValue(TLL1,sdate[1],stime[1]))
or (H >= TL_GetValue(TLL2,sdate,stime) and H[1] < TL_GetValue(TLL2,sdate[1],stime[1])) Then
ExitLong("BX");
}
}
2017-03-08
111
글번호 107586