커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

예스트레이더 언어로 변환해서 검색식 부탁드립니다.

1. 신호수식 최고가=최고값(고가,20); 최저가=최저값(저가,20); 경계=(최고가+최저가)/2-(최고가-최저가)*배분1; 경1=crossup(종가, 경계)&& 종가>시가*배분2; 경2=crossdown(c, 경계); 기준봉=valuewhen(1, 경1 or 경2, 시가); 기봉1=crossup(종가, 기준봉); 기봉2=crossdown(종가, 기준봉); 결준=valuewhen(1, 기봉1 or 기봉2, 시가); 결기1=crossup(종가, 결준); 결기2=crossdown(종가, 결준); A=valuewhen(1, 결기1 or 결기2, 시가); M5=eavg(C,5); M10=eavg(C,10); M20=eavg(C,20); M60=eavg(C,60); M120=eavg(C,120); M240=eavg(C,240); M250=eavg(C,250); M480=eavg(C,480); BH=BBandsUp(20,2); BC=BBandsC(20,2); 평균=((M5*2)+(M10*2)+(M20*3)+(M60*2)+(M120*3)+(M240*2)+(M480*2)+(BH*1)+(BC*1)) / 18; 평균라인=Tema(평균, 5, 지수); B=평균라인 + 20*stdev(평균라인,5); AA=sar(0.02,0.2); 거래대금=V*C; // 거래대금 계산 C >= A && CROSSUP(C, B) && AA <= C && C >= M250 && 거래대금 >= 6000000&& MACD(shortPeriod,longPeriod)>baseLine &&MACD(shortPeriod,longPeriod)>= eavg(MACD(shortPeriod,longPeriod),sigPeriod) 2. 지표변수 배분1 0.236 배분2 1.02 shortPeriod 12 longPeriod 26 sigPeriod 9 baseLine 0 sigPeriod 9 이건 키움증권 화살표 수식입니다. 이걸 예스트레이더 언어로 변환해서 검색식으로 만들수 있을까요?
프로필 이미지
늑대의유혹
2024-12-29
621
글번호 186714
검색
답변완료

종목 검색 부탁드려요

*문의드립니다 1) 1봉전 캔들은 음봉 , 0봉전 캔들은 양봉인 종목검색식 부탁드립니다.(일봉기준) 2) 2봉전 캔들은 음봉, 1봉전 캔들은 양봉, 0봉전 캔들은 양봉인 종목검색식 부탁드려요. 2) 이격도 보조지표에서 20일 이격도선이 내려가다가 반등할때 ( 전일보다 반등할때-일봉기준) 종목검색식 부탁드립니다.
프로필 이미지
일지매7
2024-12-29
530
글번호 186713
종목검색
답변완료

일목군형표문의

선행스팬의 골든데드가 현재봉의 위치가 아닌 25개봉 앞에 그려진 골든,데드시 매수,매도 부착드립니다.
프로필 이미지
몽고메리
2024-12-29
475
글번호 186712
시스템
답변완료

수식수정 부탁합니다

안녕하세요 수식지왕님의 마켓프로파일수식입니다. 1.아래수식이 9시에시작하는데 선물옵션에 사용하는지라 8시45분시작으로 수정해주시면 좋겠읍니다 2.차트시간 1분3분등 사용시간에따라 타임이라는 변수를 변경하는건가요? input: 타임(15); var:arr(0),k(0),tick(0),chk_cnt(0),ttm(0),t_val(0),max_tpo(0),tot_tpo(0), sum(0),acc(0),mdl_prc(0),mdl_arr(0),range_u(0),range_d(0),base(0), cal_tpo(0),up_tpo(0),dn_tpo(0),up_tail_u(0),up_tail_d(0),dn_tail_u(0),dn_tail_d(0); array:price_u[100](0),price_m[100](0),price_d[100](0), status_u[100](0),status_m[100](0),status_d[100](0), tpo_u[100](0),tpo_m[100](0),tpo_d[100](0); tick = _TickValue(); if dayindex()==0 then //매일 첫번째 봉에서 해당 변수들의 값을 0으로 초기화 { for arr = 0 to 99 { price_u[arr] = 0; price_m[arr] = 0; price_d[arr] = 0; status_u[arr] = 0; status_m[arr] = 0; status_d[arr] = 0; tpo_u[arr] = 0; tpo_m[arr] = 0; tpo_d[arr] = 0; } max_tpo = 0; tot_tpo = 0; sum = 0; acc = 0; mdl_prc = 0; mdl_arr = 0; range_u = 0; range_d = 0; base = dayopen() + tick * 149; //300개 가격대중 최상단에 해당하는 가격 price_u[0] = base; //지수 배열 상단 for arr = 1 to 99 { price_u[arr] = price_u[arr-1] - tick; } price_m[0] = price_u[99] - tick; //지수 배열 중단 for arr = 1 to 99 { price_m[arr] = price_m[arr-1] - tick; } price_d[0] = price_m[99] - tick; //지수 배열 하단 for arr = 1 to 99 { price_d[arr] = price_d[arr-1] - tick; } } ttm = TimeToMinutes(stime); //시간을 30분,15분,10분등으로 나누기 쉽도록 환산 t_val = int((ttm-540)/interval) + 1; //540은 09:00. 9시를 빼고 나서 원하는 시간단위로 나눈다 for arr = 0 to 99 { if l <= price_u[arr] and price_u[arr] <= h then { if status_u[arr] < t_val then //A가 찍혔는데 또 A를 찍을 필요가 없음. 그걸 확인 { status_u[arr] = t_val; //중복을 막기 위해 마지막 time value 저장 tpo_u[arr] = tpo_u[arr] + 1; //현재 가격대의 TPO 누적 tot_tpo = tot_tpo + 1; //전체 TPO 누적 if max_tpo < tpo_u[arr] then //TPO 최빈값 { max_tpo = tpo_u[arr]; sum = 0; //TPO가 동일한 가격대가 여러가격일 경우 acc = 0; //평균값을 구하기 위해 가격 누적변수와 가격대 수 초기화 } if max_tpo == tpo_u[arr] then //최빈값과 동일하면 { sum = sum + price_u[arr]; //해당 가격을 누적 acc = acc + 1; //가격대 개수 누적 } } } //3개의 동일 성격을 지닌 배열에 대해 한꺼번에 처리 못하므로 동일 루틴으로 3회 처리 if l <= price_m[arr] and price_m[arr] <= h then { if status_m[arr] < t_val then { status_m[arr] = t_val; tpo_m[arr] = tpo_m[arr] + 1; tot_tpo = tot_tpo + 1; if max_tpo < tpo_m[arr] then { max_tpo = tpo_m[arr]; sum = 0; acc = 0; } if max_tpo == tpo_m[arr] then { sum = sum + price_m[arr]; acc = acc + 1; } } } if l <= price_d[arr] and price_d[arr] <= h then { if status_d[arr] < t_val then { status_d[arr] = t_val; tpo_d[arr] = tpo_d[arr] + 1; tot_tpo = tot_tpo + 1; if max_tpo < tpo_d[arr] then { max_tpo = tpo_d[arr]; sum = 0; acc = 0; } if max_tpo == tpo_d[arr] then { sum = sum + price_d[arr]; acc = acc + 1; } } } } mdl_prc = round(sum/acc/tick,0)*tick; //평균하여 중심가격으로 삼음 mdl_arr = int((base-mdl_prc)/tick); //배열변수의 첨자는 정수이어야 함 //처음부터 int()를 생각해 냈던 것은 아니고 디버그 과정에서 알게 됨 range_u = mdl_arr; range_d = mdl_arr; //MessageLog(",%.2f",range_u); // 전체 TPO의 70%가 될 때까지 상하값을 비교하면서 누적 cal_tpo = iff(mdl_arr<100,tpo_u[mdl_arr],iff(mdl_arr<200,tpo_m[mdl_arr-100],tpo_d[mdl_arr-200])); for k = 0 to 150 { // range_u는 한단위씩 위로(-1), range_d는 한단위씩 아래로(+1) // TPO가 많은 쪽의 TPO를 먼저 누적한다 var2 = iff(range_u-1<100,tpo_u[range_u-1],iff(range_u-1<200,tpo_m[range_u-1-100],tpo_d[range_u-1-200])); var3 = iff(range_d+1<100,tpo_u[range_d+1],iff(range_d+1<200,tpo_m[range_d+1-100],tpo_d[range_d+1-200])); if var2 > var3 then { cal_tpo = cal_tpo + var2; range_u = range_u - 1; } else if var2 < var3 then { cal_tpo = cal_tpo + var3; range_d = range_d + 1; } else if var2 == var3 and var2 > 0 and var3 > 0 then { cal_tpo = cal_tpo + var2; range_u = range_u - 1; } if cal_tpo >= tot_tpo * 0.7 or var2 + var3 == 0 then k = 150; } up_tpo = 0; //중심가격의 상위 TPO if tpo_u[0] == 1 then up_tail_u = 0; //윗꼬리 상단 경계선, 0행부터 1이면 윗꼬리 상단은 0행이 됨 else up_tail_u = 299; //윗꼬리를 못 찾을 경우를 대비해서 상단과 하단의 관계를 역으로 만듬 //꼬리 경계값을 찾는 루틴을 성공적으로 마치면 상단값 < 하단값 성립 up_tail_d = 0; //윗꼬리 하단 경계선 //0행부터 중심가격 이전행까지 아래로 내려가면서 for arr = 0 to mdl_arr-1 { //현재 행의 tpo 값이 0이고 다음 행의 tpo값이 1이면 1의 시작으로 보고 다음 행의 행번호를 윗꼬리 상단으로 봄 if iff(arr<100,tpo_u[arr],iff(arr<200,tpo_m[arr-100],tpo_d[arr-200])) == 0 and iff(arr+1<100,tpo_u[arr+1],iff(arr+1<200,tpo_m[arr-100+1],tpo_d[arr-200+1])) == 1 then up_tail_u = arr + 1; //윗꼬리 상단 경계선 array //현재 행의 tpo 값이 1이고 다음 행의 tpo값이 1보다 크면 현재 행의 행번호를 윗꼬리 하단으로 봄 if iff(arr<100,tpo_u[arr],iff(arr<200,tpo_m[arr-100],tpo_d[arr-200])) == 1 and iff(arr+1<100,tpo_u[arr+1],iff(arr+1<200,tpo_m[arr-100+1],tpo_d[arr-200+1])) > 1 and up_tail_d == 0 then //조건을 만족하는 경우가 여러번 발생하는데 up_tail_d가 0일때만 //즉, 처음에 찾아진 값만 유효한 것로 봄 up_tail_d = arr; //윗꼬리 하단 경계선 array //TPO가 1보다 큰 상위 TPO 누적 if iff(arr<100,tpo_u[arr],iff(arr<200,tpo_m[arr-100],tpo_d[arr-200])) > 1 then up_tpo = up_tpo + iff(arr<100,tpo_u[arr],iff(arr<200,tpo_m[arr-100],tpo_d[arr-200])); } dn_tpo = 0; //중심가격의 하위 TPO dn_tail_u = 299; //아래꼬리 상단 경계선 if tpo_d[99] == 1 then dn_tail_d = 299; else dn_tail_d = 0; //아래꼬리 하단 경계선 //299행부터 중심가격 이전행까지 위로 올라가면서 for arr = 299 downto mdl_arr+1 { //TPO가 1보다 큰 하위 TPO 누적 if iff(arr<100,tpo_u[arr],iff(arr<200,tpo_u[arr-100],tpo_d[arr-200])) > 1 then dn_tpo = dn_tpo + iff(arr<100,tpo_u[arr],iff(arr<200,tpo_m[arr-100],tpo_d[arr-200])); //현재 행의 tpo 값이 1이고 윗행의 tpo값이 1보다 크면 현재 행의 행번호를 아랫꼬리 상단으로 봄 if iff(arr<100,tpo_u[arr],iff(arr<200,tpo_m[arr-100],tpo_d[arr-200])) == 1 and iff(arr-1<100,tpo_u[arr-1],iff(arr-1<200,tpo_m[arr-100-1],tpo_d[arr-200-1])) > 1 and dn_tail_u == 299 then dn_tail_u = arr; //아래꼬리 상단 경계선 array //현재 행의 tpo 값이 0이고 윗행의 tpo값이 1이면 1의 시작으로 보고 윗행의 행번호를 아랫꼬리 하단으로 봄 if iff(arr<100,tpo_u[arr],iff(arr<200,tpo_m[arr-100],tpo_d[arr-200])) == 0 and iff(arr-1<100,tpo_u[arr-1],iff(arr-1<200,tpo_m[arr-100-1],tpo_d[arr-200-1])) == 1 then dn_tail_d = arr - 1; //아래꼬리 하단 경계선 array } plot1(mdl_prc,"중심가격"); plot2(base-(range_u*tick),"가치영역(상)"); plot3(base-(range_d*tick),"가치영역(하)"); if up_tail_u <= up_tail_d then //꼬리의 경계값이 정상적으로 찾아졌다면 { plot4(base-(up_tail_u*tick),"윗꼬리상단"); //점그래프로 표현 plot5(base-(up_tail_d*tick),"윗꼬리하단"); } if dn_tail_u <= dn_tail_d then { plot6(base-(dn_tail_u*tick),"아랫꼬리상단"); plot7(base-(dn_tail_d*tick),"아랫꼬리하단"); } //plot8(up_tpo,"상위TPO"); //plot9(dn_tpo,"하위TPO");
프로필 이미지
바닥차기
2024-12-29
624
글번호 186711
지표

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

프로필 이미지
cntbs
2024-12-29
34
글번호 186710
종목검색
답변완료

지표 부탁드립니다.

항상 수고하시고 새해 복 미리 받으세요 아래 수식은 직전고점 직전저점 찾는 수식입니다. 변수를 5로 했구요 마지막에 표시된 고점 320.30에서 마지막 직전저점 319.75를 뺀값을 고점320.30에 더한값(0.55) 320.85 에 노란선으로 표시되게 하구요 또 마지막 저점 319.75에서 뺀값(0.55) 319.2를 그림처럼 분홍색선 으로 표시하고 수치도 그림처럼 표시할수 있게 해주시면 좋겠습니다. 그리고 고점에서 저점을 뺀값에 1.618배 또는 2배 3배 까지 확장해서 표시할수 있게 해주시면 감사하겠습니다. input : Leftbar(5),Rightbar(5); var : TL(0),Tx(0); if SwingHigh(1,H,Leftbar,Rightbar,Leftbar+Rightbar+1) != -1 Then { TL = TL_New(sDate[Rightbar],sTime[Rightbar],H[Rightbar],sDate,sTime,H[Rightbar]); TL_SetColor(TL,Red); TX = Text_New(sDate[Rightbar],sTime[Rightbar],H[Rightbar],NumToStr(H[Rightbar],2)); Text_SetStyle(TX,2,1); } if SwingLow(1,L,Leftbar,Rightbar,Leftbar+Rightbar+1) != -1 Then { TL = TL_New(sDate[Rightbar],sTime[Rightbar],L[Rightbar],sDate,sTime,L[Rightbar]); TL_SetColor(TL,Cyan); Tx = Text_New(sDate[Rightbar],sTime[Rightbar],L[Rightbar],NumToStr(L[Rightbar],2)); Text_SetStyle(TX,2,0); }
프로필 이미지
superman
2024-12-29
557
글번호 186709
지표

아담스꺽 님에 의해서 삭제되었습니다.

프로필 이미지
아담스꺽
2024-12-28
0
글번호 186708
종목검색
답변완료

종목검색식 부탁드림니다.

항상 노고에 감사드림니다. 아래의 수식을 종목검색식으로 부탁드림니다. A1=BBandsup(20, 2); A2=BBandsup(40, 2); A3=BBandsup(60, 2); A4=MA(C, 120, 단순); if(Crossup(C, A1) && Crossup(C, A2) && Crossup(C, A3), D, 0) && Crossup(C, A4)
프로필 이미지
존슨비치
2024-12-28
498
글번호 186707
종목검색
답변완료

시작시간식 설정 확인 부탁드립니다.

아래의 시작시간설정식에서는 13시30분에 완성되는 30분봉에서 진입신호발생 조건이 완성되었는데 신호가 발생하지 않고 시작시간을 130000 로 설정해야 13시30분봉에 진입신호가 발생합니다. 시작시간을132000이나133000로 설정했을 경우에 30분봉상 13시30분봉부터 신호가 발생할 수 있게하려는데 수식 수정 좀 부탁드립니다. input : StartTime(132000),EndTime(60000); var : Tcond(false); IF Endtime > starttime Then SetStopEndofday(Endtime); Else { if sDate != sDate[1] Then SetStopEndofday(Endtime); } 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 { Tcond = true; IF Endtime <= starttime Then { SetStopEndofday(0); } } if Tcond == true Then { 진입청산수식 }
프로필 이미지
산수유
2024-12-28
561
글번호 186706
시스템
답변완료

키움종목검색식변환이요...

키움 종목검색식입니다. 변환부탁드립니다. 감사합니다.
프로필 이미지
시온사랑
2024-12-28
565
글번호 186705
검색