커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4734
글번호 230811
답변완료
Input문에 대해...
YT를 이제 시작하는 초보입니다.
시스템식에서 결과가 좀 이상하여 아래와 같이 디버깅을 해 보았습니다.
주석문이 달린 (1)번을 출력한 후, (2)번을 출력하니
변경된 (2)번의 결과가 나오지 않고 (1)번의 결과만 나오는데...
왜 값이 바뀌지 않는지요...
//input : len(0.3), CutPnt(1.0), stopLen(0.02); ---(1)
input : len(0.5), CutPnt(2.0), stopLen(0.05); ---(2)
MessageLog("len %0.2f, CutPnt %0.2f, stopLen %.2f", len, CutPnt, stopLen);
2015-10-30
191
글번호 91905
답변완료
함수부탁드립니다
수고많으십니다
아래수식에
ADX(14)가 y축 수치 20이하시 익절이든손실이든 청산수식 추가 부탁드립니다
if var1 > var2 and var2 > var3 Then
if adx (14) > 23 then
buy("b",Atlimit,var1-PriceScale*2);
if var1 < var2 and var2 < var3 Then
if adx (14) > 23 then
sell("s",Atlimit,var1+PriceScale*2);
2015-10-30
182
글번호 91904
답변완료
수식 요청 드립니다.
차트적용 수식 점검 부탁 드립니다.
1.요청 - 당일 1번 진입 당일손실(1.2)(피라미딩 적용, 미적용)
- 진입 후 계속손실 또는 진입수익(1.0PT) 전까지, 기존 당일손실제한 적용
2.요청 - 당일 2번진입 당일손실(1.2) (첫손실 포함, 수익은 제외 당일손절)(피라미딩 적용, 미적용)
- 진입 후 진입수익(1.0PT) 발생 기준, 계속 수익일경우 기존 당일손실제한 적용,
- 진입 후 진입수익(1.0PT) 발생 기준, 계속 손실발생시 10분마다 0.1PT 당일손실제한 차감
2시간 경과 차감 누적으로 손절(0.2PT일경우 1시간 경과 손절)
- 진입 후 진입수익(1.0PT) 발생 기준, 손실발생시 10분마다 0.1PT 차감하고, 다시 진입수익(1.0PT)을 초과할경우, 진입수익(1.0PT) 기준으로 추가 수익시 손실차감 중지, 손실시 손실차감을 계속 하는 수식 입니다.
---------------------------------------------------------------------------------
예) 1. 당일청산 300틱, TRIX, (2. 피라미딩 3EA 적용) 적용할 경우 아래 결과 입니다.
1. 아래수식을 기본수식에 적용 당일손절 1.2PT, 진입수익 1PT, 시간누적 당일손절 차감을
10분에 0.2PT로 적용할 경우, 진입수익 1PT 발생 후 1시간 경과시 강제 청산 안되네요.
당일 1번 진입 후, 계속 손실 발생시에는 시간누적 당일손절 차감되어 강제청산 반대현상.
피라미딩 적용, 미적용, 신호오류 점검 요청 드립니다.
2. 아래수식을 기본수식에 피라미딩 적용, 미적용시 진입신호 청산신호 오류가 발생 하네요.
피라미딩 적용, 미적용, 신호오류 점검 요청 드립니다.
<<< 1. 2. 모두 당일손절제한이 초과해도 손절이 안되고, 누적시간 도달해야 손절 됨니다. >>>
1.
input :N(1),당일손실(1.2),i증감(0.1),진입수량(1),진입수익(1.0);
var : cnt(0),BCount(0),SCount(0);
var : NP(0),PreNP(0),DayPL(0),loss(0),v1(0);
var : TT(0),KK(0),DD(0);
NP = NetProfit;
if date != date[1] Then{
preNP = NP[1];
Condition1 = false;
Condition11 = false;
v1 = 0;
}
dayPL = NP-PreNP;
BCount = 0 ;
SCount = 0 ;
for cnt = 0 to 10 {
if EntryDate(cnt) == sdate and MarketPosition(cnt) == 1 then
BCount = BCount + 1;
if EntryDate(cnt) == sdate and MarketPosition(cnt) == -1 then
SCount = SCount + 1;
}
if Condition1 == false and TotalTrades > TotalTrades[1] Then{
Condition1 = true;
if PositionProfit(1) > 0 Then
v1 = PositionProfit(1);
}
//-----------------------------------------------------------------------------------------------------
#당일손실제한
if MarketPosition == 1 Then{
#진입후 포지션 수익이 진입수익이상 발생
if Condition11 == false and PositionProfit >= 진입수익 Then{
Condition11 = true;
TT = TimeToMinutes(stime);//시간저장
}
#당일진입수익이 1포인트이상 발생하지 않았으면 기존청산 유지
if Condition11 == false Then
ExitLong("당일손실제한bx3",AtStop,avgEntryPrice-(당일손실+(dayPL-v1))/CurrentContracts);
#당일진입수익이 1.5이상 발생 => 1.0 기준 으로 수정요청
if Condition11 == true Then{
KK = TimeToMinutes(stime)-TT; #발생봉과 현재봉의 분차이
DD = int(KK/10); #분을 10으로 나누어 몇십분 경과했는지 계산
#당일손실값에 0.1*DD만큼 차감
ExitLong("당일손실제한bx31",AtStop,avgEntryPrice-(max(0,(당일손실-(0.2*DD)))+(dayPL-v1))/CurrentContracts);
}
}
if MarketPosition != 1 Then
Condition11 = false;
if MarketPosition == -1 Then{
#진입후 포지션 수익이 진입수익이상 발생
if Condition12 == false and PositionProfit >= 진입수익 Then{
Condition12 = true;
TT = TimeToMinutes(stime);//시간저장
}
#당일진입수익이 1포인트이상 발생하지 않았으면 기존청산 유지
if Condition12 == false Then{
KK = TimeToMinutes(stime)-TT; #발생봉과 현재봉의 분차이
DD = int(KK/10); #분을 10으로 나누어 몇십분 경과했는지 계산
#당일손실값에 0.1*DD만큼 차감
ExitShort("당일손실제한sx3",AtStop,avgEntryPrice+(max(0,(당일손실-(0.2*DD)))+(dayPL-v1))/CurrentContracts);
}
#당일진입수익이 1.5이상 발생 => 1.0 기준 으로 수정요청
if Condition11 == true Then{
KK = TimeToMinutes(stime)-TT; #발생봉과 현재봉의 분차이
DD = int(KK/10); #분을 10으로 나누어 몇십분 경과했는지 계산
#당일손실값에 0.1*DD만큼 차감
ExitShort("당일손실제한sx31",AtStop,avgEntryPrice+((당일손실-(0.2*min(DD,당일손실/0.2)))-(dayPL-v1))/CurrentContracts);
}
}
if MarketPosition != -1 Then
Condition12 = false;
//------------------------------------------------------------------------------------------------------
#기존수식 손실손절 스위칭
if MarketPosition == -1 and crossup(H,EntryPrice+1.2) and BCount+SCount < N and dayPL > 당일손실 Then
buy("1BX");
if MarketPosition == 1 and CrossDown(L,EntryPrice-1.2) and BCount+SCount < N and dayPL > 당일손실 Then
sell("1SX");
//------------------------------------------------------------------------------------------------------
if MarketPosition == 1 Then
Buy("bb",AtStop,LatestEntryPrice(0)+i증감,진입수량);
if MarketPosition == -1 Then
sell("ss",AtStop,LatestEntryPrice(0)-i증감,진입수량);
//=======================================================================================================
Input : Period(12), sigPeriod(9);
value1 = TRIX(Period);
value2 = ema(value1, sigPeriod);
# 매수/매도청산
If CrossUP(value1, value2) and BCount+SCount < N and dayPL > -당일손실 Then
{
Buy();
}
# 매도/매수청산
If CrossDown(value1, value2) and BCount+SCount < N and dayPL > -당일손실 Then
{
Sell();
}
SetStopEndofday(150000);
**************************************************************************************
2.
Input : Period(12), sigPeriod(9);
value1 = TRIX(Period);
value2 = ema(value1, sigPeriod);
input :N(2),당일손실(1.2),i증감(0.1),진입수량(1),진입수익(1.0);
var : cnt(0),BCount(0),SCount(0);
var : NP(0),PreNP(0),DayPL(0),loss(0),v1(0);
var : TT(0),KK(0),DD(0);
NP = NetProfit;
if date != date[1] Then{
preNP = NP[1];
Condition1 = false;
Condition11 = false;
v1 = 0;
}
dayPL = NP-PreNP;
BCount = 0 ;
SCount = 0 ;
for cnt = 0 to 10 {
if EntryDate(cnt) == sdate and MarketPosition(cnt) == 1 then
BCount = BCount + 1;
if EntryDate(cnt) == sdate and MarketPosition(cnt) == -1 then
SCount = SCount + 1;
}
if Condition1 == false and TotalTrades > TotalTrades[1] Then{
Condition1 = true;
if PositionProfit(1) > 0 Then
v1 = PositionProfit(1);
}
//-----------------------------------------------------------------------------------------------------
#당일손실제한
if MarketPosition == 1 Then{
#진입후 포지션 수익이 진입수익이상 발생
if Condition11 == false and PositionProfit >= 진입수익 Then{
Condition11 = true;
TT = TimeToMinutes(stime);//시간저장
}
#당일진입수익이 1포인트이상 발생하지 않았으면 기존청산 유지
if Condition11 == false or BCount+SCount == 1 Then
ExitLong("당일손실제한bx3",AtStop,avgEntryPrice-(당일손실+(dayPL-v1))/CurrentContracts);
#당일진입수익이 1.5이상 발생
if Condition11 == true and BCount+SCount >= 2 Then{
KK = TimeToMinutes(stime)-TT; #발생봉과 현재봉의 분차이
DD = int(KK/10); #분을 10으로 나누어 몇십분 경과했는지 계산
#당일손실값에 0.1*DD만큼 차감
ExitLong("당일손실제한bx31",AtStop,avgEntryPrice-(max(0,(당일손실-(0.2*DD)))+(dayPL-v1))/CurrentContracts);
}
}
if MarketPosition != 1 Then
Condition11 = false;
if MarketPosition == -1 Then{
#진입후 포지션 수익이 진입수익이상 발생
if Condition12 == false and PositionProfit >= 진입수익 Then{
Condition12 = true;
TT = TimeToMinutes(stime);//시간저장
}
#당일진입수익이 1포인트이상 발생하지 않았으면 기존청산 유지
if Condition12 == false or BCount+SCount == 1 Then{
ExitShort("당일손실제한sx3",AtStop,avgEntryPrice+(max(0,(당일손실-(0.2*DD)))+(dayPL-v1))/CurrentContracts);
}
#당일진입수익이 1.5이상 발생
if Condition11 == true and BCount+SCount >= 2 Then{
KK = TimeToMinutes(stime)-TT; #발생봉과 현재봉의 분차이
DD = int(KK/10); #분을 10으로 나누어 몇십분 경과했는지 계산
#당일손실값에 0.1*DD만큼 차감
ExitShort("당일손실제한sx31",AtStop,avgEntryPrice+((당일손실-(0.2*min(DD,당일손실/0.2)))-(dayPL-v1))/CurrentContracts);
}
}
if MarketPosition != -1 Then
Condition12 = false;
//------------------------------------------------------------------------------------------------------
#기존수식 손실손절 스위칭
if MarketPosition == -1 and crossup(H,EntryPrice+0.3 and BCount+SCount < N and dayPL > 당일손실 Then
buy("1BX");
if MarketPosition == 1 and CrossDown(L,EntryPrice-0.3) and BCount+SCount < N and dayPL > 당일손실 Then
sell("1SX");
//------------------------------------------------------------------------------------------------------
if MarketPosition == 1 Then
Buy("bb",AtStop,LatestEntryPrice(0)+i증감,진입수량);
if MarketPosition == -1 Then
sell("ss",AtStop,LatestEntryPrice(0)-i증감,진입수량);
//---------------------------------------------------------------------------
# 매수/매도청산
If CrossUP(value1, value2) and BCount+SCount < N and dayPL > -당일손실 Then
{
Buy();
}
# 매도/매수청산
If CrossDown(value1, value2) and BCount+SCount < N and dayPL > -당일손실 Then
{
Sell();
}
SetStopEndofday(150000);
2015-11-02
200
글번호 91903
답변완료
로직문의
옵션 trix 20분봉으로 하고 잇읍니다.
콜옵션 20분, 풋옵션 20분 이렇게 양방향을 자동주문 걸고 잇읍니다.
옵션 매수신호에는 정상적으로 매수체결되는데,
매도신호에는 증거금 부족으로 체결이 안됩니다.
(원래 매수만 하게 이렇게 해놓았읍니다)
그런데, 몇가지 문제가 발생합니다.
손절매가 가능합니까?
매수 포지션 1계약일때 => 손절매면 매수청산하여 0 계약이 되고,
매도 포지션 1계약일때(실제로는 매도체결안되고 잔고상 0 계약상태겠죠.
챠트에서만 매도 포지션으로 떠있읍니다) => 손절매면 오히려 매수 1계약이 됩니다.
매수포지션만 손절매가 되고, 매도포지션은 손절매시 그냥 0계약 유지되게 가능합니까?
두번째로는 매수,매도 잔고 유지가 가능합니까?
매수포지션 1계약 상태일때 => 매도신호 발생하면 매수청산하고, 증거금
부족으로 매도 1계약 체결은 안되어, 잔고상 0 계약 상태가 됩니다.
그런데, 매도포지션 1계약일때 => 매수신호뜨면 2번 매수 체결되어 매수포지션
2계약이 되버립니다. (매도포지션땐 실제로는 잔고상 0계약 상태이므로,
매수가 연달아 2번나와 매수 2계약이 되버립니다)
주문시작신호를 진입신호로, 진입주문지연을 5초로 설정해도 위와 같은 문제가 발생합니다. (아마도 주문시작신호는 첫 주문시만 적용되고, 두번재부터는 청산,진입 무조건
다 되게 해놓은것 같읍니다.모든신호가 아닌 진입신호로 설정해도 말입니다)
위와 같은 현상을 해결 가능합니까?
(매수1계약시 매도신호발생 -> 잔고상 0계약 되고,
매도 1계약시 매수신호 발생 -> 잔고상 0계약 유지되게, 매수 2계약 안되고)
이 상태로 말입니다.
2015-10-30
181
글번호 91902
답변완료
문의드립니다
이동평균 5, 20 골든크로스 매수신호
매수신호 봉의 저가이하에서 매수
진입가격에 +0.3%이상 수익중이고 이동평균 5, 20 데드크로스 매도
부탁드립니다
2015-10-30
179
글번호 91901
답변완료
로직 추가 문의
답변 감사합니다.
아래 글에서 한가지만 추가 문의합니다.
아래 2)번 답변, 십자봉미포함 로직에서
십자봉이 2번째 뜨는 경우는 제외하고, 첫번째 뜨는 경우엔
매매신호 나오게 가능합니까?
예로, 빨간봉이 2개 연속 나오는데,
1) 첫째봉 빨간봉(십자봉 아님), 두번째봉 빨간봉(십자봉) => 신호없음.
2) 첫재봉 십자봉, 둘째봉 십자봉 아닌 경우 => 신호나옴.
이렇게 2)경우만 매수신호 나오게 하는 경우입니다.
--------------------------------------------------------------------
안녕하세요
예스스탁입니다.
1.
input : N(2);
if dayindex+1 >= N then{
if countif(C>O or (C == O and c >= C[1]),N) == N Then
buy();
if countif(C<O or (C == O and c < C[1]),N) == N Then
sell();
}
2.
input : N(2);
if dayindex+1 >= N then{
if countif(C>O,N) == N Then
buy();
if countif(C<O,N) == N Then
sell();
}
즐거운 하루되세요
> 초록이 님이 쓴 글입니다.
> 제목 : 로직 재문의
> 아래글에 대한 2가지 재문의입니다.
1) 아래 로직을 적용해보니, 첫봉에서 매매신호가 뜨는 경우가
발생합니다.
예로, 전일 마지막봉이 빨간봉이고, 당일 첫봉이 빨간봉이면
빨간봉이 2개 연속뜬것으로 인식해 매수신호가 나옵니다.
전일봉은 무시하고, 당일 첫봉부터만 적용되도록 가능합니까?
2)아래 로직에서 십자봉을 제외한 로직은 어떻게 됩니까?
===========================================================
예스스탁입니다.
if countif(C>O or (C == O and c >= C[1]),2) == 2 Then
buy();
if countif(C<O or (C == O and c < C[1]),2) == 2 Then
sell();
즐거운 하루되세요
> 초록이 님이 쓴 글입니다.
> 연결선물지수 3분봉을 하고 잇읍니다.
봉 색깔이 2개 연속 빨간봉이면 매수, 2개연속 파란봉이면 매도
이렇게 하고 싶읍니다.
해당봉 종가가 직전봉 종가 대비 상승 또는 하락 여부는 따지지
않고, 오로지 봉 색깔만을 변수로 하고자 합니다.
(십자봉도 포함시키되, 십자봉 역시 봉 색깔만을 고려합니다).
매수,매도 포지션 모두 로직 부탁합니다.
2015-11-02
186
글번호 91900
답변완료
문의드립니다.
안녕하세요
1. 해외선물 주봉 차트에서 이번달 최고 거래량이 발생한 주봉의 고저와 저번달 최고 거래량이 발생한 주봉의 고저를 분봉에 나타나게 하는 지표식
2. 해외선물 일봉 차트에서 이번주 최고 거래량이 발생한 일봉의 고저와 저번주 최고 거래량이 발생한 일봉의 고저를 분봉에 나타나게 하는 지표식을 부탁드립니다.
감사합니다.
2015-10-30
186
글번호 91899
답변완료
부탁 드립니다.
항상 도움 주셔서 깊이 감사 드립니다.
질문1)YT변환 부탁 드립니다
sum(if(C>C(1),C-min(C(1),L),0))+sum(if(C<C(1),C-max(C(1),H),0))
질문2) 다음을 상승시 체결음과 하락시 체결음으로 구분할수 있는지요?
PlaySound( "C:₩eFriend Global YesTraderefriendglobalyestrader₩data₩Sound₩alert.wav");
질문3)
하루전의 08:00 에서
금일 07:00 까지
대륙별 거래시간 표시 부탁 드립니다.
-당일용-> 당일것만 표시
-전일용-> 전일의 아시아,유럽,미국장 표시
질문4)
그림과 같이 표시 부탁 드립니다.
가급적 TL선의 중간 또는 우측에 부탁 드립니다.
미리 감사 드립니다.
input : 아시아시작(081000),아시아종료(152000);
input : 유럽시작(153000),유럽종료(213000);
input : 미국시작(214000),미국종료(065000);
var : D1(0),T1(0),H1(0),L1(0),Tcond1(false);
var : D2(0),T2(0),H2(0),L2(0),Tcond2(false);
var : D3(0),T3(0),H3(0),L3(0),Tcond3(false);
var : TL11(0),TL12(0),TL13(0),TL14(0);
var : TL21(0),TL22(0),TL23(0),TL24(0);
var : TL31(0),TL32(0),TL33(0),TL34(0);
if stime == 아시아시작 or (stime > 아시아시작 and stime[1] < 아시아시작) Then{
D1 = sdate;
T1 = stime;
H1 = H;
L1 = L;
Tcond1 = true;
}
if Tcond1 == true Then{
if H > H1 Then
H1 = H;
if L < L1 Then
L1 = L;
TL_Delete(TL11);
TL_Delete(TL12);
TL_Delete(TL13);
TL_Delete(TL14);
TL11 = TL_New(D1,T1,H1,Sdate,stime,H1);
TL12 = TL_New(D1,T1,L1,Sdate,stime,L1);
TL13 = TL_New(D1,T1,H1,D1,T1,L1);
TL14 = TL_New(sdate,stime,H1,sdate,stime,L1);
TL_SetColor(TL11,RED);
TL_SetColor(TL12,RED);
TL_SetColor(TL13,RED);
TL_SetColor(TL14,RED);
}
if time == 아시아종료 or (time > 아시아종료 and time[1] < 아시아종료) Then
Tcond1 = false;
if stime == 유럽시작 or (stime > 유럽시작 and stime[1] < 유럽시작) Then{
D2 = sdate;
T2 = stime;
H2 = H;
L2 = L;
Tcond2 = true;
}
if Tcond2 == true Then{
if H > H2 Then
H2 = H;
if L < L2 Then
L2 = L;
TL_Delete(TL21);
TL_Delete(TL22);
TL_Delete(TL23);
TL_Delete(TL24);
TL21 = TL_New(D2,T2,H2,Sdate,stime,H2);
TL22 = TL_New(D2,T2,L2,Sdate,stime,L2);
TL23 = TL_New(D2,T2,H2,D2,T2,L2);
TL24 = TL_New(sdate,stime,H2,sdate,stime,L2);
TL_SetColor(TL21,YELLOW);
TL_SetColor(TL22,YELLOW);
TL_SetColor(TL23,YELLOW);
TL_SetColor(TL24,YELLOW);
}
if time == 유럽종료 or (time > 유럽종료 and time[1] < 유럽종료) Then
Tcond2 = false;
if stime == 미국시작 or (stime > 미국시작 and stime[1] < 미국시작) Then{
D3 = sdate;
T3 = stime;
H3 = H;
L3 = L;
Tcond3 = true;
}
if Tcond3 == true Then{
if H > H3 Then
H3 = H;
if L < L3 Then
L3 = L;
TL_Delete(TL31);
TL_Delete(TL32);
TL_Delete(TL33);
TL_Delete(TL34);
TL31 = TL_New(D3,T3,H3,Sdate,stime,H3);
TL32 = TL_New(D3,T3,L3,Sdate,stime,L3);
TL33 = TL_New(D3,T3,H3,D3,T3,L3);
TL34 = TL_New(sdate,stime,H3,sdate,stime,L3);
TL_SetColor(TL31,BLUE);
TL_SetColor(TL32,BLUE);
TL_SetColor(TL33,BLUE);
TL_SetColor(TL34,BLUE);
}
if time == 미국종료 or (time > 미국종료 and time[1] < 미국종료) Then
Tcond3 = false;
2015-11-02
253
글번호 91898
답변완료
지표부탁드립니다
지표식을 부탁드립니다
1 특정주가 기준 퍼센트 채널
특정주가(250)(변수처리가능) 을 기준으로 퍼센트채널을 0.25 0.5 1 1.25 4개
(퍼센트채널 도 변수처리가능 ) 를 같이 사용할수있게 부탁드립니다
2 (38541)번의 당일진폭 국내선물 에서는 진폭글이 잘나오는데요
해외선물 유로선물 에서는 그냥 0.01 진폭으로나옵니다 해외선물의 뒷자리숫자가
소수점뒷자리 가 4 자리수자여서 그런것같습니다
제가 초보라서 수정된식을 부탁드립니다
항시 애써주시는 담당자님의 무궁한 발전을 기원합니다
감사합니다
2015-10-30
202
글번호 91897