커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3443
글번호 230811
아침 님에 의해서 삭제되었습니다.
2023-06-12
12
글번호 169665
답변완료
문의드립니다.
트레이딩뷰에서 참조해온, 시간단위의 바 표시를 거래량단위의 바표시로 바꾸는 수식입니다.
예스랭귀지로 변환해서 사용가능할지 문의드리며, 사용가능하다면 예스랭귀지로 변환하고 싶습니다.
//*** Functions
changed(x) => x != x[1]
//*** Inputs
price = input(open, "Price Data")
bartype = input("Volume Bar", "Bar Type", options=["Volume Bar","Dollar Bar"])
delta = input(34, "Delta", minval=0., step=.01)
//*** Main
bar = 0.0
bar := (bartype=="Volume Bar" ? nz(bar) + volume : nz(bar) + volume * price)
bar := bar > delta ? 0.0 : bar
long = nz(bar) + volume > delta and open < close
short = nz(bar) + volume > delta and open > close
state = 0
state := long ? 1 : short ? -1 : nz(state[1])
longst = changed(state) and state[1]==-1
shortst = changed(state) and state[1]==1
plotshape(longst ? low : na, location=location.belowbar, style=shape.triangleup, color=color.lime, size=size.tiny, text=" ", textcolor=color.white, transp=0)
plotshape(shortst ? high : na, location=location.abovebar, style=shape.triangledown, color=color.red, size=size.tiny, text=" ", textcolor=color.white, transp=0)
2023-06-11
1451
글번호 169664
답변완료
적용가능하도록 부탁드립니다.
트레이딩뷰에서 사용되는 지표를 적용하고 싶습니다(2가지). 도움 부탁 드립니다.
1. 캔들(Smoothed Heiken Ashi Candles)
len=input(10)
o=ema(open,len)
c=ema(close,len)
h=ema(high,len)
l=ema(low,len)
haclose = (o+h+l+c)/4
haopen = na(haopen[1]) ? (o + c)/2 : (haopen[1] + haclose[1]) / 2
hahigh = max (h, max(haopen,haclose))
halow = min (l, min(haopen,haclose))
len2=input(10)
o2=ema(haopen, len2)
c2=ema(haclose, len2)
h2=ema(hahigh, len2)
l2=ema(halow, len2)
col=o2>c2 ? red : lime
plotcandle(o2, h2, l2, c2, title="heikin smoothed", color=col)
2. 보조지표(stc)
indicator(title='[SHK] Schaff Trend Cycle (STC)', shorttitle='STC', overlay=false)
EEEEEE = input(12, 'Length')
BBBB = input(26, 'FastLength')
BBBBB = input(50, 'SlowLength')
AAAA(BBB, BBBB, BBBBB) =>
fastMA = ta.ema(BBB, BBBB)
slowMA = ta.ema(BBB, BBBBB)
AAAA = fastMA - slowMA
AAAA
AAAAA(EEEEEE, BBBB, BBBBB) =>
AAA = input(0.5)
var CCCCC = 0.0
var DDD = 0.0
var DDDDDD = 0.0
var EEEEE = 0.0
BBBBBB = AAAA(close, BBBB, BBBBB)
CCC = ta.lowest(BBBBBB, EEEEEE)
CCCC = ta.highest(BBBBBB, EEEEEE) - CCC
CCCCC := CCCC > 0 ? (BBBBBB - CCC) / CCCC * 100 : nz(CCCCC[1])
DDD := na(DDD[1]) ? CCCCC : DDD[1] + AAA * (CCCCC - DDD[1])
DDDD = ta.lowest(DDD, EEEEEE)
DDDDD = ta.highest(DDD, EEEEEE) - DDDD
DDDDDD := DDDDD > 0 ? (DDD - DDDD) / DDDDD * 100 : nz(DDDDDD[1])
EEEEE := na(EEEEE[1]) ? DDDDDD : EEEEE[1] + AAA * (DDDDDD - EEEEE[1])
EEEEE
mAAAAA = AAAAA(EEEEEE, BBBB, BBBBB)
mColor = mAAAAA > mAAAAA[1] ? color.new(color.green, 20) : color.new(color.red, 20)
if mAAAAA[3] <= mAAAAA[2] and mAAAAA[2] > mAAAAA[1] and mAAAAA > 75
alert("Red", alert.freq_once_per_bar)
if mAAAAA[3] >= mAAAAA[2] and mAAAAA[2] < mAAAAA[1] and mAAAAA < 25
alert("Green", alert.freq_once_per_bar)
plot(mAAAAA, color=mColor, title='STC', linewidth=2)
ul = plot(25, color=color.new(color.gray, 70))
ll = plot(75, color=color.new(color.gray, 70))
fill(ul, ll, color=color.new(color.gray, 96))
부탁드립니다.
2023-06-11
1505
글번호 169663
답변완료
문의 드립니다!
안녕하세요!
옵션챠트에서 data1을 콜, data2를 풋으로 설정후
이 data1, 2에 각각 아래식을 적용시 2개의 가로선이 다른 가격대에서 발생되는데요
이 2개의 가로선 사이에 색상을 입히는 수식을 구하고싶습니다
* 가로선의 두께와 색상은 사용자지정이 가능토록 부탁드립니다
감사합니다!
--------------------------------------------------------------------------------
var : V1(Data1(C),data1);
if crossup(data10(H),data11(L)) or CrossDown(data10(L),data11(H)) Then
{
v1 = data1(C);
}
plot1(v1);
2023-06-11
1175
글번호 169662
답변완료
다른 PC에서 접속하여 기존PC에서쓰던 지표,검색식등을 사용방법
다른 PC에서 접속하여 기존PC에서쓰던 지표,검색식등을 동일하게 사용하고자합니다
종합환경설정>설정정보관리 에서 개인설정정보 서버 저장하기를하고 다른PC에서
개인설정정보 내려받기를해도 기존 검색식등은 사용할수없는데요,
검색식,지표수식등이 PC에 로컬로 저장이되어서 그러는건지,
다른 PC에서 사용할수 있는 방법을 부탁드립니다
매번 감사합니다
2023-06-11
933
글번호 169661
답변완료
문의드립니다.
수고많으십니다.
다계약에서 익절이든 손절이든 청산후 바로 동일방향 신호가 나와서 게시판에 있는 재진입금지 수식을 넣어봤으나 원하는 결과가 나오지 않습니다.
3계약 진입시 모두 청산후부터 20봉까지 진입이 강제로 안되는 수식을 원합니다.
미리 감사드립니다.
2023-06-11
1104
글번호 169660
답변완료
부탁 드립니다
수고 하십니다
키움차트 수식 입니다
예스로 변환 좀 부탁 드립니다
매수 진입
R=highest(H,X);
S=lowest(L,X);
A=countsince(time>=T1,crossUp(c,R(1)) or crossDown(c,S(1)));
crossUp(A,0.5) and C>R(1)
수식 : 매수청산
R=highest(H,X);
S=lowest(L,X);
crossDown(c,S(1))
2023-06-11
1259
글번호 169659
답변완료
추세선 상하대칭
input : Period(250);
Var:j(0),T(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 : btx1(0),btx2(0),btx11(0),btx12(0),btx21(0),btx22(0);
Plot1(value12);
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];
if hival[0] > 0 and Loval[0] > 0 Then
{
btx11 = Text_New(date12,time12,Value11+abs(Hival[0]-loval[0])*1.618,"■");
btx12 = Text_New(date12,time12,Value11+abs(Hival[0]-loval[0])*0.618,"■");
btx1 = Text_New(date12,time12,Value11+abs(Hival[0]-loval[0]),"■");
btx2 = Text_New(date12,time12,Value12-abs(Hival[0]-loval[0]),"■");
btx21 = Text_New(date12,time12,Value12-abs(Hival[0]-loval[0])*1.618,"■");
btx22 = Text_New(date12,time12,Value12-abs(Hival[0]-loval[0])*0.618,"■");
Text_SetStyle(btx11,2,2);
Text_SetStyle(btx12,2,2);
Text_SetStyle(btx1,2,2);
Text_SetStyle(btx2,2,2);
Text_SetStyle(btx21,2,2);
Text_SetStyle(btx22,2,2);
Text_SetColor(btx11,Lime);
Text_SetColor(btx12,Lime);
Text_SetColor(btx1,Blue);
Text_SetColor(btx2,Blue);
Text_SetColor(btx21,Lime);
Text_SetColor(btx22,Lime);
}
}
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];
Text_SetLocation(btx11, date12,time12,Value11+abs(Hival[0]-loval[0])*1.618);
Text_SetLocation(btx12, date12,time12,Value11+abs(Hival[0]-loval[0])*0.618);
Text_SetLocation(btx1, date12,time12,Value11+abs(Hival[0]-loval[0]));
Text_SetLocation(btx2, date12,time12,Value12-abs(Hival[0]-loval[0]));
Text_SetLocation(btx21, date12,time12,Value12-abs(Hival[0]-loval[0])*1.618);
Text_SetLocation(btx22, date12,time12,Value12-abs(Hival[0]-loval[0])*0.618);
}
}
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];
if hival[0] > 0 and Loval[0] > 0 Then
{
btx11 = Text_New(date12,time12,Value12+abs(Hival[0]-loval[0])*1.618,"■");
btx12 = Text_New(date12,time12,Value12+abs(Hival[0]-loval[0])*0.618,"■");
btx1 = Text_New(date12,time12,Value12+abs(Hival[0]-loval[0]),"■");
btx2 = Text_New(date12,time12,Value11-abs(Hival[0]-loval[0]),"■");
btx21 = Text_New(date12,time12,Value11-abs(Hival[0]-loval[0])*1.618,"■");
btx22 = Text_New(date12,time12,Value11-abs(Hival[0]-loval[0])*0.618,"■");
Text_SetStyle(btx11,2,2);
Text_SetStyle(btx12,2,2);
Text_SetStyle(btx1,2,2);
Text_SetStyle(btx2,2,2);
Text_SetStyle(btx21,2,2);
Text_SetStyle(btx22,2,2);
Text_SetColor(btx11,Lime);
Text_SetColor(btx12,Lime);
Text_SetColor(btx1,Red);
Text_SetColor(btx2,Red);
Text_SetColor(btx21,Lime);
Text_SetColor(btx22,Lime);
}
}
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];
Text_SetLocation(btx11, date12,time12,Value12+abs(Hival[0]-loval[0])*1.618);
Text_SetLocation(btx12, date12,time12,Value12+abs(Hival[0]-loval[0])*0.618);
Text_SetLocation(btx1, date12,time12,Value12+abs(Hival[0]-loval[0]));
Text_SetLocation(btx2, date12,time12,Value11-abs(Hival[0]-loval[0]));
Text_SetLocation(btx21, date12,time12,Value11-abs(Hival[0]-loval[0])*1.618);
Text_SetLocation(btx22, date12,time12,Value11-abs(Hival[0]-loval[0])*0.618);
}
}
네모 표시를, 추세선의 크기가 작으면 무시하고 1P 이상일 때만 표시되게 수정 부탁드립니다.
2023-06-11
1699
글번호 169658
답변완료
수식 부탁드립니다.
1. 진입조건
기술적적조건1 (TDI, DI)
TDI = 최근 20일추세크기 - 이전 20일 동안 횡보변동성크기
추세크기 = 절대값(최근20일 동안의 20일 모멘텀들의 합)
횡보변동성크기 = (최근 40일동안의 20일 모멘텀 절대값의 합) -(최근20일동안의 20 일 모멘텀 절대값의 합)
DI = 최근 20일 동안의 20일 모멘텀 값의 합
buy power = 현재봉 포함 과거 n일 간의 최고점 - 15일 전봉 포함 과거 n일간의 최저점
(n기간 선택가능하게)
sell power = n일전 봉 포함 과거 15일간의 최고점 - 현재봉 포함 과거 15일 간의 최저점
TTF(n기간) = (buy power-sell power)/(0.5 * (buy power + sell power)) * 100
TTF > 100 이면서 DI가 TDI를 상향 돌파시 매수
TTF <-100 이면서 DI가 TDI를 하향 돌파시 매도
거래수량(총 예수금의 1%) = 예수금/ (100 * (20봉간 최고값-최저값))
=> 예스랭귀지에서 예수금을 읽어와서 거래가 가능한지 아니면 예수금을 직접 입력해줘야하는지 궁금합니다.
기술적조건2 (adx,force index, chaikin oscillator)
종가가 N일간의 최고점 돌파(N값 선택가능하게) and
돌파시점의 ADX값이 N일전의 ADX값보다 클 것 and
돌파시점의 force index값이 N일전의 force index값보다 클 것 and
돌파시점의 chaikin oscillator 값이 N일전의 chaikin oscillator값보다 클 것
시간조건
09:00이후 진입, 15:20에 보유한 모든 수량 청산
예수금조건
거래수량(총 예수금의 1%) = 예수금/ (100 * (20봉간 최고값-최저값))
2. 필터조건
ADX 조건1) ADX > 25 일 것
ADX 조건2) (ADX 20봉평균 < 10) and (최근 3일 ADX >10 일 것) and
(ADX - 5일전 ADX >0 일 것)
ADX 조건 1 혹은 ADX조건2를 만족할 것
3. 청산조건
청산조건1 (최고-최저 range)
진입이후 봉이 갱신될 때마다
청산지점(진입후 최고가- 3* abs[20봉간 최고값-최저값])의 값을 비교하여,
기존 청산지점 > 새로계산된 청산지점 -> 기존 청산지점 유지
기존 청산지점 < 새로계산된 청산지점 -> 새로 계산된 청산지점을 청산지점으로 갱신
청산조건2 (표준편차)
진입이후 봉이 갱신될 때마다
청산지점(진입후 최고가 - 3*abs[20봉간 표준편차])의 값을 비교하여,
기존 청산지점 > 새로계산된 청산지점 -> 기존 청산지점 유지
기존 청산지점 < 새로계산된 청산지점 -> 새로 계산된 청산지점을 청산지점으로 갱신
2023-06-10
1153
글번호 169657