커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

지표 부탁드립니다.

안녕하세요. 거래량 지표서식 부탁드립니다. 영운문에 수식관리자에서 쓰고있는건데 예스트레이더에 쓰려고합니다. 미리 감사합니다~^^ 수식 수식1 PVI(C)+NVI(C) 수식2 AVG(PVI(C),PERIOD)+AVG(NVI(C),PERIOD) 수식3 A=PVI(C)+NVI(C); B=AVG(PVI(C),PERIOD)+AVG(NVI(C),PERIOD); MIN(A,B) --------------------------------------- 지표조건설정 period 25 -------------------------------------- 라인설정 거래량 색상-빨강 과열-노랑 침체-파랑 기준값-1 평균 색상-파랑 과열-하늘색 침체-하늘색 기준값-1 표시 색상-없음(흰색) 과열-없음(흰색) 침체-없음(흰색) 기준값-1
프로필 이미지
이민섭
2022-11-05
839
글번호 163547
지표

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

프로필 이미지
oni
2022-11-06
30
글번호 163546
지표
답변완료

부탁드립니다

수고하십니다 아래그림은 콜14개 풋14개 교차된 그림입니다 (연두색 선들은 콜들의(현재가선),풋들의(현재가선) 입니다 그림의 타원형은 콜14개(현재가) ,풋14개(현재가)가 중 콜,풋이 맞나 콜(현재가) ,풋(현재가)가 같을 때 이때 봉의 콜저 < 풋고 - 0.15 And 콜현재가 > 풋현재가 --→조건만족할때마다 콜승으로보고 중심에 선긋기 Else 풋저 < 콜고 - 0.15 And 풋현재가 > 콜현재가 --→조건만족할때마다 풋승으로보고 중심에 선긋기 //콜;Data2~Data15 (14개) Data2; Data3; Data4; //중략 Data13; Data14; Data15; //풋;Data16~Data29 (14개) Data16; Data17; Data18; //중략 Data27; Data28; Data29;
프로필 이미지
파생돌이
2022-11-05
801
글번호 163545
지표
답변완료

수식부탁드립니다...

1.매수진입조건 1-1-코스피200 선물 09시30부터 적용시작 오전 12시매매 종료 -연결선물 2분봉에서 볼린저밴드 (20,2) 중심선 양봉돌파시 선물2계약 매수진입 진입시 2계약 모두 -5틱에 자동 스탑로스 1-2 청산조건 -진입후 5틱 1계약 청산 -1계약은 볼린저밴드 역돌파(음봉돌파)시 청산 2.매도진입조건 2-1-코스피200 선물 09시30부터 적용시작 오전 12시매매 종료 -연결선물 2분봉에서 볼린저밴드 (20,2) 중심선 음봉돌파시 선물2계약 매도진입 진입시 2계약 모두 -5틱에 자동 스탑로스 2-2 청산조건 -진입후 5틱 1계약 청산 -1계약은 볼린저밴드 역돌파(양봉돌파)시 청산
프로필 이미지
신보드
2022-11-05
884
글번호 163544
시스템
답변완료

문의드립니다

아래지표식에서 고가 저가 가로선 말고 이평선 처럼 나오는 라인만 색상을 임의로 지정할수 있게 하거나 만일 불가능하다면 안나오게(표시가 안되게) 부탁드립니다 input : Period(10); var : A1(0),A2(0),AA(0); A1 = ma(C,Period/2); A2 = ma(C,Period); AA = Ma(2*A1 - A2, Sqrt(Period)); if AA > AA[1] Then var1 = AA; if AA < AA[1] Then var2 = AA; Plot1(AA,"수식1"); Plot2(var1,"고가"); Plot3(Var2,"저가");
프로필 이미지
러블리
2022-11-06
979
글번호 163543
지표
답변완료

문의 드립니다

Inputs: XAvgLen(3), HiLoLen(50), Retrace(0.382); Vars: XAvg(0),HiHi(0),LoLo(0),Retracement(0),HRetrace(0),LRetrace(0); XAvg = Ema(C, XAvgLen); HiHi = Highest(High, HiLoLen); LoLo = Lowest(Low, HiLoLen); Retracement = (HiHi - LoLo) * Retrace; HRetrace = HiHi - Retracement; Lretrace = LoLo + Retracement; if XAvg > HRetrace Then buy(); if XAvg < LRetrace Then Sell(); ------------ 위 수식어에 해외선물 매매시간 (10:15~ 익일 05:55) 및 손절 50틱를 추가로 부탁드립니다.
프로필 이미지
푸른
2022-11-06
995
글번호 163542
시스템
답변완료

다종목 차트값 인식

안녕하세요 이전에 아래와같이 답변을 받았습니다. 답변에는 문제가 없으나 응용이 어려워서 문의드립니다 한 차트에 3종목을 띄워놓고 그 3종목 데이터를 인식하게 하려는데 data1의 첫봉만 인식이 되고, 나머지는 계속 현재 종가를 가져오는거같아요 수정 부탁드립니다 if index == 0 Then var1 = data1(C); var2 = data2(C); var3 = data3(C); value1 = data1(c)/var1*100; value2 = data2(c)/var2*100; value3 = data3(c)/var3*100; Plot1(value1); Plot2(value2); Plot3(value3); ---------------이전 답변------------- 안녕하세요 예스스탁입니다. if index == 0 Then var1 = C; value1 = c/var1*100; Plot1(value1); 즐거운 하루되세요 > 퀀트드래곤 님이 쓴 글입니다. > 제목 : 차트 전체에서의 첫봉(한개)의 값 > 안녕하세요 차트 전체 기간(일봉) 중 첫날 종가를 알 수 있을까요? 구할 수 있다면 아래와같이 차트로 보고싶은데 수식 부탁드립니다. 차트 전체의 첫 날 종가 / 차트 전체의 첫 날 종가 * 100 차트 전체의 둘째날 종가 / 차트 전체의 첫 날 종가 * 100 차트 전체의 셋째날 종가 / 차트 전체의 첫 날 종가 * 100 차트 전체의 넷째날 종가 / 차트 전체의 첫 날 종가 *100 ... ~~~ ... 오늘 종가 / 차트 전체의 첫 날 종가*100 이렇게 일봉차트에서 조회되는 첫날부터 오늘까지의 종가를 계속 나누면서 와야하는 차트를 만들고 싶은데 부탁드립니다
프로필 이미지
퀀트드래곤
2022-11-05
904
글번호 163541
지표
답변완료

수정부탁드립니다

변곡점 자리에서 에서 단가표시 및 수직선표시 부탁드립니다 Input:atrLength(60),multi(3),fTetxt10(20); Var:j(0),dayATR(0),sum(0),upTr(100),dnTr(-100),trnd(0), date11(0),date12(0),time11(0),time12(0),TL1(0),tx(0), date21(0),date22(0),time21(0),time22(0),TL2(0), date31(0),date32(0),time31(0),time32(0),TL3(0); Array:hiVal[10](0),loVal[10](0),hiBar[10](0),loBar[10](0); //hiVal[1]은 전고점, hiVal[2]는 전전고점, hiVal[3]은 전전전고점 //hiVal[0]은 변곡점 이후 현재봉까지의 고점. 현재 고점은 진행중이므로 계속 바뀐다. //loVal[0]은 반대 개념 sum = 0; for j = 1 to atrLength { sum = sum + Max(C[j+1],H[j]) - Min(C[j+1],L[j]); } dayATR = sum/atrLength; //일봉기준으로 ATR 산출 for j = 1 to 9 { //전고,전저점을 9개까지 보관 loBar[j] = loBar[j] + 1; //전저점의 위치. 현재 봉으로부터 떨어져 있는 거리 hiBar[j] = hiBar[j] + 1; //전고점의 위치 } if hiVal[0] <= H or hiVal[0] == 0 then { //전고,전저점 이후 현재까지의 고점 hiVal[0] = H; //0을 체크한 이유는 초기에 값이 없는 구간이 생기기 때문 hiBar[0] = 0; //현재 고점의 위치가 0이란 것은 현재봉의 고가가 구간 고점이라는 의미 } else { hiBar[0] = hiBar[0] + 1; //현재 고점의 위치 } if loVal[0] >= L or loVal[0] == 0 then { //전고,전저점 이후 현재까지 저점 loVal[0] = L; loBar[0] = 0; } else { loBar[0] = loBar[0] + 1; //현재 구간 저점의 위치 } if trnd != dnTr && hiVal[0] > H && hiVal[0] - (dayATR * multi) > L then trnd = dnTr; //저가가 고가 대비 변동률보다 밑으로 떨어지면 하락추세로 설정 //단, 현재봉의 고가가 변곡점 이후 최고가이면 상승 추세가 진행중이라고 본다. //그래서 현재봉의 고가가 hiVal[0]보다 작다는 조건이 추가되었다. else if trnd != upTr && loVal[0] < L && loVal[0] + (dayATR * multi) < H then trnd = upTr; //고가가 저가 대비 변동률보다 높으면 상승추세로 설정 if trnd[1] == upTr and trnd == dnTr then { //상승추세였다가 하락추세로 바뀌었다면 for j = 8 downto 1 { //새로운 전고점이 생기는 것이므로 hiVal[j+1] = hiVal[j]; //전고점을 하나씩 뒤로 보낸다. hiBar[j+1] = hiBar[j]; //전고점은 전전고점이 되고, 전전고점은 전전전고점이 된다. } hiVal[1] = hiVal[0]; //새로운 전고점에 현재 고점을 대입 hiBar[1] = hiBar[0]; hiVal[0] = H; //전고점이 확정되었으므로 전고점 이후 최고가는 현재봉의 고가 hiBar[0] = 0; loVal[0] = L; loBar[0] = 0; //전고점이 새로 생긴 것이니까 전저점에서 전고점까지 추세선을 긋는다. date11 = date[loBar[1]]; //추세선 시작일. 전저점의 날짜 time11 = stime[loBar[1]]; //추세선 시작시간 Value11 = loVal[1]; //추세선 시작가격 date12 = date[hiBar[1]]; //추세선 종료일. 전고점의 날짜 time12 = stime[hiBar[1]]; //추세선 종료시간 Value12 = hiVal[1]; //추세선 종료가격 TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); //TL_New는 신규 추세선을 그려주는 함수 } if trnd[1] == dnTr and trnd == dnTr and //추세는 하락 상태에서 바뀌지 않았는데 hiVal[1] < hiVal[0] then { //전고점보다 더 높은 고점이 출현했다면 if loVal[1] <= loVal[0] then { //전저점은 갱신되지 않았다면 hiVal[1] = hiVal[0]; //전고점을 현재의 고점으로 바꿔준다. hiBar[1] = hiBar[0]; hiVal[0] = H; hiBar[0] = 0; loVal[0] = L; loBar[0] = 0; //전고점이 추가된 게 아니고 바뀐 것이므로 종료일,종료시간,종료가격만 바꿔준다. date12 = date[hiBar[1]]; //추세선 종료일 time12 = stime[hiBar[1]]; Value12 = hiVal[1]; TL_SetEnd(TL1, date12,time12,Value12); //TL_SetEnd는 기존추세선의 종료지점을 변경해주는 추세선 함수이다. //TL_Delete 함수를 써서 직전의 추세선을 지우고 다시 TL_New로 추세선을 추가해도 된다. } else { //전저점도 갱신되었다면 for j = 8 downto 1 { //전고점, 전저점을 새로이 추기 hiVal[j+1] = hiVal[j]; //전고점을 하나씩 뒤로 보낸다. hiBar[j+1] = hiBar[j]; //전고점은 전전고점이 되고, 전전고점은 전전전고점이 된다. loVal[j+1] = loVal[j]; //전저점을 하나씩 뒤로 보낸다. loBar[j+1] = loBar[j]; //전저점은 전전저점이 되고, 전전저점은 전전전저점이 된다. } hiVal[1] = hiVal[0]; //새로운 전고점에 현재 고점을 대입 hiBar[1] = hiBar[0]; loVal[1] = loVal[0]; //새로운 전저점에 현재 저점을 대입 loBar[1] = loBar[0]; hiVal[0] = H; //전고점 이후 최고가는 현재봉의 고가 hiBar[0] = 0; loVal[0] = L; loBar[0] = 0; //전저,전고점이 새로 생긴 것이니까 전전고점에서 전저점까지 //그리고 전저점에서 전고점까지 추세선 2개를 생성한다. date11 = date[hiBar[2]]; //추세선 시작일. 전전고점의 날짜 time11 = stime[hiBar[2]]; //추세선 시작시간 Value11 = hiVal[2]; //추세선 시작가격 date12 = date[loBar[1]]; //추세선 종료일. 전저점의 날짜 time12 = stime[loBar[1]]; //추세선 종료시간 Value12 = loVal[1]; //추세선 종료가격 TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); TL_SetSize(TL1,2); date11 = date[loBar[1]]; //추세선 시작일. 전저점의 날짜 time11 = stime[loBar[1]]; //추세선 시작시간 Value11 = loVal[1]; //추세선 시작가격 date12 = date[hiBar[1]]; //추세선 종료일. 전고점의 날짜 time12 = stime[hiBar[1]]; //추세선 종료시간 Value12 = hiVal[1]; //추세선 종료가격 TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); } } if trnd[1] == dnTr and trnd == upTr then { //추세가 하락에서 상승으로 바뀌었을 경우 for j = 8 downto 1 { //이전저점은 전전저점으로, 전전저점은 전전전저점으로 번호를 부여 loVal[j+1] = loVal[j]; loBar[j+1] = loBar[j]; } loVal[1] = loVal[0]; loBar[1] = loBar[0]; loVal[0] = L; loBar[0] = 0; hiVal[0] = H; hiBar[0] = 0; date11 = date[hiBar[1]]; //전저점이 새로이 생긴 것이므로 시작점은 전고점이 된다. time11 = stime[hiBar[1]]; Value11 = hiVal[1]; date12 = date[loBar[1]]; time12 = stime[loBar[1]]; Value12 = loVal[1]; TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); } if trnd[1] == upTr and trnd == upTr and //추세는 상승을 유지하고 있는데 loVal[1] > loVal[0] then { //전저점보다 낮은 저가가 출현했다면 if hiVal[1] >= hiVal[0] then { //고점 갱신이 되지 않았다면 loVal[1] = loVal[0]; //직전의 전저점만 바꿔준다. loBar[1] = loBar[0]; loVal[0] = L; loBar[0] = 0; hiVal[0] = H; hiBar[0] = 0; date12 = date[loBar[1]]; time12 = stime[loBar[1]]; Value12 = loVal[1]; TL_SetEnd(TL1, date12,time12,Value12); } else { //고점도 이전고점보다 높다면 for j = 8 downto 1 { //전고점,전저점을 새로이 생성 hiVal[j+1] = hiVal[j]; hiBar[j+1] = hiBar[j]; loVal[j+1] = loVal[j]; loBar[j+1] = loBar[j]; } hiVal[1] = hiVal[0]; hiBar[1] = hiBar[0]; loVal[1] = loVal[0]; loBar[1] = loBar[0]; loVal[0] = L; loBar[0] = 0; hiVal[0] = H; hiBar[0] = 0; date11 = date[loBar[2]]; //시작점이 전전저점 time11 = stime[loBar[2]]; Value11 = loVal[2]; date12 = date[hiBar[1]]; //종료는 전고점 time12 = stime[hiBar[1]]; Value12 = hiVal[1]; TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); TL_SetSize(TL1,2); date11 = date[hiBar[1]]; //2번째 시작은 전고점이 된다. time11 = stime[hiBar[1]]; Value11 = hiVal[1]; date12 = date[loBar[1]]; //2번째 종료는 전저점 time12 = stime[loBar[1]]; Value12 = loVal[1]; TL1 = TL_New(date11,time11,Value11,date12,time12,Value12); } } /* if loVal[2] < loVal[1] then { if loBar[2][1] + 1 != loBar[2][0] then { date21 = date[loBar[2]]; time21 = stime[loBar[2]]; Value21 = loVal[2]; date22 = date[0]; //추세선이므로 현재 봉까지 그려준다. time22 = stime[0]; Value22 = (loVal[1]-loVal[2])/(loBar[2]-loBar[1])*loBar[2]+LoVal[2]; //종료시점의 가격은 직선의 기울기와 절편을 계산해서 구한다. TL2 = TL_New(date21,time21,Value21,date22,time22,Value22); } else { //전전저점이 바뀌지 않았다면 종료시점만 변경하면 된다. date22 = date[0]; time22 = stime[0]; Value22 = (loVal[1]-loVal[2])/(loBar[2]-loBar[1])*loBar[2]+LoVal[2]; TL_SetEnd(TL2, date22,time22,Value22); //TL_SetExtRight 함수는 추세선을 오른쪽으로 연장하는 함수인데 //이 함수를 사용하면 모든 추세선이 현재봉까지 연장되어 알아볼 수가 없다. } } if hiVal[2] > hiVal[1] then { if hiBar[2][1] + 1 != hiBar[2][0] then { date31 = date[hiBar[2]]; time31 = stime[hiBar[2]]; Value31 = hiVal[2]; date32 = date[0]; time32 = stime[0]; Value32 = (hiVal[1]-hiVal[2])/(hiBar[2]-hiBar[1])*hiBar[2]+hiVal[2]; TL3 = TL_New(date31,time31,Value31,date32,time32,Value32); } else { date32 = date[0]; time32 = stime[0]; Value32 = (hiVal[1]-hiVal[2])/(hiBar[2]-hiBar[1])*hiBar[2]+hiVal[2]; TL_SetEnd(TL3, date32,time32,Value32); } } */ if trnd == upTr and loVal[2] > loVal[1] then TL_SetColor(TL1,BLUE); else if trnd == dnTr and hiVal[2] < hiVal[1] then TL_SetColor(TL1,RED); else TL_SetColor(TL1,BLACK); TL_SetSize(TL1,2); TL_SetColor(TL2,RED); TL_SetColor(TL3,BLUE);
프로필 이미지
외국인
2022-11-04
907
글번호 163540
강조

외국인 님에 의해서 삭제되었습니다.

프로필 이미지
외국인
2022-11-04
0
글번호 163539
강조