커뮤니티

예스랭귀지 Q&A

글쓰기

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

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

수식 부탁드립니다.

90틱 챠트에 30분봉의 캔들을 배경에 보여주고 싶습니다.
프로필 이미지
오늘도수익
2025-07-18
236
글번호 192571
지표
답변완료

종목검색수식부탁드립니다:)

A=MA(C,240); B=(A+AVGIF(C-A,-1,0.0)-2*STDEVIF(C-A,-1,0.0)); //가격박스 하단선 D=(B*1); AA=BBandsdown(95,2); //BB 하단선 crossup(C,D) && crossup(C,AA) 이 수식인데 종목검색식으로 변환가능한지 문의드립니다! 감사합니다!
프로필 이미지
조나리
2025-07-18
223
글번호 192570
종목검색
답변완료

수식수정요청

안녕하세요 다음의 수식을 항셍 10시15 분 고가 저가 에 표시하려고 하는데 잘못되었는지 안되네요 수정 부탁드려요 Vars: myHigh(0), myLow(0), flagCaptured(false); If Date <> sDate[1] Then Begin flagCaptured = false; End; If (sTime == 10000) And (flagCaptured == false) Then Begin myHigh = High; myLow = Low; flagCaptured = true; End; Plot1(myHigh, "10:15 고가",Green); Plot2(myLow, "10:15 저가",Red);
프로필 이미지
알리섬
2025-07-18
256
글번호 192568
지표
답변완료

검색식 부탁 드립니다

A1=LRL(20); A2=LRL(40); Valuewhen(1,crossup(A1,A2),A1) A1이 1봉전보다 지표값이 0봉전이 낮다 주가는A1을 돌파한 종목 검색식 부탁드립니다
프로필 이미지
님이랑
2025-07-18
199
글번호 192565
종목검색
답변완료

부탁드립니다

매수 신호만 표시 : - 60일선 위에서(매도 신호는 표시 안되게) - 20일선이 상승 전환 후 - 첫번째 양봉이 꼬리까지 돌파 했을때 매도 신호만 표시 : - 60일선 아래에서(매수 신호는 표시 안되게) - 20일선이 하락 전환 후 - 첫번째 음봉이 꼬리까지 이탈 했을때
프로필 이미지
와우리
2025-07-18
212
글번호 192560
시스템
답변완료

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

항상 노고에 감사드림니다. 아래의 수식을 종목검색식으로 부탁드림니다. A=ma(C, 120); B=TEMA(C, 기간); B1=(highest(high, 중간값)+lowest(low, 중간값))/2; B2=Crossup(B1, B); B2 && C>A 지표변수 기간 20 중간값 26
프로필 이미지
존슨비치
2025-07-18
237
글번호 192558
종목검색
답변완료

수식 부탁드립니다.

Inputs: length(55); Vars: level(0), hma1(0), hma2(0), vol_sum(0); Vars: shift_col(0); Vars: reversal_dn_signal(0), reversal_up_signal(0); Vars: prev_hma1(0), prev_hma2(0); // Hull MA 직접 계산 함수 호출 (별도 구현 필요) hma1 = HMA(Close, length); hma2 = HMA(Close, length)[5]; // 거래량 합산 vol_sum = Volume[2] + Volume[1] + Volume[0]; // 상승 전환 조건: hma1 이전 <= hma2 이전 이고 현재 hma1 > hma2 if (prev_hma1 <= prev_hma2) and (hma1 > hma2) then begin level = Low; end else if (prev_hma1 >= prev_hma2) and (hma1 < hma2) then begin level = High; end else begin level = level[1]; end; // 바 색상 숫자 (1=Up, 0=Down) if Close < level then begin shift_col = 0; end else begin shift_col = 1; end; // 반전 신호 조건 reversal_dn_signal = 0; reversal_up_signal = 0; if (High[2] < level) and (High < level) and (High[1] > level) then reversal_dn_signal = 1; if (Low[2] > level) and (Low[1] < level) and (Low > level) then reversal_up_signal = 1; // 이전 HMA 값 저장 (꼭 마지막에) prev_hma1 = hma1; prev_hma2 = hma2; // 결과 플롯 Plot1(level, "Market Level"); //////////사용자 함수 hma/////////////////// Inputs: price(numericseries), length(numeric); Vars: halfLength(0), sqrtLength(0); Vars: wma1(0), wma2(0), diff(0); halfLength = IntPortion(length / 2); sqrtLength = IntPortion(Sqrt(length)); wma1 = WMA(price, halfLength); wma2 = WMA(price, length); diff = 2 * wma1 - wma2; hma = WMA(diff, sqrtLength); -------------------------------------------------------------- 질문1 (1분봉)에서 plot1 (일봉)값을 그대로 표현하고 싶어요~ 질문2 1분봉에서 가격이동평균 5일 이평을 표현하는 방법도 알려주세요
프로필 이미지
허밍스타
2025-07-18
299
글번호 192557
지표
답변완료

추세선 수정 부탁합니다

아래 추세선 높이를 구하는 수식값을 높이(높이%),200(3.20%)이런 식으로 표시하는 수식으로 수정 부탁드립니다 diff = value12-value11; diff = (value12-value11)/value12*100; ================================================ input : Period(35),선두께(2),기준(-10),p(5); Var:상승색(Turquoise), 하락색(Turquoise),Vpower(0),mav(0); Var:j(0),T(0); Var: date11(0),date12(0),time11(0),time12(0),TL1(0),TL(0),tl9(0), date21(0),date22(0),time21(0),time22(0),diff(0), date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0),tl4(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0); Array:r[7](0),fr[7](0),TL2[7](0),TL3[7](0),TX2[7](0),TX3[7](0); Plot1(0); For j = 0 To 19 { HiBar[j] = HiBar[j] + 1; LoBar[j] = LoBar[j] + 1; } Vpower = upVol/(upVol+downVol)*100-50; mav = ma(Vpower,p); if 기준 < mav Then T = 1; if 기준 > mav Then T = -1; If T == -1 Then { If T[1] != -1 Then { For j = 18 DownTo 0 { LoVal[j+1] = LoVal[j]; LoBar[j+1] = LoBar[j]; } LoVal[0] = L; LoBar[0] = 0; date11 = date[HiBar[0]]; time11 = stime[HiBar[0]]; Value11 = HiVal[0]; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,하락색); date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; for j = 0 to 6 { fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]); } diff = value12-value11; TX = Text_New(sDate,sTime,value12,NumToStr(diff,2)); Text_SetStyle(tx,2,0); Text_SetColor(tx,Blue); Text_SetSize(tx,12); } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date22 = date[0]; time22 = stime[0]; diff = value12-value11; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); Text_SetLocation(tx,sDate,sTime,value12); Text_SetString(tx,NumToStr(diff,2)); } } If T == 1 Then { If T[1] != 1 Then { For j = 18 DownTo 0 { HiVal[j+1] = HiVal[j]; HiBar[j+1] = HiBar[j]; } HiVal[0] = H; HiBar[0] = 0; date11 = date[LoBar[0]]; time11 = stime[LoBar[0]]; Value11 = LoVal[0]; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,상승색); date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; for j = 0 to 5 { fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]); } diff = value12-value11; TX = Text_New(sDate,sTime,value12,NumToStr(diff,2)); Text_SetStyle(tx,2,1); Text_SetColor(tx,Red); Text_SetSize(tx,12); } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date32 = date[0]; time32 = stime[0]; diff = value12-value11; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); Text_SetLocation(tx,sDate,sTime,value12); Text_SetString(tx,NumToStr(diff,2)); } } TL_SetSize(TL1,선두께); TL_SetDrawMode(TL1,0);
프로필 이미지
팔보채
2025-07-17
273
글번호 192556
지표
답변완료

시스템 매매 관련 문의 입니다...

아래 수식은 예스 시스템 매매 수식이고 180분봉 매매입니다.. 이수식에 덧붙여서 원하는 조건은 한봉에서 매도를 하면 같은 봉에서 다시 매수를 하게 되는데, 같은 봉에서 매도 매수를 하지않는 조건하고 그리고 진입을 할때 분할로 진입하는 조건을 변수로 지정할수 있도록 해주셨으면합니다. 끝으로 매매 시작날자를 변수로 지정할수 있도록 해주면 감사하겠습니다... **첨부사진보시면 수익을 극대화 했는데, 익절후에 바로 같은 봉에 매수진입을 하게되어서 수익을 반납하는 경우를 방지하기 위해서 입니다... input : short(12),long(26),P(60); var : macdv(0),mav(0); macdv = macd(short,long); mav = ma(C,P); if macdv > 0 and C > mav Then buy(); if macdv < 0 and C < mav Then sell();
프로필 이미지
서민순
2025-07-18
249
글번호 192555
시스템