커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3732
글번호 230811
답변완료
지표문의
1.안녕하세요
아래는 rsi band 라는 지표 인데요
구현 해보구 싶은게요.
UpBand와DnBand 양봉이구 확장이고 하면 매수
UpBand와DnBand 음봉이구 확장이고 하면 매도
시스템하고 지표 좀 부탁할께요.
지표는 빨강,파랑선으로요.
2.Input:Length(14),UpLevel(70),DnLevel(30);
Var:Upband(0),DnBand(0),MidLine(0);
RSI_BAND(Length,UpLevel,DnLevel,0,UpBand,DnBand,MidLine); // 현재 봉에서의 밴드 값
Plot1(UpBand);
Plot2(MidLine);
Plot3(DnBand);
RSI_BAND.yfu
Inputs: Length(NumericSimple),TargetUpLevel(NumericSimple),TargetDnLevel(NumericSimple),
NxtYn(NumericSimple), // 다음 봉의 값을 구하려면 1을 아니면 0을 넣어준다.
oUpBand(NumericRef), // 주소전달방식임을 선언
oDnBand(NumericRef), // 값을 입력받는게 아니라 여기에 결과값을 채워서 반환한다.
oMidLine(NumericRef); // 변수명 앞에 소문자를 o를 붙인 것은 output 변수입을 나타냅니다.
Variables: 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 > TargetUpLevel Then // 상단밴드
oUpBand = (((TargetUpLevel - 100) / TargetUpLevel * UpAvg) + DownAvg) * (Length - 1) + C;
Else
oUpBand = ((TargetUpLevel / (100 - TargetUpLevel) * DownAvg) - UpAvg) * (Length - 1) + C;
If Value1 > TargetDnLevel Then // 하단밴드
oDnBand = (((TargetDnLevel - 100) / TargetDnLevel * UpAvg) + DownAvg) * (Length - 1) + C;
Else
oDnBand = ((TargetDnLevel / (100 - TargetDnLevel) * DownAvg) - UpAvg) * (Length - 1) + C;
MidLevel = (TargetUpLevel + TargetDnLevel) / 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 // 다음 봉 여부가 0인 경우
{
If Value1[1] > TargetUpLevel Then
oUpBand = (((TargetUpLevel - 100) / TargetUpLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + C[1];
Else
oUpBand = ((TargetUpLevel / (100 - TargetUpLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + C[1];
If Value1[1] > TargetDnLevel Then
oDnBand = (((TargetDnLevel - 100) / TargetDnLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + C[1];
Else
oDnBand = ((TargetDnLevel / (100 - TargetDnLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + C[1];
MidLevel = (TargetUpLevel + TargetDnLevel) / 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];
}
RSI_BAND = 1; //사용자함수는 반환값이 있어야 한다고 했습니다.
// oUpBand, oDnBand, oMidLine 는 메모리 주소이지 반환값이 아닙니다.
// 그래서 마지막에 아무 값이나 넘겨 줘야 하기 때문에 그냥 1을 넣어 줬습니다.
3.그럼 수고하세요
2020-05-08
1036
글번호 138676
답변완료
수평선 재질문
항상 감사합니다.
아래에서 오늘날짜는 수평선이 그어지지 않게 할수 있나요?
============
input : n(3);
var : cnt(0),hh(0),ll(0),mm(0),tl(0);
Array : dd[100](0),tt[100](0);
if bdate != bdate[1] Then
{
dd[0] = bdate[1];
tt[0] = stime[1];
for cnt = 1 to 99
{
dd[cnt] = dd[cnt-1][1];
tt[cnt] = tt[cnt-1][1];
}
if dd[n] > 0 then
{
hh = DayHigh(1);
ll = Daylow(1);
for cnt = 1 to n
{
if DayHigh(cnt) > hh Then
hh = DayHigh(cnt);
if DayLow(cnt) < ll Then
ll = Daylow(cnt);
}
mm = (hh+ll)/2;
TL_Delete(tl);
tl = TL_New(dd[n],tt[n],mm,sdate,stime,mm);
TL_SetExtRight(tl,true);
}
}
2020-05-08
875
글번호 138675
답변완료
지표수식전환 요청
다음 수식을 예스지표로 부탁드립니다
수식1
StochasticsSlow(sto1,sto2)
수식2
eavg(StochasticsSlow(sto1,sto2),sto3)
수식3
eavg(StochasticsSlow(sto4,sto5),sto6)
수식4
eavg(StochasticsSlow(sto7,sto8),sto9)
조건추가설정
sto1 5
sto2 3
sto3 3
sto4 10
sto5 3
sto6 3
sto7 20
sto8 3
sto9 3
기준선 추가 50 과열70 침체30
2020-05-08
992
글번호 138674
답변완료
수식도움 부탁드립니다.
종목 : KODEX코스닥150레버리지
로직 : 12시 가격이 당일 시가보다 높을 경우 종가에 매수->익일 시가 청산
<추가적으로>
위 로직에는 12시시가를 기준으로 했는데 <Input>값을 활용하여 9시 30분, 10시, 10시 30분...등등 30분 단위 기준으로 최적화를 시켜보고 싶습니다. 이 부분도 도와주시면 감사하겠습니다.
감사합니다.
2020-05-07
947
글번호 138673
답변완료
문의드립니다.
아래식의 지표및 시스템식을 예스로 부탁합니다.
sl_type = input("%", options = ["%", "ATR", "Absolute"])
sl_perc = input(4, title = "% SL", type = input.float)
atr_length = input(10, title = "ATR Length")
atr_mult = input(4, title = "ATR Mult", type = input.float)
sl_absol = input(10, title = "Absolute SL", type = input.float)
// BACKTESTING RANGE
// From Date Inputs
fromDay = input(defval = 1, title = "From Day", minval = 1, maxval = 31)
fromMonth = input(defval = 1, title = "From Month", minval = 1, maxval = 12)
fromYear = input(defval = 2016, title = "From Year", minval = 1970)
// To Date Inputs
toDay = input(defval = 1, title = "To Day", minval = 1, maxval = 31)
toMonth = input(defval = 1, title = "To Month", minval = 1, maxval = 12)
toYear = input(defval = 2100, title = "To Year", minval = 1970)
// Calculate start/end date and time condition
startDate = timestamp(fromYear, fromMonth, fromDay, 00, 00)
finishDate = timestamp(toYear, toMonth, toDay, 00, 00)
time_cond = time >= startDate and time <= finishDate
//////////////////
// CALCULATIONS //
// SL values
sl_val = sl_type == "ATR" ? atr_mult * atr(atr_length) :
sl_type == "Absolute" ? sl_absol :
close * sl_perc / 100
// Init Variables
pos = 0
trailing_sl = 0.0
// Signals
long_signal = nz(pos[1]) != 1 and high > nz(trailing_sl[1])
short_signal = nz(pos[1]) != -1 and low < nz(trailing_sl[1])
// Calculate SL
trailing_sl := short_signal ? high + sl_val :
long_signal ? low - sl_val :
nz(pos[1]) == 1 ? max(low - sl_val, nz(trailing_sl[1])) :
nz(pos[1]) == -1 ? min(high + sl_val, nz(trailing_sl[1])) :
nz(trailing_sl[1])
// Position var
pos := long_signal ? 1 : short_signal ? -1 : nz(pos[1])
//////////////
// PLOTINGS //
plot(trailing_sl, linewidth = 2, color = pos == 1 ? color.green : color.red)
//////////////
// STRATEGY //
if (time_cond and pos != 1)
strategy.entry("long", true, stop = trailing_sl)
if (time_cond and pos != -1)
strategy.entry("short", false, stop = trailing_sl)
2020-05-07
988
글번호 138672
답변완료
YesGlobalPro 해외선물차트에서
아래 자표식이 YesGlobalPro 해외선물차트에서는 작동이 안되는데
문제점이 무엇인지 해결해 주시면 감사 하겠습니다.
var : BA(0);
BA = bids - asks;
If BA > 0 Then
plot1(BA,"매수총잔량우위");
Else
plot2(BA,"매도총잔량우위");
2020-05-07
879
글번호 138671
답변완료
문의드립니다.
안녕하세요.
아래와 같은 내용에 대한 수식작성에 어려움있어 문의드립니다.
[요청내용]
코스피200선물
Only 당일진입, 당일청산
계약수 = 1계약
30분봉 기준
매수포지션만 취할 계획.
[규칙]
1. 첫번째봉은 지켜본다.
2-1. If 현재가가 직전봉의 종가+3틱을 터치하면 매수 1계약 진입.
(종가+3틱을 지속적으로 터치하더라도 최초1회만 진입한 후,거래 안함)
2-2. If 다른 모든케이스에선 홀딩
(기존포지션이 없다면 계속 포지션 없고, 매수 진입이 돼있다면 홀딩)
2-1,2-2를 통해 어쨌든 매수 1계약 진입에 성공 했다면, 그 이후론 마지막 봉까지 거래
안함.
*현재가 : 현재 실시간으로 움직이는 가격
3. 마지막봉 종가에 Exit
(궁금증 : 종가는 동시호가이후 최종 장마감 가격인데, 이게 프로그램으로 진입이 가능
한지? 불가 하면 동시호가 직전의 가격으로 포지션 청산 후 exit필요)
감사합니다.
2020-05-07
824
글번호 138669
답변완료
문의드립니다.
maLength = input(title="MovingAvgLength", type=input.integer, defval=21, minval=1)
lbLength = input(title="LookbackLength", type=input.integer, defval=4, minval=1)
src = input(title="Source", type=input.source, defval=close)
ma = sma(src, maLength)
tai = stdev(ma, lbLength)
fastMa = ema(src, lbLength)
slowMa = ema(src, maLength)
sig = sma(tai, maLength * 2)
bsc = 0
bsc := (tai > tai[1] and fastMa > slowMa) or fastMa > slowMa ? 1 : (tai > tai[1] and fastMa < slowMa) or fastMa < slowMa ? -1 : nz(bsc[1], 0)
taiColor = bsc > 0 ? color.green : bsc < 0 ? color.red : color.black
plot(tai, color=taiColor, linewidth=2)
plot(sig, color=color.black, linewidth=1)
변환 문의드립니다.
감사합니다.
2020-05-07
829
글번호 138666
답변완료
문의드립니다!!!
아래의 조건을 수식으로 만들고 싶은데 많이 어렵네요!!
도움 요청 드립니다
★ 매수조건
-조건1. 20이동평균선(종가,단순)이 우상향하고
-조건2. 1봉전 종가가 5이동평균선(종가,단순)보다 낮고
-조건3. 1봉전 종가가 시가보다 낮거나 1봉전 종가가 7이동평균선 보다 낮고
-조건4. 0봉전 18봉 중 최저가가 1봉전 18봉 중 최저가보다 높거나 같은 경우
-매수진입. 0봉전 시가 +1틱에서 매수진입
★ 매수 청산조건
- 청산조건 : +30틱 청산
- 손절조건 : -15틱 청산
★ 매도조건
-조건1. 20이동평균선(종가,단순)이 우하향하고
-조건2. 1봉전 종가가 5이동평균선(종가,단순)보다 높고
-조건3. 1봉전 종가가 시가보다 높거나 1봉전 종가가 7이동평균선 보다 높고
-조건4. 0봉전 18봉 중 최고가가 1봉전 18봉 중 최고가보다 낮거나 같은 경우
-매수진입. 0봉전 시가 -1틱에서 매수진입
★ 매도 청산조건
- 청산조건 : +30틱 청산
- 손절조건 : -15틱 청산
넘 많은거 같습니다만 부탁드립니다!!!!
수고하세요!!!
2020-05-07
826
글번호 138665