커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5420
글번호 230811
답변완료
연달아 부탁드려 죄송합니다~ 수정 부탁드립니다^^;;
밑에 붙여넣은 내용은 기존 질문했던 내용과 관리자님이 도움주신 내용 복사해서 붙여넣었습니다.
전략을 적용해보니 손절 익절을 0.5p 씩 했음에도 불구하고 최대수익이 2.89p 최대손실이
-2.17 이렇게 나오는대요. 아마도 0시가 넘은경우에 저렇게 되는듯 싶기도하고 익일로
오버되는 경우도 있어서 저런 수익 및 손실이 나오는거같기도 합니다.
수정 부탁드리는 부분은..
특정진입시간대를 2개 box로 나누고 싶은대 변수로도 조정가능하게끔 하고싶습니다.
가령 12시~18시(1box:변수에서 조정가능토록)에 1번,
22시~익일04시에(2box:변수에서 조정가능토록) 1번 진입하도록 하고싶습니다.
진입횟수 변수를 1로 조정하면 1box에서만 나오는것이 맞는것이지요?
그리고 1번째 진입이던 2번째 진입이던 포지션 집입중이면 반대신호 조건이 충족되더라
도 신호가 나오지않고 손절청산 및 익절청산으로 포지션 정리를 하고싶습니다.
(1box시간대에 매수신호가 나와 매수포지션이면 1box시간대에 반대신호 조건이 충족되어도
신호가 무시되어 익절 및 손절 가격 도달할때까지 포지션 유지. 포지션 유지상태로 2box
시간대에 까지 간다하면 2box 시간대에도 조건충족으로 나오는 신호는 나오지않게하고 기
존 포지션 유지. 만약 익절 및 손절폭까지 안온다면 05시40분 당일청산)
감사합니다~ 건강하시고 편한밤 되세요~!!
-------------------------------------------------------------------------------
안녕하세요
예스스탁입니다.
input : StartTime(120000),EndTime(180000);
input : P1(5),P2(20);
input : 진입횟수(2),익절(0.5),손절(0.5);
var : Tcond(false),entry(0);
if (sdate != sdate[1] and stime >= StartTime) or
(sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then
{
Tcond = true;
entry = 0;
}
if (sdate != sdate[1] and stime >= EndTime) or
(sdate == sdate[1] and stime >= EndTime and stime[1] < EndTime) Then
Tcond = False;
var1 = ma(C,P1);
var2 = ma(C,P2);
if Tcond == true then
{
if MarketPosition == 0 and MarketPosition != MarketPosition[1] Then
entry = entry+1;
if entry < 진입횟수 then
{
if MarketPosition == 0 and crossup(var1,var2) Then
buy("b");
if MarketPosition == 0 and CrossDown(var1,var2) Then
sell("s");
}
SetStopProfittarget(익절,PointStop);
SetStopLoss(손절,PointStop);
}
Else
{
SetStopProfittarget(0);#해제
SetStopLoss(0);#해제
}
즐거운 하루되세요
> 머어얼 님이 쓴 글입니다.
> 제목 : 수고 많으십니다 매번 번거롭게 해드려 죄송합니다~ 수식 부탁좀 드립니다~
> 해외선물에 적용할 전략이고, 주가이동평균5일선이 주가이동평균20일선을 상향 돌파하면
매수 / 하향 돌파하면 매도하는 수식인대요~ 손절 0.5p / 익절 0.5p
단, 변수로 조정 가능하게끔 하려고 하는것은 1일 1회 혹은 2회 진입 / 특정시간대에만
진입하게끔 조정하고 싶습니다 (예: 오후12시부터 오후 6시사이에 주가이동평균선이 상향
및 하향 돌파하면 매수 및 매도 1회 진입, 오후 11시부터 익일 오전3시사이에 주가이동평
균선이 상향 돌파하면 매수 및 하향돌파하면 매도 1회진입.
단, 진입신호에 따라 매수던 매도던 포지션 진입상황에서는 반대조건이 충족하더라도
신호가 나오는게 아니라 그 포지션을 유지하고 한번 진입하면
0.5p손절이던 0.5p익절로 마무리하려고 합니다.
매번 도움주셔서 감사합니다~ 수식 부탁 드립니다~ 건강하시고 수고하세요~!!
2020-03-17
261
글번호 136939
답변완료
조건별 매수진입 문의
안녕하세요.. 시스템식 작성 문의드립니다.
혼자서 작성하다가 문제가 너무 안풀려서 이렇게 문의드립니다.
제가 원하는 진입식은..
30봉 최고점과 최저점의 차이가 200틱 이하인 경우 5선 돌파시 매도
30봉 최고점과 최저점의 차이가 200틱 이상인 경우 10선 돌파시 매도
이렇게 시스템 진입식을 만들고 싶습니다
그림도 함께 첨부합니다.
2020-03-16
231
글번호 136938
답변완료
부탁드립니다
지표전환 부탁드립니다
RSI_Period = input(6, title='RSI Length')
SF = input(5, title='RSI Smoothing')
QQE = input(3, title='Fast QQE Factor')
ThreshHold = input(3, title="Thresh-hold")
//
src = input(close, title="RSI Source")
//
//
Wilders_Period = RSI_Period * 2 - 1
Rsi = rsi(src, RSI_Period)
RsiMa = ema(Rsi, SF)
AtrRsi = abs(RsiMa[1] - RsiMa)
MaAtrRsi = ema(AtrRsi, Wilders_Period)
dar = ema(MaAtrRsi, Wilders_Period) * QQE
longband = 0.0
shortband = 0.0
trend = 0
DeltaFastAtrRsi = dar
RSIndex = RsiMa
newshortband = RSIndex + DeltaFastAtrRsi
newlongband = RSIndex - DeltaFastAtrRsi
longband := RSIndex[1] > longband[1] and RSIndex > longband[1] ?
max(longband[1], newlongband) : newlongband
shortband := RSIndex[1] < shortband[1] and RSIndex < shortband[1] ?
min(shortband[1], newshortband) : newshortband
cross_1 = cross(longband[1], RSIndex)
trend := cross(RSIndex, shortband[1]) ? 1 : cross_1 ? -1 : nz(trend[1], 1)
FastAtrRsiTL = trend == 1 ? longband : shortband
////////////////////
length = input(50, minval=1, title="Bollinger Length")
mult = input(0.35, minval=0.001, maxval=5, step=0.1, title="BB Multiplier")
basis = sma(FastAtrRsiTL - 50, length)
dev = mult * stdev(FastAtrRsiTL - 50, length)
upper = basis + dev
lower = basis - dev
color_bar = RsiMa - 50 > upper ? #00c3ff : RsiMa - 50 < lower ? #ff0062 : color.gray
//
// Zero cross
QQEzlong = 0
QQEzlong := nz(QQEzlong[1])
QQEzshort = 0
QQEzshort := nz(QQEzshort[1])
QQEzlong := RSIndex >= 50 ? QQEzlong + 1 : 0
QQEzshort := RSIndex < 50 ? QQEzshort + 1 : 0
//
Zero = hline(0, color=color.white, linestyle=hline.style_dotted, linewidth=1)
////////////////////////////////////////////////////////////////
RSI_Period2 = input(6, title='RSI Length')
SF2 = input(5, title='RSI Smoothing')
QQE2 = input(1.61, title='Fast QQE2 Factor')
ThreshHold2 = input(3, title="Thresh-hold")
src2 = input(close, title="RSI Source")
//
//
Wilders_Period2 = RSI_Period2 * 2 - 1
Rsi2 = rsi(src2, RSI_Period2)
RsiMa2 = ema(Rsi2, SF2)
AtrRsi2 = abs(RsiMa2[1] - RsiMa2)
MaAtrRsi2 = ema(AtrRsi2, Wilders_Period2)
dar2 = ema(MaAtrRsi2, Wilders_Period2) * QQE2
longband2 = 0.0
shortband2 = 0.0
trend2 = 0
DeltaFastAtrRsi2 = dar2
RSIndex2 = RsiMa2
newshortband2 = RSIndex2 + DeltaFastAtrRsi2
newlongband2 = RSIndex2 - DeltaFastAtrRsi2
longband2 := RSIndex2[1] > longband2[1] and RSIndex2 > longband2[1] ?
max(longband2[1], newlongband2) : newlongband2
shortband2 := RSIndex2[1] < shortband2[1] and RSIndex2 < shortband2[1] ?
min(shortband2[1], newshortband2) : newshortband2
cross_2 = cross(longband2[1], RSIndex2)
trend2 := cross(RSIndex2, shortband2[1]) ? 1 : cross_2 ? -1 : nz(trend2[1], 1)
FastAtrRsi2TL = trend2 == 1 ? longband2 : shortband2
//
// Zero cross
QQE2zlong = 0
QQE2zlong := nz(QQE2zlong[1])
QQE2zshort = 0
QQE2zshort := nz(QQE2zshort[1])
QQE2zlong := RSIndex2 >= 50 ? QQE2zlong + 1 : 0
QQE2zshort := RSIndex2 < 50 ? QQE2zshort + 1 : 0
//
hcolor2 = RsiMa2 - 50 > ThreshHold2 ? color.silver :
RsiMa2 - 50 < 0 - ThreshHold2 ? color.silver : na
plot(FastAtrRsi2TL - 50, title='QQE Line', color=color.white, transp=0, linewidth=2)
plot(RsiMa2 - 50, color=hcolor2, transp=50, title='Histo2', style=plot.style_columns)
Greenbar1 = RsiMa2 - 50 > ThreshHold2
Greenbar2 = RsiMa - 50 > upper
Redbar1 = RsiMa2 - 50 < 0 - ThreshHold2
Redbar2 = RsiMa - 50 < lower
plot(Greenbar1 and Greenbar2 == 1 ? RsiMa2 - 50 : na, title="QQE Up", style=plot.style_columns, color=#00c3ff, transp=0)
plot(Redbar1 and Redbar2 == 1 ? RsiMa2 - 50 : na, title="QQE Down", style=plot.style_columns, color=#ff0062, transp=0)
2020-03-16
483
글번호 136937
답변완료
지표전환 부탁
다음 지표를 예스로 전환부탁드립니다
TKlength=input(9, "Tenkansen Length", minval=1)
KJlength=input(26, "Kijunsen Length", minval=1)
CSHSlength=input(26, "Chikouspan Length/Horizontal Shift", minval=1)
SBlength=input(52, "SenkouspanB Length", minval=1)
SAlength=input(26,"SenkouspanA Length", minval=1)
TK=avg(lowest(TKlength), highest(TKlength))
KJ=avg(lowest(KJlength), highest(KJlength))
CS=close
SB=avg(lowest(SBlength), highest(SBlength))
SA=avg(TK,KJ)
plot(TK, linewidth=2, color=blue, title="TenkanSen")
plot(KJ, linewidth=2, color=red, title="KijunSen")
plot(CS, offset=-CSHSlength, linewidth=2, color=#DDA0DD, title="ChikouSpan")
SenkouA=plot(SA, offset=CSHSlength, linewidth=1, color=green, title="SenkouSpanA")
SenkouB=plot(SB, offset=CSHSlength, linewidth=1, color=purple, title="SenkouSpanB")
fill(SenkouA, SenkouB, color = SA > SB ? green : red)
2020-03-16
379
글번호 136936
요타 님에 의해서 삭제되었습니다.
2020-03-16
13
글번호 136935
답변완료
부탁 드립니다.
도움에 깊이 감사 드립니다.
어제 66514번의 답변 수식에 만족합니다.
질문1)
수식의 끝부분쪽에
v61을 계산치 아니하고
var51=(var5+var15)/2; 을 계산 하고자 한다면
즉 ma(var51,sig);를 계산한다면
타분형 수식의
끝부분을 어떻게 하여야 하는지요?
질문2)
일봉 지표를 분봉에 나타 나도록 부탁 드립니다.
미리 감사 드립니다.
input:p(20),sig(3);;
var1=iff(c>o,c,0);
var2=iff(c>o,1,0);
var3=AccumN(var1,p);
var4=accumn(var2,p);
var5=iff(var1==0 or var2==0 ,c[p-1],var1/var2);
var11=iff(c<o,c,0);
var12=iff(c<o,1,0);
var13=AccumN(var11,p);
var14=accumn(var12,p);
var15=iff(var11==0 or var12==0 ,c[p-1],var11/var12);
var51=(var5+var15)/2;
타분형 수식)
input : ntime(10),P(20),sig(3);
var : S1(0),D1(0),TM(0),TF(0),cnt(0);
var : sum1(0),i1(0),sum2(0),i2(0),sum3(0);
Array : C1[100](0),O1[100](0),v61[100](0);
if Bdate != Bdate[1] Then
{
S1 = TimeToMinutes(stime);
D1 = sdate;
}
if D1 > 0 then
{
if sdate == D1 Then
TM = TimeToMinutes(stime)-S1;
Else
TM = TimeToMinutes(stime)+1440-S1;
TF = TM%ntime;
if Bdate != Bdate[1] or
(Bdate == Bdate[1] and ntime > 1 and TF < TF[1]) or
(Bdate == Bdate[1] and ntime > 1 and TM >= TM[1]+ntime) or
(Bdate == Bdate[1] and ntime == 1 and TM > TM[1]) Then
{
O1[0] = O;
for cnt = 1 to 49
{
C1[cnt] = C1[cnt-1][1];
O1[cnt] = O1[cnt-1][1];
v61[cnt] = v61[cnt-1][1];
}
}
C1[0] = C;
if O1[P] > 0 then
{
sum1 = 0;
i1 = 0;
sum2 = 0;
i2 = 0;
for cnt = 0 to P
{
if C1[cnt] > O1[cnt] Then
{
sum1 = sum1+C1[cnt];
i1 = i1+1;
}
if C1[cnt] < O1[cnt] Then
{
sum2 = sum2+C1[cnt];
i2 = i2+1;
}
}
if i1 == 0 Then
var5 = C1[P-1];
Else
var5 = sum1/i1;
if i2 == 0 Then
var15 = C1[P-1];
Else
var15 = sum2/i2;
var51 = (var5+var15)/2;
v61[0] = C-var51;
sum3 = 0;
for cnt = 0 to P
{
sum3 = sum3 + v61[cnt];
}
var71 = sum3/sig;
plot1(var71);
}
}
2020-03-17
378
글번호 136934
yes 님에 의해서 삭제되었습니다.
2020-03-16
0
글번호 136933
답변완료
문의 드립니다.
안녕하세요 항상 수고가 많으십니다.
다름이 아니오라...
일목균형표 지표를 넣으면 구금대가 캔들 앞으로 나오고 캔들이 뒤로 나오는데...
캔들과 구금대가 같이 나오게 만들수 있는지요...
구금대만 나오게 하고 싶습니다.
도움이 될까 하여 키움 수식 올려 드립니다
수식4
A=(highest(high,shortPeriod)+lowest(low,shortPeriod)+highest(high,midPeriod)+lowest(low,midPeriod))/4;
A(K)
수식5
B=(highest(high,longPeriod)+lowest(low,longPeriod))/2;
B(K)
지표설정
shortPeriod 9
midPeriod 26
longPeriod 52
K 0
감사합니다.
2020-03-16
384
글번호 136930
답변완료
지표수식전환
다음 지표를 예스수식으로 전환부탁드립니다.
//
nPeriod = input(20)
factor1 = input(0.1)
factor2 = input(0.2)
//
Cn=close
Ln=close
Hn=close
RSV=0.0
percentK=0.0
percentD= 0.0
percentJ=0.0
//
for k=0 to nPeriod-1
if Ln>low[k]
Ln:=low[k]
if Hn<high[k]
Hn:=high[k]
if Hn-Ln !=0
RSV :=(Cn-Ln)/(Hn-Ln)*100
else
RSV := 50
percentK := factor1 * 50 + factor2 * RSV
percentD := factor1 * 50 + factor2 * percentK
percentJ := 3 * percentD - 2 * percentK
//
plot(percentK, title='PERCENT-K', color=#ff0000, linewidth=1, style=plot.style_line, transp=0)
plot(percentD, title='PERCENT-D', color=#0064ff, linewidth=1, style=plot.style_line, transp=0)
plot(percentJ, title='PERCENT-J', color=#00ff00, linewidth=1, style=plot.style_line, transp=0)
2020-03-16
412
글번호 136927