커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

문의

아래는 미니선물 오버나잇 전략에 사용하는 청산수식입니다. 만기일(매월 둘째주 목요일)이 도래하면 작동됩니다. 수식에 1)~2) 내용을 추가해주시고 1개의 전략식에서 모두 병행하여 작동될 수 있게 해주세요. 1) everyday(옵션 만기일 제외) 대응 추가 - 15시10분 이후부터 장종료까지 진입과 청산 모두 금지 (오버나잇전략식이라 진입과 청산이 한국거래소 장종료시간과 겹칠 때가 있음 이를 피하기 위함) 2) 만기일 대응 추가 - 아래수식에 따라 "bx만기청산" 이름으로 청산된 경우 청산 후 1봉 경과 후 buy (수작업을 통해 포지션을 이월하기 위함) 15시10분 연결차트에서 buy 포지션 청산 15시10분 차월물차트 시험에서 자동으로 전환(수작업) 15시15분 차월물차트에서 buy 포지션 진입 3) 해당일 표현 작성만 해주세요 - 선물 만기일 - 위클리 옵션 만기일 - everyday( 선물 만기일 제외) - everyday( 위클리 옵션 만기일 제외) ***************************************************************************** 오버나잇 전략 + var : va1(0),va2(0),va3(0); va2 = date - int(date/100)*100; va3 = DayOfWeek(date); if va2 >= 8 and va2 <= 14 and va3 == 4 then { if sTime >= 151000 and marketposition == 1 Then ExitLong("bx만기청산");
프로필 이미지
좌오비우오비
2020-12-06
917
글번호 144459
시스템
답변완료

정적 VI

하이투자증권 변동성완화장치 발동현황의 가격과 지표식이 아래 그림1과 2처럼 일치가 되지 않아 문의드립니다. 1. 지표식 : 일치가 되도록 부탁드립니다~~ 그리고 수평선 끝 상단에 가격(0.00%)을 적색으로 표시 2. 강조식 : 봉을 노란색, 봉 상단에 * 표시 3. 시스템식 : 분봉에서 돌파시 매수, 이탈시 매도 var : up1(0), up2(0), up3(0), up4(0), up5(0),up6(0),Up7(0); var : dn1(0), dn2(0), dn3(0), dn4(0), dn5(0),dn6(0),dn7(0); var : a1(0),a2(0),b1(0),b2(0); if o[1]==h[1]&&o[1]==l[1]&&(v[1]==0||v[1]>=1)&&v>=1 Then{ a1 = o*1.1; b1 = o*0.9; } if date >= 19981207 then { if CodeCategory() == 2 then { if date >= 20030721 then { up1 = int(a1/100+0.00001)*100; up2 = int(a1/100+0.00001)*100; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/5+0.00001)*5; up7 = int(a1/1+0.00001)*1; } else { up1 = int(a1/1000+0.00001)*1000; up2 = int(a1/500+0.00001)*500; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/10+0.00001)*10; up7 = int(a1/1+0.00001)*1; } } Else { up1 = int(a1/1000+0.00001)*1000; up2 = int(a1/500+0.00001)*500; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/5+0.00001)*5; up7 = int(a1/1+0.00001)*1; } if CodeCategory() == 1 || CodeCategory() == 2 then { if sdate < 20101004 Then { If a1 >= 500000 Then a2 = up1; Else If a1 >= 100000 Then a2 = iff(up2>=500000, up1, up2); Else If a1 >= 50000 Then a2 = iff(up3>=100000, up2, up3); Else If a1 >= 10000 Then a2 = iff(up4>=50000, up3, up4); Else If a1 >= 5000 Then a2 = iff(up5>=10000, up4, up5); Else If a1 >= 1000 Then a2 = iff(up5>=5000, up5, up6); Else a2 = iff(up6>=1000, up6, up6); } Else { If a1 >= 500000 Then a2 = up1; Else If a1 >= 100000 Then a2 = iff(up2>=500000, up1, up2); Else If a1 >= 50000 Then a2 = iff(up3>=100000, up2, up3); Else If a1 >= 10000 Then a2 = iff(up4>=50000, up3, up4); Else If a1 >= 5000 Then a2 = iff(up5>=10000, up4, up5); Else If a1 >= 1000 Then a2 = iff(up5>=5000, up5, up6); Else a2 = iff(up6>=1000, up6, up7); } } else if CodeCategory() == 8 || CodeCategory() == 9 then { // ETF a2 = up6; } } if date >= 19981207 then { if CodeCategory() == 2 then { if date >= 20030721 then { dn1 = int(b1/100+0.00001)*100; dn2 = int(b1/100+0.00001)*100; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/5+0.00001)*5; dn7 = int(b1/1+0.00001)*1; } else { dn1 = int(b1/1000+0.00001)*1000; dn2 = int(b1/500+0.00001)*500; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/10+0.00001)*10; dn7 = int(b1/1+0.00001)*1; } } Else { dn1 = int(b1/1000+0.00001)*1000; dn2 = int(b1/500+0.00001)*500; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/5+0.00001)*5; dn7 = int(b1/1+0.00001)*1; } if CodeCategory() == 1 || CodeCategory() == 2 then { if sdate < 20101004 Then { If b1 >= 500000 Then b2 = dn1; Else If b1 >= 100000 Then b2 = iff(dn2>=500000, dn1, dn2); Else If b1 >= 50000 Then b2 = iff(dn3>=100000, dn2, dn3); Else If b1 >= 10000 Then b2 = iff(dn4>=50000, dn3, dn4); Else If b1 >= 5000 Then b2 = iff(dn5>=10000, dn4, dn5); Else If b1 >= 1000 Then b2 = iff(dn5>=5000, dn5, dn6); Else b2 = iff(dn6>=1000, dn6, dn6); } Else { If b1 >= 500000 Then b2 = dn1; Else If b1 >= 100000 Then b2 = iff(dn2>=500000, dn1, dn2); Else If b1 >= 50000 Then b2 = iff(dn3>=100000, dn2, dn3); Else If b1 >= 10000 Then b2 = iff(dn4>=50000, dn3, dn4); Else If b1 >= 5000 Then b2 = iff(dn5>=10000, dn4, dn5); Else If b1 >= 1000 Then b2 = iff(dn5>=5000, dn5, dn6); Else b2 = iff(dn6>=1000, dn6, dn7); } } else if CodeCategory() == 8 || CodeCategory() == 9 then { // ETF b2 = dn6; } } plot1(floor(a2)); plot2(Ceiling(b2));
프로필 이미지
하리마우
2020-12-05
908
글번호 144458
지표
답변완료

문의

1. 금일 첫봉부터 계산하는 수식으로 수정 요청 2. 수식 해석 3. cross 선언이 수식내에서 하는 역할 부탁드립니다. ******************************************************************************* var : A1(0),A2(0),Acount(0); var : B1(0),B2(0),Bcount(0); A1 = L; A2 = A1[1]; if A1 > A2 Then Acount = Acount+1; Else Acount = 0; var : cross(0); if Bdate != Bdate[1] Then cross = 0; cross = cross+1; if Acount == 3 Then { cross = cross+1; if cross != 4 Then Buy("b",AtMarket); }
프로필 이미지
목마와숙녀
2020-12-05
754
글번호 144457
시스템
답변완료

문의 드립니다.

안녕하세요 항상 빠른 답변 감사드립니다. 1, 종목검색식 이전 30봉 부터 1봉전까지 볼린버밴드(30,2) 상단 > 볼린버밴드(10,2) 상단 상테 지속후 볼린버밴드(10,2) 상단이 볼린버밴드(30,2) 상단을 돌파 검색
프로필 이미지
느와르
2020-12-06
686
글번호 144456
종목검색
답변완료

부탁드립니다.

안녕하세요. 종목검색식을 부탁드립니다. 0봉전 or 1봉전 or 2봉전 or 3봉전에 30이평과 240이평이 골든크로스가 난 종목검색식.
프로필 이미지
핏불
2020-12-05
756
글번호 144455
종목검색
답변완료

키움식 변환

<중심선> T= TEMA(c,20) <볼린저밴드> T + D1 * stdev(c,period) <- 상한선 T - D1 * stdev(c,period) <- 하한선 <엔벨> T + T * percent/100 <- 상한선 T - T * percent/100 <- 하한선 TEMA값을 중심으로 볼린저와 엔벨로프를 차트에 동시에 표시하고 TEMA값을 기울기에 따라 색상을 부여하고 싶습니다.. 감사합니다
프로필 이미지
중추신경
2020-12-05
869
글번호 144454
지표
답변완료

지표식 문의

수고하십니다. 분봉에서 1] 그림1에서처럼 당일 시가가 찍히고 나면 [또는 동시에] 그림2처럼 당일시가라인을 좌측으로 연장해서 수평선으로 표시하고 싶습니다. [즉, 전체 화면, 모든 기간에 당일의 시가 수평선을 표시] 2] 그림3에서처럼 전일의 고가,저가,(고가+저가)/2 라인을 당일에 수평선으로 표시되게 하고 싶습니다. 두 지표식 부탁합니다. 수고하세요...
프로필 이미지
오이도인
2020-12-05
813
글번호 144453
지표
답변완료

지표 질문 드립니다..

1. 당일 최고종가 대비 n% 빠진 구간을 표현하고 싶습니다. 2. 상승 vi 예상가 대비 n% 빠진 구간을 표현하고 싶습니다. 3. 하락 vi 예상가 대비 n% 빠진 구간을 표현하고 싶습니다. 4. 5봉 양봉 -> 이후 5봉 음봉인 식을 표현하고 싶습니다. 그 후 특정 분봉에만 이 식을 적용하는 법을 알고 싶습니다. 5. 1분봉에서만 시가 대비 종가가 1% 상승한 캔들을 표현하고 싶습니다. 6. A라는 조건이 만족되면 검색을 시작 -> A 조건이 만족된 종목들 중 B와 C 조건이 만족될때만 선별적으로 매수 진입 하는 로직을 짜기 위해서는 어떻게 설계를 해야 하나요? 7. ts 혹은 익절,손절은 수식의 끝부분에 작성하는게 좋을까요? 8. 기업의 시가총액 데이터를 쓰기 위해서는 예스스팟을 이용해야 하나요? 시가총액 1조 이하의 종목만 매매하는 로직을 만들고 싶은데요. 9. 백테스트를 개별 종목이 아닌 전 종목에다 할 수 없나요? (주식) 10. 시스템 트레이딩 시뮬레이션 -> 시스템 트레이딩 설정 -> 최대 수익 대비 하락 / 최소 가격변화 등의 옵션을 체크하는게 수식으로 작성하는것과 무슨 차이가 있는지 궁금하며 , 최소 가격변화 옵션의 의미가 궁금합니다. 개별식으로 작성해주시면 더욱 감사하겠습니다.. 좋은 하루 되세요 (--) (__)
프로필 이미지
뭐뇌
2020-12-07
874
글번호 144452
지표
답변완료

질문입니다.

5 이동평균선 쌍바닥과 쌍고점을 표현하고 싶습니다. 하락 -> 상승된 첫째 저점포인트가 하락 -> 상승되는 현재 저점포인트보다 낮아야 하며 차트상으로 종가 기준 첫번째 포인트보다 종가 기준 두번째 포인트가 더 높은 종목을 찾아내고 싶습니다. 또한 , 그 반대되는 쌍고도 역으로 표현하여 알려주시면 감사하겠습니다... ///// 그리고 , 분봉상에서 1분봉에서 적용되는지 3분봉에서 적용되는지 일봉에서 적용되는지 어떤 봉차트를 기준으로 하는 것인지 알고 싶습니다. 감사합니다!
프로필 이미지
뭐뇌
2020-12-05
976
글번호 144451
종목검색
답변완료

몇일전글올렸는데 도저히 모르겠네요.

현재 제가 사용하는 수식입니다. Input : shortPeriod(21) longPeriod(16), Period(4); input : StartTime(064500),EndTime(180000); var : Tcond(false); if (sdate != sdate[1] and stime >= StartTime) or (sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then Tcond = true; if (sdate != sdate[1] and stime >= EndTime) or (sdate == sdate[1] and stime >= EndTime and stime[1] < EndTime) Then Tcond = False; if Tcond == true Then value1 = MACD(shortPeriod, longPeriod); value2 = ema(value1, Period); # 매수/매도청산 If CrossUP(value1, value2) Then { Buy(); } # 매도/매수청산 If CrossDown(value1, value2) Then { Sell(); } 여기에서 청산수익, 손절을 100포인트잡고싶습니다. 수익 100포인트 진입시 트레일링으로 최소수익 100틱을 유지하고 싶은데.. 제 수식에 대입부탁드립니다. 감사합니다.
프로필 이미지
빛돌이
2020-12-04
908
글번호 144450
시스템