커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3216
글번호 230811
답변완료
수식문의
매수 피라미딩 진입 이후 평균 수익율 3% 이후 1% 하락시 전량 청산
매도 피라미딩 진입 이후 평균 수익율 3% 이후 1% 하락시 전량 청산
2020-08-21
733
글번호 141631
답변완료
감사합니다
Input:length(10);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),
TL1(0),처리구분(""),T(0),TL2(0),TL3(0);
var : hh(0),ll(0),ii(0),diff(0),TL41(0),TL42(0),TL43(0),TL44(0),TL45(0),TL46(0);
Array:고점[10,5](0),저점[10,5](0);
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then 처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then 처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
T = 1;
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
TL_Delete(TL2);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL_SetExtRight(TL2,False);
TL2 = TL_New(sDate[1],sTime[1],고점[1,1],sdate,sTime,고점[1,1]);
TL_SetColor(TL2,BLUE);
TL_SetSize(TL2,2);
If 고점[3,1] < 고점[2,1] and 고점[2,1] > 고점[1,1] and 저점[2,1] < 저점[1,1] Then
{
sBar = Index - 저점[2,2];
eBar = Index - 저점[1,2];
}
}
}
If 처리구분 == "저점처리" Then
{
T = -1;
lastLoVal = L;
If 저점[1,2] < 고점[1,2] Then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L Then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
TL_Delete(TL3);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL_SetExtRight(TL3,False);
TL3 = TL_New(sDate[1],sTime[1],저점[1,1],sdate,sTime,저점[1,1]);
TL_SetColor(TL3,RED);
TL_SetSize(TL3,2);
If 저점[2,1] < 저점[1,1] and 저점[2,1] < 저점[3,1] and 고점[2,1] > 고점[1,1] Then
{
sBar = Index - 고점[2,2];
eBar = Index - 고점[1,2];
}
}
}
TL_SetSize(TL1,0);
TL_SetColor(TL1,YELLOW);
TL_SetEnd(TL2,sdate,stime,고점[1,1]);
TL_SetEnd(TL3,sdate,stime,저점[1,1]);
TL_SetExtRight(TL2,true);
TL_SetExtRight(TL3,true);
if T != T[1] then
{
if T == 1 Then
{
HH = 고점[2,1];
LL = 저점[1,1];
ii = index-고점[2,2];
diff = abs(HH-LL);
}
Else
{
HH = 고점[1,1];
LL = 저점[2,1];
ii = index-저점[2,2];
diff = abs(HH-LL);
}
TL_Delete(TL41);
TL_Delete(TL42);
TL_Delete(TL43);
TL_Delete(TL44);
TL_Delete(TL45);
TL_Delete(TL46);
TL41 = TL_New(sdate[ii],stime[ii],LL+diff*2.00,sdate,stime,LL+diff*2.00);
TL42 = TL_New(sdate[ii],stime[ii],LL+diff*2.618,sdate,stime,LL+diff*2.618);
TL43 = TL_New(sdate[ii],stime[ii],LL+diff*3.618,sdate,stime,LL+diff*3.618);
TL44 = TL_New(sdate[ii],stime[ii],HH-diff*2.00,sdate,stime,HH-diff*2.00);
TL45 = TL_New(sdate[ii],stime[ii],HH-diff*2.618,sdate,stime,HH-diff*2.618);
TL46 = TL_New(sdate[ii],stime[ii],HH-diff*3.618,sdate,stime,HH-diff*3.618);
TL_SetExtRight(TL41,true);
TL_SetExtRight(TL42,true);
TL_SetExtRight(TL43,true);
TL_SetExtRight(TL44,true);
TL_SetExtRight(TL45,true);
TL_SetExtRight(TL46,true);
TL_SetSize(TL41,2);
TL_SetSize(TL42,2);
TL_SetSize(TL43,2);
TL_SetSize(TL44,2);
TL_SetSize(TL45,2);
TL_SetSize(TL46,2);
}
if T == 1 and T != T[1] and 저점[1,1] > 저점[2,1] Then
Buy();
###### 화살표 로 수정부탁드립니다 #####
2020-08-20
790
글번호 141630
답변완료
함수 수식 부탁드립니다
어떤 조건이후 봉갯수 카운트 하는 함수가 없는 듯 합니다.
예를 들어 BarsSince(crossup(C,ma(C,20)) 와 같은 함수 부탁드립니다.
꽤 편리할 텐대요.
수고하세요~
2020-08-20
862
글번호 141629
답변완료
수식부탁 드립니다
혹서기 무더위에 매번 감사드립니다.
아래의 주봉 수식을 일봉의 수식으로 변환하여 주시기바랍니다
Input : N(20);
var : Energe1(0),Energe2(0);
Energe1 = accumN(H-O,N)/accumN(O-L,N)*100;
Energe2 = accumN(H-C,N)/accumN(C-L,N)*100;
if Energe1 > Energe2 Then
find(1);
감사합니다
2020-08-20
942
글번호 141627
답변완료
문의드립니다
var : T(0);
var1 = dayhigh;
var2 = daylow;
var3 = var1-var2;
value1 = var1-var3*0.236;
value2 = var1-var3*0.500;
value3 = var1-var3*0.764;
if T <= 0 And crossup(c,value1) then
{
T = 1;
}
if T >= 0 And crossdown(c,value1) then
{
T = -1;
}
if T <= 0 And crossup(c,value3) then
{
T = 1;
}
if T >= 0 And crossdown(c,value3) then
{
T = -1;
}
Plot1(1,"지표",iff(T==1,RED,GREEN));
위수식으로 value1, value3 을 전일고가 ,전일저가로 수정부탁드립니다``미리감사드립니다
2020-08-20
820
글번호 141626
매너모드 님에 의해서 삭제되었습니다.
2020-08-20
3
글번호 141625
답변완료
부탁 드립니다.
도움에 감사 드립니다.
1)타주기(분봉용_예를 들어 10분봉 차트에서 60분봉 지표),
2)타주기(일봉용_예를 들어 60분봉 차트에서 일봉 지표) 부탁 드립니다.
미리 경배로 감사 인사 올립니다.
var : src(0),sp(0),dt(0);
src = (H+L)/2;
sp = (4*src + 3*src[1] + 2*src[2] + src[3]) / 10.0;
if CurrentBar >= 1 then
{
dt = (.0962*sp + .5769*(sp[2]));
}
참고지표1)
input :ntime(60),P(10),sig(5);
var : S1(0),D1(0),TM(0),TF(0),cnt(0);
var : C1(0),CC(0),VV(0),idx(0),sum1(0),mav1(0),sum2(0),mav2(0);
Array : value[100](0),diff[100](0);
if Bdate != Bdate[1] Then
{
S1 = TimeToMinutes(stime);
D1 = sdate;
}
if D1 > 0 then
{
if sdate == D1 Then
TM = TimeToMinutes(stime)-S1;
Else
TM = TimeToMinutes(stime)+1440-S1;
TF = TM%ntime;
if Bdate != Bdate[1] or
(Bdate == Bdate[1] and ntime > 1 and TF < TF[1]) or
(Bdate == Bdate[1] and ntime > 1 and TM >= TM[1]+ntime) or
(Bdate == Bdate[1] and ntime == 1 and TM > TM[1]) Then
{
idx = idx+1;
C1 = CC[1];
VV = 0;
For cnt = 1 to 99
{
value[cnt] = value[cnt-1][1];
diff[cnt] = diff[cnt-1][1];
}
}
2020-08-20
870
글번호 141624
답변완료
문의 드립니다.
노고에 감사드립니다.
수식 부탁드립니다.
----------------------------------------------------------------------------------------
▶분봉1개에서 진입명과 손절, 청산명을 각각 달리해서 아래와 같이 여러번 진입하려고 합니다.
아래 횟수와 순서대로 부탁드립니다.
------------------------------------
*전봉고가를 상향돌파하면 즉시 매수진입.
*전봉 시가 또는 종가를 하향돌파하면 즉시 매도스위칭.
*전봉고가를 상향돌파하면 즉시 매수스위칭.
*전봉 시가 또는 종가를 하향돌파하면 즉시 손절.
*시가+전봉레인지*0.5 = 즉시 매수진입.(분봉적용)
*현재봉 시가에 오면 즉시 손절.
*손절되지 않으면 다음봉 시가에 모두 청산.
------------------------------------------
감사합니다.
2020-08-20
833
글번호 141617
답변완료
문의드립니다
Buy("",AtMarket);
Sell("",AtMarket);
이렇게 하고 우선1호가로 지정해도
체결이 잘 안되는데
어떻게 하면 '바로바로' 체결할 수 있는지요?
문의드립니다.
2020-08-24
806
글번호 141608