커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5539
글번호 230811
답변완료
도움 요청 드립니다.
아래 지표를 트레이딩뷰에서 찾았는데요,
예트로 변환하고 싶어서 말씀올립니다.
항상 감사드립니다~
src = input(close, title ="Source")
len = input(14, title ="Length")
oblevel = input(70, title ="OB Level", maxval = 99, minval = 1)
oslevel = input(30, title ="OS Level", maxval = 99, minval = 1)
bullz = input(60, title ="Bull Zone Level", maxval = 99, minval = 1)
bearz = input(40, title ="Bear Zone Level", maxval = 99, minval = 1)
fillbtw = input(true, title ="Fill between OB and OS lines")
showbbzone = input(false, title ="Show Bull/Bear Zones")
drawmidl = input(false, title ="Draw Midline")
emasmt = input(1, title ="EMA Smoothing", minval = 1)
my_rsi(x, len) =>
u = max(x - x[1], 0)
d = max(x[1] - x, 0)
sumu = 0.0, sumd = 0.0
sumu := (u + (len - 1) * nz(sumu[1])) / len
sumd := (d + (len - 1) * nz(sumd[1])) / len
rs = sumu / sumd
res = 100 - 100 / (1 + rs)
[res, sumu, sumd]
[Rsi, sumu, sumd] = my_rsi(close, len)
diffupob = (sumd * ((100 / (100 - oblevel)) -1 )) * len - (len - 1) * nz(sumu[1])
diffdnob = (sumu / ((100 / (100 - oblevel)) -1 )) * len - (len - 1) * nz(sumd[1])
diffupos = (sumd * ((100 / (100 - oslevel)) -1 )) * len - (len - 1) * nz(sumu[1])
diffdnos = (sumu / ((100 / (100 - oslevel)) -1 )) * len - (len - 1) * nz(sumd[1])
oblev = Rsi <= oblevel ? close + diffupob : close - diffdnob
oslev = Rsi <= oslevel ? close + diffupos : close - diffdnos
oblev := ema(oblev, emasmt)
oslev := ema(oslev, emasmt)
obl = plot(oblev, color = color.red)
osl = plot(oslev, color = color.green)
fill(obl, osl, color = fillbtw ? color.new(color.gray, 89) : color.new(color.white, 100))
plot((oblev + oslev) / 2, color = drawmidl ? color.gray : color.new(color.white, 100))
//Bull/Bear Zones
diffupblzn= (sumd * ((100 / (100 - bullz)) -1 )) * len - (len - 1) * nz(sumu[1])
diffdnblzn = (sumu / ((100 / (100 - bullz)) -1 )) * len - (len - 1) * nz(sumd[1])
diffupbrzn= (sumd * ((100 / (100 - bearz)) -1 )) * len - (len - 1) * nz(sumu[1])
diffdnbrzn = (sumu / ((100 / (100 - bearz)) -1 )) * len - (len - 1) * nz(sumd[1])
bullzone = Rsi <= bullz ? close + diffupblzn : close - diffdnblzn
bearzone = Rsi <= bearz ? close + diffupbrzn : close - diffdnbrzn
bullzone := ema(bullzone, emasmt)
bearzone := ema(bearzone, emasmt)
bullzln = plot(bullzone, color = showbbzone ? color.lime : na)
bearzln = plot(bearzone, color = showbbzone ? color.lime : na)
fill(obl, bullzln, color = bullz < oblevel and showbbzone ? color.new(color.lime, 90) : color.new(color.white, 100))
fill(osl, bearzln, color = bearz > oslevel and showbbzone ? color.new(color.red, 90) : color.new(color.white, 100))
2023-04-20
984
글번호 168336
답변완료
수식 문의
안녕하세요. 아래의 수식을 예스수식으로
변환하고 싶습니다.
부탁드리겠습니다. 감사합니다.
========================================
study(title="[RS][UNTESTED]CAP Fibo Channel V2", shorttitle="[RS][UNTESTED]CFC.V2", overlay=true)
length = input(120)
Smooth = input(2), SmoothOutside = input(type=bool, defval=false)
midline = sum(avg(ohlc4,ohlc4[1]),length)/(length)//ema(ohlc4, input(6))
c = cum(close)/(1+n)
h = cum(high)/(1+n)
l = cum(low)/(1+n)
factor = avg((h-c), (c-l))// - stdev(midline, length) //<-- uncomment for psicadelic bubbling effect :p
p0 = plot(midline, color=black, linewidth=2)
//p1 = plot(midline + factor, color=black, linewidth=1, style=circles)
//p2 = plot(midline + factor * 2, color=black, linewidth=1, style=circles)
p3 = plot(ema(midline + factor * 3, SmoothOutside ? Smooth*3 : 1), color=black, linewidth=1, style=circles)
p4 = plot(ema(midline + factor * 5, SmoothOutside ? Smooth*5 : 1), color=black, linewidth=2)
p5 = plot(ema(midline + factor * 8, SmoothOutside ? Smooth*8 : 1), color=black, linewidth=1)
p6 = plot(ema(midline + factor * 13, SmoothOutside ? Smooth*13 : 1), color=black, linewidth=1, style=circles)
p7 = plot(ema(midline + factor * 21, SmoothOutside ? Smooth*21 : 1), color=black, linewidth=4)
p8 = plot(ema(midline + factor * 34, SmoothOutside ? Smooth*34 : 1), color=black, linewidth=1, style=circles)
p9 = plot(ema(midline + factor * 55, SmoothOutside ? Smooth*55 : 1), color=black, linewidth=1, style=circles)
//m1 = plot(midline - factor, color=black, linewidth=1, style=circles)
//m2 = plot(midline - factor * 2, color=black, linewidth=1, style=circles)
m3 = plot(ema(midline - factor * 3, SmoothOutside ? Smooth*3 : 1), color=black, linewidth=1, style=circles)
m4 = plot(ema(midline - factor * 5, SmoothOutside ? Smooth*5 : 1), color=black, linewidth=2)
m5 = plot(ema(midline - factor * 8, SmoothOutside ? Smooth*8 : 1), color=black, linewidth=1)
m6 = plot(ema(midline - factor * 13, SmoothOutside ? Smooth*13 : 1), color=black, linewidth=1, style=circles)
m7 = plot(ema(midline - factor * 21, SmoothOutside ? Smooth*21 : 1), color=black, linewidth=4)
m8 = plot(ema(midline - factor * 34, SmoothOutside ? Smooth*34 : 1), color=black, linewidth=1, style=circles)
m9 = plot(ema(midline - factor * 55, SmoothOutside ? Smooth*55 : 1), color=black, linewidth=1, style=circles)
fill(p3, p5, color=black, transp=80)
fill(m3, m5, color=black, transp=80)
fill(p4, p6, color=#ec8014, transp=80)
fill(m4, m7, color=#ec8014, transp=80)
fill(m4, m8, color=lime, transp=90)
fill(p4, p8, color=red, transp=90)
fill(p6,p7, color=maroon, transp=60)
fill(m6,m7, color=green, transp=60)
2023-04-20
874
글번호 168335
신대륙발견 님에 의해서 삭제되었습니다.
2023-04-20
16
글번호 168334
답변완료
문의드립니다
if 매도조건식1
{
매도
}
else if 매도조건식2
{
매도
}
else if 매도조건식3
{
매도
}
else if 매도조건식4
{
매도
}
이렇게 구성을 했습니다
예를들어서,
매도조건식1을 만족시키면 그 밑으로 매도조건식2,3,4로는 가지 않고
매도조건식1,2는 만족시키지 못했는데 매도조건식3은 만족시킨다면, 매도조건식4로는 가지않고
이렇게 이해했는데 맞을까요?
------------------------
두번째 질문입니다
data1 : 해당종목의 1분봉 차트
data2 : 해당종목의 일봉차트
매수를 하고 나서,
Data2(BarsSinceEntry) 를 사용하면 진입한 날로부터 일봉의 갯수가 계산되는 것이 맞을까요?
자꾸 분봉갯수가 계산이 되는것 같아서요 ㅠ
분봉차트에서 돌아가는 로직에, <진입한 날로부터 며칠이 되었는지>를 사용하려면
Data2(BarsSinceEntry) <- 이게 아니라 다른걸 써야될까요??
2023-04-20
917
글번호 168333
답변완료
문의드립니다
어제 달아주신 답변에 있는 식인데,
C > hc 를 1번에서는 if문 안에 if문을 한번 더 써서 넣었고,
2번에서는 if문 안에 and로 연결시켜서 넣었습니다
작동 자체는 동일하게 할것 같은데,, 혹시 다르면 어떻게 다른지 궁금합니다
(처리 속도? 효율을 위해서는 if문 안에 if문을 넣는게 낫다던가...?)
input : 수량(1);
var : hc(0),cnt(0);
hc = 0;
For cnt = 1 to 20
{
if hc == 0 or (hc > 0 and DayClose(cnt) > hc) Then
hc = DayClose(cnt);
}
<1번>
if MarketPosition==0 and NextBarSdate != sDate Then
{
if C > hc Then
Buy("진입",AtMarket,Def,수량);
}
<2번>
if MarketPosition==0 and NextBarSdate != sDate and C > hc Then
{
Buy("진입",AtMarket,Def,수량);
}
2023-04-20
990
글번호 168332
파워 님에 의해서 삭제되었습니다.
2023-04-19
736
글번호 168331
파워 님에 의해서 삭제되었습니다.
2023-04-19
1022
글번호 168330
답변완료
부탁 드립니다.
도움에 감사 드립니다.
첨부 되는 엑셀 파일의 데이터를 지표로 나타 낼수 있는지요?
미리 감사 드립니다.
2023-04-19
1431
글번호 168324
2wnwn 님에 의해서 삭제되었습니다.
2023-04-19
113
글번호 168323