커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

신대륙발견 님에 의해서 삭제되었습니다.

프로필 이미지
신대륙발견
2023-02-13
27
글번호 166218
지표
답변완료

문의드립니다

Rsi 를 중심선으로 하는 볼린저밴드를 구하고싶습니다 기간은 14, 표준편차는 2로 부탁드립니다
프로필 이미지
kns
2023-02-12
885
글번호 166217
지표
답변완료

부탁 드립니다

수고하십니다 해주신자료는 너무 잘쓰고 있습니다 아래 수식은 돈키언채널을 기반했습니다 RED,BLUE지역을 박스 처리했으면 좋겠습니다 그리고 고가,저가를 종가처리했으면 좋겠습니다 노고에 감사드리며 수고하세요 inputs: ChanLength( 20 ),MALength( 50 ) ; variables: UpperBand( 0 ),LowerBand( 0 ),MidBand( 0 ),LongOK( false ),ShortOK( false ), LowRef( 0 ),HighRef( 0 ),TriggerLine( 0 ),MAValue( 0 ) ; UpperBand = Highest( High, ChanLength ) ; LowerBand = Lowest( Low, ChanLength ) ; MAValue = hMa( Close, MALength ) ; if Low == LowerBand then begin LowRef = Low ; LongOK = false ; ShortOK = true ; end ; if High == UpperBand then begin HighRef = High ; LongOK = true ; ShortOK = false ; end ; TriggerLine = .5 * ( HighRef + LowRef ) ; Plot1( UpperBand, "UpperBand",iff(LongOK,RED,BLUE)); Plot2( LowerBand, "LowerBand",iff(LongOK,REd,BLUE)); Plot3( TriggerLine, "Trigger"); Plot4( MAValue, "Mov Avg");
프로필 이미지
비듬싸순
2023-02-12
776
글번호 166216
지표
답변완료

수식 체크 부탁 드립니다.

수고하십니다. 아래 2번 함수식의 오류 점검을 부탁드립니다. 함수식:분봉차트에서 일봉의 기간값을 분봉으로 환산하여 일봉기간내의 분봉갯수를 계산한다 오류 1번: 분봉개수의 계산이 틀립니다.(1일간의 dayindex 차이 발생) 오류 2번: n전일 last dayindex에서 당일 last dayindex까지 선이 이어져야 하는데, 그러하지 않습니다. 오류1번 때문인지 하루의 중간에서 선이 바뀝니다. # 1번 지표식 Input : Period(10), sPeriod(05) ; Var : Box_Top(0), Box_Bottom(0), sBox_Top(0), sBox_Bottom(0) ; Var : BarCount(0), sBarCount(0) ; If DataCompress == 3 Then # 일봉 { Box_Top = highest(C, Period) ; Box_Bottom = lowest( C, Period) ; sBox_Top = highest(C,sPeriod) ; sBox_Bottom = lowest( C,sPeriod) ; } If DataCompress == 2 Then # 분봉 { # 일봉차트의 봉개수를 분봉차트의 봉갯수로 구한다. BarCount = _분봉갯수_일봉(Period) ; sBarCount = _분봉갯수_일봉(sPeriod) ; # 기준값 : last DayIndex의 DayClose Box_Top = highest(iff(Bdate<NextBarSdate, DayClose, 0), BarCount - 0 ) ; Box_Bottom = lowest( iff(Bdate<NextBarSdate, DayClose, Box_Top), BarCount - 0 ) ; sBox_Top = highest(iff(Bdate<NextBarSdate, DayClose, 0), sBarCount - 0 ) ; sBox_Bottom = lowest( iff(Bdate<NextBarSdate, DayClose, sBox_Top), sBarCount - 0 ) ; } Plot1(Box_Top, "Box_Top") ; # 일자 그래프 & 빨강 Plot2(Box_Bottom, "Box_Bottom") ; # 일자 그래프 & 파랑 Plot51(sBox_Top, "sBox_Top") ; # 일자 그래프 & 빨강 Plot52(sBox_Bottom, "sBox_Bottom") ; # 일자 그래프 & 파랑 # 2번 함수식 #======================================================# # 함수명 : _분봉갯수_일봉.yfu # 지표명 : _분봉갯수_일봉.yin # 개 요 : 분봉차트에서 일봉의 기간값을 분봉으로 환산하여 일봉기간내의 분봉갯수를 계산한다. #======================================================# input : P(Numeric) ; var : cnt(0), SumDayIndex(0) ; array : svDayIndex[241](0); if Bdate[0] < NextBarSdate Then { cnt = cnt + 1 ; if cnt <= P-0 Then { svDayIndex[cnt%(P-0)] = DayIndex+1 ; SumDayIndex = SumDayIndex + svDayIndex[cnt%(P-0)] ; } Else { SumDayIndex = SumDayIndex - svDayIndex[cnt%(P-0)] + DayIndex+1 ; svDayIndex[cnt%(P-0)] = DayIndex+1 ; } } _분봉갯수_일봉 = SumDayIndex ;
프로필 이미지
목포댁
2023-02-12
867
글번호 166215
지표
답변완료

검토부탁드립니다.

안녕하세요? 부탁드려서 아래와 같은 식을 받았는데, 매도 하나만 이루어지고 안 되는데 수정도 못해보겠네요. 검토좀 부탁드리고요, 이참에 첫번째 20이평선 하회할 때 sp에서 첫진입을 시작하는 것으로 바꿔주시면 감사하겠습니다. #1)10.20,60 이평선이 정배열로 봉이 진행 중 #2) 20이평선이 60이평선 위에 있는 동안 최초로 봉의 저점이 20이평선을 하회했을때 그 봉에서의 20이평선 가격을 sp라 하고 #3) 그 뒤 60이평선이 상향 진행되어 sp 가격까지 도달된 이후 #4) 두번째로 봉의 저점이 20이평선을 하회하게 되면 그 선에서 매도 1계약하고 그 때의 20이평선 가격을 sp2라 하고 #5) 그 후 만일 봉의 저점이 60이평선을 하회하지 못한 채 봉의 저점이 20이평선 위로 올라가 최소한 10봉을 진행하게 되고 다시 60 이평선이 또 상향하여 sp2가격에 이르면 매도 1계약 #6)...그 식으로 누적시켜 가다가 상황이 반전되어 그 다음엔 반대로 역배열이 되면 독같은 방식으로 일단 최초의 역sp에서 매도진입분 전량청산하고 매수 1계약, 그 다음 sp2에서 또 매수 1계약...하는 식 input : P1(10),P2(20),P3(60); var : mav1(0),mav2(0),mav3(0); var : S(0),SP(0),SellAdd(False); var : B(0),LP(0),BuyAdd(False); mav1 = ma(C,P1); mav2 = ma(C,P2); mav3 = ma(C,P3); Condition1 = mav1 > mav2 and mav2 > mav3; Condition2 = mav1 < mav2 and mav2 < mav3; if Condition1 == true Then { if Condition1[1] == False Then S = 0; if CrossUp(mav2,mav3) then { S = 1; } Else if CrossDown(mav2,mav3) then { S = -1; } Else { if S >= 1 Then { if S == 1 Then { if CrossDown(L,mav2) Then { sp = mav2; S = 2; } } Else if S == 2 Then { if mav3 >= sp Then { S = 3; } } Else if S == 3 Then { if MarketPosition >= 0 and CrossDown(L,mav2) Then { Sell("s1",OnClose,Def,1); sp = mav2; } } } } } Else S = 0; if MarketPosition == -1 Then { if CurrentContracts > CurrentContracts[1] Then { SellAdd = true; var1 = Index; } if L < mav3 Then SellAdd = False; if SellAdd == true and Index > var1+10 and mav3 >= sp and CountIf(L>mav2,10) == 10 Then { Sell("s",OnClose,Def,1); sp = mav2; } } if Condition2 == true Then { if Condition2[1] == False Then B = 0; if CrossUp(mav2,mav3) then { B = 1; } Else if CrossDown(mav2,mav3) then { B = -1; } Else { if B <= -1 Then { if B == -1 Then { if Crossup(H,mav2) Then { LP = mav2; B = -2; } } Else if B == -2 Then { if mav3 <= LP Then { B = -3; } } Else if B == -3 Then { if MarketPosition <= 0 and CrossUp(H,mav2) Then { Buy("b",OnClose,Def,1); LP = mav2; } } } } } Else B = 0; if MarketPosition == 1 Then { if CurrentContracts > CurrentContracts[1] Then { BuyAdd = true; var2 = Index; } if H > mav3 Then BuyAdd = False; if BuyAdd == true and Index > var2+10 and mav3 <= LP and CountIf(H<mav2,10) == 10 Then { Buy("bb",OnClose,Def,1); LP = mav2; } }
프로필 이미지
음양조파
2023-02-12
819
글번호 166214
시스템
답변완료

부탁드립니다.

1. 일봉상 보조차트 저가와 주차트 저가가 0.60이내인 경우가 되면 주차트 봉에 빨강색으로, 보조차트 고가와 주차트 고가가 0.60이내인 경우가 되면 주차트 봉에 파란색으로, 보조차트 고가가 주차트 저가와 0.80이내 또는 보조차트 저가가 주차트 고가와 0.80이내가 되는 경우에는 주차트 봉에 흰색으로 구현해 주세요 고맙습니다.
프로필 이미지
서태공
2023-02-12
1178
글번호 166213
강조
답변완료

문의

급등으로 인한 단일가 구간을 알수 있은 지표 부탁드립니다. 또한 강조식으로 봉의 머리와 꼬리를 제외한 몸통에만 표시될 수 있게 해주셔요..
프로필 이미지
엉덩공주
2023-02-12
1300
글번호 166212
지표
답변완료

추세선 직전과의 차이

input : Period(120),틱1(3),틱2(4); 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),txx(0), vTL(0), vTL9(0),txxx(0), date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0),tl4(0),tx4(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(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]; for j = 0 to 6 { fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]); } Condition3 = False; if Condition3 == False and Value12 <= value11-0.5 and value12 < DayHigh-0.8 Then { Tx4=Text_New(date11,time11,value11+PriceScale*2,"●"); Condition3 = true; Text_SetStyle(tx4,2,2); Text_SetColor(tx4,Black); Text_SetSize(tx4,35); } Txx = Text_New(date11,time11,loval[0]-PriceScale*10,"●"); Condition99 = true; Text_SetColor(Txx,Red); Text_SetStyle(Txx,2,2); Text_SetSize(txx,20); if Condition99 == true and Loval[0] <= loval[1]-PriceScale*틱2 Then { Condition99 = False; Text_Delete(txx); PlaySound("C:₩예스트레이더₩data₩Sound₩reject.wav"); } } Else { 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]; } if Condition3 == False and Value12 <= value11-0.5 and value12 < DayHigh-0.8 Then { Tx4 =Text_New(date11,time11,value11+PriceScale*2,"●"); Condition3 = true; Text_SetColor(Tx4,Black); Text_SetStyle(tx4,2,2); Text_SetSize(tx4,35); } TL_Delete(tl); if Condition99 == true and Loval[0] <= loval[1]-PriceScale*틱2 Then { Condition99 = False; Text_Delete(txx); PlaySound("C:₩예스트레이더₩data₩Sound₩reject.wav"); } } } If T == 1 Then { If T[1] != 1 Then { if Condition3 == true Then Text_Delete(tx4); 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]; for j = 0 to 5 { fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]); } if Condition99 == true and Loval[0] >= Loval[1]-PriceScale*틱1 Then { Condition99 = False; Text_Delete(txx); } } 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]; } } 1. 현 수식 중에 양전환되거나 직전저점을 4틱 벗어나면 삭제되는 빨간 동그라미의 위치를 loval[0] 고정에서 하락추세선 하단을 따라 같이 내려가는 이동형으로 수정. 2-1. 추세선이 양전환되면 바로 직전고점과의 차이를, 상승 추세선 상단을 따라 같이 올라가며 표기. 처음에는 -로 출발되니까 파란 글씨로, 차이를 변경해가며 표기. - 숫자가 점차 줄어들다 직전 고점에 도달하면 차이가 0 되고, 돌파하여 +로 바뀌면 빨간색으로 변경하여 돌파된 만큼의 숫자 표기 계속. 이전 상단은 지우고 마지막 상승 추세선 차이 숫자만 남긴다. 음전환되면 반대로 바로 직전저점과의 차이를 빨간 글씨로 추세선 하단을 따라가며 표기. 숫자가 줄어들다가 직전 저점에 도달하여 0 된후 붕괴되어 -로 바뀌면 파란 글씨로 변경하여 하단을 따라 내려가며 계속 표기. 이전 하락추세선 차이 숫자는 지우고 마지막 차이 숫자만 남긴다. 2-2. 직전과의 차이 숫자 표기는 상단 하나,하단 하나씩만 남기고 이전것은 항상 삭제. 2-3. 직전과의 차이는 틱수로 계산하여 표기 (0.15면 3). 감사합니다.
프로필 이미지
고성
2023-02-13
1798
글번호 166211
지표
답변완료

문의드립니다.

아무리 검증해도 안되 문의드립니다.
프로필 이미지
카르마다
2023-02-12
1022
글번호 166210
시스템