커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

Y축 분리문의 연장 질문

안녕하세요 관리자님 우선 감사 드립니다. 일전에 Y축 분리 문의를 드렸는데 Y축은 분리 하였으나 분리된 지표를 가지고 시스템을 만들려고 하는데 신호가 표시가 안되서요 Input : Period1(20), Percent1(6), Period2(30), Percent2(6); var : DNline1(0),DNline2(0),HRwave1(0); Dnline1 = EnvelopeDown(Period1, Percent1); Dnline2 = EnvelopeDown(Period2, Percent2); HRwave1 = ((Dnline2-Dnline1)/(Dnline2+Dnline1))*100000; If crossup(0,HRwave1) Then { Buy(); } 예전 답변은 아래와 같습니다. 안녕하세요 예스스탁입니다. 하나의 지표식에 가격대가 너무 차이가 나는 지표가 혼합되어 있습니다. 문의하신 내용은 수식을 분리하셔야 합니다. 하나의 식으로 분리해서 표시할 방법은 없습니다. plot1~plot6은 봉위에 적용되어 봉과 축을 같이 사용할수 있지만 plot7과 PlotBaseLine1은 봉과 값차이가 많이나는 지표입니다. 1 수식작성후에 문범검증(f4)을 하시고 f5키를 누르시면 지표속성이 나타납니다. Y축표시를 가격으로 하시면 적용시 바로 봉위에 적용됩니다. 지표는 기본설정이 화면으로 봉차트 아래에 적용됩니다. Input : Period1(20), Percent1(6), Period2(30), Percent2(6); var : center1(0),UPline1(0),DNline1(0),center2(0),UPline2(0),DNline2(0); center1 = ma(C, Period1); UPline1 = EnvelopeUp(Period1, Percent1); Dnline1 = EnvelopeDown(Period1, Percent1); center2 = ma(C, Period2); UPline2 = EnvelopeUp(Period2, Percent2); Dnline2 = EnvelopeDown(Period2, Percent2); Plot1(center1, "중앙선"); Plot2(UPline1, "EnvelopeUp"); Plot3(Dnline1, "EnvelopeDown"); Plot4(center2, "중앙선"); Plot5(UPline2, "EnvelopeUp"); Plot6(Dnline2, "EnvelopeDown"); 2 아래식은 Y축표시를 화면으로 하시고 적용하셔야 합니다. Input : Period1(20), Percent1(6), Period2(30), Percent2(6); var : DNline1(0),DNline2(0),HRwave1(0); Dnline1 = EnvelopeDown(Period1, Percent1); Dnline2 = EnvelopeDown(Period2, Percent2); HRwave1 = ((Dnline2-Dnline1)/(Dnline2+Dnline1))*100000; Plot7(HRwave1, "신호"); PlotBaseLine1(0, "기준선1"); 즐거운 하루되세요
프로필 이미지
blueo
2020-10-05
764
글번호 142865
시스템
답변완료

69397 재 질문 올림니다.

* 바쁘신데 확인 좀 부탁 드립니다. * 아래 와 같이 했는데...스위칭 주문이 안됨니다. if MarketPosition == 1 and (IsExitName("StopLoss",1) or IsExitName("StopProfittarget",1)) == true Then SELL("STOPSWSS1") ; if MarketPosition == -1 and (IsExitName("StopLoss,1") or IsExitName("StopProfittarget",1)) == true Then Buy("STOPSWDD1") ; * 다른 변수를 써야 하나요? * 바쁜신데 죄송합니다.
프로필 이미지
요타
2020-10-05
935
글번호 142864
시스템
답변완료

부탁드립니다

$ 69406 보내주신수식 적용하니 음봉캔들 강조는 되는데 양봉캔들 강조는 아무리해도 나타나지 않습니다,확인부탁합니다.
프로필 이미지
회원
2020-10-05
813
글번호 142863
지표
답변완료

수식 문의드립니다

전일 누적거래량을 분봉에서 구현하려고 하는데요 물론 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
829
글번호 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
945
글번호 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
857
글번호 142860
지표
답변완료

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

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

청산로직 관련

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