커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4521
글번호 230811
답변완료
수식문의
MACD오실레이터의 0기준선을 종가에 붙여서
차트캔들에 저런식으로 적용하고싶습니다.
오실레이터 빨강파랑다위로하고 종가까지 채우기를 이용해서 보기쉽게 나타게 하고싶어요
2.
var1 = ma(c,20);
if var1 > var1[1] Then
value1 = var1;
if var1 > value1 Then
value1 = var1;
if var1 < var1[1] Then
value2 = var1;
if var1 < value2 Then
value2 = var2;
plot1(value1);
plot2(value2);
이수식에서 점선을 사용하는데 수평일땐 다른색이 나타나도록 적용하고 싶어요
2016-10-04
210
글번호 102429
렉쳐 님에 의해서 삭제되었습니다.
2016-10-03
0
글번호 102428
회원 님에 의해서 삭제되었습니다.
2016-10-03
0
글번호 102427
답변완료
지표
안녕하세요
1.
감마. 델타. 로. 셀카. 내재변동성
합계5개 에서.
상승교차 매수. 하락교차 매도. 식과
2.그리고 지표식. 부탁해요
2016-10-03
113
글번호 102426
답변완료
주식매매 시스템 수식부탁합니다.
안녕하십니까. 수식부탁좀 하려고 글 남깁니다. 2가지 전략 만들려고 합니다.
30분봉에서 일목균형표 TurnLen(0), StdLen(120), PrdLen(0) 이렇게 설정해놓은 차트에서
# 첫번째 전략
1. 기준선에 주가가 닿으면 매수진입
2. 만약 주가가 기준선에 닿기 전에 기준선에 3%이내 근접하여 3%이상 반등하였을때는 매수
하지 않음
# 두번째 전략
1. 기준선위로 +6%가격에 주가가 닿으면 매수진입
2. 만약 주가가 기준선위 +6%에 주가가 오지 않고 3%이내 근접하여 3%이상 반등하였을때는
매수하지 않음
감사합니다!^^
2016-10-02
112
글번호 102425
답변완료
수식문의
늘 감사
아래의 수식을 data2에서 쓸 수 있도록 변환해 주세요
if date != date[4] then{
var1 = 0;
var2 = 0;
}
if v > var1 then{
var1 = v;
var2 = var2+1;
var3 = h;
var4 = l;
}
else
var1 = var1;
plot1(var3);
plot2(var4);
if date != date[4] then{
var1 = 0;
var2 = 0;
}
if v > var1 then{
var1 = v;
var2 = var2+1;
var3 = h;
var4 = l;
}
else
var1 = var1;
if dayindex() ==0 then{
var5 = var3[4];
var6 = var4[4];
}
plot11(var5);
plot12(var6);
감사합니다
2016-10-02
114
글번호 102424
답변완료
시스템신호 2번째 신호부터 매매시작 검증
항상 감사드립니다
아래의 조건을 시스템식에 적용코자하는데 오류가 발생합니다
수정부탁드립니다
하나의 시스템에서 시간을 분할하여
17:00~익일03:00 까지는 첫번째신호는 무시하고 두번째신호부터 매매(신호시작시간17:00)
익일03:00~익일 14:30까지의 시간에서는 첫번째신호 매매(신호시작시간 03:00)
전체시간 17:00~익일 14:30 중에 밣생하는 매수매도식은 중복발생금지...
************************************************************
#############################################################
##### 1_매매식_A_17:00 ~ 03:00_ 2번째신호부터 매매 #####
#############################################################
if (stime >= 170000 or stime < 030000) Then{
# 현지시간_뉴욕 17:00 장시작~익일 03:00 #
### 동일방향 재진입금지/전일 마지막신호와 무관하게 진입 ###
var :entrycnt(0) ,T(0),count(0);
if stime == 170000 or (stime > 170000 and stime[1] < 170000) Then
Entrycnt = 0;
T = 0;
count = 0;
if MarketPosition != 0 and MarketPosition != MarketPosition[1] Then
Entrycnt = Entrycnt+1;
/******************************************************************************/
#매수조건이면 T는 1, 카운트 1증가
if T <= 0 and c>o and c>var77 and C>var51 and stok>stod and (xx+yy)>=-0 and c>var90 and c>var60 and c>피봇1차지지 then {
T = 1;
count = count+1;
#카운트가 2 이상이고 나머지 포지션 조건 만족할때 진입
if count >= 2 and ((entrycnt == 0) or (entrycnt >= 1 and MarketPosition == 0 and MarketPosition(1) != 1) or (MarketPosition == -1)) Then #동일방향 재진입금지#
BUY("B1_윗꼬리_51");
}
#매도조건이면 T는 -1, 카운트 1증가
if T >= 0 and c<o and c<var77 and c<var51 and stok<stod and (xx+yy)<=0 and c<var90 and c<var60 and c<피봇1차저항 Then{
T = -1;
count = count+1;
#카운트가 2 이상이고 나미저 포지션 조건 만족할때 진입
if count >= 2 and ((entrycnt == 0) or (entrycnt >= 1 and MarketPosition == 0 and MarketPosition(1) != -1) or (MarketPosition == 1)) then #동일방향 재진입금지#
sell("S1_윗꼬리_51");
}
}
#############################################################
##### 2_매매식_B_03:00 ~ 14:30_ 1번째신호부터 매매 #####
#############################################################
if (stime >= 030000 and stime < 143000) Then{
### 동일방향 재진입금지/전일 마지막신호와 무관하게 진입 ###
var : T2(0),count2(0);
if stime == 030000 or (stime > 030000 and stime[1] < 030000) Then
T2 = 0;
count2 = 0;
/***************************************************************/
#매수조건이면 T는 1, 카운트 1증가
if T2 <= 0 and c>o and c>var77 and C>var51 and stok>stod and (xx+yy)>=-0 and c>var90 and c>var60 and c>피봇1차지지 then {
T2 = 1;
count2 = count2+1;
#카운트가 2 이상이고 나머지 포지션 조건 만족할때 진입
if count2 >= 1 and ((entrycnt == 0) or (entrycnt >= 1 and MarketPosition == 0 and MarketPosition(1) != 1) or (MarketPosition == -1)) Then #동일방향 재진입금지#
BUY("BB1_윗꼬리_51");
}
#매도조건이면 T는 -1, 카운트 1증가
if T2 >= 0 and c<o and c<var77 and c<var51 and stok<stod and (xx+yy)<=0 and c<var90 and c<var60 and c<피봇1차저항 Then{
T2 = -1;
count2 = count2+1;
#카운트가 2 이상이고 나미저 포지션 조건 만족할때 진입
if count2 >= 1 and ((entrycnt == 0) or (entrycnt >= 1 and MarketPosition == 0 and MarketPosition(1) != -1) or (MarketPosition == 1)) then #동일방향 재진입금지#
sell("SS1_윗꼬리_51");
}
}
###################
##### 청산식 #####
###################
if MarketPosition == 1 and highest(H,BarsSinceEntry) >= EntryPrice+PriceScale*30 and (xx+yy)<=4 and (xx+yy)>0 and c<rsi70 Then
exitlong("eB_macd_sar");
if MarketPosition == -1 and lowest(L,BarsSinceEntry) <= EntryPrice-PriceScale*30 and (xx+yy)>=-4 and (xx+yy)<0 and c>rsi30 Then
exitshort("eS_macd_sar");
감사합니다
2016-10-02
122
글번호 102423
답변완료
수식부탁드립니다=======================
선물지수차트 대신 생성된 valuee 에 아래 파동지표를 적용하고 싶은데
valuee 에는 시가 고가 저가 없으니 종가만 사용해야 하네요
엄두가 안나네요
수식부탁 드림니다
// valuee 생성 ---------------------------------------
Input : Periodd(5);
var : AsksMA(0),BidsMA(0);
BidsMa = ma(bids,Periodd);
AsksMA = ma(asks,Periodd);
Var : valuee(0);
valuee = ma(bids,periodd)-ma(asks,periodd)+8000;
Plot44(BidsMA, "매수잔량이평");
Plot55(AsksMA, "매도잔량이평");
Plot66(valuee, "차");
// valuee 생성 ---------------------------------------
// 파동지표만들기 ---------------------------------------
Input:전환율(0.5),선두께(4),선색(green); //전환율 또는 변동률
Var:j(0),upTr(100),dnTr(-100),upRate(0),dnRate(0),trnd(0),
date11(0),date12(0),time11(0),time12(0),TL1(0),
date21(0),date22(0),time21(0),time22(0),TL2(0);
Array:hiVal[2](0),loVal[2](0),hiBar[2](0),loBar[2](0);
upRate = 1 + (전환율/100); //상승률
dnRate = 1 - (전환율/100); //하락률
loBar[1] = loBar[1] + 1; //전저점의 위치. 현재 봉으로부터 떨어져 있는 거리
hiBar[1] = hiBar[1] + 1; //전고점의 위치
if DayIndex == 0 then {
if trnd == upTr then {
date11 = date[loBar[1]]; //추세선 시작일
time11 = stime[loBar[1]]; //추세선 시작시간
Value11 = loVal[1]; //추세선 시작가격
}
else {
date11 = date[hiBar[1]]; //추세선 시작일
time11 = stime[hiBar[1]]; //추세선 시작시간
Value11 = hiVal[1]; //추세선 시작가격
}
date12 = date[1]; //추세선 종료일
time12 = stime[1]; //추세선 종료시간
Value12 = C[1]; //추세선 종료가격
TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); //TL_New는 신규 추세선을 그려주는 함수
TL_SetSize(TL1,선두께);
TL_SetColor(TL1,선색);
hiVal[1] = O;
hiBar[1] = 0;
loVal[1] = O;
loBar[1] = 0;
hiVal[0] = C;
hiBar[0] = 0;
loVal[0] = C;
loBar[0] = 0;
trnd = 0;
if hiVal[1] * dnRate > C then trnd = dnTr;
else if loVal[1] * upRate < C then trnd = upTr;
}
if hiVal[0] <= C then {
hiVal[0] = C;
hiBar[0] = 0;
}
else {
hiBar[0] = hiBar[0] + 1;
}
if loVal[0] >= C then {
loVal[0] = C;
loBar[0] = 0;
}
else {
loBar[0] = loBar[0] + 1;
}
if trnd != dnTr && hiVal[0] * dnRate > C then trnd = dnTr;
else if trnd != upTr && loVal[0] * upRate < C then trnd = upTr;
if trnd[1] != dnTr and trnd == dnTr then { //상승추세였다가 하락추세로 바뀌었다면
hiVal[1] = hiVal[0]; //새로운 전고점에 현재 고점을 대입
hiBar[1] = hiBar[0];
hiVal[0] = C; //전고점이 확정되었으므로 전고점 이후 최고가는 현재봉의 고가
hiBar[0] = 0;
loVal[0] = C;
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 > C then {
hiVal[1] = hiVal[0]; //전고점을 현재의 고점으로 바꿔준다.
hiBar[1] = hiBar[0];
hiVal[0] = C;
hiBar[0] = 0;
loVal[0] = C;
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] != upTr and trnd == upTr then { //추세가 하락에서 상승으로 바뀌었을 경우
loVal[1] = loVal[0];
loBar[1] = loBar[0];
loVal[0] = C;
loBar[0] = 0;
hiVal[0] = C;
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 < C then {
loVal[1] = loVal[0]; //직전의 전저점만 바꿔준다.
loBar[1] = loBar[0];
loVal[0] = C;
loBar[0] = 0;
hiVal[0] = C;
hiBar[0] = 0;
date12 = date[loBar[1]];
time12 = stime[loBar[1]];
Value12 = loVal[1];
TL_SetEnd(TL1, date12,time12,Value12);
}
TL_SetSize(TL1,선두께);
TL_SetColor(TL1,선색);
if trnd == upTr then {
date21 = date[loBar[1]]; //추세선 시작일
time21 = stime[loBar[1]]; //추세선 시작시간
Value21 = loVal[1]; //추세선 시작가격
}
else {
date21 = date[hiBar[1]]; //추세선 시작일
time21 = stime[hiBar[1]]; //추세선 시작시간
Value21 = hiVal[1]; //추세선 시작가격
}
date22 = date; //추세선 종료일
time22 = stime; //추세선 종료시간
Value22 = C; //추세선 종료가격
TL_Delete(TL2);
TL2 = TL_New(date21,time21,Value21,date22,time22,Value22);
TL_SetSize(TL2,선두께);
TL_SetColor(TL2,선색);
// 파동지표만들기끝 ---------------------------------------
2016-10-02
115
글번호 102422
답변완료
지표문의
일봉의 슬로우 스토캐스틱 지표를 분봉에 표시하고 싶습니다.
2016-10-02
104
글번호 102421