커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1541
글번호 230811
답변완료
부탁드립니다.
아래 기본제공하는 함수가 있습니다.
이함수를
일봉기준수치를 분차트에서 구현되도록
일봉기준 함수로 변환 부탁드립니다.
Input : Period(Numeric);
Var : value1(0), value2(0);
value1 = C - C[1];
if value1 > 0 Then
{
value2 = value1;
}
Else
{
value1 = 0;
value2 = C[1]-C;
}
RSI_Y = AccumN(value1, Period) / AccumN(value2, Period) * 100;
2023-04-10
945
글번호 168036
답변완료
부탁드려요
질문이 많아 죄송해요ㅜ
혼자 해보려고 했는데 잘 안돼요 ㅜ
아래 두 지표에서 종목검색식 수식을 알고 싶어요,,
1번 지표에서 빨간색 동그라미가 뜨는 종목
2번 지표에서 Plot1( c ) 또는 Plot2( c ) 가 뜨는 종목
부탁드려요(__)
1번
inputs: ATRLength(15), Strength(20), 폭(0.25);
input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2);
input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2);
var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0);
var : idx(0),hh(0),ll(0),EP1(0),EP2(0);
var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0);
var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0);
Ep1 = 2/(ATRLength+1);
Ep2 = 2/(Strength+1);
idx = idx+1;
if idx < ATRLength Then
{
hh = DayHigh;
ll = daylow;
}
Else
{
hh = Highest(High, ATRLength);
ll = Lowest(Low, ATRLength);
}
if idx < Strength Then
{
h1 = DayHigh;
l1 = daylow;
}
Else
{
h1 = Highest(High, Strength);
l1 = Lowest(Low, Strength);
}
hl = hh-ll;
if idx == 1 Then
{
ema1 = hl;
ema2 = h;
ema3 = l;
}
Else
{
ema1 = hl * EP1 + ema1 * (1-EP1);
ema2 = h * EP2 + ema2 * (1-EP2);
ema3 = l * EP2 + ema3 * (1-EP2);
}
atrv = ema1;
avgv = (ema2+ema3)/2;
upv = avgv + ATRv;
dnv = avgv - ATRv;
if idx >= 2 then
{
if c > upv[1] and c > h1[1] then trend = 1;
else if c < dnv[1] and c < l1[1] then trend = -1;
if trend < 0 and trend[1] > 0 then flag=1; else flag=0;
if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0;
if trend > 0 and dnv < dnv[1] then dnv=dnv[1];
if trend < 0 and upv > upv[1] then upv=upv[1];
if flag == 1 then upv = avgv + ATRv;
if flagh == 1 then dnv = avgv - ATRv;
if trend == 1 then ST = dnv; else ST = upv;
STrend = trend;
}
Plot1(st,"SuperTrend",iff(strend == 1,red,blue));
if Trend != Trend[1] Then
{
if Trend == 1 Then
{
var1 = h;
var2 = var1[1];
TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999);
TL_SetColor(TL,Red);
TL_SetSize(TL,0.5);
tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●");
Text_SetColor(tx,Red);
Text_SetSize(tx,10);
Text_SetStyle(tx,2,2);
if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then
{
tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●");
Text_SetColor(tx11,Magenta);
Text_SetSize(tx11,10);
Text_SetStyle(tx11,2,2);
}
if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then
{
tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●");
Text_SetColor(tx11,Lime);
Text_SetSize(tx11,10);
Text_SetStyle(tx11,2,2);
}
}
Else
{
Var3 = l;
Var4 = Var3[1];
tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●");
Text_SetColor(tx,Blue);
Text_SetSize(tx,10);
Text_SetStyle(tx,2,2);
if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then
{
tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●");
Text_SetColor(tx12,Cyan);
Text_SetSize(tx12,10);
Text_SetStyle(tx12,2,2);
}
if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then
{
tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●");
Text_SetColor(tx12,Green);
Text_SetSize(tx12,10);
Text_SetStyle(tx12,2,2);
}
}
}
Else
{
if Trend == 1 Then
{
if h > var1 Then
var1 = h;
}
if Trend == -1 Then
{
if l < var3 Then
var3 = l;
}
}
if Trend != Trend[1] Then
{
if Trend == 1 Then
{
h2 = h;
h3 = h2[1];
h4 = h3[1];
if L4 > 0 and
max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then
{
tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●");
Text_SetColor(tx1,Black);
Text_SetSize(tx1,10);
Text_SetStyle(tx1,2,2);
}
if Condition1 == true Then
Text_Delete(tx3);
}
Else #음전환
{
L2 = l;
l3 = l2[1];
l4 = l3[1];
Condition1 = False;
if L4 > 0 and max(l3,l4) <= min(L3,L4)+폭 Then
{
tx3 = Text_New_Self(sDate,sTime, st+PriceScale*2,"●");
Text_SetColor(tx3,Red);
Text_SetSize(tx3,10);
Text_SetStyle(tx3,2,2);
Condition1 = true;
}
if Condition1 == true and l2 < max(l3,l4)-폭 Then
{
Condition1 = False;
Text_Delete(tx3);
}
}
}
Else
{
if Trend == 1 Then
{
if h > h2 Then
h2 = h;
}
if Trend == -1 Then
{
if l < L2 Then
{
L2 = l;
if Condition1 == true and l2 < max(l3,l4)-폭 Then
{
Condition1 = False;
Text_Delete(tx3);
}
}
}
}
2번
input : Left(8),right(8);
Input : sto1(12), sto2(5), sto3(3);
var : StoK(0),StoD(0),cnt(0),T(0);
StoK = StochasticsK(sto1,sto2);
StoD = StochasticsD(sto1,sto2,sto3);
if SwingHigh(1,H,left,right,left+right+1) != -1 Then{
T = 1;
#고점값
var1 = H[right];
var2 = var1[1];
#고점일때 스토k값
var3 = stok[right];
var4 = var3[1];
#고점인덱스
var5 = index[right];
var6 = var5[1];
#고점사이의 최저값
if var6 > 0 then{
var7 = L[right];
for cnt = right to right+(var5-var6)
{
if L[cnt] < var7 Then
var7 = L[cnt];
}
}
}
if SwingLow(1,L,left,right,left+right+1) != -1 Then{
T = -1;
#저점값
value1 = L[right];
value2 = value1[1];
#저점일째 스토k값
value3 = stok[right];
value4 = value3[1];
#저점인덱스
value5 = index[right];
value6 = value5[1];
#저점사이의 최고값
if value6 > 0 then{
value7 = H[right];
for cnt = right to right+(value5-value6)
{
if H[cnt] > value7 Then
value7 = H[cnt];
}
}
}
if T == 1 and #최근 고점발생
var1 > var2 and var2 > 0 and #고점상승
var3 < var4 and #지표고점하락
var3 > 50 and var4 > 50 and #지표는 50위
CrossDown(c,var7) and #고점사이 최저가 하향이탈
stok < stod Then #스토는 데드상태
Plot1( c ) ;
if T == -1 and #최근 저점발생
value1 < value2 and value2 > 0 and #저점상승
value3 > value4 and #지표저점하락
value3 < 50 and value4 < 50 and #지표는 50아래
crossup(C,value7) and #저점사이 최고가 상향돌파
stok > stod Then #스토는 골드상태
Plot2( c ) ;
2023-04-10
842
글번호 168035
답변완료
수식 부탁드립니다
- 해외선물을 거래하려고 합니다.
- 시스템이 중복이 되는 면이 있어도 각각 수식을 꼭 부탁 드립니다
(시스템은 초보라 양해 부탁 드립니다)
- 매수계좌와 매도계좌를 구분하여 2개의 계좌로 거래를 하려고 합니다
- 시스템은 초보라 매수전략과 매도 전략에 대한 수식작성을 각각 부탁드립니다.
- 기본적으로 진입은 '윌리엄스R'로 진입을 하고 청산은 '목표틱수'로 하는 전략입니다.
[매수전략]
외부변수1 : 이평1(30),이평2(60),이평3(120)
외부변수2 : 윌리엄스R 기간값
외부변수3 : 1차손절틱수(-50), 청산목표틱수(+70) -
-모든 틱수의 기준은 진입가격 기준입니다.
진입 : 봉(가격)이 ‘이평3’ 위에 있고, 윌리암스R 매수신호시 매수진입
(여기서 이평 위에 있는것은 이격도로 수식을 작성을 하면 될 거 같은데,
다른 방법이 있으면 다른 방법으로 해주셔도 됩니다)
1차손절 : 진입후 바로 자동으로 1차손절틱수(-50)로 세팅되도록 부탁 드립니다
청산: 청산 목표틱수(+70) 도달시 매수청산(스위칭 전략은 없습니다)
[매도전략]
외부변수1 : 이평1(30),이평2(60),이평3(120)
외부변수2 : 윌리엄스R 기간값
외부변수3 : 1차손절틱수(-50), 청산목표틱수(+70) -
-모든 틱수의 기준은 진입가격 기준입니다.
진입 : 봉(가격)이 ‘이평3’ 아래에 있고, 윌리암스R 매도신호시 매도진입
(여기서 이평 위에 있는것은 이격도로 수식을 작성을 하면 될 거 같은데,
다른 방법이 있으면 다른 방법으로 해주셔도 됩니다)
1차손절 : 진입후 바로 자동으로 1차손절틱수(-50)로 세팅되도록 부탁 드립니다
청산: 청산 목표틱수(+70) 도달시 매도청산(스위칭 전략은 없습니다)
2023-04-10
1054
글번호 168034
답변완료
시스템식 부탁 드립니다
해외선물을 거래하려고 합니다.
- 시스템이 중복이 되는 면이 있어도 각각 수식을 꼭 부탁 드립니다
(초보라 양해 부탁 드립니다)
- 매수계좌와 매도계좌를 구분하여 2개의 계좌로 거래를 하려고 합니다
- 시스템은 초보라 매수전략과 매도 전략에 대한 수식작성을 각각 부탁드립니다.
- 기본적으로 진입은 ‘이평’으로 진입을 하고 청산은 '이평'으로 하는 전략입니다.
[매수전략]
외부변수1 : 이평1(30),이평2(60),이평3(120) 이평4(240),이평5(480)
외부변수2 : 1차손절틱수(-200),손절 트레일링스탑틱수(+5),1차목표틱수(+200)
--모든 틱수의 기준은 진입가격 기준입니다.
진입 : 봉(가격)이 ‘이평4’ 위에 있고, ‘이평5’ 상향돌파시 매수진입
(여기서 이평 위에 있는것은 이격도로 수식을 작성을 하면 될 거 같은데,
다른 방법이 있으면 다른 방법으로 해주셔도 됩니다)
1차손절 : 진입후 바로 자동으로 1차손절틱수(-200)로 세팅되도록 부탁 드립니다
트레일링 스탑 손절: 200틱 평가수익(1차목표틱) 발생시 트레일링스탑틱수(+5)
(이것은 되돌림을 당해도 손실을 최소화하기 위한 전략으로
1번만 되도록 부탁 드립니다-
지속적인 트레일링 스탑은 아닙니다)
청산: 200틱 평가 수익 후(1차목표틱)‘이평4’하향돌파시 매수청산
(스위칭 전략은 없습니다)
(1차 목표 수익 미도달시 이평4 가 붕괴가 되어도 청산이 되면 안됩니다.)
[매도전략]
외부변수1 : 이평1(30),이평2(60),이평3(120) 이평4(240),이평5(480)
외부변수2 : 1차손절틱수(-200),손절 트레일링스탑틱수(+5),1차목표틱수(+200)
--모든 틱수의 기준은 진입가격 기준입니다.
진입 : 봉(가격)이 ‘이평4’ 아래에 있고, ‘이평5’ 하향돌파시 매도진입
(여기서 이평 위에 있는것은 이격도로 수식을 작성을 하면 될 거 같은데,
다른 방법이 있으면 다른 방법으로 해주셔도 됩니다)
1차손절 : 진입후 바로 자동으로 1차손절틱수(-200)로 세팅되도록 부탁 드립니다
트레일링 스탑 손절: 200틱 평가수익(1차목표틱) 발생시 트레일링스탑틱수(+5)
(이것은 되돌림을 당해도 손실을 최소화하기 위한 전략으로
1번만 되도록 부탁 드립니다-
지속적인 트레일링 스탑은 아닙니다)
청산: 200틱 평가 수익 후(1차목표틱) ‘이평4’ 상향돌파시 매도청산
(스위칭 전략은 없습니다)
(1차 목표 수익 미도달시 이평4가 붕괴가 되어도 청산이 되면 안됩니다.)
2023-04-10
1172
글번호 168033
답변완료
시스템 식 부탁 드립니다.
- 해외선물을 거래하려고 합니다.
- 시스템이 중복이 되는 면이 있어도 각각 수식을 꼭 부탁 드립니다
(초보라 양해 부탁 드립니다)
- 매수계좌와 매도계좌를 구분하여 2개의 계좌로 거래를 하려고 합니다
- 시스템은 초보라 매수전략과 매도 전략에 대한 수식작성을 각각 부탁드립니다.
- 기본적으로 진입은 '윌리엄스R'로 진입을 하고 청산은 '이평'으로 하는 전략입니다.
[매수전략]
외부변수1 : 이평1(30),이평2(60),이평3(120) 이평4(240)
외부변수2 : 윌리엄스R 기간값
외부변수3 : 1차손절틱수(-100),손절 트레일링스탑틱수(+5),1차목표틱수(+100)
--모든 틱수의 기준은 진입가격 기준입니다.
진입 : 봉(가격)이 ‘이평4’ 위에 있고, 윌리암스R 매수신호시 매수진입
(여기서 이평 위에 있는것은 이격도로 수식을 작성을 하면 될 거 같은데,
다른 방법이 있으면 다른 방법으로 해주셔도 됩니다)
1차손절 : 진입후 바로 자동으로 1차손절틱수(-100)로 세팅되도록 부탁 드립니다
트레일링 스탑 손절: 100틱 평가수익(1차목표틱) 발생시 트레일링스탑틱수(+5)
(이것은 되돌림을 당해도 손실을 최소화하기 위한 전략으로
1번만 되도록 부탁 드립니다-
지속적인 트레일링 스탑은 아닙니다)
청산: 100틱 평가 수익 후(1차목표틱) 이평2 하향돌파시 매수청산(스위칭 전략은 없습니다)
(1차 목표 수익 미도달시 이평2가 붕괴가 되어도 청산이 되면 안됩니다.)
[매도전략]
외부변수1 : 이평1(30),이평2(60),이평3(120) 이평4(240)
외부변수2 : 윌리엄스R 기간값
외부변수3 : 1차손절틱수(-100),손절 트레일링스탑틱수(+5),1차목표틱수(+100)
--모든 틱수의 기준은 진입가격 기준입니다.
진입 : 봉(가격)이 ‘이평4’ 아래에 있고, 윌리암스R 매도신호시 매도진입
(여기서 이평 아래에 있는 것은 이격도로 수식을 작성을 하면 될 거 같은데,
다른 방법이 있으면 다른 방법으로 해주셔도 됩니다)
1차손절 : 진입후 바로 자동으로 1차손절틱수(-100)로 세팅되도록 부탁 드립니다
트레일링 스탑 손절: 100틱 평가수익(1차목표틱) 발생시 트레일링스탑틱수(+5)
(이것은 되돌림을 당해도 손실을 최소화하기 위한 전략으로
1번만 되도록 부탁 드립니다-
지속적인 트레일링 스탑은 아닙니다)
청산: 100틱 평가 수익 후(1차목표틱) 이평2 상향돌파시 매도청산(스위칭 전략은 없습니다)
(1차 목표 수익 미도달시 이평2가 붕괴가 되어도 청산이 되면 안됩니다.)
2023-04-10
1622
글번호 168032
답변완료
부탁드려요
아래 박스 지표에서 상단에 아주 근접한 종목검색하는 수식 부탁드려요ㅜ
질문이 많아서 죄송해요(__)
input : Period(88);
var : AA(false),BB(False),BBB(False);
var : CC(False),CCC(False),DD(False);
var : EE(0),FF(False);
var1 = Ema(C,5);
Var2 = Ema(C,20);
AA = H[1]>highest(c, Period)[2];
BB = C > var1 or crossup(C, Var2);
BBB = BB or BB[1] or BB[2];
CC = V[1] > highest(V, Period)[2];
CCC = CC or CC[1] or CC[2];
DD = O>C and C < (abs(C[1]-O[1])*2/3+min(C[1],O[1]));
EE = max(var1,Var2);
FF = (C>(highest(high,9)[25]+lowest(low,9)[25]+highest(high,26)[25]+lowest(low,26)[25])/4 ) and (C>(highest(high,52)[25]+lowest(low,52)[25])/2);
condition1 = AA and BBB and CCC and DD and FF;
if Condition1 == true Then
{
value1 = abs(C[1]-O[1])*2/3 + min(C[1], O[1]);
Value2 = max((abs(C[1]-O[1])*2/3+min(C[1], O[1]))*0.95, EE);
}
Plot1(value1);
Plot2(value2);
2023-04-10
1284
글번호 168031
답변완료
문의드립니다.
3. 매수신호가 청산되었을때 해당봉에서 바로 매도신호가 나오지않게 하고 싶습니다. 즉, 매수신호후 매도신호는 매수신호가 청산된 이후 10개 봉이 지나서 나올 수 있게 하고 싶습니다. 매도신호도 마찬가지입니다.
3
if 매수조건 Then
{
if MarketPosition == 0 and (TotalTrades == 0 or BarsSinceExit(1) >= 10) Then
Buy();
}
if 매도조건 Then
{
if MarketPosition == 0 and (TotalTrades == 0 or BarsSinceExit(1) >= 10) Then
Sell();
}
위와 같이 답해주셨는데 매도와 매수가 동일한 내용이라 이해가 안되니 작동 설명을 부탁드려도 되겠습니까?
미리 감사드립니다~
2023-04-09
1176
글번호 168030
답변완료
부탁드려요
아래는 키움에서 사용하던 박스지표인데요
아래 박스지표의 상단에 근접한 종목검색식 부탁드려요
그리고 예스차트용으로 지표수식도 부탁드려요(__)
감사합니다
multiple 15 gap 1 period 500
상단
AA=abs((H-L)/H*100);
Condition=
AA > multiple and
C<O and
O>C(1)*(1+gap/100) and
V>eavg(V(1), 20)*3;
valuewhen(1, Condition, H)
하단
AA=abs((H-L)/H*100);
Condition=
AA > multiple and
C<O and
O>C(1)*(1+gap/100) and
V>eavg(V(1), period)*3;
valuewhen(1, Condition, L)
2023-04-09
1591
글번호 168029
배움이 님에 의해서 삭제되었습니다.
2023-04-09
317
글번호 168028