커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

수식문의 드립니다.

전일종가는 dayclose()로 나타내는데 전일이평선은 어떻게 나타낼수 있나요? 예를 들어 전일종가때 20이평선은 어떻게 수식이 나오나요?
프로필 이미지
고구미
2021-10-28
636
글번호 153211
시스템

푸른물결 님에 의해서 삭제되었습니다.

프로필 이미지
푸른물결
2021-10-28
29
글번호 153210
지표
답변완료

문의 드립니다.

안녕하세요 키움 수식인데 변환좀 부탁드립니다. 수식1 aa=MACD(short,long); bb=if(aa(1)<=aa,1,-1); sum(bb) 수식2 aa=MACD(short,long); bb=if(aa(1)<=aa,1,-1); sum(bb) 수식3 aa=MACD(short,long); bb=if(aa(1)<=aa,1,-1); cc=sum(bb); if(cc(1)>=cc,cc,0) 수식4 0 지표조건 short 30 long 60 항상 도움주심에 감사드립니다.
프로필 이미지
로꼬로꼬
2021-10-28
720
글번호 153209
지표
답변완료

문의드립니다.

안녕하세요. 1분봉에서 일봉 이평선 가격을 기준으로 매수/매도하는 수식을 작성하려고 합니다. 거의 일봉으로만 거래를 하다보니 분봉 시스템에 익숙치 않아서 도움을 부탁드립니다. 시스템 제작에 많은 도움을 주셔서 항상 감사드립니다. 전략은 개장 후 시가가 밀리면 1% 하락 시마다 분할 매수(현재는 4회만 표시하였으나 횟수 제한 없이 매수할 예정)한 후 평균가 대비 5% 상승 시 매도하는 전략입니다. 단 일봉 이평선(5,10,20,60) 중 현재가격 바로 아래에 있는 일봉이평선을 기준으로 삼아서 그 이평선 도달 전까지만 매수하고 이평선을 이탈(-2%)하면 손절할 예정이며, 일 1회만 거래하려고 합니다. 아래 수식으로 작성을 해봤는데 수정 부탁드립니다. 좋은 하루 보내세요. input : p5(0), p10(0),p20(20), p60(60),p120(120),p240(240); input : dayperiod5(5), dayperiod10(10), dayperiod20(20),dayperiod60(60); var : cond1(False), cond11(False), cond12(False); var : ma5(0),ma10(0),ma20(0),ma60(0),ma120(0),ma240(0), 이평(0), count(0); var : cnt(0),sum5(0), sum10(0), sum20(0), sum60(0), daymav(0), daymav5(0), daymav10(0), daymav20(0), daymav60(0); var : min1(0), min2(0), min3(0), min4(0); if Bdate != Bdate[1] Then { Cond1 = False; #당일조건만족여부 count = 0; } #일봉 이동평균계산 sum5 = 0; For cnt = 0 to dayPeriod5-1 { sum5 = sum5 + DayClose(cnt); } daymav5 = sum5/dayPeriod5; // 현재 20일선 sum10 = 0; For cnt = 0 to dayPeriod10-1 { sum10 = sum10 + DayClose(cnt); } daymav10 = sum10/dayPeriod10; // 현재 20일선 sum20 = 0; For cnt = 0 to dayPeriod20-1 { sum20 = sum20 + DayClose(cnt); } daymav20 = sum20/dayPeriod20; // 현재 20일선 sum60 = 0; For cnt = 0 to dayPeriod60-1 { sum60 = sum60 + DayClose(cnt); } daymav60 = sum60/dayPeriod60; // 현재 20일선 // 분봉 종가와 일봉이평선과의 간격 확인 min1 = nthminlist(1,C-daymav5,C-daymav10,C-daymav20,C-daymav60); min2 = nthminlist(2,C-daymav5,C-daymav10,C-daymav20,C-daymav60); min3 = nthminlist(3,C-daymav5,C-daymav10,C-daymav20,C-daymav60); min4 = nthminlist(4,C-daymav5,C-daymav10,C-daymav20,C-daymav60); // 종가가 모든 이평선보다 위에 있으면 daymav를 제일 높은 가격의 이평선선택 if min1>0 Then daymav = NthMaxList(1, daymav5, daymav10, daymav20, daymav60); // 1개의 이평선이 종가보다 높은 경우, 2번재 높은 가격의 이평선을 선택 Else if min2 > 0 Then daymav = NthMaxList(2, daymav5, daymav10, daymav20, daymav60); Else if min3 > 0 Then daymav = NthMaxList(3, daymav5, daymav10, daymav20, daymav60); Else if min4 > 0 Then daymav = NthMaxList(4, daymav5, daymav10, daymav20, daymav60); Else daymav = 0; If cond1 == False and MarketPosition == 0 and C < DayOpen(0) and C>daymav and count< 1 Then { Buy("b1", AtLimit, DayOpen(0)*0.99,1); } If cond1 == False and MarketPosition == 1 and C < DayOpen(0) and C>daymav and count< 2 Then { Buy("b2", AtLimit, DayOpen(0)*0.98,1); } If cond1 == False and MarketPosition == 1 and C < DayOpen(0) and C>daymav and count< 3 Then { Buy("b3", AtLimit, DayOpen(0)*0.97,1); } If cond1 == False and MarketPosition == 1 and C < DayOpen(0) and C>daymav and count< 4 Then { Buy("b4", AtLimit, DayOpen(0)*0.96,1); } If MarketPosition == 1 then { // 이평선 2% 이탈 시 손절 ExitLong("bx1",AtLimit,daymav*0.98,"",1,2); //익절(5%) ExitLong("bx11",AtLimit,AvgEntryPrice*1.05,"",1,2); } If CurrentEntries<CurrentEntries[1] Then count = count + 1;
프로필 이미지
깜피
2021-10-27
636
글번호 153208
시스템
답변완료

문의드립니다.

제가 문의를 정확히 드리지 못해 죄송합니다. 아래 수식으로 데모해보니 맞지않는 부분이 있습니다. 확인부탁드립니다. 30분봉이 기준이고 거기에 6분봉 조건이 같은 방향이면 매수 매도 진입하는 원칙입니다. 30분봉이 매수신호 나와있으면 6분봉은 매수로만 진입이 되야 합니다. 30분봉이 매도신호 나와있으면 6분봉은 매도로만 진입이 되야 합니다. * 30분봉 - 매수 신호 조건 1. 30분봉이 이전 10번째 봉 고가 위에 있을 때 단, 현재 캔들이 자기 시가를 깰 때와 앞 캔들의 저가를 깰 때는 매수 신호가 사라지고 다시 회복하면 매수 신호가 나오도록 해주세요. 2. 30분봉이 이전 10번째 봉 고가를 돌파할 때 단, 10번째 봉 고가를 깰 때 매수 신호가 사라지고 다시 돌파하면 매수 신호가 나오도록 해주세요. - 매도 신호 조건 1. 30분봉이 이전 10번째 봉 저가 아래에 있을 때 단, 현재 캔들이 자기 시가를 돌파할 때와 앞 캔들의 고가를 돌파할 때는 매도 신호가 사라지고 다시 회복하면 매도 신호가 나오도록 해주세요. 2. 30분봉이 이전 10번째 봉 저가를 돌파(깰)할 때 단, 10번째 봉 저가를 돌파할 때 매도 신호가 사라지고 다시 깨면 매도 신호가 나오도록 해주세요. * 6분봉 - 매수 신호 및 매수 조건 1. 이전 10개 캔들의 최고가를 돌파할 때 매수 신호 및 즉시 매수. 2. 이미 이전 10개 캔들 위에서 시작할 때는 앞 캔들 고가를 돌파할 때 매수 신호 및 즉시 매수 - 매도 신호 및 매도 조건 1. 이전 10개 캔들의 최저가를 돌파할 때 매도 신호 및 즉시 매도. 2. 이미 이전 10개 캔들 아래에서 시작할 때는 앞 캔들 저가를 돌파할 때 매도 신호 및 즉시 매도 ## 종가에 진입하는 식에서는 매수는 양봉에만, 매도는 음봉에만 진입하도록 해주세요. 이번 데모에서 이런 문제가 생겨서 남깁니다. 1. 돌파 즉시 매수가 들어가지 않습니다. 2. 30분봉이 30분동안 매수 신호를 유지하고 있는 경우, 6분봉은 이전 5개 캔들 중 최고가를 돌파할 때만 매수 신호가 나오며 매수 진입해야 합니다. 6분봉에서 매도 신호가 나오더라도 30분봉은 매수 신호이니 매도 진입은 하지 않아야 맞는데, 매도 진입이 되고 있습니다. 3. 6분봉에서 이전 10개 캔들의 최고가를 돌파하지 않았는데 매수가 들어가고 있습니다. 아래 수식에서 수정할 부분 확인 수정 부탁드립니다. 감사합니다~~ 1 즉시진입 input : ntime1(6),ntime2(30),n(10); input : StartTime(222500),EndTime(010000); input : 익절틱수(50),손절틱수(50); var : S1(0),D1(0),TM(0),TF1(0),TF2(0),cnt(0),HH(0),LL(0); var : Tcond(false),BE1(False),BE2(False),SE1(False),SE2(False); Array : H1[50](0),L1[50](0),H2[50](0),L2[50](0); 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 Bdate != Bdate[1] Then { S1 = TimeToMinutes(stime); D1 = sdate; } if D1 > 0 then { if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF1 = TM%ntime1; TF2 = TM%ntime2; if Bdate != Bdate[1] or (Bdate == Bdate[1] and ntime1 > 1 and TF1 < TF1[1]) or (Bdate == Bdate[1] and ntime1 > 1 and TM >= TM[1]+ntime1) or (Bdate == Bdate[1] and ntime1 == 1 and TM > TM[1]) Then { H1[0] = H; L1[0] = L; For cnt = 1 to 49 { H1[cnt] = H1[cnt-1][1]; L1[cnt] = L1[cnt-1][1]; } } if H1[0] > 0 and H > H1[0] Then H1[0] = H; if L1[0] > 0 and L < L1[0] Then L1[0] = L; HH = 0; LL = 0; if H1[n] > 0 and L1[n] > 0 Then { For cnt = 1 to N { if HH == 0 or (HH > 0 and H1[cnt] > HH) Then HH = H1[cnt]; if LL == 0 or (LL > 0 and L1[cnt] < LL) Then LL = L1[cnt]; } } if Bdate != Bdate[1] or (Bdate == Bdate[1] and ntime2 > 1 and TF2 < TF2[1]) or (Bdate == Bdate[1] and ntime2 > 1 and TM >= TM[1]+ntime2) or (Bdate == Bdate[1] and ntime2 == 1 and TM > TM[1]) Then { H2[0] = H; L2[0] = L; For cnt = 1 to 49 { H2[cnt] = H2[cnt-1][1]; L2[cnt] = L2[cnt-1][1]; } BE1 = False; BE2 = False; SE1 = False; SE2 = False; } if H2[0] > 0 and H > H2[0] Then H2[0] = H; if L2[0] > 0 and L < L2[0] Then L2[0] = L; if Tcond == true Then { if MarketPosition <= 0 and HH > 0 Then Buy("b1",AtStop,HH+PriceScale*1); if MarketPosition <= 0 and H2[n] > 0 Then Buy("b2",AtStop,H2[n]+PriceScale*1); if MarketPosition >= 0 and LL > 0 Then Sell("s1",AtStop,LL-PriceScale*1); if MarketPosition >= 0 and L2[n] > 0 Then Sell("s2",AtStop,L2[n]-PriceScale*1); if MarketPosition <= 0 and HH > 0 and H2[n] > 0 Then Buy("b3",AtStop,max(HH,H2[n])+PriceScale*1); if MarketPosition >= 0 and L1[n] > 0 and L2[n] > 0 Then Sell("s3",AtStop,min(LL,L2[n])-PriceScale*1); if H >= HH+PriceScale*1 Then BE1 = true; if H >= H2[n]+PriceScale*1 Then BE2 = true; if L <= LL-PriceScale*1 Then SE1 = true; if L <= H2[n]+PriceScale*1 Then SE2 = true; if BE1 == true and BE2 == False Then Buy("b41",AtStop,H2[n]+PriceScale*1); if BE1 == False and BE2 == true Then Buy("b42",AtStop,HH+PriceScale*1); if SE1 == true and SE2 == False Then Sell("s41",AtStop,L2[n]-PriceScale*1); if SE1 == False and SE2 == true Then Sell("s42",AtStop,LL+PriceScale*1); } } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); IF Endtime > starttime Then SetStopEndofday(Endtime); Else { if sDate != sDate[1] Then SetStopEndofday(Endtime); } if (sdate != sdate[1] and stime >= StartTime) or (sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then { IF Endtime <= starttime Then { SetStopEndofday(0); } } 2. 종가진입 input : ntime1(6),ntime2(30),n(10); input : StartTime(222500),EndTime(010000); input : 익절틱수(50),손절틱수(50); var : S1(0),D1(0),TM(0),TF1(0),TF2(0),cnt(0),HH(0),LL(0); var : Tcond(false),BE1(False),BE2(False),SE1(False),SE2(False); Array : H1[50](0),L1[50](0),H2[50](0),L2[50](0); 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 Bdate != Bdate[1] Then { S1 = TimeToMinutes(stime); D1 = sdate; } if D1 > 0 then { if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF1 = TM%ntime1; TF2 = TM%ntime2; if Bdate != Bdate[1] or (Bdate == Bdate[1] and ntime1 > 1 and TF1 < TF1[1]) or (Bdate == Bdate[1] and ntime1 > 1 and TM >= TM[1]+ntime1) or (Bdate == Bdate[1] and ntime1 == 1 and TM > TM[1]) Then { H1[0] = H; L1[0] = L; For cnt = 1 to 49 { H1[cnt] = H1[cnt-1][1]; L1[cnt] = L1[cnt-1][1]; } } if H1[0] > 0 and H > H1[0] Then H1[0] = H; if L1[0] > 0 and L < L1[0] Then L1[0] = L; HH = 0; LL = 0; if H1[n] > 0 and L1[n] > 0 Then { For cnt = 1 to N { if HH == 0 or (HH > 0 and H1[cnt] > HH) Then HH = H1[cnt]; if LL == 0 or (LL > 0 and L1[cnt] < LL) Then LL = L1[cnt]; } } if Bdate != Bdate[1] or (Bdate == Bdate[1] and ntime2 > 1 and TF2 < TF2[1]) or (Bdate == Bdate[1] and ntime2 > 1 and TM >= TM[1]+ntime2) or (Bdate == Bdate[1] and ntime2 == 1 and TM > TM[1]) Then { H2[0] = H; L2[0] = L; For cnt = 1 to 49 { H2[cnt] = H2[cnt-1][1]; L2[cnt] = L2[cnt-1][1]; } BE1 = False; BE2 = False; SE1 = False; SE2 = False; } if H2[0] > 0 and H > H2[0] Then H2[0] = H; if L2[0] > 0 and L < L2[0] Then L2[0] = L; if Tcond == true Then { if MarketPosition <= 0 and HH > 0 and C > HH+PriceScale*1 Then Buy("b1"); if MarketPosition <= 0 and H2[n] > 0 and C > H2[n]+PriceScale*1 Then Buy("b2"); if MarketPosition >= 0 and LL > 0 and C < LL-PriceScale*1 Then Sell("s1"); if MarketPosition >= 0 and L2[n] > 0 and C < L2[n]-PriceScale*1 Then Sell("s2"); if MarketPosition <= 0 and HH > 0 and H2[n] > 0 and C > max(HH,H2[n])+PriceScale*1 Then Buy("b3"); if MarketPosition >= 0 and L1[n] > 0 and L2[n] > 0 and C < min(LL,L2[n])-PriceScale*1 Then Sell("s3"); if C >= HH+PriceScale*1 Then BE1 = true; if C >= H2[n]+PriceScale*1 Then { BE2 = true; } if C <= LL-PriceScale*1 Then SE1 = true; if C <= H2[n]+PriceScale*1 Then SE2 = true; if BE1 == true and BE2 == true and (BE1[1] == False or BE2[1] == False) Then Buy("b4"); if SE1 == true and SE2 == true and (SE1[1] == true or SE2 == False) Then Sell("s4"); } } SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop); IF Endtime > starttime Then SetStopEndofday(Endtime); Else { if sDate != sDate[1] Then SetStopEndofday(Endtime); } if (sdate != sdate[1] and stime >= StartTime) or (sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then { IF Endtime <= starttime Then { SetStopEndofday(0); } }
프로필 이미지
jesten77
2021-10-28
591
글번호 153207
시스템

신대륙발견 님에 의해서 삭제되었습니다.

프로필 이미지
신대륙발견
2021-10-27
17
글번호 153206
지표
답변완료

문의 드립니다.

안녕하세요. 지난번에 작성해주신 수식을 테스트 하는 중에 수정이 필요한 부분이 있어서 문의 드립니다. 작성해주신 코드에서 2번 항목[지표 값이 갱신(새로운 6연속 양봉 발생) 된 이후] B) [포지션을 보유하고 있을 경우 (A 또는 B에서 진입한 경우)]의 -> 매수 포지션(A)를 손절 또는 수익 발생 후 C 또는 D를 돌파하는 경우 C,D 돌파거래를 각각 한번 거래를 진행한다. -> 매도 포지션(B)를 손절 또는 수익 발생 후 C 또는 D를 돌파하는 경우 C,D 돌파 거래를 각각 한번 거래를 진행한다. 또한 4번 항목 4. 목표 값 및 손절 값을 도달 못할 시 익일 오전 5:30분 (장 종료 30분전)에 보유 중인 모든 포지션을 자동 청산한다. 추가 부탁드립니다. 제가 직접 코드에 setstopendofday(xtime)을 넣었더니 익일 종가 청산 이후 다음날 거래에서 거래가 안됩니다. 꼭 답변 부탁 드립니다. 매번 감사합니다. 혹시 위에 문의 드린 내용이 구현 가능하지 않는다면 대체 방안을 알려 주시면 감사하겠습니다. ----------------------------------------------------------------------- A : 최초로 발생한 6연속 양봉의 (최고점) B : 최초로 발생한 6연속 양봉의 최저점 C : 두번째로 발생한 6연속 양봉의 (최고점) D : 두번째로 발생한 6연속 양봉의 최저점 거래시간: [진입시간: 금일 오전 11시부터 익일 오전 1:00, 청산시간: 금일 오전 11시부터, 익일 오전 5:30분 (장종료 30분전까지)] 1. 지표 값이 생성(최초로 발생한 6연속 양봉) 된 이후 -> A 돌파 시 한번의 매수 기회 / B 돌파 시 한번의 매도 기회가 주어진다. 예) A돌파 후 B에서 손절 -> B 스위칭 -> A도달시 손절 후 스위칭을 하지 않는다. 예) A돌파 후 목표가 청산 - > B돌파 이후 목표가 청산 - > A 또는 B 다시 돌파시 거래하지 않는다. 목표가: 1) 매수 진입 시: A+ (A-B) / 매도 진입시: B - (A-B) 2) 매수 진입(A 돌파) 시 손절 또는 수익 발생 후 다시 A를 돌파 하여도 거래하지 않는다. 매도 진입(B 돌파) 시 손절 또는 수익 발생 후 다시 B를 돌파 하여도 거래하지 않는다. 손절가: 1) A 돌파 시, B 값에 손절 후 스위칭(최초 B값 진입 시 스위칭 진행) / B 돌파 시, A 값에 손절 후 스위칭(최초 A값 진입 시 스위칭 진행) *목표가 및 손절가에 도달하지 못하고 지표 값이 갱신 될 경우 2번으로 넘어간다. 2. 지표 값이 갱신(새로운 6연속 양봉 발생) 된 이후 A) 보유하고 있는 포지션이 없을 경우 -> C 돌파 시 한번의 매수 기회 / D 돌파 시 한번의 매도 기회가 주어진다. 예) C돌파 후 B에서 손절 -> D 스위칭 -> C도달시 손절 후 스위칭을 하지 않는다. 예) C돌파 후 목표가 청산 - > D돌파 이후 목표가 청산 - > C 또는 D 다시 돌파시 거래하지 않는다. 목표가: 1) 매수 진입 시: C + (C-D) / 매도 진입시: D - (C-D) 2) 매수 진입(C 돌파) 시 손절 또는 수익 발생 후 다시 C를 돌파 하여도 거래하지 않는다. 매도 진입(D 돌파) 시 손절 또는 수익 발생 후 다시 D를 돌파 하여도 거래하지 않는다. 손절가: 1) C 돌파 시, D 값에 손절 후 스위칭(최초 D값 진입 시 스위칭 진행) / D 돌파 시, C 값에 손절 후 스위칭(최초 C값 진입 시 스위칭 진행) B) 포지션을 보유하고 있을 경우 (A 또는 B에서 진입한 경우) -> 매수 또는 매도를 이미 진입한 경우 C, D를 이용하여 목표가 및 손절가를 새롭게 갱신한다. 목표가: 1) 매수 진입 시: C + (C-D) / 매도 진입시: D - (C-D) 2) 매수 포지션을 손절 또는 수익 발생 후 C를 돌파하는 경우 단 한번 거래를 진행한다. 매도 포지션을 손절 또는 수익 발생 후 D를 돌파하는 경우 단 한번 거래를 진행한다. 손절가: 1) C 돌파 시, D 값에 손절 후 스위칭(최초 D값 진입 시 스위칭 진행) / D 돌파 시, C 값에 손절 후 스위칭(최초 C값 진입 시 스위칭 진행) 3. 지표 값이 지속적으로 갱신 될 경우 (E,F / G,H / I,J ....) -> 2번을 반복한다. 4. 목표 값 및 손절 값을 도달 못할 시 익일 오전 5:30분 (장 종료 30분전)에 보유 중인 모든 포지션을 자동 청산한다. ------------------------------------------------------------- input : n(6); input : StartTime(110000),EndTime(010000),Xtime(053000); var : HH(0),LL(0),Tcond(false); 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 Bdate != Bdate[1] Then { var1 = 0; HH = 0; LL = 0; Condition1 = False; Condition2 = False; } if (Bdate[n] != Bdate and CountIf(C>O,6) == 6) or (bdate[n] == bdate and CountIf(C>O,6) == 6 and C[6] < O[6]) Then { HH = Highest(H,6); LL = Lowest(L,6); } if Tcond == true and HH > 0 and LL > 0 Then { if CrossUp(C,HH) Then { if Condition1 == False Then Buy("b"); Else ExitShort("sx"); Condition1 = true; } if CrossDown(C,LL) Then { if Condition2 == False Then Sell("s"); Else ExitLong("bx"); Condition2 = true; } if MarketPosition == 1 Then ExitLong("bp",AtLimit,HH+(HH-LL)); if MarketPosition == -1 Then ExitShort("sp",AtLimit,LL-(HH-LL)); } -------------------------------------------------
프로필 이미지
7out
2021-10-27
779
글번호 153205
시스템
답변완료

문의드립니다

혹시 이게 가능한지요? 신호가 나오는 캔들의 종가에 매수나 매도 진입인데요. 종가에 바로 진입하지 않고 조정받았다가 종가를 돌파할때 매수나 매도 진입 가능하게 수식을 짤 수 있나요? 즉, 신호가 나왔어도 조정받고 다시 종가를 돌파할 때 매수, 다시 종가를 깰 때 매도, 이렇게 진입이 조정 가능한지 질문 드립니다. 가능하다면 아래 수식에 첨가해 주시면 감사하겠습니다. input : StartTime(101200),EndTime(114000); input : Length(20), D1(2); input : 익절1(30),손절1(30),청산구분시간(103000),익절2(50),손절2(30),익절연속횟수(3),손절연속횟수(2); var : Tcond(false),profit(0),loss(0); 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; profit = 0; loss = 0; } if TotalTrades > TotalTrades[1] Then { if IsExitName("bp1.",1) or IsExitName("bp2.",21) or IsExitName("bp1",1) or IsExitName("bp2",21) or IsExitName("sp1.",1) or IsExitName("sp2.",1) or IsExitName("sp1",1) or IsExitName("sp2",1) Then profit = profit+1; Else profit = 0; if IsExitName("bl1.",1) or IsExitName("bl2.",1) or IsExitName("bl1",1) or IsExitName("bl2",1) or IsExitName("sl1.",1) or IsExitName("sl2.",1) or IsExitName("sl1",1) or IsExitName("sl2",1) Then loss = loss+1; Else loss = 0; } var1 = BollBandUp(Length,D1); var2 = BollBandDown(Length,D1); if Tcond == true Then { If CrossUP(H,var1) and (c > o or (C==O and C >= C[1])) and profit < 익절연속횟수 and loss < 손절연속횟수 then { Buy("b",OnClose,DEF,1); if sTime >= StartTime and sTime < 청산구분시간 Then { ExitLong("bp1.",AtLimit,C+PriceScale*익절1,"",1,1); ExitLong("bl1.",AtStop,C-PriceScale*손절1,"",1,1); } if sTime >= 청산구분시간 and sTime < Endtime Then { ExitLong("bp2.",AtLimit,C+PriceScale*익절2,"",1,1); ExitLong("bl2.",AtStop,C-PriceScale*손절2,"",1,1); } } If CrossDown(L,Var2) and (C < O or (C==O and C < C[1])) and profit < 익절연속횟수 and loss < 손절연속횟수 then { Sell("s",OnClose,DEF,1); if sTime >= StartTime and sTime < 103000 Then { ExitShort("sp1.",AtLimit,C-PriceScale*익절1,"",1,1); ExitShort("sl1.",AtStop,C+PriceScale*손절1,"",1,1); } if sTime >= 103000 and sTime < Endtime Then { ExitShort("sp2.",AtLimit,C-PriceScale*익절2,"",1,1); ExitShort("sl2.",AtStop,C+PriceScale*손절2,"",1,1); } } } if MarketPosition == 1 Then { if sTime >= StartTime and sTime < 청산구분시간 Then { ExitLong("bp1",AtLimit,EntryPrice+PriceScale*익절1,"",1,1); ExitLong("bl1",AtStop,EntryPrice-PriceScale*손절1,"",1,1); } if sTime >= 청산구분시간 and sTime < Endtime Then { ExitLong("bp2",AtLimit,EntryPrice+PriceScale*익절2,"",1,1); ExitLong("bl2",AtStop,EntryPrice-PriceScale*손절2,"",1,1); } } if MarketPosition == -1 Then { if sTime >= StartTime and sTime < 103000 Then { ExitShort("sp1",AtLimit,EntryPrice-PriceScale*익절1,"",1,1); ExitShort("sl1",AtStop,EntryPrice+PriceScale*손절1,"",1,1); } if sTime >= 103000 and sTime < Endtime Then { ExitShort("sp2",AtLimit,EntryPrice-PriceScale*익절2,"",1,1); ExitShort("sl2",AtStop,EntryPrice+PriceScale*손절2,"",1,1); } } IF Endtime > starttime Then SetStopEndofday(Endtime); Else { if sDate != sDate[1] Then SetStopEndofday(Endtime); } if (sdate != sdate[1] and stime >= StartTime) or (sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then { IF Endtime <= starttime Then { SetStopEndofday(0); } }
프로필 이미지
호정0688
2021-10-27
720
글번호 153204
시스템
답변완료

문의 드립니다.

input : price(83.50); if MarketPosition == 0 and H < Price Then Buy("b",AtStop,Price); ExitLong("Bp",AtLimit,Price+PriceScale*20); ExitLong("Bl",AtStop,Price-PriceScale*5); 위에 로직은 기준가 설정 후 매수용인데요. 매도 진입 후 손절5틱 익절20틱으로 부탁드립니다.
프로필 이미지
선물대장
2021-10-27
571
글번호 153202
시스템