커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4397
글번호 230811
답변완료
부탁드립니다.
1. 60분챠트에서 현재일 01시봉의 고점과 저점이 전일 01시 봉의 고점과 저점과 연결된 추세선으로 구현되도록 부탁드립니다. 그러면서 전일과 전전일, 전전일과 전전전일까지 계속 01시봉의 고점과 저점이 3일동안 연결된 추세선을 구현해 주세요, 고맙습니다.
2018-06-11
181
글번호 119670
잡다백수 님에 의해서 삭제되었습니다.
2018-06-11
0
글번호 119669
답변완료
문의드립니다
1.
아래 2개 지표를 합쳐서 한 지표 수식으로 부탁드립니다
input : P14(14),P3(3);
var1 = (DIPLUS(P14)-DIMINUS(P14)) / (DIPLUS(P14)+DIMINUS(P14));
var2 = ema(var1,P3);
plot1(var1);
plot2(var2);
PlotBaseLine1(0.5);
PlotBaseLine2(-0.5);
input : Period(14);
var : ADXv(0),DP(0),DM(0);
ADXv = ADX(Period);
DP = DiPlus(Period);
DM = DiMinus(Period);
if ADXv > ADXv[1] Then
plot1(ADXv,"ADX",RED);
Else
plot1(ADXv,"ADX",BLUE);
plot2(DP,"+DI");
plot3(DM,"-DI");
PlotBaseLine1(10, "기준선 10");
PlotBaseLine2(40, "기준선 40");
2.
아래지표하고 RSI 지표를 한지표로 부탁드립니다
input : Period(14);
var : ADXv(0),DP(0),DM(0);
ADXv = ADX(Period);
DP = DiPlus(Period);
DM = DiMinus(Period);
if ADXv > ADXv[1] Then
plot1(ADXv,"ADX",RED);
Else
plot1(ADXv,"ADX",BLUE);
plot2(DP,"+DI");
plot3(DM,"-DI");
PlotBaseLine1(10, "기준선 10");
PlotBaseLine2(40, "기준선 40");
2018-06-11
192
글번호 119667
답변완료
식문의드립니다.(
안녕하세요, 아래식 작성해주셔서 감사합니다.
제가 문의드린거랑 다른부분이 있어 수정부탁드리고자 다시 문의드립니다.
1. 청산부분
청산도 비율로 부탁드립니다.
청산시 옵션이 하나 더 붙는데
가령 청산값을 0.7로 하고 손절을 0.3으로 했을시
진행되는 가격값이 0.4에 다았을때
청산값을 0.6으로 조정되도록 부탁드립니다.
2.
매입 수량설정 부탁드립니다.
3.
다음날 고점이 갱신되면 저점은 그대로고 완성봉의 고점에서 비율에 대한 값을
재조정합니다.
감사합니다
--------------------------------------------------
안녕하세요
예스스탁입니다.
input : ndate(20180601),ntime(90000),고점(100),저점(90),rate(0.652),매매구분(1),청산값(100);
var : Tcond(false),HH(0),LL(0);
if sdate == ndate and stime == ntime Then
{
Tcond = true;
hh = 고점;
ll = 저점;
}
if Tcond == true then
{
if H > hh Then
hh = h;
if l < ll Then
ll = l;
var1 = hh-(hh-LL)*rate;
if 매매구분 == 1 and H < var1 and stime < 144000 Then
buy("b",AtStop,var1);
if 매매구분 == -1 and H < var1 and stime < 144000 Then
sell("s",AtLimit,var1);
}
if MarketPosition == 1 Then
ExitLong("bx",atlimit,청산값);
if MarketPosition == -1 Then
ExitShort("sx",atlimit,청산값);
SetStopEndofday(151500);
즐거운 하루되세요
> 스누피독 님이 쓴 글입니다.
> 제목 : 식 문의드립니다
> 안녕하세요, 식부탁드립니다.
.제가 지정한 일자와 시간(분봉기준), 지정한 값에
피보나치조정대 0(고점)과 1(저점)을 설정하고
설정한 0과1 안에 진입설정값을 잡아 진입,청산을 합니다.
고점을 설정한 날보다 앞으로 진행되는 날들에서(지나온 시간에서의 고점은 무시)
높은 값이 나오면 완성봉의 고점을 0(고점)으로 갱신하여 인식하고 1은
그대로 유지하여 조정대 값을 변경설정합니다.
.진입은 설정 값(예 0.652)에 진입하고 14시40분 이전에만 진입합니다
(설정한 선 값에 가까운 윗 한호가 가격값으로 진입,
진입수량, 매수.매도설정, 진입은 시장가진입)
설정한 값보다 아래에서 값이 시작할시 진입하되
위 설정된 조정대값의 간격을 그대로 유지하여
진입한 시작한 값이 진입설정값이 되도록 부탁드립니다.
.청산은 설정값에 진입하되
조건으로로 설정한 선값에 가격봉이 닫고 청산값으로 향할시 다른 설정값을 정하여 청산한다
손절값은 따로 설정합니다.
(설정한 선값에 가까운 윗호가 가격값으로 진입,
진입한 수량 전량청산, 시장가)
청산은 당일 15시15분에 무조건 전량청산합니다
청산,손절이되면 재진입(진입에서 설정한 수량을 다 매수하지못하여도) 하지않습니다.
위 식 부탁드립니다.
2018-06-11
173
글번호 119665
답변완료
시간대 표시수식
특정 시간대만 차트에서 표기를 하고 싶습니다. 세로라인이든 바탕화면의 색이든..
예들 들어 09:00~15:00 구간을 강조하는 표시(화살표나.. 문자..)정도.. 가능한지요?
2018-06-11
237
글번호 119664
2wnwn 님에 의해서 삭제되었습니다.
2018-06-12
29
글번호 119642
답변완료
즉시 진입 가능?
1.신호 발생시 즉시 진입 가능한가요?
제가 알기론 봉이 완성되어야 진입이 되는걸로 아는데요
청산에서 편법으로 직전봉의 지표와 비교하면 즉시 청산이 가능하다고 하셨는데
진입도 편법이 있나요?
2. 현재가가 20일 신고가 돌파시 매수진입
5이평 20이평 데드크로스 매수청산
시스템식 부탁 드립니다.
2018-06-11
150
글번호 119638
답변완료
문의드립니다
매번 성의있는 답변 정말 고맙습니다 ^^
1, 지난 5월 24일자 "57927번" 질문에대한 답변내용에 대한 수정질문 드립니다
답변대로 설정하니 잘 작동이됩니다만 행사가 가 10개다보니 너무 빈번한 음성신호에
좀 헷갈리네요
(1), 그래서 이 행사가를 총6개(콜풋 각3개씩)로 수정된 수식 부탁드립니다
(2), 그리고 매일매일 바뀌는 가격에따라 행사가의 일부를 변경하게되는데..
변경후 교차지점이 아닌데도 음성신호가 계속 나오네요
뭔가 제가 설정상 문제가 있는건지?
혹은 행사가를 바꾸면 다른 무언가도 같이 설정을 변경해야하는건지 모르겠네요
2, 그리고 아래 58142번 문의에대한 답변 내용중에서...
<data1,data2,data3이 콜
data4,data5,data6이 풋으로 설정되었다고 보고 작성해 드립니다.
설정하신 데이터 번호와 다르면 해당 번호에 맞게 수정하셔야 합니다>
라고 하셨는데...
(1) 여기서 data1 은 "기본차트" 인 "콜"을 뜻하는것인가요?
감사합니다 ^^
2018-06-11
171
글번호 119636
답변완료
지표수정
아래지표에서
점과 선이 그려지는데.
빨강점이 찍히면 빨강점에서 파란점이 찍힐때까지
찍히고 파란점이 찍히면 빨강이 나올때까지 각 봉마다 찍히게 부탁 드립니다.
Input:chRate(1); //전환율 또는 변동률
Var:j(0),upTr(100),dnTr(-100),upRate(0),dnRate(0),trnd(0),TL(0),
date11(0),date12(0),time11(0),time12(0),TL1(0),
date21(0),date22(0),time21(0),time22(0),TL2(0),
date31(0),date32(0),time31(0),time32(0),TL3(0);
Array:hiVal[10](0),loVal[10](0),hiBar[10](0),loBar[10](0);
//hiVal[1]은 전고점, hiVal[2]는 전전고점, hiVal[3]은 전전전고점
//hiVal[0]은 변곡점 이후 현재봉까지의 고점. 현재 고점은 진행중이므로 계속 바뀐다.
//loVal[0]은 반대 개념
var : TL13(0),TL14(0),color(0),Tx1(0),Tx2(0),tx3(0),tx4(0);
upRate = 1 + (chRate/100); //상승률
dnRate = 1 - (chRate/100); //하락률
for j = 1 to 9 { //전고,전저점을 9개까지 보관
loBar[j] = loBar[j] + 1; //전저점의 위치. 현재 봉으로부터 떨어져 있는 거리
hiBar[j] = hiBar[j] + 1; //전고점의 위치
}
if hiVal[0] <= H or hiVal[0] == 0 then { //전고,전저점 이후 현재까지의 고점
hiVal[0] = H; //0을 체크한 이유는 초기에 값이 없는 구간이 생기기 때문
hiBar[0] = 0; //현재 고점의 위치가 0이란 것은 현재봉의 고가가 구간 고점이라는 의미
}
else {
hiBar[0] = hiBar[0] + 1; //현재 고점의 위치
}
if loVal[0] >= L or loVal[0] == 0 then { //전고,전저점 이후 현재까지 저점
loVal[0] = L;
loBar[0] = 0;
}
else {
loBar[0] = loBar[0] + 1; //현재 구간 저점의 위치
}
if trnd != dnTr && hiVal[0] > H && hiVal[0] * dnRate > L then trnd = dnTr;
//저가가 고가 대비 변동률보다 밑으로 떨어지면 하락추세로 설정
//단, 현재봉의 고가가 변곡점 이후 최고가이면 상승 추세가 진행중이라고 본다.
//그래서 현재봉의 고가가 hiVal[0]보다 작다는 조건이 추가되었다.
else if trnd != upTr && loVal[0] < L && loVal[0] * upRate < H then trnd = upTr;
//고가가 저가 대비 변동률보다 높으면 상승추세로 설정
if trnd[1] == upTr and trnd == dnTr then { //상승추세였다가 하락추세로 바뀌었다면
for j = 8 downto 1 { //새로운 전고점이 생기는 것이므로
hiVal[j+1] = hiVal[j]; //전고점을 하나씩 뒤로 보낸다.
hiBar[j+1] = hiBar[j]; //전고점은 전전고점이 되고, 전전고점은 전전전고점이 된다.
}
hiVal[1] = hiVal[0]; //새로운 전고점에 현재 고점을 대입
hiBar[1] = hiBar[0];
hiVal[0] = H; //전고점이 확정되었으므로 전고점 이후 최고가는 현재봉의 고가
hiBar[0] = 0;
loVal[0] = L;
loBar[0] = 0;
//전고점이 새로 생긴 것이니까 전저점에서 전고점까지 추세선을 긋는다.
date11 = date[loBar[1]]; //추세선 시작일. 전저점의 날짜
time11 = stime[loBar[1]]; //추세선 시작시간
Value11 = loVal[1]; //추세선 시작가격
date12 = date[hiBar[1]]; //추세선 종료일. 전고점의 날짜
time12 = stime[hiBar[1]]; //추세선 종료시간
Value12 = hiVal[1]; //추세선 종료가격
//TL1 = TL_New(date11,time11,Value11,date12,time12,Value12);
//TL_New는 신규 추세선을 그려주는 함수
}
if trnd[1] == dnTr and trnd == dnTr and //추세는 하락 상태에서 바뀌지 않았는데
hiVal[1] < hiVal[0] and //전고점보다 더 높은 고점이 출현했다면
hiVal[0] * dnRate > L then {
hiVal[1] = hiVal[0]; //전고점을 현재의 고점으로 바꿔준다.
hiBar[1] = hiBar[0];
hiVal[0] = H;
hiBar[0] = 0;
loVal[0] = L;
loBar[0] = 0;
//전고점이 추가된 게 아니고 바뀐 것이므로 종료일,종료시간,종료가격만 바꿔준다.
date12 = date[hiBar[1]]; //추세선 종료일
time12 = stime[hiBar[1]];
Value12 = hiVal[1];
TL_SetEnd(TL1, date12,time12,Value12);
//TL_SetEnd는 기존추세선의 종료지점을 변경해주는 추세선 함수이다.
//TL_Delete 함수를 써서 직전의 추세선을 지우고 다시 TL_New로 추세선을 추가해도 된다.
}
if trnd[1] == dnTr and trnd == upTr then { //추세가 하락에서 상승으로 바뀌었을 경우
for j = 8 downto 1 {
//이전저점은 전전저점으로, 전전저점은 전전전저점으로 번호를 부여
loVal[j+1] = loVal[j];
loBar[j+1] = loBar[j];
}
loVal[1] = loVal[0];
loBar[1] = loBar[0];
loVal[0] = L;
loBar[0] = 0;
hiVal[0] = H;
hiBar[0] = 0;
date11 = date[hiBar[1]]; //전저점이 새로이 생긴 것이므로 시작점은 전고점이 된다.
time11 = stime[hiBar[1]];
Value11 = hiVal[1];
date12 = date[loBar[1]];
time12 = stime[loBar[1]];
Value12 = loVal[1];
//TL1 = TL_New(date11,time11,Value11,date12,time12,Value12);
}
if trnd[1] == upTr and trnd == upTr and //추세는 상승을 유지하고 있는데
loVal[1] > loVal[0] and //전저점보다 낮은 저가가 출현했다면
loVal[0] * upRate < H then {
loVal[1] = loVal[0]; //직전의 전저점만 바꿔준다.
loBar[1] = loBar[0];
loVal[0] = L;
loBar[0] = 0;
hiVal[0] = H;
hiBar[0] = 0;
date12 = date[loBar[1]];
time12 = stime[loBar[1]];
Value12 = loVal[1];
TL_SetEnd(TL1, date12,time12,Value12);
}
if trnd == upTr and loVal[2] > loVal[1] then{
TL_SetColor(TL1,BLUE);
color = blue;
}
else if trnd == dnTr and hiVal[2] < hiVal[1] then{
TL_SetColor(TL1,RED);
color = RED;
}
else{
TL_SetColor(TL1,BLACK);
color = BLACK;
}
TL_SetSize(TL1,2);
TL_SetColor(TL2,RED);
TL_SetColor(TL3,BLUE);
if var1 <= 0 and Trnd == uptr and Trnd != Trnd[1] Then{
var1 = 1;
value1 = loval[1];
TX1 = Text_New(sdate[lobar[1]],stime[lobar[1]],value1-PriceScale*2,"●");
TL_SetColor(TL,RED);
TL_SetSize(TL,2);
Text_SetStyle(TX1,2,2);
Text_SetColor(TX1,RED);#텍스트 색상
TX2= Text_New(sdate[lobar[1]],stime[lobar[1]],L,"상승");
Text_SetColor(TX2,RED);#텍스트 색상
TL13 = TL_New(date11,time11,Value11,date12,time12,Value11);
TL14 = TL_New(date12,time12,Value11,date12,time12,Value12);
TL_SetColor(TL13,color);
TL_SetColor(TL14,color);
}
if var1 >= 0 and Trnd == dntr and Trnd != Trnd[1] then{
var1 = -1;
value1 = hival[1];
TX3 = Text_New(sdate[hibar[1]],stime[hibar[1]],value1+PriceScale*2,"●");
TL_SetColor(TL,BLUE);
TL_SetSize(TL,2);
Text_SetStyle(TX3,2,2);#텍스트 좌우 상하 정렬
Text_SetColor(TX3,BLUE);#텍스트 색상
TX4= Text_New(sdate[hibar[1]],stime[hibar[1]],H,"하락");
Text_SetColor(TX4,BLUE);#텍스트 색상
TL13 = TL_New(date11,time11,Value11,date12,time12,Value11);
TL14 = TL_New(date12,time12,Value11,date12,time12,Value12);
TL_SetColor(TL13,color);
TL_SetColor(TL14,color);
}
2018-06-11
202
글번호 119635