커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3433
글번호 230811
파워 님에 의해서 삭제되었습니다.
2023-12-20
0
글번호 175041
파워 님에 의해서 삭제되었습니다.
2023-12-20
666
글번호 175040
답변완료
간단한 수식 부탁드립니다.
예전에 요청해서 만들어주신 수식을 바탕으로 물타기 피라미팅 전략을 운용중입니다.
아래와 같이, 최근 진입 시점보다 일정 비율 떨어지면 추가로 진입을 하도록 되어 있습니다.
이렇게 하니 진입 횟수가 줄어드는 느낌이 있어서 여기에 진입조건 하나를 더 추가하려고 합니다.
if MarketPosition == 1 Then
{
if sTime < 153000 Then
Buy("bb",AtLimit,LatestEntryPrice(0)*(1-물타기/100));
}
물타기 진입 조건
1) 이미 매수 수량이 있는 경우에
2) 최근 매수 진입보다 0.5% 더 떨어지면 진입 (위의 수식에 이미 반영되어 있는 조건)
3) 가장 최근 익절 가격보다 1% 떨어지면 진입
1)이 만족한 상태에서, 2 or 3이 만족하면 추가 진입하도록 작성 부탁드립니다.
참고로 익절은 진입 가격에서 1% 상승하면 익절되도록 설정해둔 상태입니다.
감사합니다
2023-12-20
805
글번호 175039
답변완료
시스템식 부탁드립니다.
항상 도움 주셔서 감사합니다.
종목: 해외선물(통화종목)
차트 : 60분봉
요청식1 : 아래와 같은 시스템식에서 평가 잔고금액(예수금+평가금액)이
500$ 이하이면 전체청산 후 매매중지하는 시스템식 부탁드립니다.
(보통 해외선물 매매시 예수금(증거금)을 원화로 가지고 있는데
$(달러)로 코딩 가능한가요?-원화 예수금이든 달러 예수금이든
평가금액을 체크후 일정금액 이상 손실이면 청산하고 싶습니다.)
요청식2 : 아래와 같은 시스템식에서 평가 잔고금액(예수금+평가금액)이
1,000$ 이상이면 전체청산 후 매매중지하는 시스템식 부탁드립니다.
(보통 해외선물 매매시 예수금(증거금)을 원화로 가지고 있는데
$(달러)로 코딩 가능한가요?-원화 예수금이든 달러 예수금이든
평가금액을 체크후 일정금액 이상 수익이면 청산하고 싶습니다.)
요청식3 : 아래와 같은 시스템식에서 가격이 떨어져서 손실이 나면
2배로 추가 매수를 들어가는데
진입한 거래별로 일정한 간격(손절간격)으로 손절(청산)을 설정하고 싶습니다.
예) 1계약 = 100포인트 가격에 매수진입
2계약 = 90포인트 가격에 매수진입
4계약 = 80포인트 가격에 매수진입
위와 같이 진입했다고 가정시
1계약 = 100포인트 매수진입에 대해 가격이 50포인트 도달시 1계약 청산
2계약 = 90포인트 매수진입에 대해 가격이 40포인트 도달시 2계약 청산
4계약 = 80포인트 매수진입에 대해 가격이 30포인트 도달시 4계약 청산
요청식4 : 아래와 같은 시스템식에서 매수진입 횟수가 10회 이상이면
모두 청산후 매매중지 시스템식 부탁드립니다.
요청식5 : 아래와 같은 시스템식에서 매수진입 계약이 100계약 이내까지만
추가 진입하도록 시스템식 부탁드립니다.
또는 매수진입 횟수가 10회 이내까지만 추가 진입하도록 시스템식 부탁드립니다.
요청식6 : 아래와 같은 시스템식에서 잔고는 빼고 평가손실 금액이
-100$ 이상이면 전체청산 후 매매중지하는 시스템식 부탁드립니다.
요청식7 : 아래와 같은 시스템식에서 잔고는 빼고 평가이익 금액이
100$ 이상이면 전체청산 후 매매중지하는 시스템식 부탁드립니다.
#--------------------------------------------
input : pst(1) ;
input : 진입가격(10) ;
input : 청산가격(10) ;
var : vol(0) ;
value1 = 진입간격/pointvluae ;
value2 = 청산간격/pointvluae ;
if pst == 1 Then
{
if MarketPosition == 0 and TotalTrades == TotalTrades[1] Then
{
vol = 1;
Buy("b",OnClose,Def,vol);
}
if MarketPosition == 1 Then
{
if MaxEntries > MaxEntries[1] Then
vol = vol*2;
Buy("bb",AtLimit,EntryPrice(0)-PriceScale*(value1*MaxEntries),vol);
ExitLong("bp",AtLimit,AvgEntryPrice+PriceScale*Value2);
}
}
#--------------------------------------------
감사합니다.
2023-12-20
855
글번호 175038
답변완료
부탁드립니다2
수고 많으십니다.
아래 1)거래량 지표와 아래 2)의 Data2 거래량 지표를 합친 수식을 만들고자합니다.
번거롭더라도 도와주시면 감사하겠습니다.
오늘도 좋은하루 되시길 바랍니다.
====================
1)지표
input : R1(0),G1(0),B1(0);
input : R2(0),G2(0),B2(0);
var : hh(0),ll(0);
if Bdate != Bdate[1] Then
{
var1 = 0;
Var2 = Upvol-DownVol;
}
var1 = var1 + (Upvol-DownVol);
if CurrentDate == sDate Then
Plot1(var1,"당일실매수거래량",iff(var1 > 0,RGB(0,0,0),RGB(0,0,0)));
if CurrentDate == sDate Then
plot2(Var2,"첫봉종가");
if Bdate != Bdate[1] Then
{
hh = var1;
ll = var1;
}
Else
{
if var1 > hh Then
hh = var1;
if var1 < ll Then
ll = var1;
}
if CurrentDate == sDate Then
plot11(Var2+75,"첫봉종가+50");
if Bdate != Bdate[1] Then
{
hh = var1;
ll = var1;
}
Else
{
if var1 > hh Then
hh = var1;
if var1 < ll Then
ll = var1;
}
if CurrentDate == sDate Then
plot12(Var2-75,"첫봉종가-50");
if Bdate != Bdate[1] Then
{
hh = var1;
ll = var1;
}
Else
{
if var1 > hh Then
hh = var1;
if var1 < ll Then
ll = var1;
}
if CurrentDate == sDate Then
{
Plot3(hh,"최고");
plot4(ll,"최저");
plot5(ll+(hh-ll)*0.25,"25.0%");
plot6(ll+(hh-ll)*0.382,"38.2%");
plot7(ll+(hh-ll)*0.500,"50.0%");
plot8(ll+(hh-ll)*0.508+0.08,"50+0.02%");
plot9(ll+(hh-ll)*0.618,"61.8%");
plot10(ll+(hh-ll)*0.75,"75.0%");
plot13(ll+(hh-ll)*0.125,"12.5%");
plot14(ll+(hh-ll)*0.875,"87.5%");
plot15(ll+(hh-ll)*0.500+70,"10+60%");
plot16(ll+(hh-ll)*0.500-70,"220-60%");
Plot17(var1+20,"당일실매수거래량2",iff(var1 > 0,RGB(0,0,0),RGB(0,0,0)));
plot18(ll+(hh-ll)*0.243,"25.30%");
plot19(ll+(hh-ll)*0.743,"75.30%");
PlotBaseLine1(0);
}
2) 지표
var : C2(0,Data2),H2(0,Data2),L2(0,Data2),cnt(0,Data2);
var : Sidx(0,Data2),Sidx1(0,Data2),Eidx(0,Data2),Eidx1(0,Data2),Pre1(0,Data2);
C2 = Data2(c);
if Data2(Bdate != Bdate[1]) Then
{
H2 = C2;
L2 = C2;
Sidx = data2(Index);
Sidx1 = Sidx[1];
Eidx1 = Eidx[1];
}
Eidx = data2(Index);
if data2(Bdate != Bdate[1] or (Bdate == bdate[1] and C2 > h2)) Then
h2 = C2;
if data2(Bdate != Bdate[1] or (Bdate == Bdate[1] and C2 < l2)) Then
l2 = C2;
if Sidx1 > 0 Then
{
pre1 = 0;
For cnt = data2(Index)-Eidx1 to data2(Index)-Sidx1
{
if data2(sDate[cnt] < sDate and sTime[cnt] <= sTime) Then
{
pre1 = C2[cnt];
cnt = data2(Index-Sidx1+1);
}
}
}
// if CurrentDate == sDate and Data1(sDate) == Data2(sDate) Then
{
Plot1(C2,"참조",IFf(C2 >0,RGB(0,0,0),RGB(0,0,0)));
Plot2(H2,"최고");
Plot3(L2,"최저");
Plot4(pre1,"전일");
PlotBaseLine1(0);
Plot5(Data2(OpenD(0)),"D2당일시가");
Plot6(Data2(HighD(0)),"D2당일고가");
Plot7(Data2(LowD(0)),"D2당일저가");
Plot8(Data2(LowD(0)+(HighD(0)- LowD(0))*0.236),"23.6%");
Plot9(Data2(LowD(0)+(HighD(0)- LowD(0))*0.764),"76.4%");
Plot10(Data2(LowD(0)+(HighD(0)- LowD(0))*0.382),"38.2%");
Plot11(Data2(LowD(0)+(HighD(0)- LowD(0))*0.618),"61.8%");
Plot12(Data2(LowD(0)+(HighD(0)- LowD(0))*0.50),"50.0%");
Plot13(Data2(LowD(0)+(HighD(0)- LowD(0))*0.50-50),"-50.0%");
}
2023-12-20
1078
글번호 175037
답변완료
부탁드립니다.
안녕하세요?
아래 지표에서 2일 시작선에서 pt1과, 2일 시작선에서 pt2사이를 채우기하는것이 아니라
PT1과 PT2 사이를 채우기하고자 합니다.
노고에 감사드리며 부탁드려봅니다.
===================================
input : p(2),pt1(1.25),pt2(1.5);
input : 굵기1(5),R1(255),G1(0),B1(0);
input : 굵기2(5),R2(255),G2(0),B2(0);
input : 굵기3(5),R3(0),G3(0),B3(255);
input : 굵기4(5),R4(0),G4(0),B4(255);
var : cnt(0),sum(0),mav(0);
var : TL1(0),TL2(0),TL3(0),TL4(0),TL5(0);
var : box1(0),box2(0),box3(0),box4(0);
sum = DayOpen(0);
if P >= 2 Then
{
For cnt = 1 to P-1
{
sum = sum + DayClose(cnt);
}
}
mav = sum/P;
if Index == 0 or (sTime >= 152000 and sTime[1] < 152000) Then
{
var1 = sDate;
Var2 = stime;
}
if Bdate != Bdate[1] Then
{
if var1 > 0 and Var2 > 0 Then
{
#mav+pt2 ~ mav+pt1
box1 = box_new(var1,Var2,mav+pt2,sDate,sTime,mav+pt1);
#mav+pt1 ~ mav
box2 = box_new(var1,Var2,mav+pt1,sDate,sTime,mav);
#mav ~ mav-pt1
box3 = box_new(var1,Var2,mav,sDate,sTime,mav-pt1);
#mav-pt1 ~ mav-pt2
box4 = box_new(var1,Var2,mav-pt2,sDate,sTime,mav-pt1);
box_SetColor(box1,RGB(R1,G1,B1));
box_SetColor(box2,RGB(R2,G2,B2));
box_SetColor(box3,RGB(R3,G3,B3));
box_SetColor(box4,RGB(R4,G4,B4));
box_SetSize(box1, 굵기1);
box_SetSize(box2, 굵기2);
box_SetSize(box3, 굵기3);
box_SetSize(box4, 굵기4);
Box_SetFill(box1,true,10);#채우기 투명도 10
Box_SetFill(box2,true,10);#채우기 투명도 10
Box_SetFill(box3,true,10);#채우기 투명도 10
Box_SetFill(box4,true,10);#채우기 투명도 10
}
}
Else
{
if sTime < 150000 Then
{
box_SetBegin(box1,var1,Var2,mav+pt2);
box_SetEnd(box1,sDate,sTime,mav+pt1);
box_SetBegin(box2,var1,Var2,mav+pt1);
box_SetEnd(box2,sDate,sTime,mav);
box_SetBegin(box3,var1,Var2,mav);
box_SetEnd(box3,sDate,sTime,mav-pt1);
box_SetBegin(box4,var1,Var2,mav-pt1);
box_SetEnd(box4,sDate,sTime,mav-pt2);
}
}
2023-12-20
858
글번호 175036
답변완료
문의드립니다
a=c>c(1)*p1;
b=c>h(1);
d=c(1)<l(2);
조건=a && b && d;
고가=VALUEWHEN(1,조건,DAYHIGH());
저가=VALUEWHEN(1,조건,DAYLOW());
중심=(고가+저가)/2;
결과=crossdown(c,저가);
결과2=crossup(c,고가);
s=sum(1);
a_cnt=valuewhen(1,조건,s);
b_cnt=valuewhen(1,결과,s);
c_cnt=valuewhen(1,결과2,s);
결과3=a_cnt<b_cnt && b_cnt<c_cnt;
결과4=결과3(1) && 저가>c;
결과값=countsince(조건,결과4)==1;
결과값2=결과4 && 결과값;
시가=valuewhen(1,결과값2(1),o);
시가2=(시가*p2)*p2;
저가이탈=crossdown(l,시가2);
d_cnt=valuewhen(1,결과값2,s);
e_cnt=valuewhen(1,저가이탈,s);
조건2=d_cnt<e_cnt;
결과값3=countsince(결과값2,조건2)==1;
결과값4=조건2 && 결과값3
p1=1.03
p2=0.97
종목검색식으로 변환 부탁드립니다!
위 조건에 해당하는 봉을 화살표로 표시하는 지표식도 같이 부탁드려요!
추운데 감기조심하세요!
2023-12-19
942
글번호 175035
답변완료
MACD
아래는 얼마전 "MACD(7,16)이 0돌파하고 익일에 역이평배열이 상승전환"하는 수식을 작성해주신것입니다.
감사히 쓰다보니 개선할 점이 있어 요청드립니다.
요청의 요지는,
이것을
- MACD 0선돌파와 금일 동시에 발생하는 것과
- MACD 0선돌파일 익익일에 역이평 상승전환이 발생하는 것을
아래 수식에 추가하여 한 수식에서 구하고자 합니다.
즉, MACD발생일을 기준으로 역이평 상승전환이 0봉, +1봉(현 수식), +2봉에
나오는 것입니다.
동시에 나오는(0봉) 것이 함께 만들기 어렵다면,
아래 수식에 +2봉 것만 추가하셔도 무방하겠읍니다.
(이 경우, MACD발생종목 하나하나 매일 확인해야 함)
부탁드리겠읍니다.
이상
===========================================================================
var : A1(0),A2(0),A3(0),A4(0),A5(0),A6(0),B1(False),B2(False),B3(False),B4(False);
VAR : AA1(0),AA2(0),AA3(0),AA4(0),조건(False);
A1=MA(C,3);
A2=MA(C,5);
A3=MA(C,8);
A4=MA(C,10);
A5=MA(C,20);
A6=MA(C,60);
B1=A1<A5 && A5<A6;
B2=A2<A5 && A5<A6;
B3=A3<A5 && A5<A6;
B4=A4<A5 && A5<A6;
IF B1 TheN {AA1=1;} ElsE {AA1=0;}
IF B2 TheN {AA2=1;} ElsE {AA2=0;}
IF B3 TheN {AA3=1;} ElsE {AA3=0;}
IF B4 TheN {AA4=1;} ElsE {AA4=0;}
조건=AA1[1]+AA2[1]+AA3[1]+AA4[1]>=1 && AA1+AA2+AA3+AA4==0 && C>O;
var1 = macd(7,16);
Condition1 = CrossUp(var1,0);
IF Condition1[1] == true and 조건 && !조건[1] TheN
Find(1);
2023-12-19
1086
글번호 175034
파워 님에 의해서 삭제되었습니다.
2023-12-19
1
글번호 175033