커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4612
글번호 230811
답변완료
지표 문의 드립니다
지표식 문의 드립니다
1지표. 오늘이 월요일이라고 할 경우
지난주 월요일부터 오늘 까지의 고가, 저가,중간값을
차트에 표시하고 싶습니다
화,수,목,금요일의 경우는, 지난주는 빼고 이번 월요일부터의
고가,저가,중간값을 차트에 나오도록 하고 싶습니다
2지표.오늘이 1일이라고 할 경우
지난달 1일부터 오늘 까지의 고가,저가, 중간값을
차트에 표시하고 싶습니다
그리고 2일부터는 이번달 1일부터 오늘(~다음달 1일까지가 되겠지요,,,)까지의
고가,저가,중간값을 차트에
나오도록 하고 싶습니다
도와주세요,,,감사합니다
2016-05-26
127
글번호 98500
답변완료
수식 문의
최근 10개 봉의 표준편차를 구해서 현재 봉의 아래 위로 밴드를 만들어 표시하고 있습니다.
1 표준편차 밴드와 2 표준편차 밴드(표준편차의 2배)를 만들고 싶은데 수식을 부탁드립니다.
2016-05-26
130
글번호 98499
답변완료
타주기 시스템식 오류수정
항상 감사드립니다
아래 타주기 시스템식이 구동이 되질않습니다.
오류수정부탁드립니다
종목:크루드
주챠트:200틱
타주기챠트:20틱
##########################
### 선행스팬2(48) 기준 ###
##########################
var : 선행1(0,data1),선행2(0,data2);
선행1 = data1((Highest(High, 48) + Lowest(Low, 48)) / 2); #선행스팬2_48#
선행2 = data2((Highest(High, 48) + Lowest(Low, 48)) / 2); #선행스팬2_48#
######################
##### ADX 시스템 #####
######################
input : Period3(336), Period4(336);
var : ADX1(0,data1),DP1(0,data1),DM1(0,data1);
var : ADX2(0,data2),DP2(0,data2),DM2(0,data2);
ADX1 = data1(ADX(Period3));
DP1 = data1(DiPlus(Period3));
DM1 = data1(DiMinus(Period3));
if DP1 > DM1 Then
var13= 1 ;
if DP1 < DM1 Then
var13= -1 ;
ADX2 = data2(ADX(Period4));
DP2 = data2(DiPlus(Period4));
DM2 = data2(DiMinus(Period4));
if DP2 > DM2 Then
var14 = 1 ;
if DP2 < DM2 Then
var14 = -1 ;
#########################
##### 당일익절 설정 #####
#########################
input : 당일수익틱수(100),당일손실틱수(50);
var : NP(0),PreNP(0),dayPL(0),DollerToTick(0),당일수익(0),당일손실(0);
NP = NetProfit;
당일수익 = PriceScale*당일수익틱수;
당일손실 = PriceScale*당일손실틱수;
if stime == 170000 or (stime > 170000 and stime[1] < 170000) then
PreNP = NP[1];
#당일 손익(포인트)
DayPL = NetProfit-PreNP ;
### 동일방향 재진입금지/전일 마지막신호와 무관하게 진입 ###
### 2회연속손실시 시스템 신호발생 금지 ###
### 시초가 갭발생시(20틱이상) 첫번재신호 발생금지 ###
var : entrycnt(0),cond(false),T(0),count(0),gap(false),Xcond(false);
#장시작
if stime == 170000 or (stime > 170000 and stime[1] < 170000) Then{ # 현지시간_뉴욕 17:00 장시작 #
Entrycnt = 0;
cond = false;
Xcond = false;
#매수매도 방향을 알기위한 변수 초기값은 0
T = 0;
#조건만족횟수 카운트 초기화 0
count = 0;
#시가가 전봉종가(전일종가)보다 20틱이상 크거나 20틱이상 낮으면
#gap은 true 아니면 false
if O >= C[1]+PriceScale*20 or O <= C[1]-PriceScale*20 Then
gap = true;
Else
gap = false;
}
if MarketPosition != 0 and MarketPosition != MarketPosition[1] Then
Entrycnt = Entrycnt+1;
if TotalTrades > TotalTrades[1] and (IsExitName("BP",1) or IsExitName("BL",1) or IsExitName("SP",1) or IsExitName("SL",1)) Then
Xcond = true;
cond = false;
#2회연속 손실시 진입금지#
if entrycnt >= 2 Then{
if MarketPosition == 0 and PositionProfit(1) < 0 and PositionProfit(2) < 0 Then
cond = true;
if MarketPosition != 0 and PositionProfit(0) < 0 and PositionProfit(1) < 0 Then
cond = true;
}
if (stime > 170000 or stime < 143000) and (DayPL < 당일수익틱수*PriceScale and dayPL > -당일손실틱수*PriceScale and Xcond == false ) Then{
# 현지시간_뉴욕 17:00 장시작~익일 14:30 장종료 #
##############################
##### 1_ 매매식 #####
##############################
if T <= 0 and #T가 0이고 매수조건이 만족하면
((entrycnt == 0) or
(entrycnt >= 1 and ((MarketPosition == 0 and MarketPosition(1) != 1) or (MarketPosition == -1)))) and #동일방향 재진입금지#
data1(c)>선행1 and var13==1 and var14==1 Then {
T = 1; #T는 1(매수조건만족했음을 나타냄)
count = count+1; #count는 1증가, 장시작이후 조건만족 횟수를 카운트
#gap이 false이거나 gap이 true이면 count가 2이상일때 진입
if gap == false or (gap == true and count >= 2) Then
{
if cond == false then
buy("B_200_20");
Else
ExitShort();
}
}
if T >= 0 and
((entrycnt == 0) or
(entrycnt >= 1 and ((MarketPosition == 0 and MarketPosition(1) != -1) or (MarketPosition == 1)))) and #동일방향 재진입금지#
data1(c)<선행1 and var13==-1 and var14==-1 Then {
T = -1;
count = count+1;
#gap이 false이거나 gap이 true이면 count가 2이상일때 진입
if gap == false or (gap == true and count >= 2) Then
{
if cond == false Then
sell("S_200_20");
Else
ExitLong();
}
}
}
2016-05-26
116
글번호 98498
답변완료
수식문의드립니다
1분봉에서
입력한 날자의 dayvolume을 첨부한 그림처럼 9시1분봉부터 15:00분까지
그대로 지표로 가져오고 싶습니다.
부탁드립니다
(_ _)
2016-05-25
159
글번호 98497
답변완료
추가질문
안녕하세요.
지난번 원격으로 연결하여 프로그램을 작성해 주어
진심으로 감사드립니다.
처음 수식에서 보완해야할 사항과 추가할 사항이 있습니다.
1. 매수신호 4개 매도신호 4개중
매도신호 1번과 4번이 4개월분 복기를 해보았는데 신호가 한번도 나오지 않습니다.
(손으로 복기시는 여러번 나옵니다)
2. 리버스 신호중 진입할때 리버스신호와 일반진입신호가 구별이 되지 않습니다.
3. 추가로
현재수식은 종가 진입하는것으로 되어있는데
종가가 아니고 매수는 (종가 - 7틱), 매도는 (종가 + 7틱)에서
신호가 나오며 체결되게 할 수 있는지요.
2016-05-25
107
글번호 98496
답변완료
종가손절
Input : shortPeriod(1), longPeriod(20) ;
Var : value(0);
value = OSCP(shortPeriod, longPeriod);
# 매수/매도청산
If CrossUP(value, 0) and c > O
Then { Buy(); Exitshort(); }
5p손실시 즉시손절한다와 ( 종가손절한다)
# 매도/매수청산
If CrossDown(value,0) and C < O
Then { Sell(); Exitlong(); }
3p손실시 즉시손절한다와 ( 종가손절한다)
위두식을부탁합니다 상하손절가격이다름니다
항상감사합니다.
2016-05-25
107
글번호 98495
답변완료
문의드립니다.
수고하십니다. 자문을 구합니다.
var1 = h[1]-l[1];
if crossup(c,var1) Then
buy("b");
Exitlong("s",AtMarket);
일봉에서 매수후 다음날 시가에 청산하는 식인데
청산후 다시 조건에 만족하면 상기 매수가 반복되게 하고 싶습니다.
어떻게 하면 되는지요?
2016-05-25
113
글번호 98494
답변완료
가격표시
안녕하세요.늘 도움 감사드립니다.
아래의 지표에서 표시되는 파동의 5 와 20 의 고점 저점의 선과 피보나치선이 선만 나타는데
차트에 가격표시가 나타날수 잇도록 부탁드립니다.
Input:ShortPeriod(5),LongPeriod(20),선두께(2),선색(green);
Var:j(0),ma1(0),ma2(0);
Var: date11(0),date12(0),time11(0),time12(0),TL1(0),
date21(0),date22(0),time21(0),time22(0),
date31(0),date32(0),time31(0),time32(0);
Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0),ZZ[20](0);
Array:r[7](0),fr[7](0),TL2[7](0),TL3[7](0);
For j = 0 To 19
{
HiBar[j] = HiBar[j] + 1;
LoBar[j] = LoBar[j] + 1;
}
ma1 = ma(C,ShortPeriod);
ma2 = ma(C,LongPeriod);
If ma1 < ma2 Then
{
If ma1[1] >= ma2[1] Then
{
For j = 18 DownTo 0
{
LoVal[j+1] = LoVal[j];
LoBar[j+1] = LoBar[j];
ZZ[j+1] = ZZ[j];
}
LoVal[0] = L;
LoBar[0] = 0;
ZZ[0] = L;
date11 = date[HiBar[0]];
time11 = stime[HiBar[0]];
Value11 = HiVal[0];
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
TL1 = TL_New(date11,time11,Value11,date12,time12,Value12);
date21 = date[HiBar[0]];
time21 = stime[HiBar[0]];
date22 = date[0];
time22 = stime[0];
for j = 0 to 6
{
fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]);
TL2[j] = TL_New(date21,time21,fr[j],date22,time22,fr[j]);
TL_SetColor(TL2[j],red);
}
}
Else If LoVal[0] > L Then
{
LoVal[0] = L;
LoBar[0] = 0;
ZZ[0] = L;
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
TL_SetEnd(TL1, date12,time12,Value12);
date22 = date[0];
time22 = stime[0];
for j = 0 to 6
{
TL_SetEnd(TL2[j],date22,time22,fr[j]);
}
}
}
Else If ma1 > ma2 Then
{
If ma1[1] <= ma2[1] Then
{
For j = 18 DownTo 0
{
HiVal[j+1] = HiVal[j];
HiBar[j+1] = HiBar[j];
ZZ[j+1] = ZZ[j];
}
HiVal[0] = H;
HiBar[0] = 0;
ZZ[0] = H;
date11 = date[LoBar[0]];
time11 = stime[LoBar[0]];
Value11 = LoVal[0];
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
TL1 = TL_New(date11,time11,Value11,date12,time12,Value12);
date31 = date[LoBar[0]];
time31 = stime[LoBar[0]];
date32 = date[0];
time32 = stime[0];
for j = 0 to 6
{
fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]);
TL3[j] = TL_New(date31,time31,fr[j],date32,time32,fr[j]);
TL_SetColor(TL3[j],blue);
}
}
Else If HiVal[0] < H Then
{
HiVal[0] = H;
HiBar[0] = 0;
ZZ[0] = H;
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
TL_SetEnd(TL1, date12,time12,Value12);
date32 = date[0];
time32 = stime[0];
for j = 0 to 6
{
TL_SetEnd(TL3[j],date32,time32,fr[j]);
}
}
}
TL_SetSize(TL1,선두께);
TL_SetColor(TL1,선색);
2016-05-25
160
글번호 98493
곽민수 님에 의해서 삭제되었습니다.
2016-05-25
0
글번호 98492