커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3418
글번호 230811
답변완료
문의 드립니다.
안녕하세요
항상 빠른 답변 감사드립니다.
당일 한번만 진입하는 시스템에서
진입시점 이전의 최저가를 스탑로스값으로 설정하고자 합니다.
가령 13시에 매수 진입하였다면
13시 이전에 daylow 값을 스탑로스값으로 자동 설정하고 싶습니다.
매수진입가격 50% 청산
매수진입 이전 최저가 나머지 청산
위와 같은 식을 요청 드립니다.
그럼 좋은 하루 되세요^^
2020-04-12
650
글번호 137844
답변완료
감사합니다
1,시스템식
crossup(cci(기간),기준값)
기간 20
기준값 -100.00
cci 과매도이탈 1차매수
crossup(cci(기간),기준값)
기간 20
기준값 0.00
cci 기준값 상향돌파 2차매수
위 두가지 조건으로 시스템 부탁드립니다
2 종목검색
위 시스템 식으로 당일 1차매수 2차매수 신호가 발생하는
종목만 일봉에서 종목검색식 부탁드립니다
2020-04-12
699
글번호 137843
답변완료
타주기지수이평
매번 성실한 답변에 감사드립니다.
(일봉==>분봉)
아래 타주기 이평 지표식를 타주기 지수이평 지표식으로 변경 부탁드립니다.
감사합니다.
input : P(20);
var : sumV(0), maV(0), count(0);
if date !=date[1] Then{
var11=mav[1];
}
sumV = 0;
for count = 0 to P-1 {
sumV = sumV+DayClose(count);
}
maV = sumV / P;
2020-04-12
726
글번호 137842
답변완료
매수청산 수식 부탁드려요
국내 주식 분할매수 후 아래와 같이 "개별청산매매수"변수에 의해 해당 수량보다 낮으면
SetStopProfittarget(청산률,PercentStop); 로 개별 청산하고
해당 수량보다 높으면 ExitLong("누적분 일청",atlimit,AvgEntryPrice*(1+(일괄청산률)/100)); 의 수식으로 평균값의 일정수익시 전량 청산으로 활용하고 있는데요
if MaxEntries <= 개별청산매매수 Then
SetStopProfittarget(청산률,PercentStop);
Else
{
SetStopProfittarget(0);
ExitLong("누적분 일청",atlimit,AvgEntryPrice*(1+(일괄청산률)/100));
}
다음과 같이 매수 청산하는 수식 부탁드리겠습니다.
1. 분할매수한 수량이 25개 이하시 매수한 평균값의 10% 도달시 일괄 청산
2. 분할매수한 수량이 25개-50개일때 매수한 평균값의 5% 도달시 보유수량의 50% 청산
3. 분할매수한 수량이 50-100개일때 매수한 평균값이 3% 도달시 부유수량의 50% 청산
4. 분할매수하 수량이 100-200일때 매수한 평균값이 2% 도달시 보유수량의 50% 청산
하는 식으로 구현가능할까요?
2020-04-12
784
글번호 137841
답변완료
시스템 수식전환시 부탁드립니다
<1>다음 지표에서 red가 그려질때 매수, blue가 그려지면 매도
input : length(20),mult(2);
var : atr_(0),max1(0),min1(0),max_(0),min_(0),is_uptrend_prev(false),is_uptrend(false);
var : stops(0),vstop_prev(0),vstop1(0),vstop(0),is_trend_changed(false);
atr_ = atr(length);
max1 = max(max_, close);
min1 = min(min_, close);
is_uptrend_prev = is_uptrend[1];
stops = iff(is_uptrend_prev,max1 - mult * atr_ , min1 + mult * atr_);
vstop_prev = vstop[1];
vstop1 = iff(is_uptrend_prev , max(vstop_prev, stops) , min(vstop_prev, stops));
is_uptrend = close - vstop1 >= 0;
is_trend_changed = is_uptrend != is_uptrend_prev;
max_ = iff(is_trend_changed , close , max1);
min_ = iff(is_trend_changed , close , min1);
vstop = iff(is_trend_changed ,iff(is_uptrend, max_ - mult * atr_ , min_ + mult * atr_),vstop1);
plot1(vstop,"vstop",iff(is_uptrend ,red , BLUE));
<2> 빨간선일때 매수 파란선에 매도
input : length(20),mult(2);
var : atr_(0),max1(0),min1(0),max_(0),min_(0),is_uptrend_prev(false),is_uptrend(false);
var : stops(0),vstop_prev(0),vstop1(0),vstop(0),is_trend_changed(false);
atr_ = atr(length);
max1 = max(max_, close);
min1 = min(min_, close);
is_uptrend_prev = is_uptrend[1];
stops = iff(is_uptrend_prev,max1 - mult * atr_ , min1 + mult * atr_);
vstop_prev = vstop[1];
vstop1 = iff(is_uptrend_prev , max(vstop_prev, stops) , min(vstop_prev, stops));
is_uptrend = close - vstop1 >= 0;
is_trend_changed = is_uptrend != is_uptrend_prev;
max_ = iff(is_trend_changed , close , max1);
min_ = iff(is_trend_changed , close , min1);
vstop = iff(is_trend_changed ,iff(is_uptrend, max_ - mult * atr_ , min_ + mult * atr_),vstop1);
plot1(vstop,"vstop",iff(is_uptrend ,red , BLUE));
<3>ema가 MA 상향돌파 매수, 반대일때 매도
input : MediaMovel(21),MediaMovelExponencial(9),MediaObv(50);
var : src(0),obv(0),mav(0),emav(0),obvma(0);
src = c;
mav = ma(src,MediaMovel);
emav = ema(src,MediaMovelExponencial);
obvma = ma(obv,MediaObv);
2020-04-12
762
글번호 137840
답변완료
시스템 수식전환
다음 내용(지표)를 시스템 수식으로 전환부탁드립니다.
<1>일목균형표에서 양운이거나 전환선이 기준선을 상승 돌파할때 매수, 음운이거나 전환선이 기준선을 하락돌파할 때 매도
<2>일목균형표에서 양운인 상태에서 전환선이 기준선을 상승 돌파할때 매수, 음운인 상태에서 전환선이 기준선을 하락돌파할 때 매도
<3>일목균형표에서 전환선이 기준선을 상승 돌파한 상태에서 양운일때 매수, 전환선이 하락돌파한 상태에서 음운일때 매도
<4>일목균형표에서 양운이거나 기준선이 전환선을 상승 돌파할때 매수(손절 기준선), 음운이거나 기준선이 전환선을 하락돌파할 때 매도(손절 기준선)
<5>일목균형표에서 양운인 상태에서 기준선이 전환선을 상승 돌파할때 매수(손절 기준선), 음운인 상태에서 기준선이 전환선을 하락돌파할 때 매도(손절 기준선)
<6>일목균형표에서 기준선이 전환선을 상승 돌파한 상태에서 양운일때 매수(손절 기준선), 기준선이 전환선을 하락돌파한 상태에서 음운일때 매도(손절 기준선)
<7>일목균형표에서 양운이거나 기준선이 전환선을 상승 돌파할때 매수(손절 전환선), 음운이거나 기준선이 전환선을 하락돌파할 때 매도(손절 전환선)
<8>일목균형표에서 양운인 상태에서 기준선이 전환선을 상승 돌파할때 매수(손절 전환선), 음운인 상태에서 기준선이 전환선을 하락돌파할 때 매도(손절 전환선)
<9>일목균형표에서 기준선이 전환선을 상승 돌파한 상태에서 양운일때 매수(손절 전환선), 기준선이 전환선을 하락돌파한 상태에서 음운일때 매도(손절 전환선)
2020-04-12
808
글번호 137839
답변완료
부탁드립니다.
안녕하세요.
다음지표식을 검색식으로 부탁드립니다.
}
최종꼭지점 = "저점";
}
var1 = iff(최종꼭지점 == "고점",1,iff(최종꼭지점 == "저점",-1,0));
if var1 = -1 Then{
PLOT1(저[2,1]);
PLOT2(고[1,1]);
}
Else{
PLOT1(저[1,1]);
PLOT2(고[2,1]);
}
}
plot3(LRLV);
1.고점[2]> 고점[1]에서 고점[1] < 고점 이고 저점 위에 있을때 검색식
부탁드립니다.
2020-04-12
657
글번호 137838
답변완료
국내 주식 수식 수정 요청드림니다.
아래 수식으로 분할 매수-청산 운영하고 있습니다.
참고로: 국내 주식 / ETF 포함
분봉 운용
12개의 분할 조건에 의해 분할 매수 진입버전입니다.
청산은 매매횟수에 따라 150회 이하는 각각 개별 수익 청산
150회 이상 매수시에는 특정 수익시 일괄매도로 설계했는데요 다음과 같이 바꾸고 싶어요
반영 부탁드리겠습니다.
기존에 매매 횟수별로 구분하는 청산을 다음과 같이 매매구분을 횟수와 상관없이 다음과 같이
매수 조건 홀수별로 1.3.5.7.9,11로 매수된 수량은 개별 수익청산 SetStopProfittarget(청산률,PercentStop);
매수 조건 짝수별로 2.4.6.8.10,12로 매수된 수량은 평균수익률 도달시 일괄청산 으로
ExitLong("누적분 일청",atlimit,AvgEntryPrice*(1+(일괄청산률)/100));
해주시면 감사하겠습니다.
ps 혹시 위부분이 구현되기 어렵다면 매매횟수별로 홀수-개별 수익청산 짝수매매-평균수익시 일곽청산으로는 가능할까요??
어떤것으로 해도 상관없습니다만 수식이 간편한것으로 해주시면 감사하겠습니다.
==================================================================================
input : n(20),하락퍼센트(1);
input : p(20),MFI값(100);
input : 매매수(200),금액1(20),금액2(20),금액3(20),금액4(20),금액5(25);
input : 금액6(30),금액7(35),금액8(40),금액9(45),금액10(50);
input : 금액11(60),금액12(70);
input : 전일대비하락률(1),청산률(10),일괄청산률(9),개별청산매매수(165);
var1 = highest(H,n);
var2 = mfi(P);
if stime < 140000 then
{
# 1번 매수 조건
if MaxEntries < 매매수 and
c < var1*하락퍼센트 and
var2 < MFI값 and
c < o and
c <= c[1]*(100-전일대비하락률)/100 Then
buy("b1",OnClose,def,Floor(금액1*10000/c));
# 2번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.01) and
var2 < (MFI값-1) and
c < o and
c <= c[1]*(99.8-전일대비하락률)/100 Then
buy("b2",OnClose,def,Floor(금액2*10000/c));
# 3번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.02) and
var2 < (MFI값-3) and
c < o and
c <= c[1]*(99.6-전일대비하락률)/100 Then
buy("b3",OnClose,def,Floor(금액3*10000/c));
# 4번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.03) and
var2 < (MFI값-5) and
c < o and
c <= c[1]*(99.4-전일대비하락률)/100 Then
buy("b4",OnClose,def,Floor(금액4*10000/c));
# 5번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.04) and
var2 < (MFI값-7) and
c < o and
c <= c[1]*(99.2-전일대비하락률)/100 Then
buy("b5",OnClose,def,Floor(금액5*10000/c));
# 6번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.05) and
var2 < (MFI값-9) and
c < o and
c <= c[1]*(99-전일대비하락률)/100 Then
buy("b6",OnClose,def,Floor(금액6*10000/c));
# 7번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.06) and
var2 < (MFI값-11) and
c < o and
c <= c[1]*(98.8-전일대비하락률)/100 Then
buy("b7",OnClose,def,Floor(금액7*10000/c));
# 8번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.07) and
var2 < (MFI값-13) and
c < o and
c <= c[1]*(98.6-전일대비하락률)/100 Then
buy("b8",OnClose,def,Floor(금액8*10000/c));
# 9번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.08) and
var2 < (MFI값-15) and
c < o and
c <= c[1]*(98.4-전일대비하락률)/100 Then
buy("b9",OnClose,def,Floor(금액9*10000/c));
# 10번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.09) and
var2 < (MFI값-17) and
c < o and
c <= c[1]*(98.2-전일대비하락률)/100 Then
buy("b10",OnClose,def,Floor(금액10*10000/c));
# 11번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.1) and
var2 < (MFI값-19) and
c < o and
c <= c[1]*(98-전일대비하락률)/100 Then
buy("b11",OnClose,def,Floor(금액10*10000/c));
# 12번 매수 조건
if MaxEntries < 매매수 and
c < var1*(하락퍼센트-0.11) and
var2 < (MFI값-21) and
c < o and
c <= c[1]*(97.8-전일대비하락률)/100 Then
buy("b12",OnClose,def,Floor(금액10*10000/c));
if MaxEntries <= 개별청산매매수 Then
SetStopProfittarget(청산률,PercentStop);
Else
{
SetStopProfittarget(0);
ExitLong("누적분 일청",atlimit,AvgEntryPrice*(1+(일괄청산률)/100));
}
}
Else
SetStopProfittarget(0);
2020-04-12
661
글번호 137837
답변완료
지표 수식 문의드립니다.
첫번째 5분봉의 고가 라인 그리기
아마 그려지면 직선으로 그려져야 하는데 어떻게 하는지 부탁드립니다.
2020-04-12
662
글번호 137836