커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

지표 질문입니다

아래 72376 답변을 다음과 같이 수정 부탁드립니다 최근 4캔들 가운데 (시가-종가) 폭이 가장 큰 양봉 고가(H)를 표시한다 최근 4캔들 가운데 (시가-종가) 폭이 가장 큰 양봉 저가(L)를 표시한다 (H*2-L)을 표시한다 (L*2-L)을 표시한다 최근 4캔들 가운데 (시가-종가) 폭이 가장 큰 음봉 고가(U)를 표시한다 최근 4캔들 가운데 (시가-종가) 폭이 가장 큰 음봉 저가(D)를 표시한다 (U*2-D)를 표시한다 (D*2-U)를 표시한다 감사합니다 --------------------------------------- 안녕하세요 예스스탁입니다. input : n(8); var : cnt(0); var1 = 0; var2 = 0; value1 = 0; value2 = 0; For cnt = 0 to n-1 { if C[cnt] > O[cnt] and (var1 == 0 or (var1 > 0 and abs(H[cnt]-L[cnt]) > var1)) Then { var1 = abs(H[cnt]-L[cnt]); value1 = H[cnt]; value11 = L[cnt]; } if C[cnt] < O[cnt] and (var2 == 0 or (var2 > 0 and abs(H[cnt]-L[cnt]) > var2)) Then { var2 = abs(H[cnt]-L[cnt]); value2 = H[cnt]; value22 = L[cnt]; } } if value1 > 0 Then { Plot1(value1); Plot2(value11); Plot3(value1*2-value11); Plot4(value11*2-value11); } if value2 > 0 Then { Plot5(value2); Plot5(value22); Plot7(value2*2-value22); Plot8(value22*2-value22); } 즐거운 하루되세요 > 유튜버 님이 쓴 글입니다. > 제목 : 지표 질문입니다 > 최근 8캔들 가운데 (고가-저가) 폭이 가장 큰 양봉 고가(H)를 표시한다 최근 8캔들 가운데 (고가-저가) 폭이 가장 큰 양봉 저가(L)를 표시한다 (H*2-L)을 표시한다 (L*2-L)을 표시한다 최근 8캔들 가운데 (고가-저가) 폭이 가장 큰 음봉 고가(U)를 표시한다 최근 8캔들 가운데 (고가-저가) 폭이 가장 큰 음봉 저가(D)를 표시한다 (U*2-D)를 표시한다 (D*2-U)를 표시한다 감사합니다
프로필 이미지
회원
2021-05-11
1324
글번호 148925
지표

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

프로필 이미지
에구머니
2021-05-11
0
글번호 148924
지표
답변완료

72379번 재문의

72379번 재문의 입니다. 감사합니다.
프로필 이미지
에구머니
2021-05-11
1414
글번호 148923
지표

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

프로필 이미지
회원
2021-05-11
0
글번호 148922
지표
답변완료

수식 수정 부탁드립니다

안녕하세요 아래 수식에 로스컷 3회 연속 걸리면 매매정지가 되도록 돼 있습니다 문제점은 '23시 이후 로스컷이 될 경우 경우 익일 오전 7시가 되어야 매매를 재개'한다는 것 입니다 항상 감사합니다 ---- input : T(1),N(4),조건(2),매수전략(2),매도전략(0),매수기간(10),매도기간(0),매수청산(5),매도청산(0),매수트레일링스탑사용(0),매수트레일링스탑(0),매도트레일링스탑사용(0),매도트레일링스탑(0),매수로스컷위치(0),매도로스컷위치(0),손절(0); input : 플러스매도청산(0),마이너스매수청산(0),제로매수청산(0),제로매도청산(0),StartTime(070000),EndTime(070000),로스컷횟수(3),매매정지(10),매수포인트(0),매도포인트(0); var : LL(0),HH(0),최저가(0),최고가(0),cnt(0),sum(0),CL(0),CS(0),Lss(0),S(false),acounting(0),TS_L(0),TS_S(0),first(false),second(false); var : Tcond(false),S1(0),D1(0),TM(0),b_vv(0),losscut_point(0),hhh(0),lll(0); Array : VV[20](0); if 조건 == 1 then { Condition1 = L[4]>L[3] and L[3] >L[2] and H>H[1] and H[1]>H[2] and min(L[2],L[1],L) == L[2]; Condition2 = H[4]<H[3] and H[3]<H[2] and L<L[1] and L[1]<L[2] and max(H[2],H[1],H) == H[2] ; } else if 조건 ==2 then { Condition1 = L[4]>L[2] and H>H[2] and min(L[4],L[3],L[2],L[1],L) == L[2]; Condition2 = H[4]<H[2] and L<L[2] and max(H[4],H[3],H[2],H[1],H) == H[2] ; } if ( ( var2 == 0 and C > hh and vv[0] == -1 ) or LL == 0 or (CL !=0 and C > CL) ) and condition1 == true and Condition1[1] == False Then { var1 = var1+1; LL = L[2]; CL = C; CS = 0; if 매수트레일링스탑사용 == 1 then TS_L = L[매수트레일링스탑]; else TS_L = 0; if acounting <= 0 then acounting = 1; else acounting = acounting + 1; VV[0] = 1; For cnt = 1 to 19 { VV[cnt] = VV[cnt-1][1]; } if VV[N-1] != 0 Then { sum = 0; For cnt = 0 to N-1 { sum = sum + VV[cnt]; } } } else { if L < LL Then { var1 = 0; } } if (( var1 == 0 and C < ll and vv[0] ==1) or hh == 0 or (CS != 0 and C < CS) ) and condition2 == true and Condition2[1] == False Then { var2 = var2+1; HH = H[2]; CS = C; CL = 0; if 매도트레일링스탑사용 == 1 then TS_S = H[매도트레일링스탑]; else TS_S = 0; if acounting >= 0 then acounting = -1; else acounting = acounting - 1; VV[0] = -1; For cnt = 1 to 19 { VV[cnt] = VV[cnt-1][1]; } if VV[N-1] != 0 Then { sum = 0; For cnt = 0 to N-1 { sum = sum + VV[cnt]; } } } Else { if H > HH Then { var2 = 0; } } if Bdate != Bdate[1] Then { S1 = TimeToMinutes(stime); D1 = sdate; Condition4 = False; } if D1 > 0 then { if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; } #청산이 이루어질 때마다 아래와 같이 진행 if TotalTrades > TotalTrades[1] Then { Condition4 = False; losscut_point ==0; TS_L = 0; TS_S = 0; #3회 연속손실 여부 if PositionProfit(1) < 0 Then Lss = Lss+1; Else Lss = 0; if lss >= 로스컷횟수 Then { Condition4 = true; Lss = 0; } } #최근을 제외한 이전 4개 포인트 합 b_vv = vv[4]+vv[3]+vv[2]+vv[1]; #새로운 포인트가 나왔는지 확인하는 수식 if acounting != acounting[1] then S = true; else S = false; #매매조건 condition5 = sum >= 매수포인트 and vv[0] == 1; #매수조건 condition6 = sum <= 매도포인트 and vv[0] == -1; #매도조건 #돌파매수기준점 hhh = Highest(h,매수기간); lll = Lowest(l,매도기간); #거래시간 설정 if T == 0 Then Condition7 = (sTime > starttime and sTime < Endtime); Else if T == 1 Then Condition7 = (sTime > starttime or sTime < Endtime); #정해진 매매시간에 포지션이 없으면 if condition7 == true Then { if 매수전략 !=0 and 매수전략 == 1 then { #매수조조건에 만족하고 새로운 포인트가 나왔으며 최근봉 저가와 종가가 다르면 if condition5 == true and S == true and L != C then { #3번연속 손실이 발생했는지 확인 if condition4 == false then { Buy("1전략매수"); S = False; if marketposition == 0 then { losscut_point = L[매수로스컷위치]; } } if condition4 == true and TM >= TM[BarsSinceExit(1)]+ 매매정지 Then { Buy("1전략매수2"); S = False; if marketposition == 0 then { losscut_point = L[매수로스컷위치]; } } } } if 매도전략 !=0 and 매도전략 == 1 then { #매도조건에 만족하고 새로운 포인트가 나왔으며 최근봉 고가와 종가가 다르면 if condition6 == true and S == true and H != C then { #3번연속 손실이 발생했는지 확인 if condition4 == false then { sell("1전략매도"); S = False; if marketposition == 0 then { losscut_point = H[매도로스컷위치]; } } if condition4 == true and TM >= TM[BarsSinceExit(1)]+ 매매정지 Then { sell("1전략매도2"); S = False; if marketposition == 0 then { losscut_point = H[매도로스컷위치]; } } } } #전략2 실행 if 매수전략 != 0 and 매수전략 == 2 then { #매수조건을 만족하면 if condition5 == true then { #3번연속 손실이 발생했는지 확인 if condition4 == false and C > hhh[1] then { buy("돌파매수"); } if condition4 == true and C > hhh[1] and TM >= TM[BarsSinceExit(1)]+ 매매정지 Then { buy("돌파매수2"); } } } if 매도전략 != 0 and 매도전략 == 2 then { #매도조건을 만족하면 if condition6 == true Then { #3번연속 손실이 발생했는지 확인 if condition4 == false and C < lll[1] Then { sell("돌파매도"); } if condition4 == true and C < lll[1] and TM >= TM[BarsSinceExit(1)]+ 매매정지 Then { sell("돌파매도2"); } } } } #청산조건 if marketposition > 0 then { if 매수전략 == 1 then { if sum ==0 and b_vv == 2 and 제로매수청산 == 1 Then ExitLong("0포인트 매수청산"); if vv[0] == -1 and 마이너스매수청산 == 1 Then Exitlong("'-1' 매도청산"); ExitLong("매수로스컷",atstop,losscut_point); If 매수트레일링스탑사용 == 1 then Exitlong("매수트레일링스탑",atstop,TS_L); } if 매수전략 == 2 then { if 매수청산 != 0 then ExitLong("돌파매수청산",atstop,Lowest( Low ,매수청산)); } } if MarketPosition < 0 then { if 매도전략 == 1 then { if sum ==0 and b_vv == -2 and 제로매도청산 == 1 Then Exitshort("0포인트 매도청산"); if vv[0] == 1 and 플러스매도청산 == 1 Then ExitShort("'+1' 매도청산"); Exitshort("매도로스컷",atstop,losscut_point); If 매도트레일링스탑사용 == 1 then Exitshort("매도트레일링스탑",atstop,TS_S); } if 매도전략 == 2 then { if 매도청산 != 0 then ExitShort("돌파매도청산",atstop,Highest( High ,매도청산)); } } #타겟청산 SetStopLoss( 손절 ,PointStop);
프로필 이미지
산이보리
2021-05-12
1385
글번호 148917
시스템
답변완료

수식 요청 드립니다.

안녕하세요. 1. 연결선물 당일청산 다수의 진입과 스위칭 또는 청산을 반복하는 분봉 시스템에서 매수 - 매도신호 발생 후 다음봉에 매수 신호가 연속 발생시 매수진입 매도 - 매수신호 발생 후 다음봉에 매도 신호가 연속 발생시 매수진입 진입수식(예제)의 진입신호가 1봉 이내 연속 반대신호일 인경우만 진입, 1봉 이상에서 신호발생시 진입금지하는 수식 요청 드립니다. 작성해주신 수식적용시 진입 신호가 없어서 오늘 조건에 맞는 1분봉 차트 매도조건(매수는 반대) 예제수식으로 재요청 드립니다. 가능하면 패스되는 신호도 차트에서 보이도록 해주세요. #진입수식(신호조건 예제) var : EMA1(0),EMA2(0); EMA1= ema(ema(ema(c,2),2),2); EMA2 = ema(ema(ema(c,4),4),4); if CrossDown(EMA1,EMA2) Then{ Sell("S"); } if CrossUP(EMA1,EMA2) Then{ Buy("B"); } //---------------------------------------------------------------------- 안녕하세요 예스스탁입니다. Input : Period(12), sigPeriod(9); var : Bidx(0),Sidx(0); value1 = TRIX(Period); value2 = ema(value1, sigPeriod); If CrossUP(value1, value2) and Index == Sidx+1 Then { Buy("b"); bidx = Index; } If CrossDown(value1, value2) and Index == Bidx+1 Then { Sell("s"); Sidx = Index; } 즐거운 하루되세요 > dandy 님이 쓴 글입니다. > 제목 : 수식 요청 드립니다. > 안녕하세요. 1. 연결선물 당일청산 다수의 진입과 스위칭 또는 청산을 반복하는 분봉 시스템에서 매수 - 매도신호 발생 후 다음봉에 매수 신호가 연속 발생시 매수진입 매도 - 매수신호 발생 후 다음봉에 매도 신호가 연속 발생시 매수진입 진입수식(예제)의 진입신호가 1봉 이내 연속 반대신호일 인경우만 진입, 1봉 이상에서 반대 신호발생시 진입금지하는 수식 요청 드립니다. #진입수식(예제) Input : Period(12), sigPeriod(9); value1 = TRIX(Period); value2 = ema(value1, sigPeriod); # 매수/매도청산 If CrossUP(value1, value2) Then{ Buy(); } # 매도/매수청산 If CrossDown(value1, value2) Then{ Sell(); }
프로필 이미지
dandy
2021-05-11
1331
글번호 148915
시스템
답변완료

수정 부탁드립니다.

안녕하세요...글번호 63633 차트지표에 마지막지표값 %에서 갯수로수정부탁드립니다 잔량에 라인색상을 제임의로 할수있게. 지정된색을 삭제해주세요. 잔량라인은 당일것만 그려지게요. 매수총건수 매도총건수= 갯수로표시 건수최고= 갯수로표시 건수최저= 갯수로표시 매수총잔량 매도총잔량 = 갯수로표시 잔량최고= 갯수로표시 잔량최저= 갯수로표시 잔량라인색상 지정색 삭제 잔량라인은 당일것만 그려지게요. 수고하세요...꾸벅
프로필 이미지
보인다
2021-05-11
1363
글번호 148912
지표
답변완료

문의드립니다

Var1 = DayHigh(1); Var2 = DayLow(1); Var3 = var1 - Var2; Longliq = Highest(H,BarsSinceEntry+1)-Var3 * P ; If MarketPosition == 1 Then ExitLong("EL", atstop, Longliq); 이런 식으로 전날의 레인지를 참고하여 청산을 한다고 했을때 하루의 첫봉에서 청산요건이 발동했을때 첫봉에서는 레인지 계산을 전날의 전날 즉 2일전 레인지로 계산하고 두번째 봉부터 다시 전날의 레인지로 계산하는것 같습니다. 첫봉부터 올바르게 계산하도록 하는 방법은 없을까요
프로필 이미지
시고르시고르
2021-05-11
1317
글번호 148906
시스템
답변완료

수식검증 부탁드려요

그림에서 처럼 침체구간 이후 저점이 높아지는 구간에서 K선이 D선을 돌파하는 순간을 종목검색으로 찾고 싶어서 수식을 만들어 봤는데 종목검색이 안되네요,, 저번에 부탁드린 수식에서 급등신호를 빼고 만들면 될줄 알았는데 검색이 안돼요 수정 부탁드려요,, Input : sto1(12), sto2(5), sto3(5);; var : stok(0),stod(0),T(0),L1(0),L2(0); stok = StochasticsK(sto1,sto2); stod = StochasticsD(sto1,sto2,sto3); if stok > stok[1] Then T = 1; if stok < stok[1] Then T = -1; #상승전환 if T == 1 and T != T[1] Then { L1 = stok[1]; L2 = L1[1]; } if T == 1 and L1 > L2 and L2 <= 20 and L2 > 0 and (Condition1 == true or Condition2 == true) Then { T = 2; Find(1); }
프로필 이미지
vhvh
2021-05-11
1344
글번호 148905
종목검색