커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4433
글번호 230811
답변완료
시스템식 추가 요청드립니다.
고생하십니다.
최근 아래와 같은 답변을 받았읍니다
제가 나이가 적지가 않아 부대조건을 추가하는게 쉽지가 않네요..
어렵게 표현한것같아서 쉽게 다시 설명드리고 아래 시스템식에 추가할수있게 부탁코저 합니다
* 추가로 입력할 부대조건
1. 기준선 설정 : 장 시작후 첫 번째 나오는 1틱 조건봉의 종가
2. 익,손절 설정 : 익절 0.50P이상,손절 -0.50
3. 손절후는 첫 조건봉 나올시 재진입
4. 제외 조건봉 : 무손실 1틱봉( 갭하락 상승 1틱 양봉,갭 상승 1틱 음봉)
5. 변수로 설정 : 주기,익손절,U-turn지점(0.20,0.70)
답변부탁드립니다.
혹여 잘 안될시에 다시 쉽게 뺼거빼고 재등록 하겠습니다.
감사합니다.
안녕하세요
예스스탁입니다.
진입과 청산조건으로만 작성한 내용입니다.
부대조건 중 내용은 어떻게 추가해야 할지 잘 모르겠습니다.
청산도 모두 청산식으로 작성했습니다.
해당 내용 참고하셔서 수정보완하시기 바랍니다.
if C[1] <= O[1]-PriceScale*2 and
C >= O+PriceScale*1 Then
buy("b",AtMarket);
if C[1] >= O[1]+PriceScale*2 and
C <= O-PriceScale*1 Then
sell("s",AtMarket);
if MarketPosition == 1 Then{
ExitLong("bl",AtStop,EntryPrice-0.5);
var1 = (highest(H,BarsSinceEntry)-EntryPrice);
var2 = int(var1/0.5);
if highest(H,BarsSinceEntry) >= EntryPrice+var2*0.5+0.3 Then
ExitLong("bx",AtStop,EntryPrice+var2*0.5);
}
if MarketPosition == -1 Then{
ExitShort("sl",AtStop,EntryPrice+0.5);
var1 = (EntryPrice-lowest(L,BarsSinceEntry));
var2 = int(var1/0.5);
if Lowest(L,BarsSinceEntry) <= EntryPrice-var2*0.5+0.3 Then
ExitShort("sx",AtStop,EntryPrice-var2*0.5);
}
즐거운 하루되세요
> 대구어린울프 님이 쓴 글입니다.
> 제목 : 시스템 작성 부탁드립니다.
> 그동안 답변주신것 감사드리고,아래와 같이 전략작성을 부탁드리고자 합니다
** 진입조건(진입 조건봉)
① 2틱이상 음봉 다음 1틱양봉 발생후 다음봉 시가에 매수 진입
② 2틱이상 양봉 다음 1틱음봉 발생후 다음봉 시가에 매도 진입
** 청산조건 및 역진입
① 익 0.30P-0.50 도달후 U-turn시 0.00점 청산(설정된 기준선에 매수시는 음봉종가
접속,매도시는 양봉 종가 접속시 청산 역진)
② 익 0..80P-1.00 ( “ ”) 익 0.50점 청산 ( “ ” )
③ 익 1.30P-1.50 ( “ ”) 익 1.00점 청산 ( “ ” )
④ 익 1.80P-2.00 ( “ ”) 익 1.50점 청산 ( “ ” )
⑤ 익 2.30P-2.50 ( “ ”) 익 2.00점 청산 ( “ ” )
⑥ 익 2.80P-3.00 ( “ ”) 익 2.50점 청산 ( “ ” )
⑦ 익 3.30P-3.50 ( “ ”) 익 3.00점 청산 ( “ ” )
⑧ 0.50P단위로 단계적으로 확대
** 부대조건
* 익 0.50 이상, 손절 0.50
* 상기 청산후 바로 역진입(1틱 조건봉 아니어도 됨)
* 기준선 도달전 역조건봉 나올시 청산 역진입
* 손절후는 첫조건봉 나올시 진입
* 기준선 설정 : 장시작후 첫진입한 1틱봉의 종가
* 무손실 1틱은 제외(갭상승 1틱 음봉,갭하락 1틱 양봉)
* 익절,손절,주기는 변수로
감사합니다..^^
2017-03-02
124
글번호 107400
답변완료
청산식 문의 드립니다.
진입가 대비 수익이 나고 있을경우 예를들어 최고 수익에서 5틱이상 수익이 감소되면 청산하는 식을 알고 싶습니다.
감사합니다.
2017-03-02
98
글번호 107389
ceri21 님에 의해서 삭제되었습니다.
2017-03-02
1
글번호 107388
답변완료
5봉평균과 변동성
아래 건은 일봉을 적용한 것입니다.
분봉으로 바꾸고 적용은 변수에서 n분봉으로 할 수 있게 요청드립니다.
늘 고맙습니다.
var : AA(0), BB(0), CC(0), DD(0), EE(0);
AA = dayhigh(1)-daylow(1);
BB = dayhigh(2)-daylow(2);
CC = dayhigh(3)-daylow(3);
DD = dayhigh(4)-daylow(4);
EE = dayhigh(5)-daylow(5);
var1 = (AA+BB+CC+DD+EE)/5;
if crossup(C, dayopen() + var1*1.04) then
buy();
if crossdown(C, dayopen() - var1*0.96) then
sell();
2024-08-31
129
글번호 107376
답변완료
수식수정부탁드립니다=======
/*보정치로 보정하기전의 ( TEMA2+호가더하기/1000 )을 plot90으로 표시하고싶습니다 부탁드립니다*/
Input: 보정치(0),호가더하기(0),지수더하기(0),폭보정(1.5),지수호가테마LENGTH1(10),순매수LENGTH2(10),급변(0.05)
,순매수테마보정한계(0.3),순매수테마급증보정(0.5),순매수테마급감보정(0.5)
,지수테마보정한계(0.3),지수테마급증보정(0.5),지수테마급감보정(0.5) ;
var : AsksMA(0),BidsMA(0), Period(1),idx(0),EP(0),E11(0),E12(0),E13(0),E21(0),E22(0),E23(0);
Var : value(0);
Var : valuec(0);
var : va61(0);
var : va71(0);
var : va80(0);
var : va81(0);
var : va90(0);
var : va91(0);
var : va92(0);
var : va93(0);
var : va94(0);
var : va95(0);
var : va96(0);
VAR : TEMA1(0);
VAR : TEMA2(0);
VAR : TEMA3(0);
VAR : vmin(0);
VAR : vmax(0);
BidsMa = ma(bids,Period);
AsksMA = ma(asks,Period);
value = ma(bids,period)-ma(asks,period)+29000;
Plot2(BidsMA, "매수잔량이평");
Plot3(AsksMA, "매도잔량이평");
Plot4(value, "차");
//**************************************************************
//*************************************************************
va91=((c-c[1])/c[1]*100)*20000/20000;
va93=((value-value[1])/value[1]*70)*125/2900;
if Bdate != Bdate[1] Then{
idx = 0;
var1 = 100;
var2 = 100;
plot10(var1);
plot11(var2);
plot51(var2 +호가더하기/1000 );
}
Else{
idx = idx+1;
var1 = var1+(var1*(va91/100));
if abs(va71[5]-va71) <= 보정치/10000 Then
var2 = var1;
else
var2 = var2+(var2*(va93/95));
plot10(var1+지수더하기/1000 );
plot11(var2+호가더하기/1000 );
plot51(var2+호가더하기/1000 );
TEMA3 = (3 * Ema(var2+호가더하기/1000 ,순매수LENGTH2)) - (3 * Ema(Ema(var2+호가더하기/1000 ,순매수LENGTH2),순매수LENGTH2)) +
(Ema(Ema(Ema(var2+호가더하기/1000 ,순매수LENGTH2),순매수LENGTH2),순매수LENGTH2));
if TEMA3 >TEMA3[1]+순매수테마보정한계 then TEMA3 = ((TEMA3 -TEMA3[1])*순매수테마급증보정)+TEMA3[1];
if TEMA3 <TEMA3[1]-순매수테마보정한계 then TEMA3 = TEMA3[1]-((TEMA3[1] -TEMA3)*순매수테마급감보정);
if TEMA3 >TEMA3[1]+50 then TEMA3 = ((TEMA3 -TEMA3[1])*0.9)+TEMA3[1];
if TEMA3 <TEMA3[1]-50 then TEMA3 = TEMA3[1]-((TEMA3[1] -TEMA3)*0.9);
plot52(TEMA3,"순매수테마");
}
if var2-var1 > 폭보정 Then var2=var1;
if var1-var2 > 폭보정 Then var2=var1;
//if va71[1] < va71 and va71[1] + 0.05 > va71 then var2=var1;
//if va71[1] > va71 and va71[1] - 0.05 > va71 then var2=var1;
EP = 2/(지수호가테마LENGTH1+1);
if idx == 0 Then{
E11 = var1;
E21 = var2;
}
Else{
E11 = var1 * EP + E11 * (1-EP);
E21 = var2 * EP + E21 * (1-EP);
}
if idx <= 1 Then{
E12 = E11;
E22 = E21;
}
Else{
E12 = E11 * EP + E12 * (1-EP);
E22 = E21 * EP + E22 * (1-EP);
}
if idx <= 2 Then{
E13 = E12;
E23 = E22;
}
Else{
E13 = E12 * EP + E13 * (1-EP);
E23 = E22 * EP + E23 * (1-EP);
}
TEMA1 = (3 * E11) - (3 * E12) + (E13);
if TEMA1 >TEMA1[1]+지수테마보정한계 then TEMA1 = ((TEMA1 -TEMA1[1])*지수테마급증보정)+TEMA1[1];
if TEMA1 <TEMA1[1]-지수테마보정한계 then TEMA1 = TEMA1[1]-((TEMA1[1] -TEMA1)*지수테마급감보정);
if TEMA2 >TEMA2[1]+지수테마보정한계 then TEMA2 = ((TEMA2 -TEMA2[1])*지수테마급증보정)+TEMA2[1];
if TEMA2 <TEMA2[1]-지수테마보정한계 then TEMA2 = TEMA2[1]-((TEMA2[1] -TEMA2)*지수테마급감보정);
TEMA2 = (3 * E21) - (3 * E22) + (E23);
PLOT30(TEMA1+지수더하기/1000 ,"지수테마",iff((TEMA1 +지수더하기/1000 )>(TEMA1 +지수더하기/1000)[1]+00,BLACK,iff((TEMA1 +지수더하기/1000 )<(TEMA1 +지수더하기/1000 )[1]-00,BLACK,BLACK)));
PLOT31(TEMA2 +호가더하기/1000,"호가테마");
vmin = min(TEMA1+지수더하기/1000 ,TEMA2+호가더하기/1000 );
vmax = max(TEMA1+지수더하기/1000 ,TEMA2+호가더하기/1000 );
if TEMA1+지수더하기/1000> TEMA2+호가더하기/1000 Then{
var80 = (TEMA1+지수더하기/1000- TEMA2 +호가더하기/1000 )*0.5+TEMA2+호가더하기/1000 ;
}
if TEMA1 < TEMA2+호가더하기/1000 Then{
var80 = (TEMA2+호가더하기/1000 -TEMA1+지수더하기/1000)*0.5+TEMA1+지수더하기/1000 ;
}
PLOT17(var80,"지호평균");
//테마합 일정 수량차이상의 급등락 표시
if TEMA3 > TEMA3[1]+ 급변 Then{plot21(vmin-0.05,"급등");}
if TEMA3 < TEMA3[1]- 급변 Then{plot22(vmin-0.05,"급락");}
va71 =( TEMA2+호가더하기/1000 - TEMA1+지수더하기/1000 )+100;
if ( TEMA2+호가더하기/1000 )[1] < ( TEMA2+호가더하기/1000 ) and (TEMA1+지수더하기/1000)[1] < (TEMA1+지수더하기/1000) Then{
PLOT25((vmin )-0.02,"매수예비");
//PlaySound("C:₩예스트레이더₩data₩Sound₩pp.wav");
}
if ( TEMA2+호가더하기/1000 )[1] > ( TEMA2+호가더하기/1000 ) and (TEMA1+지수더하기/1000)[1] > (TEMA1+지수더하기/1000) Then{
PLOT26((vmin )-0.02,"매도예비");
// PlaySound("C:₩예스트레이더₩data₩Sound₩dingdong.wav");
}
PLOT60(va71,"55");
if CrossUp (( TEMA2+호가더하기/1000 ),(TEMA1+지수더하기/1000)) Then{
//if (TEMA1[1]+지수더하기/1000 )< (TEMA1+지수더하기/1000) and (va71[1] )< (va71)then {
PLOT45((vmin )-0.02,"매수막대");
PlaySound("C:₩예스트레이더₩data₩Sound₩up.wav");
}
if CrossDown (( TEMA2+호가더하기/1000 ),(TEMA1+지수더하기/1000)) Then{
// if (TEMA1[1]+지수더하기/1000 )> (TEMA1+지수더하기/1000) and (va71[1] )> (va71) Then{
PLOT46((vmin )-0.02,"매도막대");
PlaySound("C:₩예스트레이더₩data₩Sound₩dingdong.wav");
}
if va71[1]+급변 < va71 Then {
PLOT18((va71 )+0.01,"매도");
}
if va71[1]-급변 > va71 Then {
PLOT19((va71 )+0.01,"매수");
}
va96 = (tema1 - tema2)*1000;
PLOT61(va96,"66");
2017-03-02
117
글번호 107375
qha71 님에 의해서 삭제되었습니다.
2017-03-02
25
글번호 107374
답변완료
시스템으로
란녕하세요 시스템식으로 부탁요
var : cnt(0);
Array : DO[10](0),DH[10](0),DL[10](0),DC[10](0);
Array : NO[10](0),NH[10](0),NL[10](0),NC[10](0);
#주간장 시고저종
if stime == 090000 or (stime > 090000 and stime[1] < 090000) Then{
DO[0] = O;
DH[0] = H;
DL[0] = L;
for cnt = 1 to 9{
DO[cnt] = DO[cnt-1][1];
DH[cnt] = DH[cnt-1][1];
DL[cnt] = DL[cnt-1][1];
DC[cnt] = DC[cnt-1][1];
}
}
if stime >= 090000 and stime <= 151500 Then{
DC[0] = C;
if H > DH[0] Then
DH[0] = H;
if L < DL[0] Then
DL[0] = L;
}
#야간장 시고저종
if stime == 180000 or (stime > 180000 and stime[1] < 180000) Then{
NO[0] = O;
NH[0] = H;
NL[0] = L;
for cnt = 1 to 9{
NO[cnt] = NO[cnt-1][1];
NH[cnt] = NH[cnt-1][1];
NL[cnt] = NL[cnt-1][1];
NC[cnt] = NC[cnt-1][1];
}
}
if stime >= 180000 or stime < 090000 Then{
NC[0] = C;
if H > NH[0] Then
NH[0] = H;
if L < NL[0] Then
NL[0] = L;
}
plot1(DH[1],"주간장고가");
plot2(DL[1],"주간장저가");
plot3(DC[1],"주간장종가");
plot4(DO[0],"주간장시가");
if stime >= 090000 and stime <= 151500 then{
plot5(NH[0],"야간장고가");
plot6(NL[0],"야간장저가");
plot7(NC[0],"야간장종가");
plot8(NO[0],"야간장시가");
}
else{
plot5(NH[1],"야간장고가");
plot6(NL[1],"야간장저가");
plot7(NC[1],"야간장종가");
plot8(NO[0],"야간장시가");
}
시가 기준으로 부탁해요 감사 ^^
2017-03-02
98
글번호 107373
답변완료
문의드립니다~
항생매매할때입니다~
시뮬레이션차트에서 우측위에 160틱의 틱데이터를 디스켓모양나온거로 저장누르고나서
몇일지난뒤에 월물바뀌고 나서 누르니깐 제대로 나오지 않아서요~
불러와 보니깐 일봉차트가 뜨면서 이상하게 나오네요~
틱데이터가 일주일단위로 없어지는데요 금요일저녁에 일주일분 틱데이터를 따로 저장할 수 잇는 방법이 있을까요? 원할때 불러와서 다른전략을 대입해서 전략검증도 해보고 싶은데요
일주일치 틱데이터 저장방법에 대해서 문의드립니다~
그리고 장기간 틱데이터 시뮬레이션 하고 싶은데 할 수 있는 방법이 있는지도 궁금합니다~
2017-03-02
103
글번호 107372
답변완료
키움수식 변환요청
키움증권의 McGinley Dynamic 지표인데요, 예스용으로 변환 부탁드립니다.
함수식 : McGinley Dynamic(Period,rate):
eavg(C,Period,1)+((C-(eavg(C,Period,1)) ) / (C/(eavg(C,Period,1))*rate))
Default: Period=10,rate=125
2017-03-02
204
글번호 107371