커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

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

안녕 하십니까 종목 검색식 부탁 드립니다. 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
1062
글번호 163922
종목검색
답변완료

수식의뢰

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

추세선 크기

input : Period(10),선두께(2); Var:상승색(Red), 하락색(Blue); Var:j(0),T(0); Var: date11(0),date12(0),time11(0),time12(0),TL1(0),TL(0), date21(0),date22(0),time21(0),time22(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); r[0] = 0; r[1] = 2; r[2] = 3.; r[3] = -1; r[4] = -2.; r[5] = 1; r[6] = 0.5; For j = 0 To 19 { HiBar[j] = HiBar[j] + 1; LoBar[j] = LoBar[j] + 1; } if crossup(c,highest(H,Period)[1]) Then T = 1; if CrossDown(c,Lowest(L,Period)[1]) 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]); } } 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]; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); } } 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]); } } 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]; TL_Delete(tl); TL = TL_New(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); } } TL_SetSize(TL1,선두께); 추세선이 하락하다 크기가 1.5p에 도달하면 매수,다음봉에 매수청산. 상승하다 크기가 1p에 도달하면 매도,다음봉에 매도청산. 감사합니다.
프로필 이미지
고성
2022-11-18
1250
글번호 163913
시스템
답변완료

포지션

안녕하세요. 포지션 관련하여 질문드립니다. 예를들어 제가 전략 두개를 운용중이라 하겠습니다. 하나의 전략이 매수포지션 유지 중인데, 나머지 다른 전략이 매도 포지션 진입 신호가 나온다면, 매수포지션 유지 중이었던게 매도가 되면서 청산되고 매도포지션은 매수포지션이었던게 청산되므로써 매도가 이루어진 것이므로 포지션진입을 안하게 될 것 같은데 만약 이렇게 된다면 문제를 어떻게 해결하면 좋을까요? 코스피 선물 기준으로 질문드립니다.
프로필 이미지
히익
2022-11-18
1458
글번호 163912
시스템
답변완료

수식 변환 문의

수고 하십니다. 아래 식 변환 부탁드립니다. L100, f1,f2,f3의 지표를 구현하고 싶습니다 그 외의 것이 있어서 복잡하거나 시간이 많이 걸린다면 생략하셔도 됩니다.. 수고하세요... ######## # Original Code From: TD Ameritrade IP Company, Inc. (c) 2009-2020 # Original StudyName: ATRTrailingStop # Type: Study # blackFLAG FTS SwingArms # Edited by: Jose Azcarate # blackFLAG Futures Trading - FOR EDUCATIONAL PURPOSES ONLY # TWITTER: @blackflagfuture # Settings Vary. My preferred setting is 28 / 5 But also use 30 / 8 and 5 / 3.5 depending on strategy. input trailType = {default modified, unmodified}; input ATRPeriod = 28; input ATRFactor = 5; input firstTrade = {default long, short}; input averageType = AverageType.WILDERS; input fib1Level = 61.8; input fib2Level = 78.6; input fib3Level = 88.6; Assert(ATRFactor > 0, "'atr factor' must be positive: " + ATRFactor); def HiLo = Min(high - low, 1.5 * Average(high - low, ATRPeriod)); def HRef = if low <= high[1] then high - close[1] else (high - close[1]) - 0.5 * (low - high[1]); def LRef = if high >= low[1] then close[1] - low else (close[1] - low) - 0.5 * (low[1] - high); def trueRange; switch (trailType) { case modified: trueRange = Max(HiLo, Max(HRef, LRef)); case unmodified: trueRange = TrueRange(high, close, low); } def loss = ATRFactor * MovingAverage(averageType, trueRange, ATRPeriod); def state = {default init, long, short}; def trail; switch (state[1]) { case init: if (!IsNaN(loss)) { switch (firstTrade) { case long: state = state.long; trail = close - loss; case short: state = state.short; trail = close + loss; } } else { state = state.init; trail = Double.NaN; } case long: if (close > trail[1]) { state = state.long; trail = Max(trail[1], close - loss); } else { state = state.short; trail = close + loss; } case short: if (close < trail[1]) { state = state.short; trail = Min(trail[1], close + loss); } else { state = state.long; trail = close - loss; } } def BuySignal = Crosses(state == state.long, 0, CrossingDirection.ABOVE); def SellSignal = Crosses(state == state.short, 0, CrossingDirection.ABOVE); def ex = if BuySignal then high else if SellSignal then low else if state == state.long then Max(ex[1], high) else if state == state.short then Min(ex[1], low) else ex[1]; plot TrailingStop = trail; TrailingStop.SetPaintingStrategy(PaintingStrategy.POINTS); TrailingStop.DefineColor("Long", Color.GREEN); TrailingStop.DefineColor("Short", Color.RED); TrailingStop.AssignValueColor(if state == state.long then TrailingStop.Color("Long") else TrailingStop.Color("Short")); plot Extremum = ex; Extremum.SetPaintingStrategy(PaintingStrategy.POINTS); Extremum.DefineColor("HH", Color.GREEN); Extremum.DefineColor("LL", Color.RED); Extremum.AssignValueColor(if state == state.long then Extremum.Color("HH") else Extremum.Color("LL")); Extremum.Hide(); def f1 = ex + (trail - ex) * fib1Level / 100; def f2 = ex + (trail - ex) * fib2Level / 100; def f3 = ex + (trail - ex) * fib3Level / 100; def l100 = trail + 0; plot Fib1 = f1; Fib1.SetPaintingStrategy(PaintingStrategy.POINTS); Fib1.SetDefaultColor(Color.BLACK); Fib1.Hide(); plot Fib2 = f2; Fib2.SetPaintingStrategy(PaintingStrategy.POINTS); Fib2.SetDefaultColor(Color.BLACK); Fib2.Hide(); plot Fib3 = f3; Fib3.SetPaintingStrategy(PaintingStrategy.POINTS); Fib3.SetDefaultColor(Color.BLACK); Fib3.Hide(); /* AddCloud(f1, f2, Color.LIGHT_GREEN, Color.LIGHT_RED, no); AddCloud(f2, f3, Color.GREEN, Color.RED, no); AddCloud(f3, l100, Color.DARK_GREEN, Color.DARK_RED, no);
프로필 이미지
오이도인
2022-11-18
1535
글번호 163911
지표
답변완료

문의드립니다.

아래 조건을 만족하는 종목 검색식을 부탁드립니다. 기준봉= O>C[1]*1.10 ; 상단선 =기준봉의 시가 ; 하단선= 기준봉의 1봉전 고가 ; 1) 기준봉 출현이후 상승하다가 2) 기준봉 출현이후 저가가 하단선을 한 번도 이탈하지 않고 3) 현재봉의 저가가 상단선 아래 하단선 위에 위치하는 봉이 출현 경과봉수 = 기준봉~현재봉까지의 캔들수 ; 4) 경과봉수가 20일보다 작은 종목 검색식 FIND(경과봉수); 기준봉 조건을 달리 하여 여러 검색식을 작성해 볼 생각입니다. 여건이 된다면 주석 좀 달아 주시면 감사하겠습니다.
프로필 이미지
이심전심
2022-11-18
1262
글번호 163910
종목검색

회원 님에 의해서 삭제되었습니다.

프로필 이미지
회원
2022-11-18
71
글번호 163909
지표
답변완료

지표 작성 부탁드립니다.

data1: 코스닥1분봉 data2: 코스닥일봉 data3: 나스닥일봉 data4: 다우일봉 data5: 코스피일봉 이렇게 데이터가 있을때, 1. 나스닥 전일 종가 상승률과 코스닥 당일 시가 상승률의 n일 상관관계를 지표식으로 만들고 싶습니다. (가급적이면 코스닥 1분봉 사용하지 않고, data2~5번만 사용해서 만들고 싶습니다.) 2. 위와 동일한 방식으로, 다우 전일 종가 상승률과 코스피 당일 시가 상승률의 n일 상관관계를 지표식으로 만들고 싶습니다. 여기서 - 전일 종가 상승률이란: (C - C[1])/C[1]을 의미하며, - 당일 시가 상승률이란: (당일시가 - 전일종가)/전일종가 를 의미합니다. 만약 일봉에서 당일 시가 참조가 안된다면, 하루씩 전부 앞으로 당겨서 구하는 식으로 만들어주셔도 괜찮습니다. 감사합니다.
프로필 이미지
중박주식
2022-11-18
1099
글번호 163908
지표