커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

미스포터 님에 의해서 삭제되었습니다.

프로필 이미지
미스포터
2016-10-06
0
글번호 102581
검색
답변완료

문의드립니다.

안녕하세요. 시스템관련 문의 드립니다. 이평크로스 다운 일때 long 포지션 청산 식입니다. If CrossDown(value1, Value3) and MarketPosition == 1 and stime >=091500 Then { exitlong("bx2"); } 여기서 이평선 크로스 다운 발생후 5분봉으로 3개 (15분) 뒤에도 크로스 다운이 유지되고 있으면 청산 하고, 다시 이평선이 올라가 크로스가 되지 않으면, 포지션 유지 되는 식으로 바꿔주세요. 감사합니다.
프로필 이미지
화려한인생
2016-10-06
118
글번호 102580
시스템
답변완료

항상 고맙습니다. ^.^

수식 부탁 드릴께요. 1. : 5, 20, 60, 120일선이 역배열 상태에서 Rsi 과매도 신호 발생시 매수. 주가가 120일선 터치시 매도. 2. 5, 20, 60, 120일선이 역배열 상태에서 Rsi 과매도 신호 발생이후 첫번째 macd-sig 골든크로스 발생시 매수 이평선(5,20,60,120) 이 정배열 상태서 거래량이 전봉 거래량의 3배 이상 발생시 매도! 이런것도 가능한가요?? 고맙습니다. ^.^
프로필 이미지
하늘북
2016-10-06
130
글번호 102579
시스템
답변완료

손실제한 수익제한 추가 부탁드립니다

input : 시작시간(200000),종료시간(010000),P1(5),P2(20); var : Tcond(false),entry(0),mav1(0),mav2(0),TT(0),T1(0); mav1 = ma(C,P1); mav2 = ma(C,P2); TT = TotalTrades; if stime == 시작시간 or (stime > 시작시간 and stime[1] < 시작시간) Then{ Tcond = true; T1 = TT; } if MarketPosition == 1 Then entry = (TT-T1)+1; Else entry = (TT-T1); if stime == 종료시간 or (stime > 종료시간 and stime[1] < 종료시간) Then { Tcond = false; ExitLong("bx"); ExitShort("sx"); } if Tcond == true and entry < 3 then { if crossup(mav1,mav2) and countif(crossup(mav1,mav2),90) == 3 Then buy("b"); if CrossDown(mav1,mav2) and countif(CrossDown(mav1,mav2),90) == 3 Then sell("s"); } 안녕하세요 감사 합니다 기존수식에 추가하고 싶어요 외부변수로 50틱 수익이면 청산후 매매종료 손실50틱 이면 청산후 매매종료 손실 수익틱수는 외부 변수로 부탁드립니다 감사합니다
프로필 이미지
비상8
2016-10-06
129
글번호 102574
시스템
답변완료

주식수식문의

똑같은 것으로 귀찮게하어 죄송합니다 초보라 응용이되지 않습니다ㅜ 1. 기준선+2%가격에 주가가 만족시 매수진입(봉미완성시 시세만족시 신호발생, 시가가 진입신호 가격과 같거나 낮아도 진입) # 2%값 변수로 넣어주시길 부탁합니다 2. 위와같이 기준선+7% 값으로도 수식하나 부탁합니다 감사합니다!
프로필 이미지
10년후에
2016-10-06
116
글번호 102573
시스템
답변완료

수식문의 드립니다

수식을 잘몰라서 계속 문의드려요 ㅠㅠ 죄송하고,감사하다는 말씀 먼저드릴게요 이전한달간 평균치에대해 높으면 매수 낮을시 매도하는 수식좀 알려주세요~ 그리고 예를들어서 위수식이 나오면 제가 따로 일주일이나 몇일전 이렇게 수정도 할수있나요? 그리고 종가파라볼릭 매주 월요일부터 금요일마감시간까지하는거 청산 수식할수있나요? 부탁드립니다.
프로필 이미지
꽃영이
2016-10-06
118
글번호 102572
시스템
답변완료

주식 수식재문의

항상 애쓰십니다^^전략좀 부탁하겠습니다 1. 2시이후에 만들어지는 고가 대비 -12%에서 매수진입 2시이후 고가라는 개념은 2시이전의 고가와 전혀상관없이 2시이후에 만들어지는 주가의 고가를 말합니다 즉 2시에. . 예1. 오후 2시이전 고가1200, 2시정각에 봉의 시가1000, 주가가 하락하여 900원이 되었다고 가정한다면 제가말하는 고가는 1000이됨 예2. 오후2시이전 고가 1200, 2시정각에 봉의시가1000 이후에 1300 상승하여 종가 900원이라고 한다면 2시이후의 고가이기때문에 1300원이 기준이 됩니다! 예3. 오후2시이전고가 1300, 2시정각봉의시가 1200에서 가격하락하여 종가1000이라 하면 2시이후의 고가이기 때문에 1200이됩니다 감사합니다.
프로필 이미지
10년후에
2016-10-06
122
글번호 102571
시스템
답변완료

신호검색

주 데이터는 1분봉으로 볼 것이고 1분봉 macd크로스 200틱 macd크로스 10분봉 macd크로스 이 세 조건이 어떤 순서가 먼저든, 만족하게 되면 신호가 나오게 하고싶어요 미리 감사합니다
프로필 이미지
티거야
2016-10-06
133
글번호 102570
시스템
답변완료

부탁드려요

1.현재가가 p를 크로스업하고 아래지표가 상승중이면 매수진입.... 2.현재가가 q를 크로스다운하고 아래지표가 하락중이면 매도진입... 3.아래지표가 상승에서 하락으로 바뀌면 매수청산... 4.아래지표가 하락에서 상승으로 바뀌면 매도청산... 부탁드립니다... Input:chRate(0.5); //전환율 또는 변동률 Var:j(0),upTr(100),dnTr(-100),upRate(0),dnRate(0),trnd(0),TL(0), date11(0),date12(0),time11(0),time12(0),TL1(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]은 반대 개념 var : TL13(0),TL14(0),color(0); upRate = 1 + (chRate/100); //상승률 dnRate = 1 - (chRate/100); //하락률 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] * dnRate > L then trnd = dnTr; //저가가 고가 대비 변동률보다 밑으로 떨어지면 하락추세로 설정 //단, 현재봉의 고가가 변곡점 이후 최고가이면 상승 추세가 진행중이라고 본다. //그래서 현재봉의 고가가 hiVal[0]보다 작다는 조건이 추가되었다. else if trnd != upTr && loVal[0] < L && loVal[0] * upRate < 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] and //전고점보다 더 높은 고점이 출현했다면 hiVal[0] * dnRate > L 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로 추세선을 추가해도 된다. } 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] and //전저점보다 낮은 저가가 출현했다면 loVal[0] * upRate < H 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); } if trnd == upTr and loVal[2] > loVal[1] then{ TL_SetColor(TL1,BLUE); color = blue; } else if trnd == dnTr and hiVal[2] < hiVal[1] then{ TL_SetColor(TL1,RED); color = RED; } else{ TL_SetColor(TL1,BLACK); color = BLACK; } TL_SetSize(TL1,2); TL_SetColor(TL2,RED); TL_SetColor(TL3,BLUE); if var1 <= 0 and Trnd == uptr and Trnd != Trnd[1] Then{ var1 = 1; value1 = loval[1]; TL1 = Text_New(sdate[lobar[1]],stime[lobar[1]],value1-PriceScale*2,"●"); TL_SetColor(TL,RED); TL_SetSize(TL,2); Text_SetStyle(TL1,2,2); Text_SetColor(TL1,RED);#텍스트 색상 TL= Text_New(sdate[lobar[1]],stime[lobar[1]],L,"상승"); Text_SetColor(TL,RED);#텍스트 색상 TL13 = TL_New(date11,time11,Value11,date12,time12,Value11); TL14 = TL_New(date12,time12,Value11,date12,time12,Value12); TL_SetColor(TL13,color); TL_SetColor(TL14,color); } if var1 >= 0 and Trnd == dntr and Trnd != Trnd[1] then{ var1 = -1; value1 = hival[1]; TL2 = Text_New(sdate[hibar[1]],stime[hibar[1]],value1+PriceScale*2,"●"); TL_SetColor(TL,BLUE); TL_SetSize(TL,2); Text_SetStyle(TL2,2,2);#텍스트 좌우 상하 정렬 Text_SetColor(TL2,BLUE);#텍스트 색상 TL= Text_New(sdate[hibar[1]],stime[hibar[1]],H,"하락"); Text_SetColor(TL,BLUE);#텍스트 색상 TL13 = TL_New(date11,time11,Value11,date12,time12,Value11); TL14 = TL_New(date12,time12,Value11,date12,time12,Value12); TL_SetColor(TL13,color); TL_SetColor(TL14,color); }
프로필 이미지
오동도물개
2016-10-06
147
글번호 102569
시스템