커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4425
글번호 230811
답변완료
안녕하세요?
안녕하세요
어제 작성해주신 수식 감사합니다.
52374번 수식에 수정 부탁드립니다.
당일 고점이나,저점 갱신전까지는 문제없이 변수에 할당이 잘 됨니다.
그런데 고점이나,저점 갱신시 var1에는 그전에 값이 남아 있습니다.
첨부 그림을 보시면
var1에는 그전값 1205.9
var2에는 1205.20 고점갱신후 첫번째값
var3에는 1203.80 고점갱신후 두번째값
이런식으로 데이타 밀림 현상이 있습니다.
영업일 기준으로는 변수값 리셋이 되는것 같은데요
당일 기준으로 고저갱신때 리셋거는 수식이 있으면 해결될것 같은데
초보라 도움 요청드립니다.
수정이 가능하다면 수정 부탁드립니다.
2017-03-15
160
글번호 107793
답변완료
질문드립니다
제가 지금 차트를 3분봉으로 보고 있습니다.
if h > min(c[1],L) * 1.15 then
find(1);
이걸 사용하려고 하는데 3분봉이라서 전일종가 인식을 못하는건가요??
자꾸 기준이 당일저가가 됩니다. 혹시 제가 실수한게 있는지
그리고 답변주신 식중에 ~~~~and H[1] < r1[1]) or ~~~~ 이 부분
전일 고가와 전일 r1은 수식에 적히는 이유가 뭔가요??
지식이 너무 부족해서 죄송합니다 ㅎㅎ
if h >= max(C[1],L[0])*1.15 and
((H >= r1 and H[1] < r1[1]) or (L <= r1 and L[1] > r1[1])) then
find(1);
그리고 마지막으로 저가대비 15%상승한애들중에 강조를 해주고 싶습니다.
if h > min(c[1],daylow)*1.15 Then
PlotPaintBar(h,l,"15%",black);
이렇게 식을 작성해주었는데 첫 시작되는 첫번째 봉만 검은색으로 나오게 할수는 없나요??
15%에 걸쳐있는 애들이 다 검은색으로 변해서
이것도 괜찮은데 추가적으로 하나만 하는것도 배우고 싶습니다
2017-03-14
119
글번호 107791
왓썹 님에 의해서 삭제되었습니다.
2017-03-14
0
글번호 107790
답변완료
검색식 사용법
NH트레이더 사용자입니다.
정말 죄송한데요
검색식은 스스로 만들었는데 종목검색에서 어떻게 사용해야 하는지를 몰라서
문의드립니다. 혹시 사용법 동영상이나 이런것 없나요?
메뉴얼에도 없고...
2017-03-14
138
글번호 107789
답변완료
수식부탁드림니다=================
장시작시나 시간보정시 var1과var2값이 100이되게되있는데 이걸 장시작시는 그대로두고
시간보정시만 var2값을 var1값에 일치시켜주시면 감사하겠습니다 항상감사합니다
---------------------------------------------------------------------------------
Input: 시간보정(0),보정후변화(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) or Bdate != Bdate[1] Then{
PLOT62(100,"시간보정");
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;
// if var2[5] > var1[5] then var2 = var2 - ( var2[5] - var1[5] );
// if var2[5] < var1[5] then var2 = var2 + ( var1[5] - var2[5] );
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.3;
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 sTime > (시간보정*100) and (TEMA1+지수더하기/1000)+보정후변화 < ( TEMA2+호가더하기/1000 ) and
//(TEMA1+지수더하기/1000)[1] > (TEMA1+지수더하기/1000)
//if (TEMA1+지수더하기/1000)[1]+0.0 < (TEMA1+지수더하기/1000) and va71[1]-0.01 < va71
if (TEMA1+지수더하기/1000)[1]+0.0 < (TEMA1+지수더하기/1000) and ( TEMA2+호가더하기/1000 )[1] < ( TEMA2+호가더하기/1000 )
then {
PLOT45((vmin )-0.0,"매수막대");
PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav");
}
// CrossDown (( TEMA2+호가더하기/1000 ),(TEMA1+지수더하기/1000)) Then{
//if sTime > (시간보정*100) and (TEMA1+지수더하기/1000)-보정후변화 > ( TEMA2+호가더하기/1000 ) and
//(TEMA1+지수더하기/1000)[1] < (TEMA1+지수더하기/1000)
//if (TEMA1+지수더하기/1000)[1]-0.0 > (TEMA1+지수더하기/1000) and va71[1]+0.01 > va71
if (TEMA1+지수더하기/1000)[1]+0.0 > (TEMA1+지수더하기/1000) and ( TEMA2+호가더하기/1000 )[1] > ( TEMA2+호가더하기/1000 )
then {
PLOT46((vmin )-0.0,"매도막대");
PlaySound("C:₩예스트레이더₩data₩Sound₩reject.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");
if stime == 시간보정*100 then {
PLOT62(100,"시간보정");
}
2017-03-14
123
글번호 107788
답변완료
지표 문의 드립니다.
if( (avg(if(c<c(5),(c(n)-c),0),14))<=0,100,
(100-
(100/(1+
(
(avg(if(c>c(5),(c-c(5)),0),14))/
(avg(if(c<c(5),(c(5)-c),0),14))
)
)
)
)
)
영웅문에 RMI라는 지표입니다. 예스랭에 없는 지표라 갖고와서 써보려고 하는데요
수식을 처음부터 다 뜯어 고치려니까 도저히 모르겠습니다..ㅠㅠ
영웅문과 명령어가 달라서 혹시 예스랭으로 변환 가능하면 부탁좀 드려도 될까요
2017-03-14
126
글번호 107776
답변완료
중복 되는 text없애는 방법
그림처럼 지저분하게 나오는 text를 없애고 싶습니다.
delete_text를 써도 나오네요...이유가...
2017-03-14
143
글번호 107774
답변완료
분할매도시
5퍼이상 상승 이후에 보합이나 1퍼상승부근까지 다시 내려올경우
완전매도하는 수식 추가가 가능할런지요?
지금은 분할매도로 해뒀는데 BX1 1차매도 BX2 이차매도 이런식으로 해뒀지만,
만약 BX1 1차매도 후에 다시 떨어지면 손절선까지 떨어져야 완전 매도하게 되더군요.
그러면 올랐었지만 손해보고 파는경우가 되어버려서요.
var : HH(0),Bxcond1(false),Bxcond2(false),Bxcond3(false);
var : LL(0),Sxcond1(false),Sxcond2(false),Sxcond3(false);
if MarketPosition == 1 then{
HH = highest(H,BarsSinceEntry);
if CurrentContracts < CurrentContracts[1] and LatestExitName(0) == "Bx1" Then
Bxcond1 = true;
if CurrentContracts < CurrentContracts[1] and LatestExitName(0) == "Bx2" Then
Bxcond2 = true;
if CurrentContracts < CurrentContracts[1] and LatestExitName(0) == "Bx3" Then
Bxcond3 = true;
if Bxcond1 == false and HH >= EntryPrice*1.02 and HH < EntryPrice*1.03 Then
ExitLong("Bx1",AtStop,HH-(HH-EntryPrice)*0.1,"",Floor(MaxContracts*(1/5)),1);
if Bxcond2 == false and HH >= EntryPrice*1.03 and HH < EntryPrice*1.05 Then
ExitLong("Bx2",AtStop,HH-(HH-EntryPrice)*0.1,"",Floor(MaxContracts*(2/5)),1);
if Bxcond3 == false and HH >= EntryPrice*1.07 Then
ExitLong("Bx3",AtStop,HH-(HH-EntryPrice)*0.1);
}
Else{
Bxcond1 = false;
Bxcond2 = false;
Bxcond3 = false;
}
if MarketPosition == -1 then{
LL = Lowest(L,BarsSinceEntry);
if CurrentContracts < CurrentContracts[1] and LatestExitName(0) == "Sx1" Then
Sxcond1 = true;
if CurrentContracts < CurrentContracts[1] and LatestExitName(0) == "Sx2" Then
Sxcond2 = true;
if CurrentContracts < CurrentContracts[1] and LatestExitName(0) == "Sx3" Then
Sxcond3 = true;
if Sxcond1 == false and LL <= EntryPrice*0.98 and LL < EntryPrice*0.97 Then
ExitShort("Sx1",AtStop,LL+(EntryPrice-LL)*0.3,"",Floor(MaxContracts*(1/3)),1);
if Sxcond2 == false and LL <= EntryPrice*0.97 and LL < EntryPrice*0.96 Then
ExitShort("Sx2",AtStop,LL+(EntryPrice-LL)*0.3,"",Floor(MaxContracts*(1/3)),1);
if Sxcond3 == false and LL <= EntryPrice*0.95 Then
ExitShort("Sx3",AtStop,LL+(EntryPrice-LL)*0.3);
}
Else{
Sxcond1 = false;
Sxcond2 = false;
Sxcond3 = false;
}
2017-03-14
128
글번호 107773
답변완료
저가갱신buy와 저가갱신sell
아래 건 문의드려요
* buy진입
-양봉만 카운트
-기준:첫번째 양봉 저가
-저가(up방향) 갱신이 3번째(4번째 양봉) 되면 다음 봉 시가에 buy
* sell진입
-음봉만 카운트
-기준:첫번째 음봉 저가
-저가(down방향) 갱신이 3번째(4번째 음봉) 되면 다음 봉 시가에 sell
항상 고맙습니다.
2024-09-01
132
글번호 107769