커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

문의

항상 많은 도움 감사합니다. 아래 두가지 지표를 잘 쓰고 있긴한데 수치는 맞는데 알람소리가 안 나요. 다른 지표들은 알람소리가 잘 나는데.... 수치는 맞으니까 아쉬운대로 계속 쓰다가 답답해서 다시 문의 드립니다. 알람소리 나게 부탁드립니다. 1.월고 월저 기준가 input : 입력일(20211210),Per(3); var : 기준가(0,Data2),월고(0,Data2),월저(0,Data2); var : cond1(False,Data2),cond2(False,Data2),cond3(False,Data2); if data2(sdate == 입력일) Then 기준가 = data2(lowD(0)); if data2(sdate >= 입력일) Then { if Data2(월고 == 0 or (월고 > 0 and H > 월고)) Then 월고 = data2(h); if data2(월저 == 0 or (월저 > 0 and L < 월저)) Then 월저 = data2(l); } if 기준가 > 0 Then Plot1(기준가); if 월고 > 0 Then Plot2(월고); if 월저 > 0 Then Plot3(월저); Cond1 = Data2(C<=기준가*(1+Per/100) and C >= 기준가*(1-Per/100)); Cond2 = Data2(C<=월고*(1+Per/100) and C >= 월고*(1-Per/100)); Cond3 = Data2(C<=월저*(1+Per/100) and C >= 월저*(1-Per/100)); if cond1 == true and cond1[1] == False Then PlaySound("C:₩예스트레이더₩data₩Sound₩accept.wav"); if cond2 == true and cond2[1] == False Then PlaySound("C:₩예스트레이더₩data₩Sound₩accept.wav"); if cond3 == true and cond3[1] == False Then PlaySound("C:₩예스트레이더₩data₩Sound₩accept.wav"); 2.특정일 저가 input : 날짜(20211210),Per1(3); var : D2L(0,data2),scond1(False,Data2); if data2(sdate == 날짜) Then { D2L = data2(LowD(0)); } plot1(D2L); scond1 = Data2(C) <= D2L*(1+Per1/100) and Data2(C) >= D2L*(1-Per1/100); if scond1 == true and scond1[1] == true Then PlaySound("C:₩예스트레이더₩data₩sound₩accept.wav");
프로필 이미지
육각수
2021-12-10
978
글번호 154356
지표
답변완료

수식 부탁드립니다

var : entry(0); if bdate != bdate[1] Then entry = 0; if (MarketPosition != 0 and MarketPosition != MarketPosition[1]) or (MarketPosition == MarketPosition[1] and TotalTrades > TotalTrades[1]) Then entry = entry+1; if MarketPosition <= 0 and entry < 1 Then buy("b",atlimit,dayhigh-PriceScale*35); if MarketPosition == 1 Then exitlong("bx",atlimit,lowest(L,BarsSinceEntry)+PriceScale*30); if MarketPosition >= 0 and entry < 1 Then sell("s",atlimit,daylow+PriceScale*100); if MarketPosition == -1 Then ExitShort("sx",atlimit,Highest(H,BarsSinceEntry)-PriceScale*120); if sdate != sdate[1] Then SetStopEndofday(04000); if bdate != bdate[1] Then SetStopEndofday(0); --------------------------------- 위 수식어에 추가 입니다. 매매시간 : 오전 10시부터 익일 04시 손 절 : 20틱
프로필 이미지
푸른
2021-12-10
798
글번호 154355
시스템
답변완료

수식 부탁드립니다.

1. 지표 손절값을 기준으로.. 예를들어 50틱일 경우 - 매수 진입 후 직전 3개 봉(연속 음봉) 기준으로 첫번째 봉 시가와 세번째 봉 종가의 차이가 50틱일 경우 다음 봉 진입시 손절 - 매도 진입시에도 진입 후 직전 3개 봉(연속 양봉) 기준으로 첫번째 봉 시가와 세번째 봉 종가의 차이가 50틱일 경우 손절하는 수식 부탁드립니다. 2. 그리고 아래 지표 수식이 의미하는 내용이 무엇인지 설명 부탁드립니다. input:b_time1(000000),e_time1(240000), stoK_p11(100),stoK_p12(6),stoK_p13(6), ma_p11(25),ma_p12(5),ma_p13(15),ma_p14(100), ma_p15(10),ma_p16(20),ma_p17(15); Var:stoK(0),stoD(0),TRIXv(0),TRIXsig(0),T(0); If b_time1 <= Time and Time <= e_time1 Then { stoK = StochasticsK(stoK_p11,stoK_p12); stoD = StochasticsD(stoK_p11,stoK_p12,stoK_p13); If countif(ma(C,ma_p11)[1] < ma(C,ma_p11),1) == 1 and (ma(C,ma_p12)[1] <= ma(C,ma_p13)[1] and ma(C,ma_p12) > ma(C,ma_p13)) and countif(ma(C,ma_p14)[1] < ma(C,ma_p14),1) == 1 and countif(ma(C,ma_p15)[1] < ma(C,ma_p15),1) == 1 and countif(ma(C,ma_p16)[1] < ma(C,ma_p16),1) == 1 and countif(ma(C,ma_p17)[1] < ma(C,ma_p17),1) == 1 Then { T = 1; } If countif(ma(C,ma_p11)[1] > ma(C,ma_p11),1) == 1 and (ma(C,ma_p12)[1] >= ma(C,ma_p13)[1] and ma(C,ma_p12) < ma(C,ma_p13)) and countif(ma(C,ma_p14)[1] > ma(C,ma_p14),1) == 1 and countif(ma(C,ma_p15)[1] > ma(C,ma_p15),1) == 1 and countif(ma(C,ma_p16)[1] > ma(C,ma_p16),1) == 1 and countif(ma(C,ma_p17)[1] > ma(C,ma_p17),1) == 1 Then { T = -1; } plot1(iff(T==1,100,iff(T==-1,-100,0))); plotbaseline1(0); }
프로필 이미지
미완
2021-12-10
902
글번호 154354
시스템

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

프로필 이미지
thrupass
2021-12-09
0
글번호 154353
지표
답변완료

재질문 드립니다. 텍스트가 반대로 움직입니다.ㅠ

input : 소숫점표시자리수(2),글자크기(12); var : tl1(0),tl2(0),tl3(0),tl4(0); var : tl5(0),tl6(0),tl7(0),tl8(0); var : tx1(0),tx2(0),tx3(0),tx4(0); var : tx5(0),tx6(0),tx7(0),tx8(0); plot1(dayopen(0),"당일시가"); plot2((DayHigh(1)+DayLow(1))/2,"전일중심"); plot3(DayHigh(1),"전일고가"); plot4(DayLow(1),"전일저가"); plot5(DayClose(1),"전일종가"); plot5((DayHigh(0)+DayLow(0))/2,"전일종가"); if Bdate != Bdate[1] Then { var1 = sDate; Var2 = sTime; tl1 = TL_New(sDate,sTime,DayOpen,NextBarSdate,NextBarStime,DayOpen); tl2 = TL_New(sDate,sTime,DayHigh,NextBarSdate,NextBarStime,DayHigh); tl3 = TL_New(sDate,sTime,DayLow,NextBarSdate,NextBarStime,DayLow); tl4 = TL_New(sDate,sTime,(DayHigh+DayLow)/2,NextBarSdate,NextBarStime,(DayHigh+DayLow)/2); tl5 = TL_New(sDate,sTime,DayClose(1),NextBarSdate,NextBarStime,DayClose(1)); tl6 = TL_New(sDate,sTime,DayHigh(1),NextBarSdate,NextBarStime,DayHigh(1)); tl7 = TL_New(sDate,sTime,DayLow(1),NextBarSdate,NextBarStime,DayLow(1)); tl8 = TL_New(sDate,sTime,(DayHigh(1)+DayLow(1))/2,NextBarSdate,NextBarStime,(DayHigh(1)+DayLow(1))/2); } Else { TL_setend(tl1,sDate,sTime,DayOpen); if DayHigh(0) != DayHigh(0)[1] Then { TL_SetBegin(tl2,var1,Var2,DayHigh); TL_SetBegin(tl4,var1,Var2,(DayHigh+DayLow)/2); } if DayLow(0) != DayLow(0)[1] Then { TL_SetBegin(tl3,var1,Var2,DayLow); TL_SetBegin(tl4,var1,Var2,(DayHigh+DayLow)/2); } TL_setend(tl2,sDate,sTime,DayHigh); TL_setend(tl3,sDate,sTime,DayLow); TL_setend(tl4,sDate,sTime,(DayHigh+DayLow)/2); TL_setend(tl5,sDate,sTime,DayClose(1)); TL_setend(tl6,sDate,sTime,DayHigh(1)); TL_setend(tl7,sDate,sTime,DayLow(1)); TL_setend(tl8,sDate,sTime,(DayHigh(1)+DayLow(1))/2); } Text_Delete(tx1); Text_Delete(tx2); Text_Delete(tx3); Text_Delete(tx4); Text_Delete(tx5); Text_Delete(tx6); Text_Delete(tx7); Text_Delete(tx8); tx1 = Text_New(NextBarSdate,NextBarStime,DayOpen," 당일시가"+NumToStr(DayOpen,소숫점표시자리수)); tx4 = Text_New(NextBarSdate,NextBarStime,(DayHigh+DayLow)/2," 당일중심"+NumToStr((DayHigh+DayLow)/2,소숫점표시자리수)); tx5 = Text_New(NextBarSdate,NextBarStime,DayClose(1)," 전일종가"+NumToStr(DayClose(1),소숫점표시자리수)); tx6 = Text_New(NextBarSdate,NextBarStime,DayHigh(1)," 전일고가"+NumToStr(DayHigh(1),소숫점표시자리수)); tx7 = Text_New(NextBarSdate,NextBarStime,DayLow(1)," 전일저가"+NumToStr(DayLow(1),소숫점표시자리수)); tx8 = Text_New(NextBarSdate,NextBarStime,(DayHigh(1)+DayLow(1))/2," 전일중심"+NumToStr((DayHigh(1)+DayLow(1))/2,소숫점표시자리수)); Text_SetSize(tx1,글자크기); Text_SetSize(tx2,글자크기); Text_SetSize(tx3,글자크기); Text_SetSize(tx4,글자크기); Text_SetSize(tx5,글자크기); Text_SetSize(tx6,글자크기); Text_SetSize(tx7,글자크기); Text_SetSize(tx8,글자크기); 일전에 도와주셔서 사용중인 지표식입니다. 말씀하신거처럼 빈칸을 추가해보았으나 도리어 텍스트가 왼쪽으로 이동하여 봉을 더 가리게 되는군요. 제가 잘못바꾼건지 모르겠습니다. 도와주세요!! /// 추가질문 종목차트 하단으로 위치하는 지표창위치를 종목차트 상단으로 바꾸는게 가능한지요? 가능하다면 알려주십시오.
프로필 이미지
에이오드
2021-12-09
709
글번호 154352
지표
답변완료

청산 후 재진입3(Lcount 구별)

손절이후 당일 저점 1번째 돌파시 변수 적용 결과를 살펴보았습니다.(첨부파일) 387.24 저점을 돌파할 때 진입해야는데 다른 지점에서 진입합니다. 살펴주십시요. input : n(1); var : cnt(0),count(0); Count = 0 ; for cnt = 0 to 10 { if EntryDate(cnt) == sdate then Count = Count + 1; } input : 갭하락(1.5),손절진입(50),트레진입(50),최소진입(50); input : loss(0.5),trail(1.5),최소가격(0.4),봉갯수(150); if c < DayOpen - 갭하락 and count < n Then Sell("s"); SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 Then { if TotalTrades > TotalTrades[1] Then count = 0; if daylow(0) < DayLow(0)[1] Then count = count+1; if IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and count == 손절진입 Then Sell("손절진입"); if IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and count == 트레진입 Then Sell("트레진입"); if IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and count == 최소진입 Then Sell("최소진입"); } *********************************************************************************** 안녕하세요 예스스탁입니다. CountIf가 현재봉에서 청산봉까지 루프를 반복하게 되므로 다른 방법으로 작성하면 아래와 같습니다. var : count(0); SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 Then { if TotalTrades > TotalTrades[1] Then count = 0; if daylow(0) < DayLow(0)[1] Then count = count+1; if IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and count == 3 Then Sell(); if IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and count == 2 Then Sell(); if IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and count == 1 Then Sell(); } 즐거운 하루되세요 > 목마와숙녀 님이 쓴 글입니다. > 제목 : 문의 > 답변 수식 고맙습니다. 그런데... 아래 수식을 사용하면 수식 추가 이전보다 시뮬레이션 속도가 현저히 느려지는데요. 이유가 있을까요? 피시 메모리는 동일한 조건에서 비교했습니다. 속도를 고려한 다른 수식은 없겠는지요? *************************************************************************** SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 and IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 3 Then Sell(); if MarketPosition == 0 and IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 2 Then Sell(); if MarketPosition == 0 and IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 1 Then Sell();
프로필 이미지
목마와숙녀
2021-12-16
737
글번호 154351
시스템
답변완료

디버그시 차트값 참조?/외부파일 참조가 가능한가요?

안녕하세요! 수식 작성 중에 어떨 때는 실제 데이터가 뭐가 들어 있는지 식을 실행해서보고 싶을 때가 있는데요, 그때 예를 들면 RSI함수를 화면에 무슨 숫자값들이 들어 있는지 혹은 제가 쓴 함수가 값들이 제가 원하는 대로 잘 들어 있는지 확인은 어떻게 하나요? (또 이때 숫자값을 문자열로 변환은 어떻게하는지요?) messagelog함수인가 그것은 위의 상황에 안되는 경우가 있어서 질문드립니다. 그냥 차트에 띄워서 보는 방법 밖에 없나요? 즉 그 전에 코드 에디터에서 실제 차트 데이터를 숫자들이 잘 들어 있거나 작동 잘하는지 보고 싶습니다. 그리고 궁금한 것은 예스랭귀지에서 csv파일을 출력은 메뉴얼에서 봤는데 읽는 것은 없나요? 아니면 외부 html이나 크롤링 함수들은 지원을 하는지요? 감사합니다.
프로필 이미지
nirvana
2021-12-09
656
글번호 154350
시스템
답변완료

부탁드립니다.

언제나 감사드립니다. 1. Index나 dayindex 대신에 그 상황이 발생한 시각을 지정할 수 있는지요. stime이 무슨 뜻인지 모르지만, 그런 식으로 표현할 방법이 없는지요. 특정시각 이후에 그 일이 일어난 것을 부수조건으로 설정코자 하는데, 분봉의 크기에 따라 다른 dayindex를 지정하기가 번거러워서 그럽니다. 부탁드립니다. If condition1[1]==false and condition1==true Then{ var1=Index; } 대신 If condition1[1]==false and condition1==true Then{ var1=발생시분초; } 2. 분봉에서 매수조건이 맞을 때 그날의 종가에 자동진입하게끔 시스템식을 작성하려면 어떻게 해야 하는지요. If stime==152500 and 매수조건1 Then{ buy("b1"); } If stime==152500 and 매수조건2 Then{ buy("b2"); } 이런 식으로 해도 되는지요. 3. 중복진입이 가능할 때 첫매수일로부터 5거래일 후의 정오에 자동청산한다면 어떻게 시스템식을 작성해야 하는지요. setstopendofday같은 별도의 용어가 있는지요. 4.. 위에서 매수후 5일이내의 최고점에서 팔았다고 가정할 경우에 그 시각 이전까지의 최대손실을 알 수 있는 방법이 있다면 부탁드리겠습니다. 시스템 성과를 정확히 알고 싶어서 그럽니다. 부탁드립니다. 즉 매수후 5일이내의 기간중에 최고점에서 팔았다고 가정할 경우의 수익과 최고점을 가기까지에 겪는 최대손실을 알고자 함입니다. 사후적인 검증에 의해서 기간내의 최고점에서 청산한 것으로 전제하여 그때까지의 성과와 최대손실을 성과보고서에서 확인할 방법은 없는지요. 청산목표 설정에 참고하고자 함입니다. 부탁드립니다. 5. 분봉그래프에서 같은종목의 일봉그래프를 매번 수정하지 않고 data2로 설정하는 방법은 없는지요. 6. 분봉그래프에서 일평균거래량 구하기 (1) 19일간의 dayvolume(1)의 평균을 구하는 지수식을 어떻게 표현하는지요. (2) 상장한지 20거래일이 안 된 경우 경과된 날짜만큼의 dayvolume(1)의 평균은 어떻게 구하는지요. 7. 선물에서 bids-asks의 당일 시초가를 나타낼 수 있는 방법이 있는지요.
프로필 이미지
묘선낭자
2021-12-10
560
글번호 154349
시스템

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

프로필 이미지
hakona
2021-12-09
0
글번호 154346
지표

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

프로필 이미지
2wnwn
2021-12-09
9
글번호 154342
지표