커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

79635번 마지막 확인질문입니다.

안녕하세요 예스스탁입니다. 죄송합니다.수식내용에 오류가 있었습니다. 수정한 식입니다. input : N(10); var : V2(0,data2),V3(0,data3),V4(0,data4),V5(0,data5); var : CR23(0,Data2),CR45(0,data4); V2 = Data2((O-C[1])/C[1]*100); V3 = Data3((C-C[1])/C[1]*100); V4 = Data4((C-C[1])/C[1]*100); V5 = Data5((O-C[1])/C[1]*100); CR23 = Data2(Correlation(V2,V3,N)); CR45 = Data4(Correlation(V4,V5,N)); Plot1(CR23); plot2(CR45); 즐거운 하루되세요 위의 내용을 해석하는 과정에서 2가지만 더 확인하고자 합니다. 1. V2 = Data2((O-C[1])/C[1]*100); 위 식에서 data2는 일봉이므로 장중에 봉이 미완성인 상태에서 계속 움직이게 됩니다. 그래도 시초가는 이미 정해진 것이기 때문에, 당일 장중에 시초가를 정상적으로 불러올 수 있는 것이죠? 그리고 장종료 후 봉완성된 상태에서도 마찬가지로 당일 시초가가 찍히는 것이고요? (다음날이 시작되기 전까지는) 2. var : CR23(0,Data2); 여기서 CR23 같은 경우에느 data2와 data3이 모두 사용되는데, 왜 0, 뒤에 data2로 표기하는지 구체적인 기준이 있는지 궁금합니다. 2.1. 만약 data2를 data3으로 쓰면 결과가 바뀌는지? 2.2. 만약 아무것도 안쓰고 그냥 cr23(0)으로 끝내버리면 결과가 바뀌는지? 2.3. 혹은 전혀 무관한, data1이나 data4를 쓰면 결과가 어떻게 달라지는지 궁금합니다. 감사합니다.
프로필 이미지
중박주식
2022-11-18
732
글번호 163944
지표
답변완료

수식요청드립니다

if MarketPosition == 1 Then if 청산조건 then ExitLong("bx",AtLimit,AvgEntryPrice*1.01); 위 수식에 트레일링 스탑 기능 추가부탁드립니다. 1프로 수익보존 후 고정갱신하다가 고점에서 2프로 떨어지면 청산 감사합니다.
프로필 이미지
234fsdae
2022-11-20
934
글번호 163943
시스템
답변완료

79635번 재질문입니다. 이해가 안가는 부분이 있습니다.

nput : N(10); var : V2(0,data2),V3(0,data3),V4(0,data4),V5(0,data5); var : CR23(0,Data2),CR45(0,data4); V2 = Data2((O-C[1])/C[1]*100); V3 = Data3(C-C[1]/C[1]-100); V4 = Data4(C-C[1]/C[1]-100); V5 = Data5((O-C[1])/C[1]*100); CR23 = Data2(Correlation(V2,V3,N)); CR45 = Data4(Correlation(V4,V5,N)); Plot1(CR23); plot2(CR45); 위 내용에서, 아래식은 어떤 의미인가요? V3 = Data3(C-C[1]/C[1]-100); V4 = Data4(C-C[1]/C[1]-100); 이거대로 계산하면, 중간에 C[1]/C[1]가 먼저 계산되므로, C - 1 - 100이 되어버립니다.. 중간에 분자를 묶는 괄호도 있어야 하고, 젤 뒤에도 -100이 아니라 곱하기 100이 되는거 아닌가요..?
프로필 이미지
중박주식
2022-11-18
868
글번호 163938
지표

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

프로필 이미지
234fsdae
2022-11-18
14
글번호 163933
시스템
답변완료

수식 변환 문의2

수고 하십니다. 아래 식 변환 부탁드립니다. 수고하세요... ################### https://www.prorealcode.com/prorealtime-indicators/swingarm-atr-trailing-stop/ //PRC_Swingarm ATR Trailing Stop | indicator //03.08.2020 //Nicolas @ www.prorealcode.com //Sharing ProRealTime knowledge //converted from TOS //https://www.prorealcode.com/topic/conversion-of-swingarm-atr-trailing-stop/ // --- settings trailType = 1 //1=modified, 0=unmodified ATRPeriod = 28 ATRFactor = 5 firstTrade = 0 //0= long, 1= short averageType = 3 //0 = SMA 1 = EMA 2 = WMA 3 = Wilder 4 = Triangular 5 = End point 6 = Time series 7 = Hull (PRT v11 only) 8 = ZeroLag (PRT v11 only) showArrows = 0 //0=false ; 1=true //--- end of settings fib1Level = 61.8 fib2Level = 78.6 fib3Level = 88.6 HiLo = Min(high - low, 1.5 * Average[ATRPeriod](range)) if low <= high[1] then Href = high - close[1] else Href = (high - close[1]) - 0.5 * (low - high[1]) endif if high >= low[1] then Lref = close[1] - low else Lref = (close[1] - low) - 0.5 * (low[1] - high) endif //case modified: if trailType = 1 then trueRange = Max(HiLo, Max(HRef, LRef)) else //case unmodified trueRange = tr(close) // TrueRange(high, close, low) endif iloss = ATRFactor * Average[ATRPeriod,averageType](trueRange) once init=0 if init=0 then if firsttrade=0 then state = 0 trail = close - iloss else state = 1 trail = close + iloss endif init=1 endif //case long: if state[1] = 0 then if (close > trail[1]) then state = 0 trail = Max(trail[1], close - iloss) else state = 1 trail = close + iloss endif endif //case short: if state[1] = 1 then if (close < trail[1]) then state = 1 trail = Min(trail[1], close + iloss) else state = 0 trail = close - iloss endif endif BuySignal = state<>state[1] and state = 0 SellSignal = state<>state[1] and state = 1 if BuySignal then ex = high elsif SellSignal then ex = low else if state = 0 then ex = Max(ex[1], high) elsif state = 1 then ex = Min(ex[1], low) else ex = ex[1] endif endif TrailingStop = trail if state = 0 then r=0 g=255 else r=255 g=0 endif f1 = ex + (trail - ex) * fib1Level / 100 f2 = ex + (trail - ex) * fib2Level / 100 f3 = ex + (trail - ex) * fib3Level / 100 if showArrows then l1 = state[1] = 0 and close crosses under f1[1] l2 = state[1] = 0 and close crosses under f2[1] l3 = state[1] = 0 and close crosses under f3[1] s1 = state[1] = 1 and close crosses over f1[1] s2 = state[1] = 1 and close crosses over f2[1] s3 = state[1] = 1 and close crosses over f3[1] atr = AverageTrueRange[14](close) y=0 if l1 or l2 or l3 then y =low - atr endif if s1 or s2 or s3 then y=high + atr endif if y>0 then if y>close then drawarrowdown(barindex,y) coloured(r,g,0) else drawarrowup(barindex,y) coloured(r,g,0) endif endif endif return TrailingStop coloured(r,g,0) style(line,3) as "ATR Trailing Stop" , ex coloured(r,g,0) style(point,4) as "Extremum", f1 coloured(168,168,168), f2 coloured(168,168,168), f3 coloured(168,168,168)
프로필 이미지
오이도인
2022-11-18
1352
글번호 163930
지표
답변완료

함수요청

안녕하세요? 아래 전략에 대해 스크립트 작성 요청드립니다. 국내선물 1분봉으로 일중 거래를 하고자 합니다.(오버나티트하지 않습니다.) 9시 개장후 전일종가대비 하락 출발하고 15분봉상 양봉이 누적으로 2개 혹은 30분봉으로 양봉이 1개 발생되면 익봉시가에 매도 진입 9시 개장후 전일종가대비 상승 출발하고 15분봉상 음봉이 누적으로 2개 혹은 30분봉으로 음봉이 1개 발생되면 익봉시가에 매수 진입 매수든 매도든 하루 최대 1번 진입하며 청산됩니다. 15시 강제청산합니다. 1.참조함수(data1: 1분봉, data2: 15분봉, data3: 30분봉)를 사용하여 스크립트 2. 참조함수를 사용하지 않고 1분봉으로 함수를 작성하여 스크립트를 각각 요청드립니다. 감사합니다.
프로필 이미지
흰둥이아빠
2022-11-18
937
글번호 163929
시스템
답변완료

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

안녕 하십니까 종목 검색식 부탁 드립니다. A=Disparity(기간); K99=valuewhen(1, crossup(A, 기준1) or crossdown(A, 기준1), 가격); K101=valuewhen(1, crossup(A, 기준2) or crossdown(A, 기준2), 가격); M20=ma(c,20); crossup(M20,K99) or crossup(M20,K101) 지표변수 가격 (고가+저가)/2 기간 20 기준1 99 기준2 101 키움애서 신호로 쓰던건데 종목검색 하고 싶습니다. 부탁드립니다. 감사합니다.
프로필 이미지
칼이쓰마빡가
2022-11-18
1106
글번호 163922
종목검색
답변완료

수식의뢰

수고하십니다. N(40)봉중 8% 급등한 종목을 기준봉으로 하여 N일간 등락을 반복하다가 5일선을 하향 이탈한 시점에서 종목을 검색할 수 있는 종목검색식 부탁드립니다.
프로필 이미지
심홍
2022-11-18
1188
글번호 163917
종목검색
답변완료

당일 종가선 색깔

감사합니다. 아래는 틱차트에서 5분주기 전봉전전봉갯수를 돌파할 때 종가를 표시하는 수식입니다. 이 수식이 나타내는 종가에서 1. 장시작 후 처음 나타난 종가를 저장하고 장마지막까지 지표값을 표시. 녹색 2. 장시작 후 처음 나타난 종가보다 상승한 종가 또는 이전 종가보다 상승한 종가를 저장하고 각각 장마지막까지 지표값을 표시. 빨강 3. 장시작 후 처음 나타난 종가보다 하락한 종가 또는 이전 종가보다하락한 종가를 저장하고 각각 장마지막까지 지표값을 교시. 파랑 input : ntime(5); var : S1(0),D1(0),TM(0),TF(0),B(0); var : idx(0),idx1(0),idx2(0),tx(0); if Bdate != Bdate[1] Then { S1 = TimeToMinutes(stime); D1 = sdate; var1 = 0; } if D1 > 0 then { if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF = TM%ntime; if Bdate != Bdate[1] or (Bdate == Bdate[1] and ntime > 1 and TF < TF[1]) or (Bdate == Bdate[1] and ntime > 1 and TM >= TM[1]+ntime) or (Bdate == Bdate[1] and ntime == 1 and TM > TM[1]) Then { B = B+1; idx = 0; idx1 = idx[1]; idx2 = idx1[1]; tx = Text_New(sDate,sTime,L,NumToStr(1,0)); Text_SetStyle(tx,2,0); Text_SetColor(tx,Red); Text_SetBold(tx,1); } idx = idx+1; Text_SetString(tx,NumToStr(idx,0)); Text_SetLocation(tx,sDate,sTime,L); if B >= 3 and idx > max(idx1,idx2) Then var1 = C; if var1 > 0 Then Plot1(var1); Else NoPlot(1); }
프로필 이미지
jdavid
2022-11-18
1174
글번호 163915
지표