커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

수식 질문드립니다.

data1은 선물1분봉입니다. data2는 참조차트 10틱입니다. 여기서 var1 = data2(C)-data2(C[1]) average(var1,2000) 값을 1분봉의 OHLC 값 나오도록 봉차트 구현가능한지 궁금합니다. 즉, 10틱을 다시 1분봉으로 변환해서 지표로 표기하고싶습니다. 감사합니다.
프로필 이미지
캣피쉬
2022-05-13
1336
글번호 158822
지표
답변완료

좋은 주말 되십시요

* 좋은날 좋은 주말 되십시요. <요청 사항> 아래 수식으로 진입후 손실 40틱 나면 추가 매수 시스탬좀 요청 드립니다. var1 = ma(c,5) ; Var2 = ma(c,20) if CrossUp(var1, Var2) Then Buy() ; if CrossDown(var1,Var2) Then Sell(); 일경우 진입후 손실이 40틱 나면 추가 매수 로직 과 싸운드 좀 부탁 드립니다. ex) if MarketPosition == 1 and 진입후 10봉 경과 and 손실 40틱 Then Buy("매수추가") ; if MarketPosition == -1 and 진입후 10봉 경과 and 손실 40틱 Then Buy("매도추가") ; if 매수추가 진입 PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav"); if 매도추가 진입 PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav"); 고맙습니다. 좋은 주말 되십시요.
프로필 이미지
요타
2022-05-13
1525
글번호 158821
시스템
답변완료

문의드립니다

안녕하세요 도움구하고자 문의드립니다 이평선이 10 20 30 40 50 5개있을때 이평선 순서 상관없이 어느거 하나라도 우상향일때 1로 표시 2개 우상향일때 2로 표시 3개 우상향일때 3으로 표시 이런식으로 표시 할려면 어떻게 해야도나요? 감사합니다
프로필 이미지
올독
2022-05-13
1264
글번호 158820
지표

알리섬 님에 의해서 삭제되었습니다.

프로필 이미지
알리섬
2022-05-13
13
글번호 158819
지표
답변완료

AB-ratio 시스템 변수값 고정

항상 감사드립니다 아래 ab-ratio 시스템엣 변수값을 고정하고 싶습니다 t77=1 또는 t77=-1 일때만 t80이 1 또는 -1값을 갖게 하고싶습니다 t77=1 또는 t77=-1 조건에서 t77=0 조건으로 변해서 장시간(며칠간) 지속될때는 신호가 나오질 않습니다 t77= 1 또는 t77= -1 조건일때 t80= 1 또는 t80= -1 로확정되고 t80값은 조건이 없어지더라도 그대로 며칠간 유지하고 싶습니다 t80 값은 한번 변경되면 다음변경시까지 챠트내 지표가 없어지더라도 며칠동안 그대로 유지 하고 싶습니다 Inputs: Length(5200); Variables : ABull(0), ABear(0), BBull(0), BBear(0),ARatio(0), BRatio(0); var:t66(0),t70(0),t71(0),t77(0),t80(0); ABull = accumn(High - Open, Length); ABear = Accumn(Open - Low, Length); BBull = Accumn(High - Close[1], Length); BBear = Accumn(Close[1] - Low, Length); ARatio = ABull / ABear * 100; BRatio = BBull / BBear * 100; if aRatio>100 Then t66 = 1 ; if BRatio>100 Then t70 = 1 ; if aRatio>100 and BRatio>100 Then t71 = 1 ; if t71=1 Then t77 = 1 ; if ARatio<100 Then t66 = -1 ; if BRatio<100 Then t70 = -1 ; if BRatio<100 Then t70 = -1 ; if aRatio<100 and BRatio<100 Then t71 = -1 ; if t71=-1 Then t77 = -1 ; if aRatio>100 and BRatio<100 Then t77 = 0 ; if aRatio<100 and BRatio>100 Then t77 = 0 ;
프로필 이미지
조민철
2022-05-13
1380
글번호 158818
시스템
답변완료

문의 드립니다.

안녕하세요. 저번에 도와주셔서 감사드립니다. 아래 수식에 시간만 나오게 해주셨는데 시간에 시분초 나오게 되어있는데 너무 햇갈려서 이것을 시:분:초 이렇게 수정할 수 있을까요? 또 고가에서 저가까지 몇틱이고 저가에서 고가까지 몇틱인지 표시 나오게 해줄 수 없을까요? 그러니까 고가에서 저가까지 시간 나오고 그 시간 아래에 +몇틱인지 표시 나왔으면 좋겠습니다. 또 저가에서 고가까지 시간 나오고 그 시간 위에 +몇틱인지 표시 나오게 하고 싶습니다. 감사합니다. 주말 잘 보내세요~~!! input:length(4),종가사용여부(0),파동선두께(5),수치표시(1),수평선표시(1); Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""), TL1(0),Text1(0),tl2(0),tl3(0),tl4(0),tl5(0),T(0); Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime #==========================================# HH = IFF(종가사용여부==1,C,H); LL = IFF(종가사용여부==1,C,L); If Index == 0 Then { 고[1,1] = HH; 저[1,1] = LL; } Condition1 = Highest(HH,length) == HH and 최종고가 <> HH; Condition2 = Lowest (LL,length) == LL and 최종저가 <> LL; 처리구분 = ""; If Condition1 and Condition2 Then // 기간고점과 기간저점 동시 발생 { If 최종꼭지점 == "저점" Then { If 저[1,1] > LL Then 처리구분 = "저점처리"; Else 처리구분 = "고점처리"; } Else If 최종꼭지점 == "고점" Then { If 고[1,1] < HH Then 처리구분 = "고점처리"; Else 처리구분 = "저점처리"; } } Else If Condition1 Then 처리구분 = "고점처리"; Else If Condition2 Then 처리구분 = "저점처리"; #==========================================# If 처리구분 == "고점처리" Then { T = 1; 최종고가 = HH; // 신규고점을 체크하기 위해 저장 If 최종꼭지점 == "저점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = HH; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); If 수치표시 == 1 Then { Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,4],0)); Text_SetStyle(Text1, 2, 1); Text_SetColor(Text1,BLACK); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,red); } Else If 고[1,1] < HH Then // 1번 고점보다 높은 고가 출현 { 고[1,1] = HH; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]); // 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임 If 수치표시 == 1 Then { Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]); Text_SetString(Text1,NumToStr(고[1,4],0)); } } 최종꼭지점 = "고점"; } #==========================================# If 처리구분 == "저점처리" Then { T = -1; 최종저가 = LL; If 최종꼭지점 == "고점" then { For j = 10 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = LL; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); If 수치표시 == 1 Then { Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,4],0)); Text_SetStyle(Text1, 2, 0); Text_SetColor(Text1,BLACK); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,blue); } Else If 저[1,1] > LL then { 저[1,1] = LL; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]); If 수치표시 == 1 Then { Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]); Text_SetString(Text1,NumToStr(저[1,4],0)); } } 최종꼭지점 = "저점"; } if T == -1 and T[1] != -1 Then { if 수평선표시 == 1 Then { TL2 = TL_New(고[2,3],고[2,4],고[2,1],sdate,stime,고[2,1]); TL_Delete(TL3); TL3 = TL_New(고[1,3],고[1,4],고[1,1],sdate,stime,고[1,1]); TL_SetExtRight(TL3,true); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,BLUE); TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,BLUE); } if T == 1 and T[1] != 1 Then { if 수평선표시 == 1 Then { TL4= TL_New(저[2,3],저[2,4],저[2,1],sdate,stime,저[2,1]); TL_Delete(TL5); TL5= TL_New(저[1,3],저[1,4],저[1,1],sdate,stime,저[1,1]); TL_SetExtRight(TL5,true); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,RED); TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,RED); }
프로필 이미지
스오어스
2022-05-13
1659
글번호 158817
지표
답변완료

수식문의드립니다

안녕하세요~ 아래 수식 array, for 활용해 줄이려고 해봤는데 한것이 맞는지 확인 및 모르는 부분 답변 부탁드리겠습니다! input : IB(1.5), OB(1.5), ML(12), L01(12163), L02(12139), L03(12115), L04(12091), L05(12067), L06(12043), L07(12019), L08(11995), L09(11973), L10(11949); var : Bsystem(true), Ssystem(true); if MarketPosition == 0 && condition11 == true && L <= L01 && C > L01-OB && C < L01+IB Then buy("b01"); if MarketPosition == 0 && condition12 == true && L <= L02 && C > L02-OB && C < L02+IB Then buy("b02"); if MarketPosition == 0 && condition13 == true && L <= L03 && C > L03-OB && C < L03+IB Then buy("b03"); if MarketPosition == 0 && condition14 == true && L <= L04 && C > L04-OB && C < L04+IB Then buy("b04"); if MarketPosition == 0 && condition15 == true && L <= L05 && C > L05-OB && C < L05+IB Then buy("b05"); if MarketPosition == 0 && condition16 == true && L <= L06 && C > L06-OB && C < L06+IB Then buy("b06"); if MarketPosition == 0 && condition17 == true && L <= L07 && C > L07-OB && C < L07+IB Then buy("b07"); if MarketPosition == 0 && condition18 == true && L <= L08 && C > L08-OB && C < L08+IB Then buy("b08"); if MarketPosition == 0 && condition19 == true && L <= L09 && C > L09-OB && C < L09+IB Then buy("b09"); if MarketPosition == 0 && condition10 == true && L <= L10 && C > L10-OB && C < L10+IB Then buy("b10"); 1. input의 L1, L2, L3, ... 자동계산 (등간격, array 활용) var : i(0); array : LL[9](0); LL[5] = 12067; For i = 0 to 5 {LL[4-i] = LL[5-i] + 2*ML;} For i = 5 to 9 {LL[i+1] = LL[i] - 2*ML;} => 중앙값 LL[5] 입력시, 위아래 등간격으로 자동 계산 => 맞는지 확인 부탁드립니다 2. condition11, condition12, condition13, ... 한번에 처리 array : BC[9](False); => 이렇게 array 설정해 false 입력하면 실행문의 condition과 동일하게 처리되는지 확인 부탁드립니다 3. 실행문 반복문 처리 위에 1, 2가 맞다는 전제하에 var : i(0); array : LL[9](0), BC[9](False); LL[5] = 12067; For i = 0 to 5 {LL[4-i] = LL[5-i] + 2*ML;} For i = 5 to 9 {LL[i+1] = LL[i] - 2*ML;} for i = 0 to 9 { if marketposition == 0 && BC[i] == true && L <= L[i] && C > L[i]-OB && C < L[i]+IB then buy("b{i}"); } => 상단의 실행문을 이렇게 반복문으로 바꾸는게 맞는지 확인 부탁드립니다 => buy("b{i}") 이 부분은 문자열인 "b01", "b02", "b03", ... 을 i로 어떻게 처리하는지 몰라 일단 저렇게 표시해놨는데, 이 부분도 숫자가 똑같이 증가하도록 가르쳐주시면 감사하겠습니다 감사합니다
프로필 이미지
jshwang2
2022-05-12
1483
글번호 158816
시스템
답변완료

문의 드립니다.

바쁘신 업무에 수고가 많으십니다. 항상 친절히 가르쳐 주셔셔 감사 드려요 ^^ 하기 요청내용 업무협조 부탁 드립니다. == 아 래 == A. 일목 전환선이 기준선을 상향 돌파 B. 일목 전환선이 엔벨로프 상단 저항선 돌파 C 1봉전 종가대비 0봉전 시가득락율 3% 이하 D 1봉전 종가대비 0봉전 종가득락율 3% 이상 ※ A and B and C and D => 이런 기준으로 검색식 부탁 드립니다. - 이 상 -
프로필 이미지
옥스
2022-05-12
1377
글번호 158815
종목검색
답변완료

수식 변환 문의

수고하십니다. 아래 식을 yes language로 변환 가능한지요? 수고하세요... ##s.cript는 쓰기금지 단어라고 해서 s 다음에 점을 추가했으니 제외해 주세요## 혹시 몰라서 엑셀 파일로도 첨부 합니다 ########### input SFactor = 3.618; #SuperTrend Factor input SPd = 5; #SuperTrend Length input lenColoured = 18; input lenSlow = 89; #Slow MA Length input hideSuperTrend = yes; def na = Double.Nan; s.cript nz { ##s.cript는 쓰기금지 단어라고 해서 s 다음에 점을 추가했으니 제외해 주세요## input data = 0; input data2 = -1; def ret_val = if IsNaN(data) then if data2 == -1 then 0 else data2 else data; plot nz = ret_val; } def src = close; def len = lenColoured; plot ma_coloured = wma(2 * wma(src, len / 2) - wma(src, len), round(sqrt(len))) ; # Hull WMA = (2*WMA (n/2) ? WMA (n)), sqrt (n)) ma_coloured.setHiding(hideSuperTrend); plot ma_slow = Expaverage(src,lenslow); def clrdirection = if ma_coloured > ma_coloured[3] then 1 else if ma_coloured < ma_coloured[3] then -1 else nz(clrdirection[1],1); # Supertrend Calculations def SUp=hl2-(SFactor*atr(SPd)); def SDn=hl2+(SFactor*atr(SPd)); def STrendUp = if close[1] > nz(STrendUp[1],0) then max(SUp,nz(STrendUp[1],0)) else SUp; def STrendDown = if close[1] < nz(STrendDown[1],0) then min(SDn,nz(STrendDown[1],0)) else SDn; def STrend = if close > nz(STrendDown[1],0) then 1 else if close< nz(STrendUp[1],0) then -1 else nz(STrend[1],1); def stbuy = if clrdirection == 1 and STrend==1 then nz(stbuy[1])+1 else 0; def stsell = if clrdirection ==-1 and STrend==-1 then nz(stsell[1])+1 else 0; plot long = If stbuy == 1 then Yes else no ; long.hide(); plot short = if stSell == 1 then yes else no ; short.hide(); plot LongLineMarker = if long then low else na; LongLineMarker.SetPaintingStrategy(PaintingStrategy.ARROW_UP); LongLineMarker.SetDefaultColor(Color.Green); plot ShortLineMarker = if short then High else na; ShortLineMarker.SetPaintingStrategy(PaintingStrategy.ARROW_DOWN); ShortLineMarker.SetDefaultColor(Color.Red);
프로필 이미지
오이도인
2022-05-15
1708
글번호 158814
지표