커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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
1063
글번호 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
1101
글번호 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
1029
글번호 156375
시스템
답변완료

부탁합니다^^

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

지표 수식(지표2와 지표3)의 검토 부탁드립니다

지난번 Q&A 75889번에서 작성해 주신 수식을 활용하면서 매매원칙을 연구하고 있습니다. 작성해 주신 지표수식을 연구하고 있는데, 아래 지표1의 경우에는 지표에서 산출된 값과 수기로 계산해 본 값이 정확하게 일치합니다. 그런데, 지표2와 지표3의 시스템 산출 결과는 제가 실제 데이터로 계산한 값과 차이가 납니다. 제가 아무리 수정해보려고 해도 해결할 수가 없어 도움 요청드립니다. 작성해주신 지표2와 지표3이 지난번 Q&A 75889번의 질의 내용과 다른 점이 무엇인지 검토해주시고 Q&A 75889번의 질의 내용과 같이 수정 부탁드립니다. 제가 수기 계산해 본 검증해 본 내용을 엑셀 파일로 첨부하였고 지표를 시뮬레이션 차트에서 실행한 내용(산출된 수치)을 화면 캡쳐하여 엑셀파일의 해당 sheet에 같이 첨부하였습니다. 검증내용 요약은 아래와 같습니다. 자세한 내용은 엑셀파일을 참조하시기 바랍니다. -------------------------------------------------------------- 2021.07.12을 당일(D)로 해서 실행해보면 <지표1 - 시스템> <지표1 - 수기계산> -> 정확하게 일치 425.68 425.68 437.70 437.70 435.68 435.68 <지표2 - 시스템> <지표2 - 수기계산> -> 차이 발생 425.77 425.73 437.77 437.88 435.75 435.80 <지표3 - 시스템> <지표3 - 수기계산> -> 차이 발생 425.73 425.73 438.65 438,75 435.75 435.80 cf. 위 사례 보다 차이가 훨씬 더 큰 경우도 많음. ----------------------------------------------------------------------------- 위와 같이 수정 부탁드립니다. 미리 감사드립니다. (담당자님의 편의를 위하여 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
741
글번호 156372
지표
답변완료

함수요청

안녕하세요? 전일장(우리시각으로 금일 오전에 마감) 나스닥 지수가 상승 마감했으면 국내선물을 주간장 종가에 매수하고 전일장(우리시각으로 금일 오전에 마감) 나스닥 지수가 하락 마감했으면 국내선물을 종가에 매도하고 야간시장 주간장 시초가에 청산하고자 합니다. 말씀드린 전략대로 정확하지 않더래도 논리가 비슷하게라도 스크립트 작성 부탁드립니다.
프로필 이미지
흰둥이아빠
2022-02-16
838
글번호 156371
시스템
답변완료

수평선

감사합니다. 1. 교차된 가격의 수평선의 우측 연장이 아닌 값이 한봉에만 특정되고 나머지 봉은 N/A로 표시될 때 그 한봉에만 특정된 값을 우측으로 연장하고자 합니다 예) var: AA(0); AA = var1; // var1의 지표값이 특정한 한 봉에서만 출력되고 전봉이나 다음봉의 지표값이 N/A 여서 출력값이 없을 때 출력된 특정한 지표값을 우측으로 수평선으로 출력하는 방법을 알고 싶습니다 if isnan(AA) == false then ? Plot1(AA, "특정한 한 봉의 지표값");
프로필 이미지
jdavid
2022-02-17
1037
글번호 156370
지표
답변완료

장기이평선 돌파

AA=(H+C+L)/3; BB=AA*V; cumulative_amount=sum(BB); cumulative_vol=sum(V); cumulative_amount/cumulative_vol 위수식은 상장 전체 기간의 평균 이평선입니다. 예스트레이더 종목검색식를 만들고 싶습니다. 도움 부탁드립니다.
프로필 이미지
귀족온달
2022-02-16
1046
글번호 156364
종목검색