커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3435
글번호 230811
답변완료
문의 드립니다.
//@version=5
// This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © KivancOzbilgic
//created by: @Anil_Ozeksi
//developer: ANIL ÖZEKŞİ
//author: @kivancozbilgic
indicator('HIGH AND LOW Optimized Trend Tracker', 'HL OTT', overlay=true)
length = input.int(2, 'OTT Period', minval=1)
percent = input.float(0.6, 'OTT Optimization Coeff', step=0.1, minval=0)
hllength = input.int(10, 'Highest and Lowest Length', minval=1)
src = ta.highest(high, hllength)
srcl = ta.lowest(low, hllength)
highlighting = input(title='Highlighter On/Off ?', defval=true)
mav = input.string(title='Moving Average Type', defval='VAR', options=['SMA', 'EMA', 'WMA', 'DEMA', 'TMA', 'VAR', 'WWMA', 'ZLEMA', 'TSF', 'HULL'])
Var_Func(src, length) =>
valpha = 2 / (length + 1)
vud1 = src > src[1] ? src - src[1] : 0
vdd1 = src < src[1] ? src[1] - src : 0
vUD = math.sum(vud1, 9)
vDD = math.sum(vdd1, 9)
vCMO = nz((vUD - vDD) / (vUD + vDD))
VAR = 0.0
VAR := nz(valpha * math.abs(vCMO) * src) + (1 - valpha * math.abs(vCMO)) * nz(VAR[1])
VAR
VAR = Var_Func(src, length)
DEMA = 2 * ta.ema(src, length) - ta.ema(ta.ema(src, length), length)
Wwma_Func(src, length) =>
wwalpha = 1 / length
WWMA = 0.0
WWMA := wwalpha * src + (1 - wwalpha) * nz(WWMA[1])
WWMA
WWMA = Wwma_Func(src, length)
Zlema_Func(src, length) =>
zxLag = length / 2 == math.round(length / 2) ? length / 2 : (length - 1) / 2
zxEMAData = src + src - src[zxLag]
ZLEMA = ta.ema(zxEMAData, length)
ZLEMA
ZLEMA = Zlema_Func(src, length)
Tsf_Func(src, length) =>
lrc = ta.linreg(src, length, 0)
lrc1 = ta.linreg(src, length, 1)
lrs = lrc - lrc1
TSF = ta.linreg(src, length, 0) + lrs
TSF
TSF = Tsf_Func(src, length)
HMA = ta.wma(2 * ta.wma(src, length / 2) - ta.wma(src, length), math.round(math.sqrt(length)))
Var_Funcl(srcl, length) =>
valphal = 2 / (length + 1)
vud1l = srcl > srcl[1] ? srcl - srcl[1] : 0
vdd1l = srcl < srcl[1] ? srcl[1] - srcl : 0
vUDl = math.sum(vud1l, 9)
vDDl = math.sum(vdd1l, 9)
vCMOl = nz((vUDl - vDDl) / (vUDl + vDDl))
VARl = 0.0
VARl := nz(valphal * math.abs(vCMOl) * srcl) + (1 - valphal * math.abs(vCMOl)) * nz(VARl[1])
VARl
VARl = Var_Funcl(srcl, length)
DEMAl = 2 * ta.ema(srcl, length) - ta.ema(ta.ema(srcl, length), length)
Wwma_Funcl(srcl, length) =>
wwalphal = 1 / length
WWMAl = 0.0
WWMAl := wwalphal * srcl + (1 - wwalphal) * nz(WWMAl[1])
WWMAl
WWMAl = Wwma_Funcl(srcl, length)
Zlema_Funcl(srcl, length) =>
zxLagl = length / 2 == math.round(length / 2) ? length / 2 : (length - 1) / 2
zxEMADatal = srcl + srcl - srcl[zxLagl]
ZLEMAl = ta.ema(zxEMADatal, length)
ZLEMAl
ZLEMAl = Zlema_Funcl(srcl, length)
Tsf_Funcl(srcl, length) =>
lrcl = ta.linreg(srcl, length, 0)
lrc1l = ta.linreg(srcl, length, 1)
lrsl = lrcl - lrc1l
TSFl = ta.linreg(srcl, length, 0) + lrsl
TSFl
TSFl = Tsf_Funcl(srcl, length)
HMAl = ta.wma(2 * ta.wma(srcl, length / 2) - ta.wma(srcl, length), math.round(math.sqrt(length)))
getMA(src, length) =>
ma = 0.0
if mav == 'SMA'
ma := ta.sma(src, length)
ma
if mav == 'EMA'
ma := ta.ema(src, length)
ma
if mav == 'WMA'
ma := ta.wma(src, length)
ma
if mav == 'DEMA'
ma := DEMA
ma
if mav == 'TMA'
ma := ta.sma(ta.sma(src, math.ceil(length / 2)), math.floor(length / 2) + 1)
ma
if mav == 'VAR'
ma := VAR
ma
if mav == 'WWMA'
ma := WWMA
ma
if mav == 'ZLEMA'
ma := ZLEMA
ma
if mav == 'TSF'
ma := TSF
ma
if mav == 'HULL'
ma := HMA
ma
ma
getMAl(srcl, length) =>
mal = 0.0
if mav == 'SMA'
mal := ta.sma(srcl, length)
mal
if mav == 'EMA'
mal := ta.ema(srcl, length)
mal
if mav == 'WMA'
mal := ta.wma(srcl, length)
mal
if mav == 'DEMA'
mal := DEMAl
mal
if mav == 'TMA'
mal := ta.sma(ta.sma(srcl, math.ceil(length / 2)), math.floor(length / 2) + 1)
mal
if mav == 'VAR'
mal := VARl
mal
if mav == 'WWMA'
mal := WWMAl
mal
if mav == 'ZLEMA'
mal := ZLEMAl
mal
if mav == 'TSF'
mal := TSFl
mal
if mav == 'HULL'
mal := HMAl
mal
mal
MAvg = getMA(src, length)
fark = MAvg * percent * 0.01
longStop = MAvg - fark
longStopPrev = nz(longStop[1], longStop)
longStop := MAvg > longStopPrev ? math.max(longStop, longStopPrev) : longStop
shortStop = MAvg + fark
shortStopPrev = nz(shortStop[1], shortStop)
shortStop := MAvg < shortStopPrev ? math.min(shortStop, shortStopPrev) : shortStop
dir = 1
dir := nz(dir[1], dir)
dir := dir == -1 and MAvg > shortStopPrev ? 1 : dir == 1 and MAvg < longStopPrev ? -1 : dir
MT = dir == 1 ? longStop : shortStop
HOTT = MAvg > MT ? MT * (200 + percent) / 200 : MT * (200 - percent) / 200
HOTTC = color.blue
MAvgl = getMAl(srcl, length)
farkl = MAvgl * percent * 0.01
longStopl = MAvgl - farkl
longStopPrevl = nz(longStopl[1], longStopl)
longStopl := MAvgl > longStopPrevl ? math.max(longStopl, longStopPrevl) : longStopl
shortStopl = MAvgl + farkl
shortStopPrevl = nz(shortStopl[1], shortStopl)
shortStopl := MAvgl < shortStopPrevl ? math.min(shortStopl, shortStopPrevl) : shortStopl
dirl = 1
dirl := nz(dirl[1], dirl)
dirl := dirl == -1 and MAvgl > shortStopPrevl ? 1 : dirl == 1 and MAvgl < longStopPrevl ? -1 : dirl
MTl = dirl == 1 ? longStopl : shortStopl
LOTT = MAvgl > MTl ? MTl * (200 + percent) / 200 : MTl * (200 - percent) / 200
LOTTC = color.red
HOTTLine = plot(nz(HOTT[2]), title='HOTT', color=color.new(HOTTC, 0), linewidth=2, style=plot.style_line)
LOTTLine = plot(nz(LOTT[2]), title='LOTT', color=color.new(LOTTC, 0), linewidth=2, style=plot.style_line)
FillColor = highlighting ? color.new(#9915FF, 80) : na
fill(HOTTLine, LOTTLine, title='Highligter', color=FillColor)
color1 = close > HOTT[2] ? #00FFFF : close < LOTT[2] ? #FF00FF : na
barcolor(color1)
alertcondition(ta.crossover(close, HOTT[2]), title='Price Crossover Alarm', message='PRICE OVER HOTT - BUY SIGNAL!')
alertcondition(ta.crossunder(close, LOTT[2]), title='Price Crossunder Alarm', message='PRICE UNDER LOTT - SELL SIGNAL!')
트레이딩뷰 지표입니다.
이미지처럼 두 선으로 만들어졌는데
예스로 가능할까요?
두 선만 나오게 해주세요.
2023-05-29
1399
글번호 169351
답변완료
전화상담 및 친절한 수식감사합니다.
전화상담 및 친절한 수식감사합니다.
친절한 수식덕분에 예스트레이더에서 저를 어렵게하던 부분이
해결되었습니다.
전화상담으로 예스스팟을 알려주시고
자바스크립터도 공부하게 해주시고
덕분에 예스스팟메뉴얼 usb에 담아 프린트 링제본해서
3번 완독 하고 2번 예제 실습하니
이제 어느정도 이해가 되네요
// 전역변수선언
var exit;
var PL //종합손익 확인위한 전역변수선언
var Position;
var Snum;
var Bnum;
var BuyFill;
var SellFill;
//스팟 시작
function Main_OnStart()
{
Main.SetTimer(1, 10000);
//SetTimer(nEventID,nElapse) nElapsesms 타이머 반복주기로 1000==1초
exit = false;
}
function Main_OnTimer(nEventID)
//타잉머의 ID, OnTimer이벤트 발생시 자동생성되는 다른 OnTimer이벤트와 구분하기 위한 ID를 생성하여 리턴
{
if (nEventID == 1)
{
if (exit == false)
{
//손익계산
//SetBalanceItem(sItemCode, nPosition)
//sItemCode :종목코드,단축코드 nPosition 0:구분없음 1:매도 2:매수
//MarketData1 종목 잔고셋팅
Account1.SetBalanceItem(Cd1.code, 0);
//잔고정보 변수에 저장
var vol1 = Account1.Balance.count; //수량
var pos1 = Account1.Balance.position; //포지션방향(매도1, 매수2)
var PL1 = Account1.Balance.profit; //손익
Main.MessageList("종목1",vol1,pos1,PL1);
//MarketData2 종목 잔고셋팅
Account1.SetBalanceItem(Ad2.code, 0);
//잔고정보 변수에 저장
var vol2 = Account1.Balance.count; //수량
var pos2 = Account1.Balance.position; //포지션방향(매도1, 매수2)
var PL2 = Account1.Balance.profit; //손익
Main.MessageList("종목2",vol2,pos2,PL2);
//합산손익이 1000불이상이면
PL = PL1 + PL2;
Main.MessageList("종합손익",PL);
//테스트 완료----------------------------------------------------------
if (PL >= 1000)
{
Exit = true;
//종목1이 매도포지션이면
if (pos1 == 1)
{
//전량 시장가로 매수주문(청산)
Account1.OrderBuy(Cd1.code,vo11, 0, 1);
//주문가격 0, 시장가 주문이므로(1)
}
//종목1이 매수포지션이면
if (pos1 == 2)
{
//전량 시장가로 매도주문(청산)
Account1.OrderSell(Ad2.code,vo11, 0, 1);
}
//종목2가 매도포지션이면
if (pos2 == 1)
{
//전량 시장가로 매수주문(청산)
Account1.OrderBuy(Ad2.code,vo12, 0, 1);
}
//종목2가 매수포지션이면
if (pos2 == 2)
{
//전량 시가로 매도주문(청산)
Account1.OrderSell((Ad2.code,vo12, 0, 1);
}
}
}
}
//체결통보이벤트 발생 후 체결여부 확인하고 체결될떼까지 미체결주문 누적 없도록
기존주문취소하고 일정타임이후 재주문 -----------------------------------
function Main_OnNotifyFill(NotifyFill)
{
if (Position == 1 && NotifyFill == Bnum)
//매수신호발생시(Bnum) 주문번호와 주문시 저장된 주문번호(NotifyFill)가 같으면 주문체결
{
BuyFill = 1;
//주문체결되면 BuyFill 변수에 1을 저장
}
if (Position == -1 && NotifyFill == Snum)
{
SellFill = 1;
}
}
}
체결여부 확인하고 일정시간 이후 시장가로 재주문을 넣어야 하는데
일단 두종목 이 모두 미체결 또는 한종목만 체결 또는 모두 미체결 확인하고
동시에 일정시간 후 시장가로 재주문하는 것 코딩이
한종목이면 할 수 있을 것 같은데 두종목에 조건도 3가지니 논리상 감이 잘 안오네요
참고할 수 있는 수식 부탁드립니다.
바쁘신데 죄송하고 감사합니다.
2023-05-28
1001
글번호 169350
카르마다 님에 의해서 삭제되었습니다.
2023-05-27
38
글번호 169349
답변완료
문의
항생10시15분기준으로 거래대금을 나타내는 표현부탁드립니다
2023-05-27
562
글번호 169348
답변완료
변수저장 유지
안녕하세요 특정시간의 open 가격을 변수에 저장하려는데 도움 부탁드립니다.
if sTime == 113000 Then
sg = Open;
else sg = sg[1];
2023-05-27
602
글번호 169347
회원 님에 의해서 삭제되었습니다.
2023-05-27
75
글번호 169346
회원 님에 의해서 삭제되었습니다.
2023-05-27
75
글번호 169345
답변완료
문의드립니다
종목검색식과 2가지시스템식 부탁드립니다
종목검색식 : 현재 rsi가 30이하이고 주가가 볼린저밴드 하한선 이하이며
가장 가까운 과거에 볼린저밴드 하한선을 돌파한 시점의 주가보다 현재 주가가 큰 종목을 찾는 검색식
시스템식1 : 현재 rsi가 30이하이고 시가가 볼린저밴드 하한선 이하이며
가장 가까운 과거에 볼린저밴드 하한선을 돌파한 시점의 종가보다 현재 시가가 클때 시가에 매수 , 1%이상상승시 매도
시스템식2 : 현재 rsi가 30이하이고 시가가 볼린저밴드 하한선 이하이며
가장 가까운 과거에 볼린저밴드 하한선을 돌파한 시점의 종가보다 현재 시가가 클때 시가에 매수 , 1%이상상승시 매도, 만약 장종료까지 1%이상 상승을 하지 않았을경우 다음봉 시가에 매도
2023-05-27
782
글번호 169344
답변완료
수식 부탁드립니다
수고 하십니다.
거래량이 5일 거래량이평의 2배이고
거래대금이 50억 이상이고
현재가가 시가대비 5% 이상 상승한 경우의
강조식 부탁합니다.
수고 하세요..
2023-05-27
745
글번호 169343