커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

문의합니다.

안녕하세요 금일시가에서 +200틱 이상 도달시 1계약 매도 진입 후 금일종가에서 +250틱 이상 도달시 추가로 1계약 진입 후 금일종가에서 +300틱 이상 도달시 추가로 1계약 진입 후 마지막으로 +400틱 이상도달시 마지막으로 진입 ( 총 4회 진입 ) 이 되는 진입 수식 부탁합니다.
프로필 이미지
뚜벅뚜벅
2019-02-28
217
글번호 126647
시스템
답변완료

수식 작성 부탁드려요~

조금씩 배우면서 실력이 늘어가네요 감사합니다~ 700일 지수이평선을 지지 받을때는..... 50일 지수이평선이 100일선 지수이평선을 상향 돌파시에만 매집 진입하고 100일선 지수이평선 하향이탈시 매집수량 청산 700일 지수이평선을 저항 받을때는..... 50일 지수이평선이 100일선 지수이평선을 하향 돌파시에만 매집 진입하고 100일선 지수이평선 상향이탈시 매집수량 청산입니다 손절은 30틱 매집수량 수익발생시 50틱 강제청산 * 봉 완성전이라도 50선이 100일선 돌파하여 조건 만족시 즉시 실행 주문 체결되도록 부탁드려요! 즐거운 연휴되세요^^
프로필 이미지
이태리
2019-02-28
244
글번호 126641
시스템
답변완료

질문 드려요

안녕하세요 아래는 수식지왕님의 식을 이용 조건추가하려구합니다 조건은 일간차트 하기로하고요 이것식은 매수도 시장가 매도도 시장가 진입되는데요 매수진입가 대비 1.5피 하락하면 추가 1계약진입 매도진입가 대비 1.5피 상승하면 추가 1계약 진입 하도록 부탁드립니다 감사합니다 건강하십시요 input:renkoSize(5), length(0.01), NumATRs(0.01); var:j(0),k(0),renkoCnt(0),gubun(0),Sum(0),trSum(0),atrV(0),time1(0), filename("renko3.txt"),printOK(False),ma3 (0); array:OO[50](0),HH[50](0),LL[50](0),CC[50](0), TR[50](0), //True Range upperLine[50](0), //상단채널 lowerLine[50](0), //하단채널 maV[50](0); //이평선 If DayIndex == 0 Then { //break on session에 해당, 즉 일자가 바뀌면 새로 계산 gubun = 0; //방향을 초기화한다. 이후 형성되는 가격에 의해 방향이 계산 For j = 49 DownTo 1 { //금일 시가봉을 신규 추가 OO[j] = OO[j-1]; HH[j] = HH[j-1]; LL[j] = LL[j-1]; CC[j] = CC[j-1]; TR[j] = TR[j-1]; maV[j] = maV[j-1]; upperLine[j] = upperLine[j-1]; lowerLine[j] = lowerLine[j-1]; } OO[0] = C; //분봉의 종가를 기반으로 계산하기 때문에 당일 시초가 아니다 HH[0] = C; LL[0] = C; CC[0] = C; } Else { If gubun == 0 and CC[0] > 0 Then { //일 첫봉이 완성되지 않은 시점 If OO[0] - renkoSize >= C Then { gubun = -1; //하락 방향 CC[0] = OO[0] - renkoSize; //음봉 HH[0] = OO[0]; LL[0] = CC[0]; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); //true range 계산식 참조 //macd 계산 당시와 마찬가지로 sum 값이 있을 때만 처리 If sum > 0 Then { sum = sum + CC[0] - CC[length]; //이평선 계산 원리 그대로, 현재가를 더하고 n봉전 가격 뺌 trSum = trSum + TR[0] - TR[length]; //true range의 합을 계산 maV[0] = Sum / length; //n개의 종가 합을 n으로 나누어 이동평균 계산 atrV = trSum / length; //ATR 계산식 참조 upperLine[0] = maV[0] + atrV * NumATRs; //상단 밴드 계산 lowerLine[0] = maV[0] - atrV * NumATRs; //하단 밴드 계산 } j = 0; if printOK then print(filename, "1=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f", j,gubun,OO[j],HH[j],LL[j],CC[j]); } Else If OO[0] + renkoSize <= C Then { gubun = 1; //상승 방향 CC[0] = OO[0] + renkoSize; //양봉 HH[0] = CC[0]; LL[0] = OO[0]; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); If sum > 0 Then { //계속 반복되는 공통 루틴이므로 if문 바깥으로 뺄까도 했으나 sum = sum + CC[0] - CC[length]; //더 복잡해지므로 copy & paste로 처리 trSum = trSum + TR[0] - TR[length]; maV[0] = Sum / length; atrV = trSum / length; upperLine[0] = maV[0] + atrV * NumATRs; lowerLine[0] = maV[0] - atrV * NumATRs; } j = 0; if printOK then print(filename, "2=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f", j,gubun,OO[j],HH[j],LL[j],CC[j]); } } If LL[0] - renkoSize >= C Then { gubun = -1; renkoCnt = Int(Round((LL[0]-C)/renkoSize,9)); if renkoCnt > 49 then renkoCnt = 49; For j = 49 DownTo renkoCnt { OO[j] = OO[j-renkoCnt]; HH[j] = HH[j-renkoCnt]; LL[j] = LL[j-renkoCnt]; CC[j] = CC[j-renkoCnt]; TR[j] = TR[j-renkoCnt]; maV[j] = maV[j-renkoCnt]; upperLine[j] = upperLine[j-renkoCnt]; lowerLine[j] = lowerLine[j-renkoCnt]; } For j = renkoCnt-1 DownTo 0 { OO[j] = LL[j+1]; CC[j] = LL[j+1] - renkoSize; HH[j] = OO[j]; LL[j] = CC[j]; TR[j] = max(CC[j+1],HH[j]) - min(CC[j+1],LL[j]); If sum > 0 Then { sum = sum + CC[j] - CC[j+length]; trSum = trSum + TR[j] - TR[j+length]; maV[j] = Sum / length; atrV = trSum / length; upperLine[j] = maV[j] + atrV * NumATRs; lowerLine[j] = maV[j] - atrV * NumATRs; } if printOK then print(filename, "3=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f",j,gubun,OO[j],HH[j],LL[j],CC[j]); } } Else If HH[0] + renkoSize <= C Then { gubun = 1; renkoCnt = Int(Round((C-HH[0])/renkoSize,9)); if renkoCnt > 49 then renkoCnt = 49; For j = 49 DownTo renkoCnt { OO[j] = OO[j-renkoCnt]; HH[j] = HH[j-renkoCnt]; LL[j] = LL[j-renkoCnt]; CC[j] = CC[j-renkoCnt]; TR[j] = TR[j-renkoCnt]; maV[j] = maV[j-renkoCnt]; upperLine[j] = upperLine[j-renkoCnt]; lowerLine[j] = lowerLine[j-renkoCnt]; } For j = renkoCnt-1 DownTo 0 { OO[j] = HH[j+1]; CC[j] = HH[j+1] + renkoSize; HH[j] = CC[j]; LL[j] = OO[j]; TR[j] = max(CC[j+1],HH[j]) - min(CC[j+1],LL[j]); If sum > 0 Then { sum = sum + CC[j] - CC[j+length]; trSum = trSum + TR[j] - TR[j+length]; maV[j] = Sum / length; atrV = trSum / length; upperLine[j] = maV[j] + atrV * NumATRs; lowerLine[j] = maV[j] - atrV * NumATRs; } if printOK then print(filename, "4=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f", j,gubun,OO[j],HH[j],LL[j],CC[j]); } } Else If Time >= 151500 Then { //당일 종가봉에서 For j = 49 DownTo 1 { OO[j] = OO[j-1]; HH[j] = HH[j-1]; LL[j] = LL[j-1]; CC[j] = CC[j-1]; TR[j] = TR[j-1]; maV[j] = maV[j-1]; upperLine[j] = upperLine[j-1]; lowerLine[j] = lowerLine[j-1]; } If LL[1] > C Then { //종가가 이전 봉보다 아래 형성 OO[0] = LL[1]; CC[0] = C; HH[0] = OO[0]; LL[0] = CC[0]; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); } Else If HH[1] < C Then { //종가가 이전 봉보다 위에 형성 OO[0] = HH[1]; CC[0] = C; HH[0] = CC[0]; LL[0] = OO[0]; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); } Else { //종가가 이전 봉의 중간에 형성 OO[0] = C; CC[0] = C; HH[0] = C; LL[0] = C; TR[0] = max(CC[1],HH[0]) - min(CC[1],LL[0]); } If sum > 0 Then { sum = sum + CC[0] - CC[length]; trSum = trSum + TR[0] - TR[length]; maV[0] = Sum / length; atrV = trSum / length; upperLine[0] = maV[0] + atrV * NumATRs; lowerLine[0] = maV[0] - atrV * NumATRs; } j = 0; //채널 값을 새로이 계산 if printOK then print(filename, "5=>,%.0f,%.0f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f,%.2f", j,gubun,OO[j],HH[j],LL[j],CC[j]); } } if sum == 0 and CC[length] > 0 then { for j = 0 to length - 1 { sum = sum + CC[j]; trsum = trsum + max(CC[j+1],HH[j]) - min(CC[j+1],LL[j]); } } ma3 = ma(C,91); if ma3 < OO[0] and ma3 < CC[1] Then buy("b",atmarket); if ma3 > OO[0] and ma3 > CC[1] Then sell("s",atmarket); //========================================================= 끝
프로필 이미지
회원
2019-02-28
249
글번호 126640
시스템
답변완료

문의

안녕하세요 선물차트상의 전고 전저에 호가잔량을표시나타나게 할수있읍니까
프로필 이미지
질갱이
2019-02-28
254
글번호 126634
지표
답변완료

수식 문의

아래 수식은 up,downvol 을 거래량지표에 적용하여 색깔로 구분해본 지표입니다. 이 지표에 나오는 데이타의 n봉간 누적분을 아래와 같이 표현하고 싶습니다. 질문 1 :: n봉 기간의 downvol - Upvol값을 누적하여 지표로 표현하고 싶습니다. 질문2 :: n봉 기간의 (누적 downvol - Upvol )값이 양수이면 거래량 지표에 **색을, 음수이면 @@색을 적용하고 싶습니다. 질문 3 :: n봉 기간의 (누적 downvol - Upvol )값이 양수이면 캔들에 **색을, 음수이면 @@색을 적용하고 싶습니다. 인터페이스는 불친절하지만 게시판 답변이 친절하여 덕분에 예트를 더욱 사랑하게 되었습니다. ㅋㅋ 앞으로도 잘 부탁드립니다. ㅎ If (Upvol > downvol) or (Upvol == downvol and Upvol >= Upvol[1]) Then { Plot1(V, "상승"); Plot2(0, "하락"); } Else { Plot1(0, "상승"); Plot2(V, "하락"); }
프로필 이미지
부똘이
2019-02-28
258
글번호 126631
지표
답변완료

수정수식6

60971변 전일종가 추가부탁드립니다
프로필 이미지
용각산
2019-02-28
254
글번호 126629
지표
답변완료

볼밴 수식 부탁드립니다.

1) 2분봉.. (20,2) 기본 볼밴에 5분봉 (20.2) , 30분봉 (20,2) 볼밴도 함께 표현 될수 있는 수식을 부탁드립니다.. 2) 위 수식 중에 분봉과 (20,2)값을 수정(변수) 가능하도록 부탁드립니다.
프로필 이미지
레드골드
2019-02-28
245
글번호 126628
지표
답변완료

수식 부탁 드립니다.

안녕하세요. 아래 수식 작성이 가능하신지요? 부탁드립니다. 오후 9시 이후에만 진입. 캘트너 채널 상향 돌파후 다음봉이 양봉일때 매수 캘트너 채널 하향 돌파후 다음봉이 음봉일때 매도 청산은 샹들리에 청산 적용. 감사합니다.
프로필 이미지
ctosec
2019-02-27
236
글번호 126627
시스템
답변완료

질문드립니다.

이틀전 종가보다 어제종가가 10%이상 상승한 종목 검색식 부탁드립니다.
프로필 이미지
stockric
2019-02-27
282
글번호 126626
종목검색