커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

베어샘 님에 의해서 삭제되었습니다.

프로필 이미지
베어샘
2022-02-17
29
글번호 156385
종목검색
답변완료

문의

데이트레이딩 보조차트 data2,3,4 활용 연결옵션차트는 전일 코스피200종가 기준이므로 갭보정하는 수식입니다. var : w(0,Data1),x(0,Data1),y(0,Data1); var : w2(0,Data1),x3(0,Data1),y4(0,Data1); w= data2(c)-data2(c[1]); w2 = data2(c[1])+w; x= data3(c)-data3(c[1]); x3 = data3(c[1])+x; y= data4(c)-data4(c[1]); y4 = data4(c[1])+y; 어제 종가 수식을 바르게 한 것인지요.
프로필 이미지
목마와숙녀
2022-02-17
1189
글번호 156382
시스템
답변완료

수식 보완 부탁드려요~~~

아래 수식은 지금 사용하고 있는 수식인데요.. 제가 하고 싶은 것은 다음과 같습니다. " if MarketPosition == 0 and MoneyFlow <= MFI값 and C <= Highest(H,X)*(1-Y/100) and c<c[MFI기간] " 원래는 위 수식조건이 만족할때 진입되는 거자나요,,,, 근데 저는 저 조건에 만족하는 시점에서 -3% 하락하는 포인트에서 매수진입하고 싶거든요.... 그래서 진입조건에 아래와 같이 했는데 Buy("매수",AtLimit,c*(1-3/100)); 진입되는 횟수가 너무 적어서 고믾을 해보니 매수 조건을 만족하는 것과 동시에 -3%떨어지는 시점에도 만족되어야 매수되는 것같아서요.. 제가 하고 싶은 사항은 설정된 매수조건이 되면 "그 시점"을 기준으로 -3% 하락하는 시점에 매수되는 수식을 구현하고 싶은데요 결국 진짜 매수되는 상황은 매수조건을 만족하든 안하든 매수 되는 것이지요... 어떻게 안될까요??? input : MFI기간(75),MFI값(28); input : X(4500),Y(6); var : MoneyFlow(0),MoneyFlow1(0); MoneyFlow = MFI(MFI기간); MoneyFlow1 = MFI(MFI청산기간); if MarketPosition == 0 and MoneyFlow <= MFI값 and C <= Highest(H,X)*(1-Y/100) and c<c[MFI기간] Then Buy("b",OnClose,DEf,1);
프로필 이미지
이형지
2022-02-17
947
글번호 156379
시스템
답변완료

75970 추가질문드립니다

안녕하세요~ 도움주신 수식으로 테스트해봤습니다 그런데 첨부한 사진과 같이 b1 다음에 피라미딩 b2, b3 진입이 발생 안하고 b4로 진입하는것과 같은 몇몇 봉을 빼먹고 진입하는 케이스가 계속 발생하는데 원인을 못찾겠습니다... 가능하다면 확인 부탁드리겠습니다 감사합니다 input : TT(4100), TD(20220217), MDD(200000) ; var : HB(14461.75), LB(14381), Hx(20000), Lx(1); var : e60(0), Hcount(0), Lcount(0),B(0),S(0),cnt(0),T1(0), Hstate(true), Lstate(true), N(0), unitP(0), exitC(0), rHB(0), rLB(0); N = Highest(ATr(14), 100); unitP = floor(MDD/(N*5*4*600)); exitC = (2-(MaxEntries-1)/2)*N; e60 = Ema(C,60); if Condition1 == False and sDate >= TD and sTime >= TT Then { Condition1 = true; Hcount = 0; Lcount = 0; T1 = TotalTrades; } if Condition1 == true Then { B = 0; S = 0; if TotalTrades-T1 > 0 Then { For cnt = 1 to TotalTrades-T1 { if MarketPosition(cnt) == 1 Then B = B+1; if MarketPosition(cnt) == -1 Then S = S+1; } } Hcount = B + IFf(MarketPosition == 1,1,0); Lcount = S + IFf(MarketPosition == -1,1,0); if B>0 && B == Hcount then HB = rHB; if S>0 && S == Lcount then LB = rLB; if MarketPosition <= 0 and Hstate == true then { Buy("b1",AtStop,HB,unitP); Buy("b2",AtStop,HB+0.5*N,unitP); Buy("b3",AtStop,HB+N,unitP); Buy("b4",AtStop,HB+1.5*N,unitP); } if MarketPosition >= 0 and Lstate == true then { Sell("s1",AtStop,LB,unitP); Sell("s2",AtStop,LB-0.5*N,unitP); Sell("s3",AtStop,LB-N,unitP); Sell("s4",AtStop,LB-1.5*N,unitP); } if marketposition ==1 Then { rHB = Highest(H, BarsSinceEntry) ; if rHB < HB+0.5*N Then Buy("b2.",AtStop,HB+0.5*N,unitP); if rHB < HB+N Then Buy("b3.",AtStop,HB+N,unitP); if rHB < HB+1.5*N Then Buy("b4.",AtStop,HB+1.5*N,unitP); if e60 < HB+2*N Then Exitlong("exitB1", atstop, HB-exitC); if e60 >= HB+2*N and CrossDown(close, e60) Then { ExitLong("exitB2") ; Hstate = false ; } Exitlong("exitB3", AtLimit, Hx); } if marketposition == -1 Then { rLB = Lowest(L, BarsSinceEntry); if rLB > LB-0.5*N Then Sell("s2.",AtStop,LB-0.5*N,unitP); if rLB > LB-N Then Sell("s3.",AtStop,LB-N,unitP); if rLB > LB-1.5*N Then Sell("s4.",AtStop,LB-1.5*N,unitP); if e60 > LB-2*N Then ExitShort("exitS1", atstop, LB+exitC); if e60 <= LB-2*N and CrossUp(close, e60) Then { ExitShort("exitS2"); Lstate = false ; } exitshort("exitS3", AtLimit, Lx); } if Hcount >= 3 Then Hstate = False; if Lcount >= 3 Then Lstate = False; if H >= Hx then Hstate = false; if L <= Lx then Lstate = false; }
프로필 이미지
jshwang2
2022-02-17
1086
글번호 156378
시스템

귀족온달 님에 의해서 삭제되었습니다.

프로필 이미지
귀족온달
2022-02-16
0
글번호 156377
검색
답변완료

검색식 부탁드립니다~

안녕하십니까~ 다름아니라 영웅문에서 사용하고있는 종목검색식인데 예스에서 사용해 보려합니다. 변환좀 부탁드립니다~ 감사합니다~~ A 시가총액:현재가기준 300억원 이상 B 주가범위:0일전 종가가 900원이상~ 60000원이하 C [일]거래대금 50억이상 D 기간내 등락률:[일]1봉전기준(★당일미포함) 5봉이내에서 전일종가대비종가 12%이상 종목 모두 E 주가등락률:[일]1봉전(중) 종가대비 0봉전 종가등락률 2%이상 종목 F 주가등락률:[일]1봉전(중) 종가대비 0봉전 시가등락률 7%이하 종목 A and B and C and D and E and F
프로필 이미지
따라고나
2022-02-16
1139
글번호 156376
종목검색
답변완료

설명 부족으로 추가 질문드려요~

1. 16시부터 17시 사이(시간조정가능) 정해진 거래량 이상일때 지정 포지션 진입 위 설명이 부족해서 원하는 결과가 안나오네요~ 죄송합니다. 거래량 지표중 [거래량] 이라는 지표를 기준으로 합니다. 수치가 1000~6000 정도 사이로 보입니다. 그리고 xtime 적용이 안됩니다. 체크부탁해요~ ---------------------------------------------------------------------------- 안녕하세요 예스스탁입니다. input: position(1),vol(1); input : StartTime(160000),EndTime(170000),N(50000),xtime(55800); var : ST(0),Tcond(false),sumV(0); if (sdate != sdate[1] and stime >= EndTime) or (sdate == sdate[1] and stime >= EndTime and stime[1] < EndTime) Then { Tcond = False; if MarketPosition == 0 then { if position == 1 Then Buy("매수1",OnClose,DEf,vol); if position == -1 Then Sell("매도1",OnClose,DEf,vol); } } if (sdate != sdate[1] and stime >= StartTime) or (sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then { Tcond = true; sumV = 0; } if Tcond == true Then sumV = sumV+V; if Tcond == true and sumV >= N and MarketPosition == 0 then { if position == 1 Then Buy("매수",OnClose,DEf,vol); if position == -1 Then Sell("매도",OnClose,DEf,vol); } IF Xtime > ST Then SetStopEndofday(Xtime); Else { if sDate != sDate[1] Then SetStopEndofday(Xtime); } if (sdate != sdate[1] and stime >= ST) or (sdate == sdate[1] and stime >= ST and stime[1] < ST) Then { IF Xtime <= ST Then { SetStopEndofday(0); } } 즐거운 하루되세요 > 스카스카 님이 쓴 글입니다. > 제목 : 수식 부탁드려요~ 감사합니다. ^^ > input: position(1),ntime(160000),vol(1),xtime(55800); var : ST(0); if Bdate != Bdate[1] Then { ST = sTime; } if ST > 0 then { if (sdate != sdate[1] and stime >= ntime) or (sdate == sdate[1] and stime >= ntime and stime[1] < ntime) Then { if position == 1 Then Buy("매수",OnClose,DEf,vol); if position == -1 Then Sell("매도",OnClose,DEf,vol); } } IF Xtime > ST Then SetStopEndofday(Xtime); Else { if sDate != sDate[1] Then SetStopEndofday(Xtime); } if (sdate != sdate[1] and stime >= ST) or (sdate == sdate[1] and stime >= ST and stime[1] < ST) Then { IF Xtime <= ST Then { SetStopEndofday(0); } } ------------------------------------------------------------------------------------------- 위 수식에서 수정 부탁드립니다.^^ 감사합니다. 1. 16시부터 17시 사이(시간조정가능) 정해진 거래량 이상일때 지정 포지션 진입 2. 신호가 없다면 17시 무조건 진입
프로필 이미지
스카스카
2022-02-16
1053
글번호 156375
시스템
답변완료

부탁합니다^^

안녕하세요^^ 검색식 cci보조지표에서 signal 5선이 전봉에서 -100 보다 작거나 같을 때 현재봉에서 signal -100 크고 또는 전봉에서 signa 5선이 -100보다 작고 현재봉에서 signa이 -100보다 크거나 같다. 그리고 전종가가 5평선보다 작다가 현재봉이 5평선보다 크다. 그리고 전5평선이 현5평선보다 크거나 같고 다음봉(미래봉)의 종가가 현재봉 종가와 같을때 미래 5평선이 현재5평선보다 크거나 같다 위와 같은 종목을 추출하려 합니다. 선언문 등 틀 전체를 부탁드립니다. 감사합니다^^
프로필 이미지
yjh7474
2022-02-16
985
글번호 156374
검색
답변완료

지표 수식(지표1, 2, 3)의 작성을 부탁드립니다.

담당자님, 안녕하세요. 작성해주신 지표 수식을 잘 활용하고 있습니다. Q&A 75889번의 수식을 제가 변형해서 수정해보려고 했는데 계속 에러가 발생하고 제가 의도하는 수식으로 수정할 수 없어서 작성을 부탁드립니다. (KOSPI200 주가지수 선물) 분봉 차트에서, 예를 들면 3분봉 차트에서 적용하는 지표라고 가정하고 다음과 같은 지표1, 지표2, 지표3 수식의 작성을 부탁드립니다. (Q&A 75889번 및 직전 수정의뢰 75978번과 연관되는 수식입니다.) =========================================================== =========================================================== <지표 1> (3분봉 차트에서 적용) 1) 과거 n일(n=10) 기간 중 (고가-저가) 값이 큰 상위 5개의 30분봉(30분 구간)을 선택 * 당일(D)의 수치(가격)는 계산에 반영(포함)되지 않으며 (D-1)일 부터 (D-10)일 까지의 10일간의 수치(가격)를 반영하여 산출함. ** 다른 일자의 (고가-저가) 보다 크다면 동일한 날에서 최대 2개~5개까지도 선택될 수 있음. cf. Q&A 75889번에서는 각 일자별로 그날의 30분봉 중에서 고점과 저점 사이의 봉길이가 최대인 30분봉을 1개씩만 선택하였으나 이번 수식에서는 동일한 일자에서 5개까지도 선택 가능함. 2) 위에서 선택된 상위 5개의 30분봉('고가-저가'의 값)으로 각각의 '(고가+저가)/2'를 계산하여 그 값을 각각 5개의 수평선 라인으로 표시 [=> 최종 결과값은 총 5개의 수평라인 산출] cf. ('고가-저가'의 값) 5번째 상위값 봉과 (고가-저가)값이 같은 봉이 2개 이상이면 먼저 발생한 봉을 선택 또는 담당자님이 정하는 원칙에 따라 최종적으로 총 5개만 선정되도록 함. (추가1) 위의 조건 충족한 당일(D)의 5개 수평라인은 '당일(D)의 장시작 ~ 장마감'의 기간에만 표시함. (cf. Q&A 75889번과 동일) (추가2) n일(n=10) 기간의 수치는 외부입력 변수로 하여 지표속성창에서 변경 입력이 가능 하도록 구현 (추가3) Array : R1[50](0),M1[50](0); Array : tempR1[50](0),tempM1[50](0),NTHVALUE[50](0); 등 그 외 사항은 Q&A 75889번과 동일 ============================================================ 위와 같이 지표1의 수식 작성을 부탁드립니다. =========================================================== =========================================================== <지표 2> (Q&A 75978번의 수정 내용도 반영하여 주시기 바랍니다.) (3분봉 차트에서 적용) 1) <지표1>과 동일 2) <지표1>과 동일 3) 위에서 선택된 '고가-저가'의 값이 큰 상위 5개의 30분봉에서 그 봉에 해당하는 각각의 '(종가+시가)/2'를 계산하여 그 값을 각각 수평선 라인으로 표시 [=> 총 5개의 수평라인 산출] cf. <지표1>과의 차이는 '고가-저가'의 값이 큰 상위 5개를 선택한 후 그 30분봉의 '(고가+저가)/2'가 아니고 그 30분봉의 '(종가+시가)/2'를 산출하는 것임. (추가1) <지표1>과 동일 (추가2) <지표1>과 동일 (추가3) <지표1>과 동일 ============================================================= ============================================================= 위와 같이 지표2의 수식 작성을 부탁드립니다. =========================================================== =========================================================== <지표 3> (Q&A 75978번의 수정 내용도 반영하여 주시기 바랍니다.) (3분봉 차트에서 적용) 1) (고가-저가)를 절대값(종가-시가)로 적용하는 것 이외에는 <지표1>과 동일 2) (고가-저가)를 절대값(종가-시가)로 적용하는 것 이외에는 <지표1>과 동일 3) (고가-저가)를 절대값(종가-시가)로, '(고가+저가)/2'를 '(종가+시가)/2'로 적용 이외에는 <지표1>과 동일 (추가1) <지표1>과 동일 (추가2) <지표1>과 동일 (추가3) <지표1>과 동일 ============================================================= ============================================================= 위와 같이 지표3의 수식 작성을 부탁드립니다. 위와 같이 지표1, 자표2, 지표3의 작성을 부탁드립니다. 지표작성해 주신 것에 대해 담당자님께 미리 감사드립니다. 항상 건강하시고 건승하시기 바랍니다. (담당자님의 편의를 위하여 Q&A 75889번의 담당자님 답변내용과 제 질의 내용을 아래에 기재하였습니다.) ============================================== ============================================== 수식작성 Q&A 75889번 담당자님 답변(작성 수식) 및 질의 내용 ============================================== ============================================== 작성자 : 예스스탁 작성일 : 2022-02-14 오전 9:35:15 조회수 : 9 지표 Re : 지표 수식(지표1, 지표2, 지표3) 작성 부탁드립니다. 안녕하세요 예스스탁입니다. 올림차순 또는 내림차순으로 지정해 드리기는 어렵습니다. 최근 n일 값을 계산해서 NTHVALUE에 오름차순으로 값이 저장됩니다. 10일 중 가장작은값 3개는 NTHVALUE[8],NTHVALUE[9],NTHVALUE[10]으로 지정해 출력하시면 됩니다. 1 input : 타주기분(30),n(10); var : S1(0),D1(0),TM(0),TF(0),cnt(0),HH(0),LL(0); var : ii(0),i1(0),i2(0),tempmax(0),tempi(0); Array : R1[50](0),M1[50](0); Array : tempR1[50](0),tempM1[50](0),NTHVALUE[50](0); if Bdate != Bdate[1] Then { S1 = TimeToMinutes(stime); D1 = sdate; for cnt = 1 to 49 { R1[cnt] = R1[cnt-1][1]; M1[cnt] = M1[cnt-1][1]; } } if D1 > 0 then { if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF = TM%타주기분; if Bdate != Bdate[1] or (Bdate == Bdate[1] and 타주기분 > 1 and TF < TF[1]) or (Bdate == Bdate[1] and 타주기분 > 1 and TM >= TM[1]+타주기분) or (Bdate == Bdate[1] and 타주기분 == 1 and TM > TM[1]) Then { HH = H; LL = L; if Bdate != Bdate[1] Then { R1[0] = HH-LL; M1[0] = (HH+LL)/2; } } if H > HH Then HH = H; if L < LL Then LL = L; if HH-LL > R1[0] Then { R1[0] = HH-LL; M1[0] = (HH+LL)/2; } if M1[n] > 0 Then { for ii = 0 to 49 { tempR1[ii] = R1[ii]; tempM1[ii] = M1[ii]; } For i1 = 1 to n { tempmax = -1; For i2 = 1 to n { if (tempR1[i2] >= tempmax ) then { tempmax = tempR1[i2]; tempi = i2; } } NTHVALUE[i1] = tempM1[tempi]; tempR1[tempi] = -1; } Plot1(NTHVALUE[1]); Plot2(NTHVALUE[2]); Plot3(NTHVALUE[3]); } } 2 input : 타주기분(30),n(10); var : S1(0),D1(0),TM(0),TF(0),cnt(0),HH(0),LL(0),OO(0),CC(0); var : ii(0),i1(0),i2(0),tempmax(0),tempi(0); Array : R1[50](0),M1[50](0); Array : tempR1[50](0),tempM1[50](0),NTHVALUE[50](0); if Bdate != Bdate[1] Then { S1 = TimeToMinutes(stime); D1 = sdate; for cnt = 1 to 49 { R1[cnt] = R1[cnt-1][1]; M1[cnt] = M1[cnt-1][1]; } } if D1 > 0 then { if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF = TM%타주기분; if Bdate != Bdate[1] or (Bdate == Bdate[1] and 타주기분 > 1 and TF < TF[1]) or (Bdate == Bdate[1] and 타주기분 > 1 and TM >= TM[1]+타주기분) or (Bdate == Bdate[1] and 타주기분 == 1 and TM > TM[1]) Then { HH = H; LL = L; OO = O; if Bdate != Bdate[1] Then { R1[0] = HH-LL; M1[0] = (HH+LL)/2; } } if H > HH Then HH = H; if L < LL Then LL = L; CC = C; if HH-LL > R1[0] Then { R1[0] = HH-LL; M1[0] = (OO+CC)/2; } if M1[n] > 0 Then { for ii = 0 to 49 { tempR1[ii] = R1[ii]; tempM1[ii] = M1[ii]; } For i1 = 1 to n { tempmax = -1; For i2 = 1 to n { if (tempR1[i2] >= tempmax ) then { tempmax = tempR1[i2]; tempi = i2; } } NTHVALUE[i1] = tempM1[tempi]; tempR1[tempi] = -1; } Plot1(NTHVALUE[1]); Plot2(NTHVALUE[2]); Plot3(NTHVALUE[3]); } } 3 input : 타주기분(30),n(10); var : S1(0),D1(0),TM(0),TF(0),cnt(0),OO(0),CC(0); var : ii(0),i1(0),i2(0),tempmax(0),tempi(0); Array : R1[50](0),M1[50](0); Array : tempR1[50](0),tempM1[50](0),NTHVALUE[50](0); if Bdate != Bdate[1] Then { S1 = TimeToMinutes(stime); D1 = sdate; for cnt = 1 to 49 { R1[cnt] = R1[cnt-1][1]; M1[cnt] = M1[cnt-1][1]; } } if D1 > 0 then { if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF = TM%타주기분; if Bdate != Bdate[1] or (Bdate == Bdate[1] and 타주기분 > 1 and TF < TF[1]) or (Bdate == Bdate[1] and 타주기분 > 1 and TM >= TM[1]+타주기분) or (Bdate == Bdate[1] and 타주기분 == 1 and TM > TM[1]) Then { OO = O; CC = C; if Bdate != Bdate[1] Then { R1[0] = abs(OO-CC); M1[0] = (OO+CC)/2; } } CC = C; if abs(OO-CC) > R1[0] Then { R1[0] = abs(OO-CC); M1[0] = (OO+CC)/2; } if M1[n] > 0 Then { for ii = 0 to 49 { tempR1[ii] = R1[ii]; tempM1[ii] = M1[ii]; } For i1 = 1 to n { tempmax = -1; For i2 = 1 to n { if (tempR1[i2] >= tempmax ) then { tempmax = tempR1[i2]; tempi = i2; } } NTHVALUE[i1] = tempM1[tempi]; tempR1[tempi] = -1; } Plot1(NTHVALUE[1]); Plot2(NTHVALUE[2]); Plot3(NTHVALUE[3]); } } 즐거운 하루되세요 > 원칙투자자 님이 쓴 글입니다. > 제목 : 지표 수식(지표1, 지표2, 지표3) 작성 부탁드립니다. > 담당자님, 안녕하세요. 작성해주신 지표 수식을 너무나 잘 활용하고 있습니다. 거듭 감사드립니다. (KOSPI200 주가지수 선물) 분봉 차트에서, 예를 들면 3분봉 차트에서 적용하는 지표라고 가정하고 다음과 같은 지표1, 지표2, 지표3 수식의 작성을 부탁드립니다. =========================================================== =========================================================== <지표 1> (3분봉 차트에서 적용) 1) 매일의 30분봉(장시작~09:30, 09:30~10:00.....15:30~장마감의 30분 단위 구간)의 (고가-저가) 중에서 각 해당일의 30분 구간 (고가-저가)가 최대인 30분봉(30분 구간)을 각 일자별로 1개씩 선택 (즉, 각 일자별로 그날의 30분봉 중에서 고점과 저점 사이의 봉길이가 최대인 30분봉을 1개씩 선택함) cf. 어떤 날에 (고가-저가)의 최대값이 같은 봉이 2개 이상이면(즉, 같은 수치의 최대봉이 2개 이상이면) 그 날 가장 먼저 발생한 봉을 선택 또는 담당자님이 정하는 원칙으로 각 일자에서는 1개씩만 선정함. 2) 위에서 계산된 각 일자별 (고가-저가)가 최대인 30분봉 중 (D-1)일 부터 소급하여 과거 n일(n=10) 기간 중 (고가-저가) 값이 큰 상위 3개의 30분봉(30분 구간)을 총 3개 선택 * 당일(D)의 수치(가격)는 계산에 반영(포함)되지 않으며 (D-1)일 부터 (D-10)일 까지의 10일간의 수치(가격)를 반영하여 산출함. 3) 위에서 선택된 상위 3개의 30분봉('고가-저가'의 값)으로 각각의 '(고가+저가)/2'를 계산하여 그 값을 각각 3개의 수평선 라인으로 표시 [=> 최종 결과값은 총 3개의 수평라인 산출] * [중요] 위의 조건 충족한 당일(D)의 3개 수평라인은 '당일(D)의 장시작 ~ 장마감'의 기간에만 표시함. (cf. 실시간 차트에서는 당일(D) 장시작 하면서(첫봉 만들어지면서) 바로 라인이 표시되며 그 이후 장중 분봉이 형성되면서 순차적으로 동일한 라인이 장마감까지 표시될 것으로 예상) 또한, 당일 보다 과거 기간에는 당일 조건에 의한 라인은 표시되지 않고 각 해당일의 조건에 의해 선정된 수평라인만 표시되므로 과거 각 일자에 해당하는 차트 구간에도 최대 3개 라인이 표시됨. (추가 요건1) [중요] 최종 결과물인 수평라인 3개를 plot1, plot2, plot3로 산출할 때, (최종 수치인 '(고가+저가)/2'를 sort, 정렬하여) plot1, 2, 3가 최종수치인 '(고가+저가)/2'의 크기대로 올림차순 또는 내림차순이 되도록 배열 (cf. plot1, 2, 3가 [고가-저가]의 크기 순대로의 배열이 아님) (추가 요건2) n일(n=10) 기간의 수치는 외부입력 변수로 하여 지표속성창에서 변경 입력이 가능 하도록 구현 =============================================================================== (예시) D-10일 고가 저가 고가-저가 (고가+저가)/2 장시작~09:30 360.00 359.00 1.00 09:30 ~10:00 361.00 358.10 2.90 (=> 선택2) 359.55(-> 당일(D) 구간에 라인 표시) ..... 15:00~ 장마감 360.00 359.60 0.40 ---------------------------------------------------------------------------------------- ................. D-7일 고가 저가 고가-저가 (고가+저가)/2 장시작~09:30 358.50 357.00 1.50 (=> 선택3) 357.75(-> 당일(D) 구간에 라인 표시) 09:30 ~10:00 359.20 358.00 1.20 ..... 15:00~ 장마감 359.40 359.00 0.40 ---------------------------------------------------------------------------------------- ................. D-5일 고가 저가 고가-저가 (고가+저가)/2 장시작~09:30 380.50 376.40 3.60 (=> 선택1) 378.45(-> 당일(D) 구간에 라인 표시) 09:30 ~10:00 378.00 375.00 3.00 ..... 15:00~ 장마감 377.00 356.40 0.60 ---------------------------------------------------------------------------------------- ................. D-2일 고가 저가 고가-저가 (고가+저가)/2 장시작~09:30 358.40 357.00 1.40 (=> 미선택) 357.70 (D-2일의 최대 30분봉 '고가-저가'값이 상위 3개에 미포함 되므로 1.40은 미선택됨) 09:30 ~10:00 359.10 358.00 1.10 ..... 15:00~ 장마감 359.50 359.00 0.50 ---------------------------------------------------------------------------------------- ................. D일(당일) 시가 : 361.00 ------------------------------------------------------------ <최종 구현되는 결과(plot 1,2,3의 값을 올림차순 또는 내림차순 정렬)> plot1 : 357.75 plot1 : 378.45 plot2 : 359.55 또는 plot2 : 359.55 plot3 : 378.45 plot3 : 357.75 (올림차순) (내림차순) ============================================================ 위와 같이 지표1의 수식 작성을 부탁드립니다. =========================================================== =========================================================== <지표 2> (3분봉 차트에서 적용) 1) <지표1>과 동일 2) <지표1>과 동일 3) 위에서 선택된 '고가-저가'의 값이 큰 상위 3개의 30분봉에서 그 봉에 해당하는 각각의 '(종가+시가)/2'를 계산하여 그 값을 각각 수평선 라인으로 표시 [=> 총 3개의 수평라인 산출] cf. <지표1>과의 차이는 '(고가+저가)/2'가 아니고 선택된 30분봉의 '(종가+시가)/2'를 적용하는 것임. (추가 요건1) <지표1>과 동일 (추가 요건2) <지표1>과 동일 ============================================================= ============================================================= 위와 같이 지표2의 수식 작성을 부탁드립니다. =========================================================== =========================================================== <지표 3> (3분봉 차트에서 적용) 1) (고가-저가)를 절대값(종가-시가)로 적용하는 것 이외에는 <지표1>과 동일 2) (고가-저가)를 절대값(종가-시가)로 적용하는 것 이외에는 <지표1>과 동일 3) (고가-저가)를 절대값(종가-시가)로, '(고가+저가)/2'를 '(종가+시가)/2'로 적용 이외에는 <지표1>과 동일 (추가 요건1) plot1, 2, 3가 최종수치인 '(종가+시가)/2'의 크기대로 올림차순 또는 내림차순이 되도록 배열 (추가 요건2) <지표1>과 동일 ============================================================= ============================================================= 위와 같이 지표3의 수식 작성을 부탁드립니다.
프로필 이미지
원칙투자자
2022-02-16
977
글번호 156373
지표