커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
2553
글번호 230811
답변완료
Y축 분리문의 연장 질문
안녕하세요 관리자님
우선 감사 드립니다.
일전에 Y축 분리 문의를 드렸는데
Y축은 분리 하였으나 분리된 지표를 가지고 시스템을 만들려고 하는데 신호가 표시가 안되서요
Input : Period1(20), Percent1(6), Period2(30), Percent2(6);
var : DNline1(0),DNline2(0),HRwave1(0);
Dnline1 = EnvelopeDown(Period1, Percent1);
Dnline2 = EnvelopeDown(Period2, Percent2);
HRwave1 = ((Dnline2-Dnline1)/(Dnline2+Dnline1))*100000;
If crossup(0,HRwave1) Then
{
Buy();
}
예전 답변은 아래와 같습니다.
안녕하세요
예스스탁입니다.
하나의 지표식에 가격대가 너무 차이가 나는 지표가 혼합되어 있습니다.
문의하신 내용은 수식을 분리하셔야 합니다.
하나의 식으로 분리해서 표시할 방법은 없습니다.
plot1~plot6은 봉위에 적용되어 봉과 축을 같이 사용할수 있지만
plot7과 PlotBaseLine1은 봉과 값차이가 많이나는 지표입니다.
1
수식작성후에 문범검증(f4)을 하시고 f5키를 누르시면 지표속성이 나타납니다.
Y축표시를 가격으로 하시면 적용시 바로 봉위에 적용됩니다.
지표는 기본설정이 화면으로 봉차트 아래에 적용됩니다.
Input : Period1(20), Percent1(6), Period2(30), Percent2(6);
var : center1(0),UPline1(0),DNline1(0),center2(0),UPline2(0),DNline2(0);
center1 = ma(C, Period1);
UPline1 = EnvelopeUp(Period1, Percent1);
Dnline1 = EnvelopeDown(Period1, Percent1);
center2 = ma(C, Period2);
UPline2 = EnvelopeUp(Period2, Percent2);
Dnline2 = EnvelopeDown(Period2, Percent2);
Plot1(center1, "중앙선");
Plot2(UPline1, "EnvelopeUp");
Plot3(Dnline1, "EnvelopeDown");
Plot4(center2, "중앙선");
Plot5(UPline2, "EnvelopeUp");
Plot6(Dnline2, "EnvelopeDown");
2
아래식은 Y축표시를 화면으로 하시고 적용하셔야 합니다.
Input : Period1(20), Percent1(6), Period2(30), Percent2(6);
var : DNline1(0),DNline2(0),HRwave1(0);
Dnline1 = EnvelopeDown(Period1, Percent1);
Dnline2 = EnvelopeDown(Period2, Percent2);
HRwave1 = ((Dnline2-Dnline1)/(Dnline2+Dnline1))*100000;
Plot7(HRwave1, "신호");
PlotBaseLine1(0, "기준선1");
즐거운 하루되세요
2020-10-05
764
글번호 142865
답변완료
69397 재 질문 올림니다.
* 바쁘신데 확인 좀 부탁 드립니다.
* 아래 와 같이 했는데...스위칭 주문이 안됨니다.
if MarketPosition == 1 and (IsExitName("StopLoss",1) or IsExitName("StopProfittarget",1)) == true Then
SELL("STOPSWSS1") ;
if MarketPosition == -1 and (IsExitName("StopLoss,1") or IsExitName("StopProfittarget",1)) == true Then
Buy("STOPSWDD1") ;
* 다른 변수를 써야 하나요?
* 바쁜신데 죄송합니다.
2020-10-05
935
글번호 142864
답변완료
부탁드립니다
$ 69406 보내주신수식 적용하니 음봉캔들 강조는 되는데 양봉캔들 강조는 아무리해도
나타나지 않습니다,확인부탁합니다.
2020-10-05
813
글번호 142863
답변완료
수식 문의드립니다
전일 누적거래량을 분봉에서 구현하려고 하는데요
물론 Dayvolume(1)을 사용하면 간단하게 된다는 걸 알고 있습니다
다만 응용해 보고 싶은 것들이 있어서 물어봅니다
-------------------------
var1 = Accum(V);
If bDate!=bDate[1] Then
var2 = var1[1];
var3 = var1-var2;
Plot1(var3, "test");
이렇게 하면 당일 누적거래량을 구하는 건데요
이 수식을 응용해서 이것저것 해보았는데 원하는 결과가 나오지 않네요
Dayvolume(1)을 1분봉에서 보려면 수식을 어떻게 짜야 할지 가르쳐주시면 감사하겠습니다
2020-10-05
829
글번호 142862
답변완료
작성해준 수식 구현이 안되요..오류가 뭐가 있을까요?
나스닥(e-mini 나스닥-100) 10분봉과/일봉을 설정한후 아래 수식을 넣어서 구현하면
거래가 안되네요..
뭐가 잘못되었는지 알려주시면 감사하겠습니다.
===========================================================
안녕하세요
예스스탁입니다.
input : left(5),right(5);
var : i1(0,Data1),l1(0,Data1),h1(0,Data1);
var : SLv(0,data1),SLi(0,Data1),SLh(0,data1),dd(0,Data1);
var : mav(0,Data2);
i1 = Data1(Index);
l1 = Data1(l);
h1 = Data1(h);
mav = Data2(ma(C,5));
if data1(SwingLowBar(1,l1,left,right,left+right)) != -1 Then
{
SLv = l1[right];
SLi = i1[right];
SLh = h1;
}
if SLh > 0 and h1 > slh Then
slh = h1;
if MarketPosition == 0 and
sli > 0 and Index > sli+300 and Index <= sli+1000 and
mav > mav[1] and
L > SLv*1.001 Then
Buy("b",AtLimit,Slv*1.001);
if MarketPosition == 1 Then
{
dd = sLh[BarsSinceEntry]-slv[BarsSinceEntry];
if MaxEntries == 1 Then
{
Buy("bb",AtLimit,LatestEntryPrice-dd);
ExitLong("bp1",AtLimit,LatestEntryPrice+(dd*0.5));
}
if MaxEntries == 2 Then
{
ExitLong("bp2",AtLimit,LatestEntryPrice+(dd*0.75));
ExitLong("bx",AtStop,LatestEntryPrice-(dd*1));
}
}
즐거운 하루되세요
> 이형지 님이 쓴 글입니다.
> 제목 : 해외선물 수식 부탁드림니다. ( 역추세 매매)
>
해외선물(나스닥)
data1 분봉 10분봉
data2 일봉
[1] 1차 매수 진입 조건(1계약)
data1의 1000봉에서 전저점이 1000봉 에서 300봉사이에서 전저점의 0.1%근접시 매수진입
(data1의 1000봉에서 전저점이 300봉 에서 1봉 사이에서는 전저점의 0.1%근접시에도 매수진입 X)
data2 5일봉 이동평균선 우상향시 매수 활성화
[2] 2차 매수 진입 조건(1계약)
1차 매수후 D의 틱수(전저점과 전저점이후에 최고점의 차이틱수) 만큼 하락시 추가 매수
[3] 청산 조건
(1) 1차 진입후 청산시 :
1차 매수후 D의 틱수(전저점과 전저점이후에 최고점의 차이틱수)의 50% 도달시 청산
(2) 1차,2차 진입후 청산시 :
2차 매수후 2차 매수한 시점에서 D의 틱수(전저점과 전저점이후에 최고점의 차이틱수)의 75% 도달시 전량청산(2계약) --약 수익
(3) 1차 2차 진입후 손절시:
2차 매수한 시점에서 D의 틱수만큼 더 떨어졌을때 전량(2계약) 손절
번거롭더라도 그림을 참조해서 수식 좀 부탁드리겠습니다. / 감사드림니다.
2020-10-05
945
글번호 142861
답변완료
문의드립니다.
안녕하세요 연휴는 잘 보내셨나요?
제가 어떻게 한번 해보려고 했는데 랭귀지 해석이 안 되어서
이렇게 지표 변환을 부탁드립니다.
아래 게시물을 보니 RSI 밴드 지표가 있어서 제가 사용하는 보조지표를
캔들과 같이 볼 수 있도록 RSI 밴드처럼 바꾸고 싶습니다.
제가 사용하는 지표와 참고용으로 RSI밴드 수식도 같이 올립니다.
참고로 제가 원하는건 중심선, 상단선, 하단선입니다.
변환 부탁드리며 미리 감사합니다.
===============================
제가 사용하는 지표
===============================
input : st_mult(2),st_period(14),len(20);
var : price(0),up_lev(0),dn_lev(0),upz(0),downv(0);
var : trur(0),plus(0),minus(0),sum(0),adxv(0);
var : di(0),x(0),zz(0);
price = (H+L)/2;
up_lev = price - (st_mult * atr(st_period));
dn_lev = price + (st_mult * atr(st_period));
if CurrentBar >= 1 then
{
upz = up_lev-up_lev[1];
downv = -(dn_lev-dn_lev[1]);
trur = (TrueRange + (len - 1) * trur) / len;
var1 = iff(upz > downv and upz > 0 , upz , 0);
var11 = (var1 + (len - 1) * var11) / len;
plus = var11/trur;
var2 = iff(downv > upz and downv > 0 , downv , 0);
var22 = (var2 + (len - 1) * var22) / len;
minus = var22/trur;
sum = plus + minus;
var3 = abs(plus - minus) / iff(sum == 0 , 1 , sum);
adxv = (var3 + (len - 1) * adxv) / len;
di = plus - minus;
x=adxv-di*100;
zz=x/-1;
plot1(zz,"시그널");
plot2(20,"상단");
plot3(-20,"하단");
plot4(0,"중심");
===============================
RSI밴드지표
===============================
Input : Length(14),UpLevel(70),DnLevel(30), NxtYn(0);
var : oUpBand(0),oDnBand(0),oMidLine(0);
Var : Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0),MidLevel(0);
If CurrentBar == 1 AND Length > 0 Then
Begin
UpSum = 0;
DownSum = 0;
For Counter = 0 To Length - 1
Begin
UpAmt = C[Counter] - C[Counter+1];
If UpAmt >= 0 Then
DownAmt = 0;
Else
Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpSum = UpSum + UpAmt;
DownSum = DownSum + DownAmt;
End;
UpAvg = UpSum / Length;
DownAvg = DownSum / Length;
End
Else If CurrentBar > 1 AND Length > 0 Then
Begin
UpAmt = C[0] - C[1];
If UpAmt >= 0 Then
DownAmt = 0;
Else
Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpAvg = (UpAvg[1] * (Length - 1) + UpAmt) / Length;
DownAvg = (DownAvg[1] * (Length - 1) + DownAmt) / Length;
End;
If UpAvg + DownAvg <> 0 Then
Value1 = 100 * UpAvg / (UpAvg + DownAvg);
Else
Value1 = 0;
If nxtYn == 1 Then // 다음 봉 여부가 1일 경우
{
If Value1 > UpLevel Then // 상단밴드
oUpBand = (((UpLevel - 100) / UpLevel * UpAvg) + DownAvg) * (Length - 1) + C;
Else
oUpBand = ((UpLevel / (100 - UpLevel) * DownAvg) - UpAvg) * (Length - 1) + C;
If Value1 > DnLevel Then // 하단밴드
oDnBand = (((DnLevel - 100) / DnLevel * UpAvg) + DownAvg) * (Length - 1) + C;
Else
oDnBand = ((DnLevel / (100 - DnLevel) * DownAvg) - UpAvg) * (Length - 1) + C;
MidLevel = (UpLevel + DnLevel) / 2; // 중간라인
If Value1 > MidLevel Then
oMidLine = (((MidLevel - 100) / MidLevel * UpAvg) + DownAvg) * (Length - 1) + C;
Else
oMidline = ((MidLevel / (100 - MidLevel) * DownAvg) - UpAvg) * (Length - 1) + C;
}
Else
{
If Value1[1] > UpLevel Then
oUpBand = (((UpLevel - 100) / UpLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + C[1];
Else
oUpBand = ((UpLevel / (100 - UpLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + C[1];
If Value1[1] > DnLevel Then
oDnBand = (((DnLevel - 100) / DnLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + C[1];
Else
oDnBand = ((DnLevel / (100 - DnLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + C[1];
MidLevel = (UpLevel + DnLevel) / 2;
If Value1[1] > MidLevel Then
oMidLine = (((MidLevel - 100) / MidLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + C[1];
Else
oMidline = ((MidLevel / (100 - MidLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + C[1];
}
Plot1(oUpBand);
Plot2(oMidLine);
Plot3(oDnBand);
2020-10-05
857
글번호 142860
답변완료
69400수식 제수정 부탁드립니다
다시 수정 부탁드립니다..
현제 텍스트 부분이 수직선으로 일부만 표기 되고 있습니다..
텍스트는 필요 없구요 텍스트자리에 수직선이 전부 표기가 될수 있도록 수정 부탁드려 봅니다
늘 감사드립니다..
2020-10-05
971
글번호 142858
답변완료
문의드립니다.
아래수식을 예스로 부탁합니다.
rsiSource = input(title="RSI Source", type=input.source, defval=close)
rsiLength = input(title="RSI Length", type=input.integer, defval=7)
rsiOverbought = input(title="RSI Overbought", type=input.integer, defval=70, minval=51, maxval=100)
rsiOvesold = input(title="RSI Oversold", type=input.integer, defval=30, minval=1, maxval=49)
// RSI value based on inbuilt RSI
rsiValue = rsi(rsiSource, rsiLength)
// Get the current state
isOverbought = rsiValue >= rsiOverbought
isOversold = rsiValue <= rsiOvesold
// State of the last extreme 0 for initialization, 1 = overbought, 2 = oversold
var laststate = 0
// Highest and Lowest prices since the last state change
var hh = low
var ll = high
// Labels
var label labelll = na
var label labelhh = na
// Swing lines
var line line_up = na
var line line_down = na
var last_actual_label_hh_price = 0.0
var last_actual_label_ll_price = 0.0
// FUNCTIONS
obLabelText() =>
if(last_actual_label_hh_price < high)
"HH"
else
"LH"
//plot(last_actual_label_hh_price)
osLabelText() =>
if(last_actual_label_ll_price < low)
"HL"
else
"LL"
// Create oversold or overbought label
createOverBoughtLabel(isIt) =>
if(isIt)
label.new(x=bar_index, y=na ,yloc=yloc.abovebar, style=label.style_label_down, color=color.red, size=size.tiny, text=obLabelText())
else
label.new(x=bar_index, y=na ,yloc=yloc.belowbar, style=label.style_label_up, color=color.green, size=size.tiny, text=osLabelText())
// Move the oversold swing and label
moveOversoldLabel() =>
label.set_x(labelll, bar_index)
label.set_y(labelll, low)
label.set_text(labelll, osLabelText())
line.set_x1(line_down, bar_index)
line.set_y1(line_down, low)
moveOverBoughtLabel() =>
label.set_x(labelhh, bar_index)
label.set_y(labelhh, high)
label.set_text(labelhh, obLabelText())
line.set_x1(line_up, bar_index)
line.set_y1(line_up, high)
// We go from oversold straight to overbought NEW DRAWINGS CREATED HERE
if(laststate == 2 and isOverbought)
hh := high
labelhh := createOverBoughtLabel(true)
last_actual_label_ll_price := label.get_y(labelll)
labelll_ts = label.get_x(labelll)
labelll_price = label.get_y(labelll)
line_up := line.new(x1=bar_index, y1=high, x2=labelll_ts, y2=labelll_price, width=1)
// We go from overbought straight to oversold NEW DRAWINGS CREATED HERE
if(laststate == 1 and isOversold)
ll := low
labelll := createOverBoughtLabel(false)
last_actual_label_hh_price := label.get_y(labelhh)
labelhh_ts = label.get_x(labelhh)
labelhh_price = label.get_y(labelhh)
line_down := line.new(x1=bar_index, y1=high, x2=labelhh_ts, y2=labelhh_price, width=1)
// If we are overbought
if(isOverbought)
if(high >= hh)
hh := high
moveOverBoughtLabel()
laststate := 1
// If we are oversold
if(isOversold)
if(low <= ll)
ll := low
moveOversoldLabel()
laststate := 2
// If last state was overbought and we are overbought
if(laststate == 1 and isOverbought)
if(hh <= high)
hh := high
moveOverBoughtLabel()
//If we are oversold and the last state was oversold, move the drawings to the lowest price
if(laststate == 2 and isOversold)
if(low <= ll)
ll := low
moveOversoldLabel()
// If last state was overbought
if(laststate == 1)
if(hh <= high)
hh := high
moveOverBoughtLabel()
// If last stare was oversold
if(laststate == 2)
if(ll >= low)
ll := low
moveOversoldLabel()
2020-10-05
884
글번호 142857
답변완료
청산로직 관련
주식 현물 시장에서
어떤 종목을 매수 했을경우
청산을 하기 위해서
수익률이 2~5% 일 경우 수익금이 절반이 되면 청산.
수익률이 6~10%일 경우 수익금이 2/3이 되면 청산..
이런 청산로직도 예스트레이더에서 가능 한지 궁금합니다.
2020-10-05
783
글번호 142850