커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

수식 문의드립니다

전일 누적거래량을 분봉에서 구현하려고 하는데요 물론 Dayvolume(1)을 사용하면 간단하게 된다는 걸 알고 있습니다 다만 응용해 보고 싶은 것들이 있어서 물어봅니다 ------------------------- var1 = Accum(V); If bDate!=bDate[1] Then var2 = var1[1]; var3 = var1-var2; Plot1(var3, "test"); 이렇게 하면 당일 누적거래량을 구하는 건데요 이 수식을 응용해서 이것저것 해보았는데 원하는 결과가 나오지 않네요 Dayvolume(1)을 1분봉에서 보려면 수식을 어떻게 짜야 할지 가르쳐주시면 감사하겠습니다
프로필 이미지
아래위
2020-10-05
830
글번호 142862
사용자 함수
답변완료

작성해준 수식 구현이 안되요..오류가 뭐가 있을까요?

나스닥(e-mini 나스닥-100) 10분봉과/일봉을 설정한후 아래 수식을 넣어서 구현하면 거래가 안되네요.. 뭐가 잘못되었는지 알려주시면 감사하겠습니다. =========================================================== 안녕하세요 예스스탁입니다. input : left(5),right(5); var : i1(0,Data1),l1(0,Data1),h1(0,Data1); var : SLv(0,data1),SLi(0,Data1),SLh(0,data1),dd(0,Data1); var : mav(0,Data2); i1 = Data1(Index); l1 = Data1(l); h1 = Data1(h); mav = Data2(ma(C,5)); if data1(SwingLowBar(1,l1,left,right,left+right)) != -1 Then { SLv = l1[right]; SLi = i1[right]; SLh = h1; } if SLh > 0 and h1 > slh Then slh = h1; if MarketPosition == 0 and sli > 0 and Index > sli+300 and Index <= sli+1000 and mav > mav[1] and L > SLv*1.001 Then Buy("b",AtLimit,Slv*1.001); if MarketPosition == 1 Then { dd = sLh[BarsSinceEntry]-slv[BarsSinceEntry]; if MaxEntries == 1 Then { Buy("bb",AtLimit,LatestEntryPrice-dd); ExitLong("bp1",AtLimit,LatestEntryPrice+(dd*0.5)); } if MaxEntries == 2 Then { ExitLong("bp2",AtLimit,LatestEntryPrice+(dd*0.75)); ExitLong("bx",AtStop,LatestEntryPrice-(dd*1)); } } 즐거운 하루되세요 > 이형지 님이 쓴 글입니다. > 제목 : 해외선물 수식 부탁드림니다. ( 역추세 매매) > 해외선물(나스닥) data1 분봉 10분봉 data2 일봉 [1] 1차 매수 진입 조건(1계약) data1의 1000봉에서 전저점이 1000봉 에서 300봉사이에서 전저점의 0.1%근접시 매수진입 (data1의 1000봉에서 전저점이 300봉 에서 1봉 사이에서는 전저점의 0.1%근접시에도 매수진입 X) data2 5일봉 이동평균선 우상향시 매수 활성화 [2] 2차 매수 진입 조건(1계약) 1차 매수후 D의 틱수(전저점과 전저점이후에 최고점의 차이틱수) 만큼 하락시 추가 매수 [3] 청산 조건 (1) 1차 진입후 청산시 : 1차 매수후 D의 틱수(전저점과 전저점이후에 최고점의 차이틱수)의 50% 도달시 청산 (2) 1차,2차 진입후 청산시 : 2차 매수후 2차 매수한 시점에서 D의 틱수(전저점과 전저점이후에 최고점의 차이틱수)의 75% 도달시 전량청산(2계약) --약 수익 (3) 1차 2차 진입후 손절시: 2차 매수한 시점에서 D의 틱수만큼 더 떨어졌을때 전량(2계약) 손절 번거롭더라도 그림을 참조해서 수식 좀 부탁드리겠습니다. / 감사드림니다.
프로필 이미지
이형지
2020-10-05
946
글번호 142861
시스템
답변완료

문의드립니다.

안녕하세요 연휴는 잘 보내셨나요? 제가 어떻게 한번 해보려고 했는데 랭귀지 해석이 안 되어서 이렇게 지표 변환을 부탁드립니다. 아래 게시물을 보니 RSI 밴드 지표가 있어서 제가 사용하는 보조지표를 캔들과 같이 볼 수 있도록 RSI 밴드처럼 바꾸고 싶습니다. 제가 사용하는 지표와 참고용으로 RSI밴드 수식도 같이 올립니다. 참고로 제가 원하는건 중심선, 상단선, 하단선입니다. 변환 부탁드리며 미리 감사합니다. =============================== 제가 사용하는 지표 =============================== input : st_mult(2),st_period(14),len(20); var : price(0),up_lev(0),dn_lev(0),upz(0),downv(0); var : trur(0),plus(0),minus(0),sum(0),adxv(0); var : di(0),x(0),zz(0); price = (H+L)/2; up_lev = price - (st_mult * atr(st_period)); dn_lev = price + (st_mult * atr(st_period)); if CurrentBar >= 1 then { upz = up_lev-up_lev[1]; downv = -(dn_lev-dn_lev[1]); trur = (TrueRange + (len - 1) * trur) / len; var1 = iff(upz > downv and upz > 0 , upz , 0); var11 = (var1 + (len - 1) * var11) / len; plus = var11/trur; var2 = iff(downv > upz and downv > 0 , downv , 0); var22 = (var2 + (len - 1) * var22) / len; minus = var22/trur; sum = plus + minus; var3 = abs(plus - minus) / iff(sum == 0 , 1 , sum); adxv = (var3 + (len - 1) * adxv) / len; di = plus - minus; x=adxv-di*100; zz=x/-1; plot1(zz,"시그널"); plot2(20,"상단"); plot3(-20,"하단"); plot4(0,"중심"); =============================== RSI밴드지표 =============================== Input : Length(14),UpLevel(70),DnLevel(30), NxtYn(0); var : oUpBand(0),oDnBand(0),oMidLine(0); Var : Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0),MidLevel(0); If CurrentBar == 1 AND Length > 0 Then Begin UpSum = 0; DownSum = 0; For Counter = 0 To Length - 1 Begin UpAmt = C[Counter] - C[Counter+1]; If UpAmt >= 0 Then DownAmt = 0; Else Begin DownAmt = -UpAmt; UpAmt = 0; End; UpSum = UpSum + UpAmt; DownSum = DownSum + DownAmt; End; UpAvg = UpSum / Length; DownAvg = DownSum / Length; End Else If CurrentBar > 1 AND Length > 0 Then Begin UpAmt = C[0] - C[1]; If UpAmt >= 0 Then DownAmt = 0; Else Begin DownAmt = -UpAmt; UpAmt = 0; End; UpAvg = (UpAvg[1] * (Length - 1) + UpAmt) / Length; DownAvg = (DownAvg[1] * (Length - 1) + DownAmt) / Length; End; If UpAvg + DownAvg <> 0 Then Value1 = 100 * UpAvg / (UpAvg + DownAvg); Else Value1 = 0; If nxtYn == 1 Then // 다음 봉 여부가 1일 경우 { If Value1 > UpLevel Then // 상단밴드 oUpBand = (((UpLevel - 100) / UpLevel * UpAvg) + DownAvg) * (Length - 1) + C; Else oUpBand = ((UpLevel / (100 - UpLevel) * DownAvg) - UpAvg) * (Length - 1) + C; If Value1 > DnLevel Then // 하단밴드 oDnBand = (((DnLevel - 100) / DnLevel * UpAvg) + DownAvg) * (Length - 1) + C; Else oDnBand = ((DnLevel / (100 - DnLevel) * DownAvg) - UpAvg) * (Length - 1) + C; MidLevel = (UpLevel + DnLevel) / 2; // 중간라인 If Value1 > MidLevel Then oMidLine = (((MidLevel - 100) / MidLevel * UpAvg) + DownAvg) * (Length - 1) + C; Else oMidline = ((MidLevel / (100 - MidLevel) * DownAvg) - UpAvg) * (Length - 1) + C; } Else { If Value1[1] > UpLevel Then oUpBand = (((UpLevel - 100) / UpLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + C[1]; Else oUpBand = ((UpLevel / (100 - UpLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + C[1]; If Value1[1] > DnLevel Then oDnBand = (((DnLevel - 100) / DnLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + C[1]; Else oDnBand = ((DnLevel / (100 - DnLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + C[1]; MidLevel = (UpLevel + DnLevel) / 2; If Value1[1] > MidLevel Then oMidLine = (((MidLevel - 100) / MidLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + C[1]; Else oMidline = ((MidLevel / (100 - MidLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + C[1]; } Plot1(oUpBand); Plot2(oMidLine); Plot3(oDnBand);
프로필 이미지
플로스트
2020-10-05
858
글번호 142860
지표
답변완료

69400수식 제수정 부탁드립니다

다시 수정 부탁드립니다.. 현제 텍스트 부분이 수직선으로 일부만 표기 되고 있습니다.. 텍스트는 필요 없구요 텍스트자리에 수직선이 전부 표기가 될수 있도록 수정 부탁드려 봅니다 늘 감사드립니다..
프로필 이미지
대박대박
2020-10-05
972
글번호 142858
지표
답변완료

문의드립니다.

아래수식을 예스로 부탁합니다. rsiSource = input(title="RSI Source", type=input.source, defval=close) rsiLength = input(title="RSI Length", type=input.integer, defval=7) rsiOverbought = input(title="RSI Overbought", type=input.integer, defval=70, minval=51, maxval=100) rsiOvesold = input(title="RSI Oversold", type=input.integer, defval=30, minval=1, maxval=49) // RSI value based on inbuilt RSI rsiValue = rsi(rsiSource, rsiLength) // Get the current state isOverbought = rsiValue >= rsiOverbought isOversold = rsiValue <= rsiOvesold // State of the last extreme 0 for initialization, 1 = overbought, 2 = oversold var laststate = 0 // Highest and Lowest prices since the last state change var hh = low var ll = high // Labels var label labelll = na var label labelhh = na // Swing lines var line line_up = na var line line_down = na var last_actual_label_hh_price = 0.0 var last_actual_label_ll_price = 0.0 // FUNCTIONS obLabelText() => if(last_actual_label_hh_price < high) "HH" else "LH" //plot(last_actual_label_hh_price) osLabelText() => if(last_actual_label_ll_price < low) "HL" else "LL" // Create oversold or overbought label createOverBoughtLabel(isIt) => if(isIt) label.new(x=bar_index, y=na ,yloc=yloc.abovebar, style=label.style_label_down, color=color.red, size=size.tiny, text=obLabelText()) else label.new(x=bar_index, y=na ,yloc=yloc.belowbar, style=label.style_label_up, color=color.green, size=size.tiny, text=osLabelText()) // Move the oversold swing and label moveOversoldLabel() => label.set_x(labelll, bar_index) label.set_y(labelll, low) label.set_text(labelll, osLabelText()) line.set_x1(line_down, bar_index) line.set_y1(line_down, low) moveOverBoughtLabel() => label.set_x(labelhh, bar_index) label.set_y(labelhh, high) label.set_text(labelhh, obLabelText()) line.set_x1(line_up, bar_index) line.set_y1(line_up, high) // We go from oversold straight to overbought NEW DRAWINGS CREATED HERE if(laststate == 2 and isOverbought) hh := high labelhh := createOverBoughtLabel(true) last_actual_label_ll_price := label.get_y(labelll) labelll_ts = label.get_x(labelll) labelll_price = label.get_y(labelll) line_up := line.new(x1=bar_index, y1=high, x2=labelll_ts, y2=labelll_price, width=1) // We go from overbought straight to oversold NEW DRAWINGS CREATED HERE if(laststate == 1 and isOversold) ll := low labelll := createOverBoughtLabel(false) last_actual_label_hh_price := label.get_y(labelhh) labelhh_ts = label.get_x(labelhh) labelhh_price = label.get_y(labelhh) line_down := line.new(x1=bar_index, y1=high, x2=labelhh_ts, y2=labelhh_price, width=1) // If we are overbought if(isOverbought) if(high >= hh) hh := high moveOverBoughtLabel() laststate := 1 // If we are oversold if(isOversold) if(low <= ll) ll := low moveOversoldLabel() laststate := 2 // If last state was overbought and we are overbought if(laststate == 1 and isOverbought) if(hh <= high) hh := high moveOverBoughtLabel() //If we are oversold and the last state was oversold, move the drawings to the lowest price if(laststate == 2 and isOversold) if(low <= ll) ll := low moveOversoldLabel() // If last state was overbought if(laststate == 1) if(hh <= high) hh := high moveOverBoughtLabel() // If last stare was oversold if(laststate == 2) if(ll >= low) ll := low moveOversoldLabel()
프로필 이미지
as8282
2020-10-05
885
글번호 142857
지표
답변완료

청산로직 관련

주식 현물 시장에서 어떤 종목을 매수 했을경우 청산을 하기 위해서 수익률이 2~5% 일 경우 수익금이 절반이 되면 청산. 수익률이 6~10%일 경우 수익금이 2/3이 되면 청산.. 이런 청산로직도 예스트레이더에서 가능 한지 궁금합니다.
프로필 이미지
맴맴잉
2020-10-05
783
글번호 142850
시스템
답변완료

질문드립니다

안녕하세요 VAR1 = Data4(H[1]); VAR2 = Data4(H[2]); VAR3 = Data4(H[3]); VAR4 = Data4(H[4]); VAR5 = Data4(H[5]); VAR6 = Data4(H[6]); VAR7 = Data4(H[7]); VAR8 = Data4(H[8]); VAR9 = Data4(H[9]); VAR10 = Data4(H[10]); VAR11 = Data4(H[11]); VAR12 = Data4(H[12]); 기준 : 차트 기준은 일봉차트에서 참조종목으로 같은 종목 월봉을 넣었습니다 질문1. 일봉차트 변경하면 참조종목도 동시에 자동변경되나요? 질문2. 일봉차트의 현재가와 var1~var12를 비교해서 현재가가 크면 +1, 작으면 -1 그러면 -12 ~ +12 까지의 지표가 표시될수있도록 부탁드립니다. 질문3. 어떤 지표값이 소수점일때 절삭하는 방법이 궁금합니다. 질문4. 기준에서 월봉을 참조종목으로 넣었는데 일봉기준으로 참조종목인 월봉을 넣지않고 지표 표현할수있으면 더욱 좋겠습니다. 가능할까요?
프로필 이미지
시세2
2020-10-05
673
글번호 142847
지표
답변완료

재문의

1.매번 감사드립니다 작성해준 지표(69392)에 (H+L+O)/3를 추가 해서 지표를 띄우니 표시가 안돼요 좀 봐주세요 #==========================================# Input : Length(13),UpLevel(70),DnLevel(30), NxtYn(0); var : oUpBand(0),oDnBand(0),oMidLine(0); Var : Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0),MidLevel(0); #==========================================# Var :CC(0); CC = (H+L+O)/3; #==========================================# If CurrentBar == 1 AND Length > 0 Then Begin UpSum = 0; DownSum = 0; For Counter = 0 To Length - 1 Begin UpAmt = CC[Counter] - CC[Counter+1]; If UpAmt >= 0 Then DownAmt = 0; Else Begin DownAmt = -UpAmt; UpAmt = 0; End; UpSum = UpSum + UpAmt; DownSum = DownSum + DownAmt; End; UpAvg = UpSum / Length; DownAvg = DownSum / Length; End Else IF CurrentBar > 1 AND Length > 0 Then Begin UpAmt = CC[0] - CC[1]; If UpAmt >= 0 Then DownAmt = 0; Else Begin DownAmt = -UpAmt; UpAmt = 0; End; UpAvg = (UpAvg[1] * (Length - 1) + UpAmt) / Length; DownAvg = (DownAvg[1] * (Length - 1) + DownAmt) / Length; End; If UpAvg + DownAvg <> 0 Then Value1 = 100 * UpAvg / (UpAvg + DownAvg); Else Value1 = 0; If nxtYn == 1 Then // 다음 봉 여부가 1일 경우 { If Value1 > UpLevel Then // 상단밴드 oUpBand = (((UpLevel - 100) / UpLevel * UpAvg) + DownAvg) * (Length - 1) + CC; Else oUpBand = ((UpLevel / (100 - UpLevel) * DownAvg) - UpAvg) * (Length - 1) + CC; If Value1 > DnLevel Then // 하단밴드 oDnBand = (((DnLevel - 100) / DnLevel * UpAvg) + DownAvg) * (Length - 1) + CC; Else oDnBand = ((DnLevel / (100 - DnLevel) * DownAvg) - UpAvg) * (Length - 1) + CC; MidLevel = (UpLevel + DnLevel) / 2; // 중간라인 If Value1 > MidLevel Then oMidLine = (((MidLevel - 100) / MidLevel * UpAvg) + DownAvg) * (Length - 1) + CC; Else oMidline = ((MidLevel / (100 - MidLevel) * DownAvg) - UpAvg) * (Length - 1) + CC; } Else { If Value1[1] > UpLevel Then oUpBand = (((UpLevel - 100) / UpLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC[1]; Else oUpBand = ((UpLevel / (100 - UpLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC[1]; If Value1[1] > DnLevel Then oDnBand = (((DnLevel - 100) / DnLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC[1]; Else oDnBand = ((DnLevel / (100 - DnLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC[1]; MidLevel = (UpLevel + DnLevel) / 2; If Value1[1] > MidLevel Then oMidLine = (((MidLevel - 100) / MidLevel * UpAvg[1]) + DownAvg[1]) * (Length - 1) + CC[1]; Else oMidline = ((MidLevel / (100 - MidLevel) * DownAvg[1]) - UpAvg[1]) * (Length - 1) + CC[1]; } Plot1(oUpBand,"몸통", RGb(225,220,0)); Plot2(oMidLine); Plot3(oDnBand,"몸통", BLACK); 2.그럼 즐거운 하루 되세요.
프로필 이미지
성공예견
2020-10-05
800
글번호 142838
지표
답변완료

수식을 어떻게 해야되나요

1. t-2 ~t-4 가격이동평균 20일선이 점덤 내려가는 상태 조건식 2. t-2 캔들이 rsl 30이하 (같거나 작은 경우 ) 조건식과 수식 3 t-1 캔들이 종가가 t-2 캔들이 시가보다 같거나 높은 조건식 4 t-1 캔들의 종가가 t-2캔들이 몸통보다 같거나 높은 조건식 5 t-1 캔들의 몸통보다 아랫꼬리가 2배이상인 조건식 6 ㅅ-1캔들이 몸통보다 윗꼬리와 아랫꼬리가 2배 조건식
프로필 이미지
스타그이상
2020-10-05
733
글번호 142835
종목검색