커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3443
글번호 230811
답변완료
시스템 수식문의
항상감사 드립니다.
수식작성 부탁드립니다.
1. 장 운영 시간 : 09:30~15:00/15:40 모든 잔고 청산/ 손실 150,000원 강제청산
2. 기본조건 : 일목균형지표 선행스팬1, 2는 shift안함
Inputs: TurnLen(9), StdLen(26), PrdLen(52);
var : 기준선(0), 전환선(0), 선행스팬1(0), 선행스팬2(0);
전환선 = (Highest(High, TurnLen) + Lowest(Low, TurnLen)) / 2;
기준선 = (Highest(High, StdLen) + Lowest(Low, StdLen)) / 2;
선행스팬1 = (전환선+기준선)/2;
선행스팬2 = (highest(H, PrdLen)+lowest(L, PrdLen))/2;
Plot4(선행스팬1, "선행스팬1");
Plot5(선행스팬2, "선행스팬2");
3 매수 진입 조건
3-1 진입 조건
- 주가 20일선 상승 추세
- 주가 > 20일선
- 선행스팬1 > 선행스팬2
- RSI 50이상
- 주가가 선행스팬 2 상향 돌파
3-2 청산조건
- 선행스팬1 하향돌파
4. 매도 진입 조건
4-1 진입 조건
- 주가 20일선 하락 추세
- 주가 < 20일선
- 선행스팬1 < 선행스팬2
- RSI 50이하
- 주가가 선행스팬 1 하향 돌파
4-2 청산조건
- 선행스팬2 상향돌파
* 이동평균선 과 RSI값은 변경 가능하도록 작성부탁드립니다
2023-12-18
882
글번호 174973
답변완료
시스템식 부탁드립니다.
> 진입조건:
조건1: 매수가 먼저든, 매도가 먼저든 1번만 적용.
조건2: 21시 이후에 발생한 조건일 것.
매수1 : 시가대비 +200틱(stop),3계약
매도1 : 시가대비 -200틱(stop),3계약
손절: 200틱(일괄청산)
익절1 : 300틱(1계약)
익절2: 400틱(1계약)
익절3: 500틱(1계약)
매수든, 매도든 1일 1회만 진입하고 싶습니다.
부탁드리겠습니다.
2023-12-18
905
글번호 174972
답변완료
수식 변환 부탁드립니다.
변환 가능한 수식이면 지표식 부탁드리고요.
아래 시스템식에도 ema 대신 이것으로 적용시켜 수정해 주시면 감사하겠습니다.
1. 변환할 지표식
study(title="T3 Averages", shorttitle="T3", overlay = true)
Length = input(5, minval=1)
xPrice = close
xe1 = ema(xPrice, Length)
xe2 = ema(xe1, Length)
xe3 = ema(xe2, Length)
xe4 = ema(xe3, Length)
xe5 = ema(xe4, Length)
xe6 = ema(xe5, Length)
b = 0.7
c1 = -b*b*b
c2 = 3*b*b+3*b*b*b
c3 = -6*b*b-3*b-3*b*b*b
c4 = 1+3*b+b*b*b+3*b*b
nT3Average = c1 * xe6 + c2 * xe5 + c3 * xe4 + c4 * xe3
plot(nT3Average, color=lime, title="T3")
========================================================================
2. 시스템식
input : keyvalue(5),P(100);
input : atrperiod(10);
var : src(0),xatr(0),nloss(0),xATRTrailingStop(0),pos(0),xcolor(0);
var : Emav(0);
src = close;
xATR = atr(atrperiod);
nLoss = keyvalue * xATR;
xATRTrailingStop = 0.0;
xATRTrailingStop = iff(src > iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]) and src[1] > iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]), max(iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]), src - nLoss),
iff(src < iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]) and src[1] < iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]), min(iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]), src + nLoss),
iff(src > iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]), src - nLoss, src + nLoss)));
pos = 0;
pos = iff(src[1] < iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]) and src > iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]), 1,
iff(src[1] > iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]) and src < iff(IsNan(xATRTrailingStop[1]) == true, 0,xATRTrailingStop[1]), -1, iff(IsNan(pos[1])==true, 0,pos[1])));
xcolor = iff(pos == -1 , red , iff(pos == 1 , green ,blue));
Condition1 = CrossUp(src,xATRTrailingStop);
Condition2 = CrossDown(src,xATRTrailingStop);
Emav = Ema(C,P);
if Condition1 == true Then
{
if C > Emav Then
Buy();
Else
ExitShort("SX");
}
if Condition2 == true Then
{
if C < Emav Then
Sell("Sell");
Else
ExitLong("BX");
}
2023-12-18
918
글번호 174971
파워 님에 의해서 삭제되었습니다.
2023-12-18
6
글번호 174970
답변완료
지표 질문입니다
종가 파라볼릭에서
파라볼릭 음 전환 때 파라볼릭 천정은 A
파라볼릭 음 전환 때 음전환 시킨 캔들 저가 B
C=B-(A-B)
파라볼릭 양 전환 때 파라볼릭 바닥은 D
파라볼릭 양 전환 때 양 전환 시킨 캔들 고가 E
F=E+(E-D)
파라볼릭 음 전환 때 C-(F-C) 를 그린다
파라볼릭 양 전환 때 F+(F-C) 를 그린다
감사합니다
2023-12-18
957
글번호 174969
답변완료
전환비율 data2
Input:전환비율(6);
Var : j(0,Data2),jj(0,Data2),HH(0,Data2),LL(0,Data2),hiBar(0,Data2),loBar(0,Data2),최종꼭지점("",Data2),처리구분("",Data2);
var : TL1(0,Data2),Box(0,Data2);
var : cond1(False,Data2),cond2(False,Data2);
Array:고[10,4](0,Data2),저[10,4](0,Data2);
HH=data2(H);
LL=data2(L);
If data2(Index==0) Then
{
고[1,1]=HH;
고[1,2]=0;
고[1,3]=data2(sDate);
고[1,4]=data2(sTime);
저[1,1]=LL;
저[1,2]=0;
저[1,3]=data2(sDate);
저[1,4]=data2(sTime);
}
If data2(Index>0) Then
{
hiBar=hiBar+1;
loBar=loBar+1;
}
If HH[hiBar]<HH Then hiBar=0;
If LL[loBar]>LL Then loBar=0;
cond1=저[1,1]*(1+(전환비율/100))<HH and hiBar==0;
cond2=고[1,1]*(1-(전환비율/100))>LL and loBar==0;
처리구분="";
If cond1 and cond2 Then//고점과저점조건동시만족
{
If 최종꼭지점=="저점" Then
{
If 저[1,1]>LL Then 처리구분="저점처리";
Else 처리구분="고점처리";
}
Else If 최종꼭지점=="고점" Then
{
If 고[1,1]<HH Then 처리구분="고점처리";
Else 처리구분="저점처리";
}
}
Else If cond1 Then 처리구분="고점처리";
Else If cond2 Then 처리구분="저점처리";
If 처리구분=="고점처리" Then
{
If 최종꼭지점=="저점" Then
{
For j=10 DownTo 2
{
For jj=1 To 4
{
고[j,jj]=고[j-1,jj];
}
}
고[1,1]=HH[hiBar];
고[1,2]=data2(Index)-hiBar;
고[1,3]=data2(sDate[hiBar]);
고[1,4]=data2(sTime[hiBar]);
hiBar=-1;
loBar=-1;
TL1=TL_New_Self(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
TL_SetSize(TL1,1);
TL_SetColor(TL1,RED);
Box_Delete(Box);
box=box_New_self(저[1,3],저[1,4],저[1,1],Data2(NextBarSdate),Data2(NextBarStime),고[1,1]);
box_SetColor(Box,RED);
Box_SetFill(Box,true);
}
Else If 고[1,1]<HH[hiBar] Then//1번고점보다높은고가출현
{
고[1,1]=HH[hiBar];
고[1,2]=data2(Index)-hiBar;
고[1,3]=data2(sDate[hiBar]);
고[1,4]=data2(sTime[hiBar]);
hiBar=-1;
loBar=-1;
TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]);
Box_SetEnd(Box,고[1,3],고[1,4],고[1,1]);
}
최종꼭지점="고점";
Plot1(고[1,1]);
NoPlot(2);
}
If 처리구분=="저점처리" Then
{
If 최종꼭지점=="고점" Then
{
For j=10 DownTo 2
{
For jj=1 To 4
{
저[j,jj]=저[j-1,jj];
}
}
저[1,1]=LL[loBar];
저[1,2]=data2(Index)-loBar;
저[1,3]=data2(sDate[loBar]);
저[1,4]=data2(sTime[loBar]);
hiBar=-1;
loBar=-1;
TL1=TL_New_Self(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
TL_SetSize(TL1,1);
TL_SetColor(TL1,BLUE);
Box_Delete(Box);
box=box_New_self(저[1,3],저[1,4],저[1,1],Data2(NextBarSdate),Data2(NextBarStime),고[1,1]);
box_SetColor(Box,Blue);
Box_SetFill(Box,true);
}
Else If 저[1,1]>LL[loBar] Then
{
저[1,1]=LL[loBar];
저[1,2]=data2(Index)-loBar;
저[1,3]=data2(sDate[loBar]);
저[1,4]=data2(sTime[loBar]);
hiBar=-1;
loBar=-1;
TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]);
Box_SetEnd(Box,저[1,3],저[1,4],저[1,1]);
}
최종꼭지점="저점";
Plot2(저[1,1]);
NoPlot(1);
}
박스 생성이 안되기도하고, 박스 크기도 일부 작고, 삭제도 몇군데 안됩니다.
오류 부분에서는 추세선도 이상합니다. 하락박스의 시작점에서 저를 고로 바꾸니 약간 수정되나 비슷합니다. 오류 수정 부탁드립니다.
2023-12-19
1108
글번호 174968
답변완료
문의 드립니다.
20이평 120이평 정배열이고 주가가 20이평을 아래서 위로 돌파하는 경우와
주가가 20이평 위에 있을 때 음봉에서 양봉 발생 시 매수
청산은 음봉 발생할 때 매도 청산 완료
20이평 120이평 역배열이고 주가가 20이평을 위에서 아래로 돌파하는 경우와
주가가 20이평 아래 있을 때 양봉에서 음봉 발생 시 매도
청산은 양봉 발생할 때 매수 청산 완료
부탁드립니다.
2023-12-18
783
글번호 174966
철판때기 님에 의해서 삭제되었습니다.
2023-12-18
59
글번호 174946
답변완료
수식 요청
input : Price(31850),진입횟수(1);
var : entry(0);
if Bdate != Bdate[1] Then
entry = 0;
if (MarketPosition != 0 and MarketPosition != MarketPosition[1]) or
(MarketPosition == MarketPosition[1] and TotalTrades > TotalTrades[1]) Then
entry = entry+1;
if NextBarSdate == sDate and
NextBarStime >= 91500 and
H < price and
entry < 진입횟수 Then
Buy("b",AtStop,price);
9시 15분 이후에 지정한 가격(위 식에서는 31,850원)보다 현재가가 높더라도 // 가령 9시 20분에 현재가가 지정한 가격(31,850원)을 하회하여 31,800원이 되었다가 다시 31,850원을 돌파하는 시점에도 매수가 이뤄질 수 있도록 위 수식에 추가를 요청드립니다. 노고에 감사드립니다.
2023-12-18
1167
글번호 174944