커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4437
글번호 230811
답변완료
수식부탁드립니다========================
(지표1) 을 (지표2)의 tema1에 적용할수 있나요 ? 있으면 부탁드립니다
(지표1)
Input:length(12),X(2);
Var:j(0),lastHiVal(0),lastLoVal(0),turnPntBit(""),TL1(0),tx(0);
Array:valArr[10](0),barArr[10](0),turnPntArr[10]("");
// 봉이 새로 생겼으므로 봉개수 관리하는 변수들의 봉개수 값 1씩 증가
For j = 0 To 9
{
barArr[j] = barArr[j] + 1;
}
// 고점조건 = 현재 봉의 고가가 기간최고가이면서 최고가 갱신되었을 때;
// 저점조건 = 현재 봉의 저가가 기간최저가이면서 최저가 갱신되었을 때;
// 고점,저점조건 만족시 현재 봉의 고[저]가를 변수에 저장
Condition1 = Highest(H,length) == H and lastHiVal <> H;
Condition2 = Lowest(L,length) == L and lastLoVal <> L;
If Condition1 Then lastHiVal = H;
If Condition2 Then lastLoVal = L;
// 전환점구분 null값으로 초기화;
turnPntBit = "";
// if 고점조건, 저점조건 동시 만족시 then
// if 이전 고점,저점 범위를 모두 벗어났을 때
// 전환점구분 = 고저점;
// else if 이전 고점을 갱신했다면 전환점구분 = 고점;
// else if 이전 저점을 갱신했다면 전환점구분 = 저점;
// else if 고점조건 만족하면 전환점구분 = 고점;
// else if 저점조건 만족하면 전환점구분 = 저점;
If Condition1 and Condition2 Then
{
If Max(valArr[1],valArr[2]) < H and Min(valArr[1],valArr[2]) > L Then
turnPntBit = "HiLo";
Else If Max(valArr[1],valArr[2]) < H Then turnPntBit = "Hi";
Else If Min(valArr[1],valArr[2]) > L Then turnPntBit = "Lo";
}
Else If Condition1 Then turnPntBit = "Hi";
Else If Condition2 Then turnPntBit = "Lo";
// if 전환점구분에 값이 있을 때만 then 아래 실행, 없으면 통과
If turnPntBit <> "" Then
{
// if 전환점구분이 고저점이면 then
// 이전 파동은 연장시키고 아래에서 새로이 파동선을 추가토록 한다.
If turnPntBit == "HiLo" Then
{
valArr[1] = IFF(turnPntArr[1] == "Hi",H,L);
barArr[1] = 0;
TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
If turnPntArr[1] == "Hi" Then
turnPntBit = "Lo";
Else
turnPntBit = "Hi";
}
// if 신규 전환점구분이 현재(전환점배열 1번째)와 다르면 then
// 배열값들을 이전값으로 Move;
If turnPntBit <> turnPntArr[1] Then
{
for j = 8 downto 1
{
valArr[j+1] = valArr[j];
barArr[j+1] = barArr[j];
turnPntArr[j+1] = turnPntArr[j];
}
}
// if 전환점구분이 바뀌었거나 또는
// (전환점구분은 안바뀌었는데
// (이전 고점보다 높은 고점이 발생했거나 또는
// 이전 저점보다 낮은 저점이 발생했으면)) then
If turnPntBit <> turnPntArr[1] or
(turnPntBit == turnPntArr[1] and
((turnPntBit == "Hi" and valArr[1] < H) or
(turnPntBit == "Lo" and valArr[1] > L))) Then
{
// 값 배열에는 고점 또는 저점을 대입;
// 봉개수 배열에는 0값 대입;
// 전환점 배열에 전환점구분값을 대입;
valArr[1] = IFF(turnPntBit == "Hi",H,L);
barArr[1] = 0;
turnPntArr[1] = turnPntBit;
// if 이전봉대비 전환점구분이 바뀌었다면 추세선 새로 그리고;
// else 전환점구분이 안바뀌었으면 값만 바뀐거므로 추세선 연장;
If turnPntArr[1][1] <> turnPntArr[1][0] Then{
TL1 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2],
sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
#텍스트 출력
if turnPntArr[1][0] == "Hi" then#저점
tx = Text_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2]-PriceScale*X,NumToStr(valArr[2],2));
if turnPntArr[1][0] == "Lo" then #고점
tx = Text_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2]+PriceScale*X,NumToStr(valArr[2],2));
Text_SetStyle(tx,2,2);
}
Else
TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
}
}
TL_SetSize(TL1,0.5);
TL_SetColor(TL1,BLUE);
(지표2)
Input: 폭보정(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),지수더하기(0),idx(0),EP(0),E11(0),E12(0),E13(0),E21(0),E22(0),E23(0);
Var : value(0);
Var : valuec(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 : 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]*90)*125/2500;
if Bdate != Bdate[1] Then{
idx = 0;
var1 = 100;
var2 = 100;
plot10(var1);
plot11(var2);
plot51(var2 );
}
Else{
idx = idx+1;
var1 = var1+(var1*(va91/100));
var2 = var2+(var2*(va93/100));
plot10(var1 );
plot11(var2 );
plot51(var2 );
TEMA3 = (3 * Ema(var2 ,순매수LENGTH2)) - (3 * Ema(Ema(var2 ,순매수LENGTH2),순매수LENGTH2)) +
(Ema(Ema(Ema(var2 ,순매수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;
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 ,"지수테마",iff((TEMA1 )>(TEMA1 )[1]+00,BLACK,iff((TEMA1 )<(TEMA1 )[1]-00,BLACK,BLACK)));
PLOT31(TEMA2 ,"호가테마");
vmin = min(TEMA1 ,TEMA1 ,va71);
vmax = max(TEMA1 ,TEMA1 ,va71);
if TEMA1 > TEMA2 Then{
var80 = (TEMA1 - TEMA2 )*0.5+TEMA2 ;
}
if TEMA1 < TEMA2 Then{
var80 = (TEMA2 -TEMA1 )*0.5+TEMA1 ;
}
PLOT17(var80,"지호평균");
//테마합 일정 수량차이상의 급등락 표시
if TEMA3 > TEMA3[1]+ 급변 Then{plot21(vmin-0.05,"급등");}
if TEMA3 < TEMA3[1]- 급변 Then{plot22(vmin-0.05,"급락");}
va71 =( TEMA2 - TEMA1)+100;
if (va71[1] )< (va71)then {
PLOT25((va71 )-0.02,"매수예비");
//PlaySound("C:₩예스트레이더₩data₩Sound₩pp.wav");
}
if (va71[1] )> (va71) Then{
PLOT26((va71 )-0.02,"매도예비");
// PlaySound("C:₩예스트레이더₩data₩Sound₩dingdong.wav");
}
PLOT60(va71,"55");
if (TEMA1[1] )< (TEMA1) and (va71[1] )< (va71)then {
PLOT45((va71 )-0.02,"매수막대");
PlaySound("C:₩예스트레이더₩data₩Sound₩up.wav");
}
if (TEMA1[1] )> (TEMA1) and (va71[1] )> (va71) Then{
PLOT46((va71 )-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,"매수");
}
2017-02-22
131
글번호 107111
답변완료
함수 질문드립니다
지금 수식문의 해주시는분들 수식들 적어보면서 독해를 해보고 있는데요
계속 써보고 독해해보는것이 도움 된다고 해서 그렇게 하고 있습니다.
근데 상당히 비슷한 함수들이 많이 나오는데
도데체 그 함수가 뭘 뜻하는지를 모르겠어서요 ㅎㅎ
condition~ marketposition 등등
이런 함수들 뜻이 무엇인지 어떤 경우에 사용되고 어떤 형태를 갖는지
등등 공부하고 싶은데 어디서 공부할수 있을까요??
2017-02-22
94
글번호 107110
답변완료
부탁합니다
input : Period11(20),Period12(40),Period13(80),Period14(120),Period15(160),Period16(300),Period17(600),Period18(1200),익절틱수(8),손절틱수(8);
input : ntime2(200),sig2(100);
var : mav11(0),mav12(0),mav13(0),mav14(0),mav15(0),mav16(0),mav17(0),mav18(0);
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 MarketPosition <= 0 and
mav12 < mav13 and mav13 < mav15 and mav15 < mav16 and mav16 < mav17 and crossup(mav11,mav13) Then
buy("b",OnClose,def,1);
if MarketPosition == 1 Then{
if mav11 < mav11[1] and CurrentContracts < 2 Then
buy("bb",OnClose,def,1);
if mav12 > mav13 and mav13 > mav15 and mav15 > mav16 and mav16 > mav17 and CrossDown(mav11,mav13) Then{
ExitLong("bx");
}
ExitLong("bp",atlimit,AvgEntryPrice+PriceScale*익절틱수);
ExitLong("bl",AtStop,AvgEntryPrice-PriceScale*손절틱수);
}
if MarketPosition >= 0 and
mav12 > mav13 and mav13 > mav15 and mav15 > mav16 and mav16 > mav17 and CrossDown(mav11,mav13) Then
sell("s",OnClose,def,1);
if MarketPosition == -1 then{
if mav11 > mav11[1] and CurrentContracts < 2 Then
sell("ss",OnClose,def,1);
if mav12 < mav13 and mav13 < mav15 and mav15 < mav16 and mav16 < mav17 and crossup(mav11,mav13) Then
ExitShort("sx");
ExitShort("sp",atlimit,AvgEntryPrice-PriceScale*익절틱수);
ExitShort("sl",AtStop,AvgEntryPrice+PriceScale*손절틱수);
}
위 수식에서 한가지 추가하고자 합니다
매수진입 후 익절틱수가 되면 강제청산 되지만 아래 조건이 만족하면 강제청산이 아닌
아래 시스템 식으로 매수청산이 적용되도록 하고자 합니다
---아래 조건---
만약에 매수진입 후 현재가가 매수진입평균단가보다 크고 and mav12 > mav13 and mav13 > mav15 and mav15 > mav16 and mav16 > mav17 만족하면 CrossDown(mav11,mav12)으로 매수청산
매도진입 후 익절틱수가 되면 강제청산 되지만 아래 조건이 만족하면 강제청산이 아닌
아래 시스템 식으로 매도청산이 적용되도록 하고자 합니다
---아래 조건---
만약에 매도진입 후 현재가가 매도진입평균단가보다 작고 and mav12 < mav13 and mav13 < mav15 and mav15 < mav16 and mav16 < mav17 만족하면 crossup(mav11,mav12)으로 매도청산
감사합니다
2017-02-22
107
글번호 107107
답변완료
문의드립니다
안녕하세요
주문함수 SetStopProfittarget 과 SetStopLoss 의 기준가격은 신호가 발생한 종가인가요? 아님 진입가격인가요?
예를들어, 슬리피지로 인하여 실제 진입가격이 신호발생 종가 보다 2틱 비싸게 매수가 되었다면 'SetStopProfittarget(PriceScale*10,PointStop)'의 청산은 어느것의 10틱 위가 되는지 정확히 알고싶습니다.
감사합니다
2017-02-21
123
글번호 107106
답변완료
수식문의드립니다...
120선이 상승중일 때
5선이 상승전환하면 1차 매수 익절 20틱 설정
1차매수 후 30틱밀리면 2차매수 익절 30틱 설정
2차매수 후 30틱밀리면 3차매수 익절 30틱 설정
분할 매수 중 120선이 하락전환하면
하락전환한 시점부터 50틱 밀리면 4차매수 익절 30틱설정
4차 매수후 50틱 밀리면 5차매수 익절 30틱설정
즉, 120선이 상승중일땐 30틱마다 분할매수하고 이후 120선이 하락전환하면 50틱마다 분할매수하는 수식을 만들고 싶습니다.
각 매수계약마다 위의 설명처럼 익절을 설정하고 싶습니다.
감사합니다.
2017-02-21
126
글번호 107105
답변완료
수식문의드립니다.
매수가격을 직접 입력하고 익절과 손절도 직접입력하는 수식
예) 255에 매수하고 익절 10틱 손절 5틱
255를 입력가능하게 10틱도 입력가능하게 5틱도 임의의 수로 입력가능하게 하고싶습니다.
감사합니다.
2017-02-21
106
글번호 107104
답변완료
지표를 활용해서 검색식을 만들고있는데요
if Bdate != Bdate[1] Then
var1 = 0;
if Bdate == Bdate[1] then{
if C > C[1] Then
var1 = var1+v;
if C < C[1] Then
var1 = Var1-V;
}
plot1(var1);
plot2(0);
이식으로 만들 지표값이 횡보 중인것을 캐치해보려구 검색식중에 가격횡보 검색 식에 넣서 만들어보려했는데 제대로 작동않하는거같아서요
아래식이 만들어본것구요
Input : Period(5), Percent(10);
if Bdate != Bdate[1] Then
var1 = 0;
if Bdate == Bdate[1] then{
if C > C[1] Then
var1 = var1+v;
if C < C[1] Then
var1 = Var1-V;
}
value1 = highest(var1, Period);
value2 = lowest(var1,Period);
If value1 < value2 *(1+Percent/100) && V>0 Then
{
If var1 == var1[1] Then
value3 = 0.001;
Else
value3 = (var1-var1[1])/var1[1]*100;
}
Else
value3 = 0;
Find(value3);
가격요소에 지표를 넣어봤는데 검색식엔 아무것도 않잡히네요
수정할부분을좀 잡아주시면 감사하겟습니다
2017-02-21
126
글번호 107102
답변완료
거래량 수식 부탁드립니다.
안녕하세요 수고하십니다.
15분봉에서, 예를들어 1일안에서 양봉거래량과 음봉거래량 합계를 따로 확인할수 있는
방법이 있나요?
선택범위(1일, 2일 등등)안에 양봉, 음봉 거래량을 따로 알고 싶은게 목적입니다.
문의드립니다.
2017-02-21
141
글번호 107101
답변완료
수식부탁드립니다
1.안녕하세요
30분 분봉을 보는데 upvol,downvol 를 일봉으로 표현되게 좀 작성 해주세요.
2.그럼 수고하세요
2017-02-21
113
글번호 107099