커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

지표

> 수식부탁드립니다 3가지 질문부탁드립니다 1]12달 날짜 지정입니다 2]?3개월도 날짜지정하면 가능한가요 3}? 1년단위도 날짜지정하면 가능한가요 가능하다면 시고저중종부탁드립니다. ___________________________________________ 12달 1)2021-01-30부터 2021년-02-28 2)0000-00-00부터~0000-00-00까지 3) 4) 5) | |.......... 1]1년 사용하려합니다 2021-10-25부터2021-11-25 2021-10-25부터2021-11-25 2021-10-25부터2021-11-25 . . . 2]2021-10-25부터2021-11-25일까지 시고저중 종 고가대비N%아래저가대비N% 부탁드립니다.
프로필 이미지
호정0688
2021-11-05
426
글번호 153414
지표
답변완료

지표문의입니다

수고가 많으십니다. 아래 수식을 적용할려고 보니 첨부그림과 같이 그게 나타나서 실행이 안됩니다. 무엇이 문제인건지.. 그리고 아래수식을 시스템으로 적용시킬수 있는 방법은 없는건지 궁금합니다. 감사합니다. //===================================================// Input:ChgRate(0.25),굵기(1),크기(11); Var:TL1(0),TL2(0),TL2_exist(0),color(0), 종가사용여부(0), // 종가로 계산하려면 1로 설정한다. TL_NewBit(0), // 1:NewLine 2:SetEndLine slope(0),mid_idx(0),mid_val(0),text1(0); Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime #==========================================# Value1 = ChgRateZigZag(ChgRate,종가사용여부,고,저,TL_NewBit); If Value1 == 1 Then { // 고점 If TL_NewBit == 1 Then { // 신규 If 고[2,1] < 고[1,1] Then { slope = (고[1,1] - 저[1,1]) / (고[1,2] - 저[1,2]); mid_idx = Floor((고[2,1] - 저[1,1]) / slope); mid_val = slope * mid_idx + 저[1,1]; Var1 = Index - (저[1,2] + mid_idx); TL1 = TL_New(저[1,3],저[1,4],저[1,1],sDate[Var1],sTime[Var1],mid_val); TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,고[1,3],고[1,4],고[1,1]); Var2 = Index - 저[1,2]; TL_SetColor(TL1,color[Var2]); color = RED; TL_SetColor(TL2,color); TL2_exist = 1; } Else { TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); TL_SetColor(TL1,color); TL2_exist = 0; } } If TL_NewBit == 2 Then { // 연장 TL_Delete(TL1); If TL2_exist == 1 Then TL_Delete(TL2); If 고[2,1] < 고[1,1] Then { slope = (고[1,1] - 저[1,1]) / (고[1,2] - 저[1,2]); mid_idx = Floor((고[2,1] - 저[1,1]) / slope); mid_val = slope * mid_idx + 저[1,1]; Var1 = Index - (저[1,2] + mid_idx); TL1 = TL_New(저[1,3],저[1,4],저[1,1],sDate[Var1],sTime[Var1],mid_val); TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,고[1,3],고[1,4],고[1,1]); Var2 = Index - 저[1,2]; TL_SetColor(TL1,color[Var2]); color = RED; TL_SetColor(TL2,color); TL2_exist = 1; } Else { TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); TL_SetColor(TL1,color); TL2_exist = 0; } } } Else If Value1 == -1 Then { // 저점 If TL_NewBit == 1 Then { // 신규 If 저[2,1] > 저[1,1] Then { slope = (저[1,1] - 고[1,1]) / (저[1,2] - 고[1,2]); mid_idx = Floor((저[2,1] - 고[1,1]) / slope); mid_val = slope * mid_idx + 고[1,1]; Var1 = Index - (고[1,2] + mid_idx); TL1 = TL_New(고[1,3],고[1,4],고[1,1],sDate[Var1],sTime[Var1],mid_val); TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,저[1,3],저[1,4],저[1,1]); Var2 = Index - 고[1,2]; TL_SetColor(TL1,color[Var2]); color = BLUE; TL_SetColor(TL2,color); TL2_exist = 1; } Else { TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); TL_SetColor(TL1,color); TL2_exist = 0; } } If TL_NewBit == 2 Then { // 연장 TL_Delete(TL1); If TL2_exist == 1 Then TL_Delete(TL2); If 저[2,1] > 저[1,1] Then { slope = (저[1,1] - 고[1,1]) / (저[1,2] - 고[1,2]); mid_idx = Floor((저[2,1] - 고[1,1]) / slope); mid_val = slope * mid_idx + 고[1,1]; Var1 = Index - (고[1,2] + mid_idx); TL1 = TL_New(고[1,3],고[1,4],고[1,1],sDate[Var1],sTime[Var1],mid_val); TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,저[1,3],저[1,4],저[1,1]); Var2 = Index - 고[1,2]; TL_SetColor(TL1,color[Var2]); color = BLUE; TL_SetColor(TL2,color); TL2_exist = 1; } Else { TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); TL_SetColor(TL1,color); TL2_exist = 0; } } } TL_SetSize(TL1,굵기); TL_SetSize(TL2,굵기); var : Tx(0); if value1 == 1 Then { if value1[1] == -1 Then { Tx = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1],2)+"("+NumToStr(고[1,1]-저[1,1],2)+")"); Text_SetStyle(tx,2,1); Text_SetColor(tx,BLACK); } Else { Text_SetString(tx,NumToStr(고[1,1],2)+"("+NumToStr(고[1,1]-저[1,1],2)+")"); Text_SetLocation(tx,고[1,3],고[1,4],고[1,1]); } } if value1 == -1 Then { if value1[1] == 1 Then { Tx = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1],2)+"("+NumToStr(고[1,1]-저[1,1],2)+")"); Text_SetStyle(tx,2,0); Text_SetColor(tx,BLACK); } Else { Text_SetString(tx,NumToStr(저[1,1],2)+"("+NumToStr(고[1,1]-저[1,1],2)+")"); Text_SetLocation(tx,저[1,3],저[1,4],저[1,1]); } }
프로필 이미지
3579
2021-11-05
624
글번호 153413
지표
답변완료

74532 재문의

올려주신거 감사합니다^^ 적용을 해 보았으나 제대로 구현이 안되는 것 같습니다 기호가 두개 표시를 원하는게 아니라, 1)과 2)번 수식의 조건을 동시에 만족시 신호 표시이고 2)번의 수식은 기호로 표시가 않되고 선으로만 표시가 되네요 다시 한번 검토 부탁드립니다^^
프로필 이미지
체리피커
2021-11-05
541
글번호 153412
시스템
답변완료

문의합니다

안녕하세요 호가잔량이+이면은 시초가매수진입하여-로되면은청산 매도는반대수식부탁합니다 감사합니다
프로필 이미지
질갱이
2021-11-05
630
글번호 153409
시스템
답변완료

문의드립니다

1. 연속되는 두봉에서 직전봉의 고가 보다 같거나 높은 고가의 음봉이 나오면 그 해당봉에 파란색 점을 찍어 주세요 2. 연속되는 두봉에서 직전봉의 저가 보다 같거나 낮은 저가의 양봉이 나오면 그 해당봉에 빨간색 점을 찍어 주세요 3. 1번과 2번의 해당봉이 출현 하면 점과 함께 경보음 소리가 나올 수 있도록 해주세요 감사합니다
프로필 이미지
zmfha
2021-11-05
581
글번호 153408
검색
답변완료

문의드립니다

항상 친절히 도와주심에 감사드립니다. 지난번에 진입 부분을 보완해 주신 수식입니다. 기존 종가에 진입하는 것과 별 차이가 없는거 같아 다시 문의 드립니다. 매수 매도 진입할 때 신호가 나온 캔들의 종가에 진입하는데, 바로 시장가 진입하는 것이 아니라 눌림을 받고 다시 그 종가를 돌파할 때 진입하기를 원하는 것입니다. 눌림폭을 지정해서 그 조건이 맞는 경우만 진입하도록 하는 것이 가능한지요? 예를 들면 매수 신호가 나온 종가가 25100일 경우, 반대로 10틱 이상(25090이하) 반대로 갔다가 다시 25100을 돌파하는 경우에만 25100에 매수 진입하는 것입니다. 매도는 반대의 개념입니다. 틱수를 추가해서 진입조건을 추가 가능한지요? 가능하다면 수정 부탁드립니다. 감사합니다~~ input : StartTime(101200),EndTime(114000); input : Length(20), D1(2); input : 익절1(30),손절1(30),청산구분시간(103000),익절2(50),손절2(30),익절연속횟수(3),손절연속횟수(2); var : Tcond(false),profit(0),loss(0),T(0),S(0); if (sdate != sdate[1] and stime >= EndTime) or (sdate == sdate[1] and stime >= EndTime and stime[1] < EndTime) Then Tcond = False; if (sdate != sdate[1] and stime >= StartTime) or (sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then { T = 0; Tcond = true; profit = 0; loss = 0; } if TotalTrades > TotalTrades[1] Then { if IsExitName("bp1.",1) or IsExitName("bp2.",21) or IsExitName("bp1",1) or IsExitName("bp2",21) or IsExitName("sp1.",1) or IsExitName("sp2.",1) or IsExitName("sp1",1) or IsExitName("sp2",1) Then profit = profit+1; Else profit = 0; if IsExitName("bl1.",1) or IsExitName("bl2.",1) or IsExitName("bl1",1) or IsExitName("bl2",1) or IsExitName("sl1.",1) or IsExitName("sl2.",1) or IsExitName("sl1",1) or IsExitName("sl2",1) Then loss = loss+1; Else loss = 0; } var1 = BollBandUp(Length,D1); var2 = BollBandDown(Length,D1); if Tcond == true Then { #매수조건만족하면 T에 1, 해당봉종가는 S에 저장 If CrossUP(H,var1) and (c > o or (C==O and C >= C[1])) then { T = 1; S = C; } #매도조건만족하면 T에 -1, 해당봉종가는 S에 저장 If CrossDown(L,Var2) and (C < O or (C==O and C < C[1])) then { T = -1; S = C; } #T가 1인 상태이고 S를 상향돌파하면 If T == 1 and CrossUP(c,S) then { #T는 2로 변경하고 T = 2; #매수 if profit < 익절연속횟수 and loss < 손절연속횟수 then { Buy("b",OnClose,DEF,1); if sTime >= StartTime and sTime < 청산구분시간 Then { ExitLong("bp1.",AtLimit,C+PriceScale*익절1,"",1,1); ExitLong("bl1.",AtStop,C-PriceScale*손절1,"",1,1); } if sTime >= 청산구분시간 and sTime < Endtime Then { ExitLong("bp2.",AtLimit,C+PriceScale*익절2,"",1,1); ExitLong("bl2.",AtStop,C-PriceScale*손절2,"",1,1); } } } #T가 -1인 상태에서 S를 하향이탈하면 If T == -1 and crossdown(C,S) then { #T는 -2로 변경 T = -2; #매도 if profit < 익절연속횟수 and loss < 손절연속횟수 then { Sell("s",OnClose,DEF,1); if sTime >= StartTime and sTime < 103000 Then { ExitShort("sp1.",AtLimit,C-PriceScale*익절1,"",1,1); ExitShort("sl1.",AtStop,C+PriceScale*손절1,"",1,1); } if sTime >= 103000 and sTime < Endtime Then { ExitShort("sp2.",AtLimit,C-PriceScale*익절2,"",1,1); ExitShort("sl2.",AtStop,C+PriceScale*손절2,"",1,1); } } } } if MarketPosition == 1 Then { if sTime >= StartTime and sTime < 청산구분시간 Then { ExitLong("bp1",AtLimit,EntryPrice+PriceScale*익절1,"",1,1); ExitLong("bl1",AtStop,EntryPrice-PriceScale*손절1,"",1,1); } if sTime >= 청산구분시간 and sTime < Endtime Then { ExitLong("bp2",AtLimit,EntryPrice+PriceScale*익절2,"",1,1); ExitLong("bl2",AtStop,EntryPrice-PriceScale*손절2,"",1,1); } } if MarketPosition == -1 Then { if sTime >= StartTime and sTime < 103000 Then { ExitShort("sp1",AtLimit,EntryPrice-PriceScale*익절1,"",1,1); ExitShort("sl1",AtStop,EntryPrice+PriceScale*손절1,"",1,1); } if sTime >= 103000 and sTime < Endtime Then { ExitShort("sp2",AtLimit,EntryPrice-PriceScale*익절2,"",1,1); ExitShort("sl2",AtStop,EntryPrice+PriceScale*손절2,"",1,1); } } IF Endtime > starttime Then SetStopEndofday(Endtime); Else { if sDate != sDate[1] Then SetStopEndofday(Endtime); } if (sdate != sdate[1] and stime >= StartTime) or (sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then { IF Endtime <= starttime Then { SetStopEndofday(0); } }
프로필 이미지
호정0688
2021-11-04
473
글번호 153407
시스템

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

프로필 이미지
2021-11-04
12
글번호 153406
종목검색
답변완료

부탁 드립니다.

항상 도움에 감사 드립니다. 타주기 수식 부탁 드립니다. 1)분봉지표를 분봉차트에서 2)틱봉지표를 틱봉차트에서 3)일봉지표를 분봉차트에서 4)주봉지표를 분봉차트에서 미리 감사 드립니다... 질문수식) input:P1(10); input:배수(5); input:sig(5); var1=C-L; Var2=H-C; Var3=H-L; Var4=Var1-Var2; Var5=(Var4/Var3)*V; VAR6=AccumN(Var5,P1); Var7=AccumN(V,P1); Var8=Var6/Var7; Var9=IFF(VAR8>0,Var8,0); Var10=AccumN(Var9,P1*배수); VAR11=P1*배수/100; VAR12=Var10/VAR11; VAR13=MA(VAR12,SIG); 참고1) 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; 참고2) 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-04
625
글번호 153405
지표

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

프로필 이미지
2021-11-04
0
글번호 153404
종목검색