커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

당일 종가선 색깔

감사합니다. 아래는 틱차트에서 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
1112
글번호 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
1239
글번호 163913
시스템
답변완료

포지션

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

문의드립니다.

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

79598번 다시 한번 봐주세요~

검색조건해당 안되는 종목이 나오네요? 지표는 예스에 저장되어있는것 그대로 사용햇어요 이해하기 편하게 그림첨부합니다요~ 그림에도 질문이 있어요 추가로 1. 5201종목검색후에 종목클릭하면 그종목차트가 나오게 설정은 어떻게 하나요? 아니면 6101차트를 켜놓은 상태에서 검색된 종목을 클릭하면 그 종목차트로 연동되게하는것은 어떻게 하나요? 2. 5201 종목검색을 수동으로 클릭하지 않고 자동으로 계속 작동하는 화면창은 없나요? 타증권사의 매수시세감시 같은것이요 감사합니다!
프로필 이미지
울버린777
2022-11-18
1265
글번호 163907
종목검색

234fsdae 님에 의해서 삭제되었습니다.

프로필 이미지
234fsdae
2022-11-17
16
글번호 163905
지표