커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

청산 후 재진입3(Lcount 구별)

손절이후 당일 저점 1번째 돌파시 변수 적용 결과를 살펴보았습니다.(첨부파일) 387.24 저점을 돌파할 때 진입해야는데 다른 지점에서 진입합니다. 살펴주십시요. input : n(1); var : cnt(0),count(0); Count = 0 ; for cnt = 0 to 10 { if EntryDate(cnt) == sdate then Count = Count + 1; } input : 갭하락(1.5),손절진입(50),트레진입(50),최소진입(50); input : loss(0.5),trail(1.5),최소가격(0.4),봉갯수(150); if c < DayOpen - 갭하락 and count < n Then Sell("s"); SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 Then { if TotalTrades > TotalTrades[1] Then count = 0; if daylow(0) < DayLow(0)[1] Then count = count+1; if IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and count == 손절진입 Then Sell("손절진입"); if IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and count == 트레진입 Then Sell("트레진입"); if IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and count == 최소진입 Then Sell("최소진입"); } *********************************************************************************** 안녕하세요 예스스탁입니다. CountIf가 현재봉에서 청산봉까지 루프를 반복하게 되므로 다른 방법으로 작성하면 아래와 같습니다. var : count(0); SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 Then { if TotalTrades > TotalTrades[1] Then count = 0; if daylow(0) < DayLow(0)[1] Then count = count+1; if IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and count == 3 Then Sell(); if IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and count == 2 Then Sell(); if IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and count == 1 Then Sell(); } 즐거운 하루되세요 > 목마와숙녀 님이 쓴 글입니다. > 제목 : 문의 > 답변 수식 고맙습니다. 그런데... 아래 수식을 사용하면 수식 추가 이전보다 시뮬레이션 속도가 현저히 느려지는데요. 이유가 있을까요? 피시 메모리는 동일한 조건에서 비교했습니다. 속도를 고려한 다른 수식은 없겠는지요? *************************************************************************** SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 and IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 3 Then Sell(); if MarketPosition == 0 and IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 2 Then Sell(); if MarketPosition == 0 and IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 1 Then Sell();
프로필 이미지
목마와숙녀
2021-12-16
763
글번호 154351
시스템
답변완료

디버그시 차트값 참조?/외부파일 참조가 가능한가요?

안녕하세요! 수식 작성 중에 어떨 때는 실제 데이터가 뭐가 들어 있는지 식을 실행해서보고 싶을 때가 있는데요, 그때 예를 들면 RSI함수를 화면에 무슨 숫자값들이 들어 있는지 혹은 제가 쓴 함수가 값들이 제가 원하는 대로 잘 들어 있는지 확인은 어떻게 하나요? (또 이때 숫자값을 문자열로 변환은 어떻게하는지요?) messagelog함수인가 그것은 위의 상황에 안되는 경우가 있어서 질문드립니다. 그냥 차트에 띄워서 보는 방법 밖에 없나요? 즉 그 전에 코드 에디터에서 실제 차트 데이터를 숫자들이 잘 들어 있거나 작동 잘하는지 보고 싶습니다. 그리고 궁금한 것은 예스랭귀지에서 csv파일을 출력은 메뉴얼에서 봤는데 읽는 것은 없나요? 아니면 외부 html이나 크롤링 함수들은 지원을 하는지요? 감사합니다.
프로필 이미지
nirvana
2021-12-09
694
글번호 154350
시스템
답변완료

부탁드립니다.

언제나 감사드립니다. 1. Index나 dayindex 대신에 그 상황이 발생한 시각을 지정할 수 있는지요. stime이 무슨 뜻인지 모르지만, 그런 식으로 표현할 방법이 없는지요. 특정시각 이후에 그 일이 일어난 것을 부수조건으로 설정코자 하는데, 분봉의 크기에 따라 다른 dayindex를 지정하기가 번거러워서 그럽니다. 부탁드립니다. If condition1[1]==false and condition1==true Then{ var1=Index; } 대신 If condition1[1]==false and condition1==true Then{ var1=발생시분초; } 2. 분봉에서 매수조건이 맞을 때 그날의 종가에 자동진입하게끔 시스템식을 작성하려면 어떻게 해야 하는지요. If stime==152500 and 매수조건1 Then{ buy("b1"); } If stime==152500 and 매수조건2 Then{ buy("b2"); } 이런 식으로 해도 되는지요. 3. 중복진입이 가능할 때 첫매수일로부터 5거래일 후의 정오에 자동청산한다면 어떻게 시스템식을 작성해야 하는지요. setstopendofday같은 별도의 용어가 있는지요. 4.. 위에서 매수후 5일이내의 최고점에서 팔았다고 가정할 경우에 그 시각 이전까지의 최대손실을 알 수 있는 방법이 있다면 부탁드리겠습니다. 시스템 성과를 정확히 알고 싶어서 그럽니다. 부탁드립니다. 즉 매수후 5일이내의 기간중에 최고점에서 팔았다고 가정할 경우의 수익과 최고점을 가기까지에 겪는 최대손실을 알고자 함입니다. 사후적인 검증에 의해서 기간내의 최고점에서 청산한 것으로 전제하여 그때까지의 성과와 최대손실을 성과보고서에서 확인할 방법은 없는지요. 청산목표 설정에 참고하고자 함입니다. 부탁드립니다. 5. 분봉그래프에서 같은종목의 일봉그래프를 매번 수정하지 않고 data2로 설정하는 방법은 없는지요. 6. 분봉그래프에서 일평균거래량 구하기 (1) 19일간의 dayvolume(1)의 평균을 구하는 지수식을 어떻게 표현하는지요. (2) 상장한지 20거래일이 안 된 경우 경과된 날짜만큼의 dayvolume(1)의 평균은 어떻게 구하는지요. 7. 선물에서 bids-asks의 당일 시초가를 나타낼 수 있는 방법이 있는지요.
프로필 이미지
묘선낭자
2021-12-10
582
글번호 154349
시스템

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

프로필 이미지
회원
2021-12-09
0
글번호 154346
지표

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

프로필 이미지
2wnwn
2021-12-09
9
글번호 154342
지표

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

프로필 이미지
회원
2022-01-28
236
글번호 154339
지표
답변완료

수식작성 부탁드립니다.

안녕하십니까 항상 감사드립니다. 아래 조건으로 작성하여 주신 수식 잘 사용하고 있습니다. 매수 조건: 1. 오늘 일봉이 양봉일것 2. 분봉상(3분봉에 적용 할 생각입니다.) 20이평선이 상승 일때 매수. 매도 조건: 분봉상 20이평 하락 진입횟수 3회 제한 input : P(20),진입횟수(3); var : mav(0),entry(0); if Bdate != Bdate[1] Then entry = 0; if (MarketPosition != 0 and MarketPosition != MarketPosition[1]) or (MarketPosition == MarketPosition[1] and TotalTrades > TotalTrades[1]) Then entry = entry+1; mav = ma(C,P); if MarketPosition == 0 and entry < 진입횟수 and #당일진입은 3회까지 C > DayOpen and #일봉양봉 mav > mav[1] Then #이평상승 Buy("b"); if MarketPosition == 1 and mav < mav[1] Then#이평하락 ExitLong("bx"); 위 수식 중 매수 조건에 1가지 조건을 추가 하고 싶습니다. 매수 조건: 1. 오늘 일봉이 양봉일것 2. 분봉상(3분봉에 적용 할 생각입니다.) 20이평선이 상승 일것. 3. 현재 거래량이 직전 20봉 거래량 평균보다 30%이상 많으면 매수. 매도 조건: 분봉상 20이평 하락 진입횟수 3회 제한 위 매수조건 3번 추가 가능할까요? 잘 부탁드립니다. 감사합니다.
프로필 이미지
대한이
2021-12-09
931
글번호 154335
시스템
답변완료

지표 질문입니다

1. 전일과 분리된 종가 파라볼릭 차트에서 파라볼릭이 바뀌면 직전 극점(A)와 현재 극점(B),금일 고가(C),금일 저가(D) 대칭 값을 아래와 같이 구한다 B*2-A A*2-B A*2-C A*2-D B*2-C B*2-D 2. 전일과 연결된 종가 파라볼릭 차트에서 파라볼릭이 바뀌면 직전 극점(A)와 현재 극점(B),금일 고가(C),금일 저가(D) 대칭 값을 아래와 같이 구한다 B*2-A A*2-B A*2-C A*2-D B*2-C B*2-D 감사합니다
프로필 이미지
회원
2021-12-09
793
글번호 154334
지표
답변완료

문의드립니다.

늘 감사합니다.^^ 현재가라인 기능이 있다고 들었는데, 찾지를 못하겠습니다. 그리고 ("C:₩예스트레이더₩data₩Sound₩MESU.wav"); 지표에 사운드 표시를 해 놓았는데, 소리음을 각각 다르게 할 수는 없나요? 알려주세요.
프로필 이미지
오쇼
2021-12-09
977
글번호 154332
지표