커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

아침 님에 의해서 삭제되었습니다.

프로필 이미지
아침
2023-06-12
12
글번호 169665
시스템
답변완료

문의드립니다.

트레이딩뷰에서 참조해온, 시간단위의 바 표시를 거래량단위의 바표시로 바꾸는 수식입니다. 예스랭귀지로 변환해서 사용가능할지 문의드리며, 사용가능하다면 예스랭귀지로 변환하고 싶습니다. //*** Functions changed(x) => x != x[1] //*** Inputs price = input(open, "Price Data") bartype = input("Volume Bar", "Bar Type", options=["Volume Bar","Dollar Bar"]) delta = input(34, "Delta", minval=0., step=.01) //*** Main bar = 0.0 bar := (bartype=="Volume Bar" ? nz(bar) + volume : nz(bar) + volume * price) bar := bar > delta ? 0.0 : bar long = nz(bar) + volume > delta and open < close short = nz(bar) + volume > delta and open > close state = 0 state := long ? 1 : short ? -1 : nz(state[1]) longst = changed(state) and state[1]==-1 shortst = changed(state) and state[1]==1 plotshape(longst ? low : na, location=location.belowbar, style=shape.triangleup, color=color.lime, size=size.tiny, text=" ", textcolor=color.white, transp=0) plotshape(shortst ? high : na, location=location.abovebar, style=shape.triangledown, color=color.red, size=size.tiny, text=" ", textcolor=color.white, transp=0)
프로필 이미지
고민중
2023-06-11
1451
글번호 169664
지표
답변완료

적용가능하도록 부탁드립니다.

트레이딩뷰에서 사용되는 지표를 적용하고 싶습니다(2가지). 도움 부탁 드립니다. 1. 캔들(Smoothed Heiken Ashi Candles) len=input(10) o=ema(open,len) c=ema(close,len) h=ema(high,len) l=ema(low,len) haclose = (o+h+l+c)/4 haopen = na(haopen[1]) ? (o + c)/2 : (haopen[1] + haclose[1]) / 2 hahigh = max (h, max(haopen,haclose)) halow = min (l, min(haopen,haclose)) len2=input(10) o2=ema(haopen, len2) c2=ema(haclose, len2) h2=ema(hahigh, len2) l2=ema(halow, len2) col=o2>c2 ? red : lime plotcandle(o2, h2, l2, c2, title="heikin smoothed", color=col) 2. 보조지표(stc) indicator(title='[SHK] Schaff Trend Cycle (STC)', shorttitle='STC', overlay=false) EEEEEE = input(12, 'Length') BBBB = input(26, 'FastLength') BBBBB = input(50, 'SlowLength') AAAA(BBB, BBBB, BBBBB) => fastMA = ta.ema(BBB, BBBB) slowMA = ta.ema(BBB, BBBBB) AAAA = fastMA - slowMA AAAA AAAAA(EEEEEE, BBBB, BBBBB) => AAA = input(0.5) var CCCCC = 0.0 var DDD = 0.0 var DDDDDD = 0.0 var EEEEE = 0.0 BBBBBB = AAAA(close, BBBB, BBBBB) CCC = ta.lowest(BBBBBB, EEEEEE) CCCC = ta.highest(BBBBBB, EEEEEE) - CCC CCCCC := CCCC > 0 ? (BBBBBB - CCC) / CCCC * 100 : nz(CCCCC[1]) DDD := na(DDD[1]) ? CCCCC : DDD[1] + AAA * (CCCCC - DDD[1]) DDDD = ta.lowest(DDD, EEEEEE) DDDDD = ta.highest(DDD, EEEEEE) - DDDD DDDDDD := DDDDD > 0 ? (DDD - DDDD) / DDDDD * 100 : nz(DDDDDD[1]) EEEEE := na(EEEEE[1]) ? DDDDDD : EEEEE[1] + AAA * (DDDDDD - EEEEE[1]) EEEEE mAAAAA = AAAAA(EEEEEE, BBBB, BBBBB) mColor = mAAAAA > mAAAAA[1] ? color.new(color.green, 20) : color.new(color.red, 20) if mAAAAA[3] <= mAAAAA[2] and mAAAAA[2] > mAAAAA[1] and mAAAAA > 75 alert("Red", alert.freq_once_per_bar) if mAAAAA[3] >= mAAAAA[2] and mAAAAA[2] < mAAAAA[1] and mAAAAA < 25 alert("Green", alert.freq_once_per_bar) plot(mAAAAA, color=mColor, title='STC', linewidth=2) ul = plot(25, color=color.new(color.gray, 70)) ll = plot(75, color=color.new(color.gray, 70)) fill(ul, ll, color=color.new(color.gray, 96)) 부탁드립니다.
프로필 이미지
다올
2023-06-11
1505
글번호 169663
지표
답변완료

문의 드립니다!

안녕하세요! 옵션챠트에서 data1을 콜, data2를 풋으로 설정후 이 data1, 2에 각각 아래식을 적용시 2개의 가로선이 다른 가격대에서 발생되는데요 이 2개의 가로선 사이에 색상을 입히는 수식을 구하고싶습니다 * 가로선의 두께와 색상은 사용자지정이 가능토록 부탁드립니다 감사합니다! -------------------------------------------------------------------------------- var : V1(Data1(C),data1); if crossup(data10(H),data11(L)) or CrossDown(data10(L),data11(H)) Then { v1 = data1(C); } plot1(v1);
프로필 이미지
유로파54
2023-06-11
1175
글번호 169662
지표
답변완료

다른 PC에서 접속하여 기존PC에서쓰던 지표,검색식등을 사용방법

다른 PC에서 접속하여 기존PC에서쓰던 지표,검색식등을 동일하게 사용하고자합니다 종합환경설정>설정정보관리 에서 개인설정정보 서버 저장하기를하고 다른PC에서 개인설정정보 내려받기를해도 기존 검색식등은 사용할수없는데요, 검색식,지표수식등이 PC에 로컬로 저장이되어서 그러는건지, 다른 PC에서 사용할수 있는 방법을 부탁드립니다 매번 감사합니다
프로필 이미지
seayun1
2023-06-11
933
글번호 169661
지표
답변완료

문의드립니다.

수고많으십니다. 다계약에서 익절이든 손절이든 청산후 바로 동일방향 신호가 나와서 게시판에 있는 재진입금지 수식을 넣어봤으나 원하는 결과가 나오지 않습니다. 3계약 진입시 모두 청산후부터 20봉까지 진입이 강제로 안되는 수식을 원합니다. 미리 감사드립니다.
프로필 이미지
카르마다
2023-06-11
1104
글번호 169660
시스템
답변완료

부탁 드립니다

수고 하십니다 키움차트 수식 입니다 예스로 변환 좀 부탁 드립니다 매수 진입 R=highest(H,X); S=lowest(L,X); A=countsince(time>=T1,crossUp(c,R(1)) or crossDown(c,S(1))); crossUp(A,0.5) and C>R(1) 수식 : 매수청산 R=highest(H,X); S=lowest(L,X); crossDown(c,S(1))
프로필 이미지
야할라
2023-06-11
1259
글번호 169659
시스템
답변완료

추세선 상하대칭

input : Period(250); Var:j(0),T(0); Var: date11(0),date12(0),time11(0),time12(0), date21(0),date22(0),time21(0),time22(0), date31(0),date32(0),time31(0),time32(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0); var : btx1(0),btx2(0),btx11(0),btx12(0),btx21(0),btx22(0); Plot1(value12); 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]; date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; if hival[0] > 0 and Loval[0] > 0 Then { btx11 = Text_New(date12,time12,Value11+abs(Hival[0]-loval[0])*1.618,"■"); btx12 = Text_New(date12,time12,Value11+abs(Hival[0]-loval[0])*0.618,"■"); btx1 = Text_New(date12,time12,Value11+abs(Hival[0]-loval[0]),"■"); btx2 = Text_New(date12,time12,Value12-abs(Hival[0]-loval[0]),"■"); btx21 = Text_New(date12,time12,Value12-abs(Hival[0]-loval[0])*1.618,"■"); btx22 = Text_New(date12,time12,Value12-abs(Hival[0]-loval[0])*0.618,"■"); Text_SetStyle(btx11,2,2); Text_SetStyle(btx12,2,2); Text_SetStyle(btx1,2,2); Text_SetStyle(btx2,2,2); Text_SetStyle(btx21,2,2); Text_SetStyle(btx22,2,2); Text_SetColor(btx11,Lime); Text_SetColor(btx12,Lime); Text_SetColor(btx1,Blue); Text_SetColor(btx2,Blue); Text_SetColor(btx21,Lime); Text_SetColor(btx22,Lime); } } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; date22 = date[0]; time22 = stime[0]; Text_SetLocation(btx11, date12,time12,Value11+abs(Hival[0]-loval[0])*1.618); Text_SetLocation(btx12, date12,time12,Value11+abs(Hival[0]-loval[0])*0.618); Text_SetLocation(btx1, date12,time12,Value11+abs(Hival[0]-loval[0])); Text_SetLocation(btx2, date12,time12,Value12-abs(Hival[0]-loval[0])); Text_SetLocation(btx21, date12,time12,Value12-abs(Hival[0]-loval[0])*1.618); Text_SetLocation(btx22, date12,time12,Value12-abs(Hival[0]-loval[0])*0.618); } } 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]; date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; if hival[0] > 0 and Loval[0] > 0 Then { btx11 = Text_New(date12,time12,Value12+abs(Hival[0]-loval[0])*1.618,"■"); btx12 = Text_New(date12,time12,Value12+abs(Hival[0]-loval[0])*0.618,"■"); btx1 = Text_New(date12,time12,Value12+abs(Hival[0]-loval[0]),"■"); btx2 = Text_New(date12,time12,Value11-abs(Hival[0]-loval[0]),"■"); btx21 = Text_New(date12,time12,Value11-abs(Hival[0]-loval[0])*1.618,"■"); btx22 = Text_New(date12,time12,Value11-abs(Hival[0]-loval[0])*0.618,"■"); Text_SetStyle(btx11,2,2); Text_SetStyle(btx12,2,2); Text_SetStyle(btx1,2,2); Text_SetStyle(btx2,2,2); Text_SetStyle(btx21,2,2); Text_SetStyle(btx22,2,2); Text_SetColor(btx11,Lime); Text_SetColor(btx12,Lime); Text_SetColor(btx1,Red); Text_SetColor(btx2,Red); Text_SetColor(btx21,Lime); Text_SetColor(btx22,Lime); } } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; date32 = date[0]; time32 = stime[0]; Text_SetLocation(btx11, date12,time12,Value12+abs(Hival[0]-loval[0])*1.618); Text_SetLocation(btx12, date12,time12,Value12+abs(Hival[0]-loval[0])*0.618); Text_SetLocation(btx1, date12,time12,Value12+abs(Hival[0]-loval[0])); Text_SetLocation(btx2, date12,time12,Value11-abs(Hival[0]-loval[0])); Text_SetLocation(btx21, date12,time12,Value11-abs(Hival[0]-loval[0])*1.618); Text_SetLocation(btx22, date12,time12,Value11-abs(Hival[0]-loval[0])*0.618); } } 네모 표시를, 추세선의 크기가 작으면 무시하고 1P 이상일 때만 표시되게 수정 부탁드립니다.
프로필 이미지
고성
2023-06-11
1699
글번호 169658
지표
답변완료

수식 부탁드립니다.

1. 진입조건 기술적적조건1 (TDI, DI) TDI = 최근 20일추세크기 - 이전 20일 동안 횡보변동성크기 추세크기 = 절대값(최근20일 동안의 20일 모멘텀들의 합) 횡보변동성크기 = (최근 40일동안의 20일 모멘텀 절대값의 합) -(최근20일동안의 20 일 모멘텀 절대값의 합) DI = 최근 20일 동안의 20일 모멘텀 값의 합 buy power = 현재봉 포함 과거 n일 간의 최고점 - 15일 전봉 포함 과거 n일간의 최저점 (n기간 선택가능하게) sell power = n일전 봉 포함 과거 15일간의 최고점 - 현재봉 포함 과거 15일 간의 최저점 TTF(n기간) = (buy power-sell power)/(0.5 * (buy power + sell power)) * 100 TTF > 100 이면서 DI가 TDI를 상향 돌파시 매수 TTF <-100 이면서 DI가 TDI를 하향 돌파시 매도 거래수량(총 예수금의 1%) = 예수금/ (100 * (20봉간 최고값-최저값)) => 예스랭귀지에서 예수금을 읽어와서 거래가 가능한지 아니면 예수금을 직접 입력해줘야하는지 궁금합니다. 기술적조건2 (adx,force index, chaikin oscillator) 종가가 N일간의 최고점 돌파(N값 선택가능하게) and 돌파시점의 ADX값이 N일전의 ADX값보다 클 것 and 돌파시점의 force index값이 N일전의 force index값보다 클 것 and 돌파시점의 chaikin oscillator 값이 N일전의 chaikin oscillator값보다 클 것 시간조건 09:00이후 진입, 15:20에 보유한 모든 수량 청산 예수금조건 거래수량(총 예수금의 1%) = 예수금/ (100 * (20봉간 최고값-최저값)) 2. 필터조건 ADX 조건1) ADX > 25 일 것 ADX 조건2) (ADX 20봉평균 < 10) and (최근 3일 ADX >10 일 것) and (ADX - 5일전 ADX >0 일 것) ADX 조건 1 혹은 ADX조건2를 만족할 것 3. 청산조건 청산조건1 (최고-최저 range) 진입이후 봉이 갱신될 때마다 청산지점(진입후 최고가- 3* abs[20봉간 최고값-최저값])의 값을 비교하여, 기존 청산지점 > 새로계산된 청산지점 -> 기존 청산지점 유지 기존 청산지점 < 새로계산된 청산지점 -> 새로 계산된 청산지점을 청산지점으로 갱신 청산조건2 (표준편차) 진입이후 봉이 갱신될 때마다 청산지점(진입후 최고가 - 3*abs[20봉간 표준편차])의 값을 비교하여, 기존 청산지점 > 새로계산된 청산지점 -> 기존 청산지점 유지 기존 청산지점 < 새로계산된 청산지점 -> 새로 계산된 청산지점을 청산지점으로 갱신
프로필 이미지
고민중
2023-06-10
1153
글번호 169657
시스템