커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5459
글번호 230811
답변완료
수고많습니다. 4가지 조건검색중 3가지 이상조건이 될때 검색되게 해주세요... 감사드립
input : sonarP(20),sonarsig(9),voscP1(5),voscP2(20),rsiP(14);
Var21 = SONAR(sonarP);
Var22 = ema(Var21,sonarsig);
Var5 = OSCV(voscP1,voscP2);
var6 = RSI(rsiP);
if CrossUp(Var21,Var22) and Var21[1] < 0 and
Var5 > 0 and var6[1]<=30 AND var6[1]<var6 Then
Find(1);
input : pd(22), bbl(20), mult(2.0), lb(50), ph(0.85),기간1(10),기간2(20);
var : wvf(0), sDev(0), midLine(0), upperBand(0),rangeHigh(0), OverSold(0);
var : ap(0),esa(0),d(0),ci(0),wt1(0),wt2(0);
# williams vix fix 및 과매도권 밴드 계산
wvf = ((highest(close, pd) - low) / (highest(close, pd))) * 100;
sDev = mult * std(wvf, bbl);
midLine = ma(wvf, bbl);
upperBand = midLine + sDev;
rangeHigh = (highest(wvf, lb)) * ph;
# 웨이브트렌드
ap = (HIGH+LOW+CLOSE)/3;
esa = Ema(ap, 기간1);
d = Ema(abs(ap - esa), 기간1);
ci = (ap - esa) / (0.015 * d);
wt1 = Ema(ci,기간2);
wt2 = ma(wt1,4);
if wt1[1]<=-53 && (wvf >= upperBand or wvf >= rangeHigh or wvf[1] >= upperBand or wvf[1] >= rangeHigh) &&
wvf[1]>wvf && Crossup(wt1,wt2)
Then
Find(1);
input : 배분1(0.236),배분2(1.02);
var : 중최고가(0),중최저가(0);
var : 경계(0),경계1(False),경계2(False);
var : 기준봉(0),기준봉1(False),기준봉2(False);
var : 결과기준(0),결과기준1(False),결과기준2(False);
var : 평균(0),평균라인(0);
var : a(0), m5(0),m10(0),m20(0),m60(0),m120(0),m240(0),m480(0);
var : bh(0),bc(0),b(0),aa(0);
중최고가=highest(h,20);
중최저가=lowest(l,20);
경계=(중최고가+중최저가)/2-(중최고가-중최저가)*배분1;
경계1=crossup(c, 경계)&& c>o*배분2;
경계2=crossdown(c, 경계);
if 경계1 or 경계2 Then
기준봉 = O;
기준봉1=crossup(c, 기준봉);
기준봉2=crossdown(c, 기준봉);
if 기준봉1 or 기준봉2 Then
결과기준=o;
결과기준1=crossup(c, 결과기준);
결과기준2=crossdown(c, 결과기준);
if 결과기준1 or 결과기준2 Then
A=o;
M5=ema(C,5);
M10=ema(C,10);
M20=ema(C,20);
M60=ema(C,60);
M120=ema(C,120);
M240=ema(C,240);
M480=ema(C,480);
BH=BollBandUp(20,2);
BC=ma(c,20);
평균=((M5*2)+(M10*2)+(M20*3)+(M60*2)+(M120*3)+(M240*2)+(M480*2)+(BH*1)+(BC*1)) / 18;
평균라인=Ema(Ema(Ema(평균, 5), 5), 5);
B=평균라인 + 20*std(평균라인,5);
AA=sar(0.02,0.2);
if C>=A && CROSSUP(C,B) && AA<=C Then
Find(1);
input : rsiLenghth(14);
input : rsiOverBought(70);
input : rsiOverSold(30);
var : bullishCandle(False),bearishCandle(False);
var : rsiValue(0),isRSIOB(False),isRSIOS(False),tradeSignal(False);
var : tx1(0),tx2(0),조건(False);
bullishCandle=close >= open[1] and close[1] < open[1];
//close[1] < open[1] && close[1] >= open && close >= open[1];
//high >= high[1] and low <= low[1]
rsiValue=rsi(rsiLenghth);
isRSIOB=rsiValue >= rsiOverBought and rsiValue;
isRSIOS=rsiValue <= rsiOverSold and rsiValue;
tradeSignal=((isRSIOS or isRSIOS[1] or isRSIOS[2]) and bullishCandle);
if tradeSignal && bullishCandle && C>O Then
Find(1);
2024-02-15
953
글번호 176636
답변완료
480 tjs
10분봉에서....
1 ,주가가 480 선위에 있고
2 ,스톡해스틱 슬로우 12, 5, 5,=> (0 에서 20 사이ㄷ또는 (1 or 2 봉전) 20돌파)
3 ,볼린저밴드 period :20 , d1 : 2 의 하단선 맞고거나 or 돌파 (저가도 인정)
위세경우를 만족 하는 검색식과 종목검색식을 알고 싶습니다.
새해 복 많이 받의세요
2024-02-15
746
글번호 176635
2wnwn 님에 의해서 삭제되었습니다.
2024-02-15
11
글번호 176634
답변완료
수식요청
다음 조건에 맞는 수식을 요청드립니다.
0.(일봉 1봉전) 평균거래량 5만주 이상
1.(일봉 1봉전) 주가범위 천원~ 5만원
a.0봉전 RSI(14) 65.0선 상향돌파
b.1봉전 RSI(14) 64.9 이하
c.2봉전 RSI(14) 64.9 이하
d.3봉전 RSI(14) 64.9 이하
e.4봉전 RSI(14) 64.9 이하
f.5봉전 RSI(14) 64.9 이하
g.0봉전 지수이평배열 60>120>240
h.0봉전 이평이격도; 시가 1이평과 종가 240이평 95%~110%
i.0봉전 지수이평배열 60<120<240
j.0봉전 이평이격도; 종가 1이평과 종가 240이평 70%~105%
k.1봉전 대비 0봉전 종가등락율: 3%이상
0 and 1 and a and b and c and d and e and f and ((g and h) or (i and j)) and k
소량으로 자동매매에 사용해보고자 하는 수식입니다.
2024-02-14
1037
글번호 176633
답변완료
종목검색 수식 작성 부탁드립니다.
지표는 만들어진거 같은데 이걸 검색기로 옮기니까 작동을 안하는것 같습니다 ㅠㅠ
볼린저벤드(15, 3.5) 오른쪽 수평으로 25일 이동한 상단선을
현재가격이 돌파하거나 위에 있는 종목을 검색하고 싶습니다
2024-02-14
953
글번호 176632
답변완료
다음의 지표를 분봉에서 사용하고자합니다.
항상 친절한 답변 감사드립니다.
새해에 복많이 받어세요.
아래의 일봉지표를 5분봉에 사용하는것으로 변경 부탁드립니다.
감사합니다. ^^
input: LeftL(3),RightL(3),period(500);
var : c1(0),c2(0),k(0),cnt(0),aaa(0),bbb(0),aaa1(0),bbb1(0);
Array : swingH[4](0), swingL[4](0);
Array : swingHbar[4](0), swingLbar[4](0);
if SwingHigh(1,H,LeftL,RightL,LeftL+RightL+1) != -1 Then
{
for k = 4 DownTo 2
{
swingH[k] = swingH[k-1];
swingHbar[k] = swingHbar[k-1];
if swingHbar[k] <= Index-Period Then
{
swingH[k] = -1;
swingHbar[k] = -1;
}
}
}
2024-02-14
765
글번호 176631
답변완료
문의 드립니다
일봉이 20봉 이상 60이평 위에 있고
그중 60이평이랑 이격도가 10프로이상인 봉이 10개 이상이고
그 기간중 120봉 신고가를 경신하고
60이평을 데드크로스하는 지점의 시가의 선을 60봉동안 표시하고 싶습니다.
감사합니다.
2024-02-14
604
글번호 176630
답변완료
추세 박스
1번수식.
input : Period(250);
Var:TL(0),j(0),T(0),tx(0) ,box(0);
Var: date11(0),date12(0),time11(0),time12(0),
date21(0),date22(0),time21(0),time22(0),
date31(0),date32(0),time31(0),time32(0);
Array: HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0);
var : tx98count(0), tx99count(0);
Plot1(value12,"value12",IFf(t==1,Red,Blue));
For j = 0 To 19
{
HiBar[j] = HiBar[j] + 1;
LoBar[j] = LoBar[j] + 1;
}
if crossup(c,highest(H,Period)[1]) Then
T = 1;
if CrossDown(c,Lowest(L,Period)[1]) Then
T = -1;
If T == -1 Then
{
If T[1] != -1 Then
{
For j = 18 DownTo 0
{
LoVal[j+1] = LoVal[j];
LoBar[j+1] = LoBar[j];
}
LoVal[0] = L;
LoBar[0] = 0;
date11 = date[HiBar[0]];
time11 = stime[HiBar[0]];
Value11 = HiVal[0];
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
date21 = date[HiBar[0]];
time21 = stime[HiBar[0]];
date22 = date[0];
time22 = stime[0];
box = Box_New_Self(date11,time11,Value11,date12,time12,Value12);
Condition99 = False;
tx99count = 0;
}
Else
{
If LoVal[0] > L Then
{
LoVal[0] = L;
LoBar[0] = 0;
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
date22 = date[0];
time22 = stime[0];
Box_SetEnd(box,date12,time12,Value12);
{
}
if value12 > value11-0.7 Then
{
Box_SetColor(box,Cyan);
Box_SetFill(box,true,50);
}
else if value12 <= value11-0.7 and value12 > value11-0.9 Then
{
Box_SetColor(box,Yellow);
Box_SetFill(box,true,70);
}
else if value12 <= value11-0.9 and value12 > value11-1.3 Then
{
Box_SetColor(box,Lime);
Box_SetFill(box,true,60);
}
else if value12 <= value11-1.3 and value12 > value11-1.6 Then
{
Box_SetColor(box,Cyan);
Box_SetFill(box,true,40);
}
else if value12 <= value11-1.6 and value12 > value11-2 Then
{
Box_SetColor(box,Blue);
Box_SetFill(box,true,20);
}
else
{
Box_SetColor(box,Yellow);
Box_SetFill(box,true,50);
}
Condition99 = False;
}
Else
{
if Condition99 == False and value12 <= value11-0.9 and H >= value12+PriceScale*3 Then
{
Condition99 = true;
tx99count = tx99count+1;
if tx99count >= 1 Then
{
TL= TL_New_Self(sDate,sTime,H+0.15,sDate,sTime,999);
TL_SetColor(TL,Magenta);
TL_SetSize(TL,1);
}
}
}
}
}
If T == 1 Then
{
If T[1] != 1 Then
{
For j = 18 DownTo 0
{
HiVal[j+1] = HiVal[j];
HiBar[j+1] = HiBar[j];
}
HiVal[0] = H;
HiBar[0] = 0;
date11 = date[LoBar[0]];
time11 = stime[LoBar[0]];
Value11 = LoVal[0];
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
date31 = date[LoBar[0]];
time31 = stime[LoBar[0]];
date32 = date[0];
time32 = stime[0];
box = Box_New_Self(date11,time11,Value11,date12,time12,Value12);
Condition98 = False;
tx98count = 0;
}
If HiVal[0] < H Then
{
HiVal[0] = H;
HiBar[0] = 0;
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
date32 = date[0];
time32 = stime[0];
Box_SetEnd(box,date12,time12,Value12);
{
}
if Value12 >= value11+1.3 Then
{
Box_SetColor(box,Pink);
Box_SetFill(box,true,70);
}
else if value12 >= value11+0.8 and value12 < value11+1.3 Then
{
Box_SetColor(box,Magenta);
Box_SetFill(box,true,30);
}
Else
{
Box_SetColor(box,Orange);
Box_SetFill(box,true,60);
}
Condition98 = False;
}
Else
{
if Condition98 == False and value12 >= value11+0.9 and L <= value12-PriceScale*3 Then
{
Condition98 = true;
tx98count = tx98count+1;
if tx98count >= 1 Then
{
TL= TL_New_Self(sDate,sTime,H-0.15,sDate,sTime,-999);
TL_SetColor(TL,Blue);
TL_SetSize(TL,1);
}
}
}
}
2번수식.
input : Period(250);
Var:TL(0),j(0),T(0),tx(0) ,box(0);
Var: date11(0),date12(0),time11(0),time12(0),
date21(0),date22(0),time21(0),time22(0),
date31(0),date32(0),time31(0),time32(0);
Array: HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0);
var : tx98count(0), tx99count(0);
Plot1(value12,"value12",IFf(t==1,Red,Blue));
For j = 0 To 19
{
HiBar[j] = HiBar[j] + 1;
LoBar[j] = LoBar[j] + 1;
}
if crossup(c,highest(H,Period)[1]) Then
T = 1;
if CrossDown(c,Lowest(L,Period)[1]) Then
T = -1;
If T == -1 Then
{
If T[1] != -1 Then
{
For j = 18 DownTo 0
{
LoVal[j+1] = LoVal[j];
LoBar[j+1] = LoBar[j];
}
LoVal[0] = L;
LoBar[0] = 0;
date11 = date[HiBar[0]];
time11 = stime[HiBar[0]];
Value11 = HiVal[0];
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
date21 = date[HiBar[0]];
time21 = stime[HiBar[0]];
date22 = date[0];
time22 = stime[0];
box = Box_New(date11,time11,Value11,date12,time12,Value12);
}
If LoVal[0] > L Then
{
LoVal[0] = L;
LoBar[0] = 0;
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
date22 = date[0];
time22 = stime[0];
Box_SetEnd(box,date12,time12,Value12);
}
if value12 > value11-0.7 Then
{
Box_SetColor(box,Cyan);
Box_SetFill(box,true,50);
}
else if value12 <= value11-0.7 and value12 > value11-0.9 Then
{
Box_SetColor(box,Yellow);
Box_SetFill(box,true,70);
}
else if value12 <= value11-0.9 and value12 > value11-1.3 Then
{
Box_SetColor(box,Lime);
Box_SetFill(box,true,60);
}
else if value12 <= value11-1.3 and value12 > value11-1.6 Then
{
Box_SetColor(box,Cyan);
Box_SetFill(box,true,40);
}
else if value12 <= value11-1.6 and value12 > value11-2 Then
{
Box_SetColor(box,Blue);
Box_SetFill(box,true,20);
}
else
{
Box_SetColor(box,Yellow);
Box_SetFill(box,true,50);
}
}
If T == 1 Then
{
If T[1] != 1 Then
{
For j = 18 DownTo 0
{
HiVal[j+1] = HiVal[j];
HiBar[j+1] = HiBar[j];
}
HiVal[0] = H;
HiBar[0] = 0;
date11 = date[LoBar[0]];
time11 = stime[LoBar[0]];
Value11 = LoVal[0];
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
date31 = date[LoBar[0]];
time31 = stime[LoBar[0]];
date32 = date[0];
time32 = stime[0];
box = Box_New(date11,time11,Value11,date12,time12,Value12);
}
If HiVal[0] < H Then
{
HiVal[0] = H;
HiBar[0] = 0;
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
date32 = date[0];
time32 = stime[0];
Box_SetEnd(box,date12,time12,Value12);
}
if Value12 >= value11+1.3 Then
{
Box_SetColor(box,Pink);
Box_SetFill(box,true,70);
}
else if value12 >= value11+0.8 and value12 < value11+1.3 Then
{
Box_SetColor(box,Magenta);
Box_SetFill(box,true,30);
}
Else
{
Box_SetColor(box,Orange);
Box_SetFill(box,true,60);
}
}
윗 그림은 박스만 있는 2번 수식이고, 정상입니다.
아래 그림은 그 박스 수식에, 3틱 변동시 세로선 추가하면 오류 나오는 1번 수식입니다.
선물 10틱 차트에서, 1번 수식 박스 세로선 모두 구현되게 수정 부탁드립니다.
다른 수식에서도 분봉은 정상이나 틱차트에서 오류 나올 때가 가끔 있습니다.
정상 박스는 처음부터 테두리가 없는데, 오류가 생길 때는 네모 테두리가 생겼다가 정상으로 되기도하나 그대로 테두리만 끝까지 존재합니다.
2024-02-14
829
글번호 176629
회원 님에 의해서 삭제되었습니다.
2024-02-15
18
글번호 176628