커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4710
글번호 230811
답변완료
연산에 대해 질문드립니다
1.
If (var1 or var2)<C
If (var1<C) or (var2<C)
위 두게가 같은 것인 가요?
2. If ((var1<C) or (var2<C)) and var3>C 이 수식을 통과하는게 아래 3경우가 맞지요?
var1이 종가보다 작고, var3은 종가보다 클 경우
var2가 종가보다 작고, var3은 종가보다 클 경우
var1과 var2 모두 종가보다 작고, var3은 종가보다 클 경우
언제나 친절한 답변에 감사합니다.
2015-12-14
129
글번호 93367
답변완료
문의드립니다.
이미 매수한 종목에 대한 매도만을 시스템으로 실행하고자 합니다.
매도식은 1분봉상 90일 선을 데드크로스 할 경우 전량 매도입니다.
2015-12-14
126
글번호 93366
답변완료
함수수정요청(11-1호)
안녕하세요?
함수 수정 요청드립니다.
아래의 함수에서 SetStopInactivity(3,10,PercentStop)에 의해 청산이 되면 청산이후 당일 추가진입이 안되도록 수정요청드립니다.
var : entry1(0);
var : ho1(0),OL1(0),HL1(0);
var : maho1(0),maOL1(0),maHL1(0);
var : cnt1(0),sumho1(0),sumOL1(0),sumHL1(0);
var : EntryCnt1(0);
var : V1(0),V2(0),V3(0),V4(0),V5(0);
var : V6(0),V7(0),V8(0),V9(0),V10(0);
if bdate != bdate[1] Then
entry1 = 0;
if MarketPosition != 0 and MarketPosition != MarketPosition[1] Then
entry1 = entry1+1;
ho1 = Dayhigh-Dayopen;
OL1 = DayOpen-DayLow;
HL1 = DayHigh-DayLow;
sumho1 = 0;
sumOL1 = 0;
sumHL1 = 0;
for cnt1 = 1 to 10{
sumho1 = sumho1 + (dayhigh(cnt1)-dayopen(cnt1));
sumOL1 = sumOL1 + (DayOpen(cnt1)-DayLow(cnt1));
sumHL1 = sumHL1 + (DayHigh(cnt1)-DayLow(cnt1));
}
maho1 = sumho1/10;
maOL1 = sumOL1/10;
maHL1 = sumHL1/10;
V1 = dayopen(0)+maho1;
V2 = DayOpen(0)-maOL1;
V3 = DayOpen(0)+maHL1;
V4 = DayOpen(0)-maHL1;
V5 = NthMaxList(1,V1,V2,V3,V4);
V6 = NthMaxList(2,V1,V2,V3,V4);
V9 = NthMaxList(3,V1,V2,V3,V4);
V10 = NthMaxList(4,V1,V2,V3,V4);
V7 = (V5+V10)/2;
V8 = (V6+V9)/2;
if MarketPosition == 0 and entry1 == 0 Then{
if V7 > V8 Then
sell("s1",AtStop,v7);
if V7 < V8 Then
sell("s2",Atlimit,v8);
}
if MarketPosition == -1 and IsEntryName("s1") == true Then{
ExitShort("sp1",atlimit,V9);
ExitShort("sl1",AtStop,V6);
}
if MarketPosition == -1 and IsEntryName("s2") == true Then{
ExitShort("sp2",atlimit,V9);
ExitShort("sl2",AtStop,V6);
}
var : TF(0);
var : Xtime(0), Etime(false),cnt(0),mav1(0),mav2(0);
var : HV(0),LV(0),HV1(0),LV1(0),HV2(0),LV2(0);
Array : HH[50](0),LL[50](0),CC[50](0);
mav1 = ma(c,5);
mav2 = ma(C,20);
TF = TimeToMinutes(stime)%30;
if Bdate != Bdate[1] Then{
Etime = true;
if stime >= 090000 Then
Xtime = 050000;
Else
Xtime = 060000;
}
if Bdate != Bdate[1] or (TF < TF[1] and stime > stime[1]) or date != date[1] Then{
HH[0] = H;
LL[0] = L;
for cnt = 1 to 49{
HH[cnt] = HH[cnt-1][1];
LL[cnt] = LL[cnt-1][1];
CC[cnt] = CC[cnt-1][1];
}
}
if H > HH[0] Then
HH[0] = H;
if L < LL[0] Then
LL[0] = L;
CC[0] = C;
if HH[25+2] > 0 Then{
HV = HH[0];
LV = LL[0];
HV1 = HH[1];
LV1 = LL[1];
HV2 = HH[2];
LV2 = LL[2];
for cnt = 0 to 25{
if HH[cnt] > HV Then
HV = HH[cnt];
if LL[cnt] < LV Then
LV = LL[cnt];
if HH[cnt+1] > HV Then
HV = HH[cnt+1];
if LL[cnt+1] < LV Then
LV = LL[cnt+1];
if HH[cnt+2] > HV Then
HV = HH[cnt+2];
if LL[cnt+2] < LV Then
LV = LL[cnt+2];
}
var1 = (HV+LV)/2;
var2 = (HV1+LV1)/2;
var3 = (HV2+LV2)/2;
if Etime == true then{
if MarketPosition == 0 and CC[0] > var1 and CC[1] < var2 and CC[2] < var3 and C >= daylow+0.5 Then
buy("b",AtMarket);
if MarketPosition == 1 and c <= highest(H,BarsSinceEntry)-0.5 and CrossDown(mav1,mav2) Then
ExitLong("bx",AtMarket);
}
}
if stime == Xtime or (stime > Xtime and stime[1] < Xtime) Then{
Etime = false;
ExitLong();
}
SetStopLoss(1.5,PercentStop);
SetStopProfittarget(3,PercentStop);
SetStopInactivity(3,10,PercentStop);
2015-12-13
138
글번호 93363
답변완료
문의드립니다
var : cnt(0),count(0),Pergap(0);
count = 0;
for cnt = 0 to 20{
if sdate == EntryDate(cnt) Then
count = count+1;
}
Pergep = abs(dayclose(1)-dayopen(0));
if perdayrange >= 3 Then{
#첫봉신호
if sTime == 144900 Then{
buy("b1",AtStop,NextBarOpen +0.3);
sell("s1",AtStop,NextBarOpen -0.3);
}
if stime == 151500 Then{
buy("b4",AtStop,NextBarOpen +0.3);
sell("s4",AtStop,NextBarOpen -0.3);
}
if stime == 151600 Then{
buy("b5",AtStop,NextBarOpen +0.3);
sell("s5",AtStop,NextBarOpen -0.3);
#두번째봉부터 11시까지
if stime >= 090000 and count < 1 and stime < 135900 Then{
if MarketPosition == 0 Then{
buy("b",AtStop,DayOpen +0.3);
sell("s",AtStop,DayOpen -0.3);
안녕하십니까
종가가 달라서 9시 1분봉에 진입하지 않고 2분봉에 진입하여 저렇게 설정되어있습니다..
그런데 전전날에 폭이 3이상이고 전날에 폭이 3이하인데 첫봉신호
설정한것들이 거래를 합니다.
이것을 방지하고 전날에만 폭이 3이상일 때 거래하고 싶은데 어떻게 해야하죠?
감사합니다.
2015-12-13
137
글번호 93362
아슬란 님에 의해서 삭제되었습니다.
2015-12-13
10
글번호 93361
답변완료
문의드립니다.
1.
Input:Rsi변동폭(0.5);
Var:j(0),상승(100),하락(-100),양방향(2),추세(0),
파동선(0),Rsi파동선(0),방향(0),추세선(0);
Array:고[20](0),저[20](0),고Bar[20](0),저Bar[20](0),
Rsi고[20](0),Rsi저[20](0),Rsi고Bar[20](0),Rsi저Bar[20](0);
Input : RSIP(14), Period(50),dv(2.1);
var : RSIV(0),Mid(0),BBup(0),BBdn(0),RSIBandB(0);
RSIV = RSI(RSIP);
Mid = ma(RSIV,Period);
BBup = Mid+STD(RSIV,Period)*dv;
BBdn = Mid-STD(RSIV,Period)*dv;
RSIBandB = (RSIv - BBdn)/(BBup - BBdn);
#==========================================#
# 전고점,전저점 index 증가
#==========================================#
For j = 1 To 19
{
Rsi고Bar[j] = Rsi고Bar[j] + 1;
Rsi저Bar[j] = Rsi저Bar[j] + 1;
저Bar[j] = 저Bar[j] + 1;
고Bar[j] = 고Bar[j] + 1;
}
#==========================================#
# 최근 고,저 갱신
#==========================================#
If Rsi고[0] <= RSIBandB || Rsi고[0] == 0 || IsNaN(Rsi고[0]) == True Then
{
Rsi고[0] = RSIBandB;
Rsi고Bar[0] = 0;
}
Else
Rsi고Bar[0] = Rsi고Bar[0] + 1;
If Rsi저[0] >= RSIBandB || Rsi저[0] == 0 || IsNaN(Rsi저[0]) == True Then
{
Rsi저[0] = RSIBandB;
Rsi저Bar[0] = 0;
}
Else
Rsi저Bar[0] = Rsi저Bar[0] + 1;
If 고[0] <= H || 고[0] == 0 || IsNaN(고[0]) == True Then
{
고[0] = H;
고Bar[0] = 0;
}
Else
고Bar[0] = 고Bar[0] + 1;
If 저[0] >= L || 저[0] == 0 || IsNaN(저[0]) == True Then
{
저[0] = L;
저Bar[0] = 0;
}
Else
저Bar[0] = 저Bar[0] + 1;
#==========================================#
# 추세방향 결정
#==========================================#
If Rsi저[0][1] + Rsi변동폭 > RSIBandB[1] &&
Rsi저[0][1] + Rsi변동폭 <= RSIBandB Then 방향 = 상승;
If Rsi고[0][1] - Rsi변동폭 < RSIBandB[1] &&
Rsi고[0][1] - Rsi변동폭 >= RSIBandB Then 방향 = 하락;
#==========================================#
# 추세변화에 따른 변곡점 처리
#==========================================#
If 방향[1] == 하락 && 방향 == 상승 Then
{
For j = 18 DownTo 1
{
Rsi저[j+1] = Rsi저[j];
Rsi저Bar[j+1] = Rsi저Bar[j];
저[j+1] = 저[j];
저Bar[j+1] = 저Bar[j];
}
Rsi저[1] = Rsi저[0];
Rsi저Bar[1] = Rsi저Bar[0];
Rsi파동선 = Rsi저[0];
Rsi저[0] = RSIBandB;
Rsi저Bar[0] = 0;
Rsi고[0] = RSIBandB;
Rsi고Bar[0] = 0;
저[1] = 저[0];
저Bar[1] = 저Bar[0];
파동선 = 저[0];
저[0] = L;
저Bar[0] = 0;
고[0] = H;
고Bar[0] = 0;
}
Else If 방향[1] == 상승 && 방향 == 하락 Then
{
For j = 18 DownTo 1
{
Rsi고[j+1] = Rsi고[j];
Rsi고Bar[j+1] = Rsi고Bar[j];
고[j+1] = 고[j];
고Bar[j+1] = 고Bar[j];
}
Rsi고[1] = Rsi고[0];
Rsi고Bar[1] = Rsi고Bar[0];
Rsi파동선 = Rsi고[0];
Rsi고[0] = RSIBandB;
Rsi고Bar[0] = 0;
Rsi저[0] = RSIBandB;
Rsi저Bar[0] = 0;
고[1] = 고[0];
고Bar[1] = 고Bar[0];
파동선 = 고[0];
고[0] = H;
고Bar[0] = 0;
저[0] = L;
저Bar[0] = 0;
}
Else If 방향[1] == 하락 && 방향 == 하락 Then
{
If Rsi고[1] < Rsi고[0] &&
Rsi고[0][1] - Rsi변동폭 <= RSIBandB[1] &&
Rsi고[0][1] - Rsi변동폭 > RSIBandB Then
{
Rsi고[1] = Rsi고[0];
Rsi고Bar[1] = Rsi고Bar[0];
Rsi파동선 = Rsi고[0];
Rsi고[0] = RSIBandB;
Rsi고Bar[0] = 0;
}
If 고[1] < 고[0] &&
고[0] > H Then
{
고[1] = 고[0];
고Bar[1] = 고Bar[0];
파동선 = 고[0];
고[0] = H;
고Bar[0] = 0;
}
}
Else If 방향[1] == 상승 && 방향 == 상승 Then
{
If Rsi저[1] > Rsi저[0] &&
Rsi저[0][1] + Rsi변동폭 >= RSIBandB[1] &&
Rsi저[0][1] + Rsi변동폭 < RSIBandB Then
{
Rsi저[1] = Rsi저[0];
Rsi저Bar[1] = Rsi저Bar[0];
Rsi파동선 = Rsi저[0];
Rsi저[0] = RSIBandB;
Rsi저Bar[0] = 0;
}
If 저[1] > 저[0] &&
저[0] < L Then
{
저[1] = 저[0];
저Bar[1] = 저Bar[0];
파동선 = 저[0];
저[0] = L;
저Bar[0] = 0;
}
}
#==========================================#
# 지표식 출력
#==========================================#
If Rsi파동선[1] != Rsi파동선 Then {
Plot1(파동선); //적당껏 수평이동
# PlaySound("C:₩예스트레이더₩data₩Sound₩sound6.wav");
}
Else If LastBarOnChart == 1 Then {
plot1(Iff(방향 == 상승,고[0],저[0]));
#PlaySound("C:₩예스트레이더₩data₩Sound₩sound6.wav");
}
#상승 다이버전스 : 주가의 저점 하락 + 지표의 저점 상승
If 저[2] > 저[1] && Rsi저[2] < Rsi저[1] Then
{
추세선 = (저[1]-저[2])/(저Bar[2]-저Bar[1])*저Bar[2] + 저[2];
Plot2(추세선,"상승다이버전스");
}
#하락 다이버전스 : 주가의 고점 상승 + 지표의 고점 하락
if 고[2] < 고[1] && Rsi고[2] > Rsi고[1] Then
{
추세선 = (고[1]-고[2])/(고Bar[2]-고Bar[1])*고Bar[2] + 고[2];
Plot3(추세선,"하락다이버전스");
}
...................................................................................
2.
input : 고점(265),저점(264);
var1 = 고점-저점;
plot1(고점+var1*1.000);
plot2(고점+var1*0.618);
plot3(고점+var1*0.236);
plot4(고점);
plot5(저점+var1*0.724);
plot6(저점+var1*0.618);
plot7(저점+var1*0.500);
plot8(저점+var1*0.382);
plot9(저점+var1*0.236);
plot10(저점);
plot11(저점-var1*0.236);
plot12(저점-var1*0.618);
plot13(저점-var1*1.000);
....................................................................................
1번지표와 2번지표를 결합해서 하나로 만들고 싶습니다.
1번을 실행해 보면 챠트에 파동선이 그려지는데..(다이버젼스선은 생략해 주세요)
그 파동선의 고점과 저점 (즉 꺽은선이 생기면)이 생기면
그에 해당되는 피보나치 비율을 수평선으로 그려 주셨으면 합니다.
다시 파동선에서 꺽은선이 생기면 그에 따라 피보나치 수평선 다섯개도 다시 갱신해 주시구요.
가능한 대로 표현해 주세요
감사합니다.
2015-12-13
197
글번호 93360
답변완료
수식수정바랍니다
안녕하세요.
아래수식은 해선에서 직전30분봉의 고가 저가 종가를 현재30분동안 표시하는데요
이게 23시30-24시까지봉이(30분) 원래표시는 24시부터24시30분까지 인데
24시30분부터 1시까지(30분늦게) 표시가 되고, 24시부터 24시30분까지 30분간봉은
아에 표시가 되지않네요.이것좀 수정바랍니다.
input : Atime1(30),Atime2(60);
var : TF1(0),H1(0),H11(0),L1(0),L11(0),C1(0),C11(0);
var : TF2(0),H2(0),H21(0),L2(0),L21(0),C2(0),C21(0);
TF1 = TimeToMinutes(stime)%Atime1;
if Bdate != Bdate[1] or (TF1 < TF1[1] and stime > stime[1]) Then{
H1 = H;
L1 = L;
H11 = H1[1];
L11 = L1[1];
C11 = C1[1];
}
if H > H1 Then
H1 = H;
if L < L1 Then
L1 = L;
C1 = C;
TF2 = TimeToMinutes(stime)%Atime2;
if Bdate != Bdate[1] or (TF2 < TF2[1] and stime > stime[1]) Then{
H2 = H;
L2 = L;
H21 = H2[1];
L21 = L2[1];
C21 = C2[1];
}
if H > H2 Then
H2 = H;
if L < L2 Then
L2 = L;
C2 = C;
plot1(H11);
plot2(L11);
plot3(C11);
plot4(H21);
plot5(L21);
plot6(C21);
수고하십시요
2015-12-13
130
글번호 93359
답변완료
수식 수정부탁드립니다.
Input :SP(8),SSP(9);
var1 = ma(c,SP);
var2 = ma(C,SSP);
VAR3 = (VAR1+VAR2)/1.5;
var4 = ENVELOPEDOWN(10,4);
var5 = LOWEST(C,10);
var6 = BOLLBANDUP(10,1);
var7 = BOLLBANDUP(10,1.5);
VAR8 = BOLLBANDUP(10,2);
{If Var4[1] < Var5[1] and (Crossup(C,Var6) OR CrossUP(C,Var7) AND CrossUP(C,Var8)) Then
VALUE1 = Var3[1];}
if CountIF(value1<l,20)[1] then
//1봉전을 기준으로 최근 20봉동안 저가가 모두 VALUE1보다 큰경우를 검색하고 싶습니다.
VAR9=1;
Else
VAR9=0;
FIND(vAR9);
2015-12-13
141
글번호 93358
답변완료
문의 드립니다
var : TL28(0);
TL_Delete(TL28);
TL28 = TL_New(sdate[c[0]],sTime[c[0]],c[0],sdate,stime,c);
TL_SetSize(TL28,4);
TL_SetExtRight(TL28,true);
#TL_SetExtleft(TL28,true);
TL_SetColor(TL28,rgb(255,0,128));
}
위 수식에서 수평선이 좌우로 모두 연장선이 그려 집니다
TL_SetExtleft 이 설정은 안한 상태에서도 계속 그려지는데
수평선 발생 시점에서 우측으로만 그려 지도록 해 주세요
둘째 질문은요
위 수식에서
52개 봉에서의 최고점과 최저점의 수평선을 긋고 싶은데
발생시점에서 좌측연장선은 지우고 우측으로만 연장되도록 그리고 싶습니다.
감사 합니다
2015-12-13
115
글번호 93357