커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

문의드립니다

Input : N(20); var : Energe1(0),Energe2(0); Energe1 = accumN(H-O,N)/accumN(O-L,N)*100; Energe2 = accumN(H-C,N)/accumN(C-L,N)*100; plot1(accumN(H-O,N)/accumN(O-L,N)*100, "Energy1"); plot2(accumN(H-C,N)/accumN(C-L,N)*100, "Energy2"); Energy1 82이하일 때 매수 Energy1 128이상일 때 매도
프로필 이미지
july
2017-07-10
88
글번호 111157
시스템
답변완료

문의드립니다

해선차트에서 Pivot을 1.분봉차트에서, 당일기간동안만 텍스트표시와 함께 Y축까지 우측연장하여 표시하는식 2.일봉차트에, 텍스트표시와 함께 수평선으로 차트의 좌에서 Y축까지 우측연장하여 표시하는식 부탁드립니다.
프로필 이미지
뉴스타트
2017-07-10
103
글번호 111156
지표
답변완료

질문드립니다

해외선물 시가선 돌파시 시가에서 진입하려고 합니다. var : do(0); do=DayOpen(); if c > do and crossup(c,do) Then buy("매수",AtLimit,DayOpen); if c < do && crossdown(c,do) Then sell("매도",AtLimit,dayopen); SetStopEndofday(040000); 제가 생각했던것은 종가가 시가 돌파시 시가선에서 매수하는것인데 저대로 적용을 하니 시가선을 돌파해도 진입을 안하는경우가 많더라구요 수정좀 부탁드립니다. 추가로 +35틱 기준으로 청산식도 만들어주세요 감사합니다
프로필 이미지
하늘이여o
2017-07-09
91
글번호 111155
시스템
답변완료

부탁드립니다

수고하십니다 아래수식으로적용핸는데,수평선오른쪽끝에(2)라는숫자가안뜨내요 아떻게해야하나요? var : L2(0,data2),H2(0,data2); var : L3(0,data3),H3(0,data3); var : diff2(0,data2),diff3(0,data2); var : V1(0,data2),V2(0,data2); #data2-data3 L2 = data2(LowD(0)); H2 = data2(highD(0)); L3 = data3(LowD(0)); H3 = data3(highD(0)); diff2 = Abs(L2-H3); diff3 = Abs(H2-L3); if diff2 <= 0.15 and diff2[1] > 0.15 Then V1 = h; if diff2 <= 0.15 and diff2[1] > 0.15 Then V2 = l; if diff3 <= 0.15 and diff3[1]> 0.15 Then V1 = h; if diff3 <= 0.15 and diff3[1]> 0.15 Then V2 = l; if stime >= 90000 and stime <= 152500 Then{ plot1(V1); plot2(V2); } var : tx1(0),tx2(0); Text_Delete(Tx1);Text_Delete(Tx2); tx1 = Text_New(sdate,stime,v1,"2"); tx2 = Text_New(sdate,stime,v2,"2"); Text_SetStyle(tx1,5,1);Text_SetStyle(tx2,5,1);
프로필 이미지
파생돌이
2017-07-09
106
글번호 111153
지표
답변완료

문의

K=Rsi(P9); LL=VALUEWHEN(1,K>=HP,L); HH=VALUEWHEN(1,K>=HP,H); IF(K>=HP,HH+MA(H-L,20),LL) 지표조건에서 HP는 70 P9는 9 키움으로 표현된 지표입니다 이것을 30분봉에 나타나는것을 3분봉에 표현되게 부탁드립니다
프로필 이미지
레전드
2017-07-09
136
글번호 111150
지표
답변완료

수식 부탁드립니다

1. 최근 1시간 동안 20 캔들 최고가의 최대값이 최근 2시간 동안 20 캔들 최고가의 최대값보다 낮을 경우 최근 1시간 동안 20 캔들 최저가의 최소값를 붕괴시킬 때 매도 최근 1시간 동안 20 캔들 최저가의 최소값이 최근 2시간 동안 20 캔들 최저가의 최소값보다 높을 경우 최근 1시간 동안 20 캔들 최고가의 최대값를 돌파시킬 때 매수 2. 최근 100 캔들 동안 20 캔들 최고가의 최대값이 최근 200 캔들 동안 20 캔들 최고가의 최대값보다 낮을 경우 최근 100 캔들 동안 20 캔들 최저가의 최소값를 붕괴시킬 때 매도 최근 100 캔들 동안 20 캔들 최저가의 최소값이 최근 200 캔들 동안 20 캔들 최저가의 최소값보다 높을 경우 최근 100 캔들 동안 20 캔들 최고가의 최대값를 돌파시킬 때 매수 감사합니다
프로필 이미지
회원
2017-07-09
122
글번호 111149
시스템
답변완료

지표식 부탁드립니다.

아래의 1번 지표식의 LRLv 선을 2번지표식의 var1 의 꺾은선으로 변경한 병합 된 지표식을 부탁 드립니다. < 1번 지표식 > Input : LRLP(10); input : A(3),MU(2); var : LRLv(0),UPv(0),dnv(0),Ov(0); LRLv = LRL(C,LRLP); Ov = DayClose(1); if Bdate!=Bdate[1] Then { upv = Ov+atr(A)*MU; dnv = Ov-atr(A)*MU; } if Bdate == Bdate[1] Then { if CrossUp(LRLv,upv) Then { upv = upv[1]+atr(A)*MU; dnv = upv[1]; } if CrossDown(LRLv,dnv) Then { upv = dnv[1]; dnv = dnv[1]-atr(A)*MU; } } plot1(LRLv); plot2(upv); plot3(dnv); #==================================================================# #==================================================================# < 2번 지표식 > Input:전환가격(1),종가사용여부(1),파동선두께(1),수치표시(1); Var:j(0),jj(0),HH(0),LL(0),hiBar(0),loBar(0),최종꼭지점(""),처리구분(""), TL1(0),Text1(0); Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime #==========================================# HH = IFF(종가사용여부 == 1,C,H); LL = IFF(종가사용여부 == 1,C,L); If Index == 0 Then { 고[1,1] = HH; 고[1,2] = 0; 고[1,3] = sDate; 고[1,4] = sTime; 저[1,1] = LL; 저[1,2] = 0; 저[1,3] = sDate; 저[1,4] = sTime; } If Index > 0 Then // Index가 0일때는 이전 봉이 없으므로 Index가 1일때부터 1씩 증가 { hiBar = hiBar + 1; // 최고점을 찍은 고[저]가의 위치를 저장 해놓기 위해 봉번호를 카운트한다. loBar = loBar + 1; } If HH[hiBar] < HH Then hiBar = 0; // 현재 봉이 최고가이면 봉번호를 0으로 초기화 If LL[loBar] > LL Then loBar = 0; Condition1 = 저[1,1] + 전환가격 < HH and hiBar == 0; // 전저점에서 전환가격만큼 더한 값보다 고가가 크다면 추세가 변한 것으로 보고 신규 고점으로 인식 Condition2 = 고[1,1] - 전환가격 > LL and loBar == 0; // 전고점에서 전환가격만큼 뺀 값보다 저가가 작다면 추세가 변한 것으로 보고 신규 저점으로 인식 처리구분 = ""; If Condition1 and Condition2 Then // 고점과 저점 조건 동시 만족 { If 최종꼭지점 == "저점" Then { If 저[1,1] > LL Then 처리구분 = "저점처리"; Else 처리구분 = "고점처리"; } Else If 최종꼭지점 == "고점" Then { If 고[1,1] < HH Then 처리구분 = "고점처리"; Else 처리구분 = "저점처리"; } } Else If Condition1 Then 처리구분 = "고점처리"; Else If Condition2 Then 처리구분 = "저점처리"; If 처리구분 == "고점처리" Then { If 최종꼭지점 == "저점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = HH[hiBar]; 고[1,2] = Index - hiBar; 고[1,3] = sDate[hiBar]; 고[1,4] = sTime[hiBar]; hiBar = -1; // 다음 봉의 고가가 기준 고가로 인식되려면 hiBar 값이 0이 되어야 한다. // 봉이 바뀔 때마다 hiBar의 값을 1씩 증가시키므로 다음 봉의 hiBar 값은 0이 된다. loBar = -1; TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); If 수치표시 == 1 Then { Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1],2)); Text_SetStyle(Text1, 2, 1); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,BLACK); } Else If 고[1,1] < HH[hiBar] Then // 1번 고점보다 높은 고가 출현 { 고[1,1] = HH[hiBar]; 고[1,2] = Index - hiBar; 고[1,3] = sDate[hiBar]; 고[1,4] = sTime[hiBar]; hiBar = -1; loBar = -1; TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]); // 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임 If 수치표시 == 1 Then { Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]); Text_SetString(Text1,NumToStr(고[1,1],2)); } } 최종꼭지점 = "고점"; } If 처리구분 == "저점처리" Then { If 최종꼭지점 == "고점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = LL[loBar]; 저[1,2] = Index - loBar; 저[1,3] = sDate[loBar]; 저[1,4] = sTime[loBar]; hiBar = -1; loBar = -1; TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); If 수치표시 == 1 Then { Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1],2)); Text_SetStyle(Text1, 2, 0); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,BLACK); } Else If 저[1,1] > LL[loBar] Then { 저[1,1] = LL[loBar]; 저[1,2] = Index - loBar; 저[1,3] = sDate[loBar]; 저[1,4] = sTime[loBar]; hiBar = -1; loBar = -1; TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]); If 수치표시 == 1 Then { Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]); Text_SetString(Text1,NumToStr(저[1,1],2)); } } 최종꼭지점 = "저점"; } var1 = iff(최종꼭지점 == "고점",1,iff(최종꼭지점 == "저점",-1,0)); if var1 = -1 Then{ PLOT1(저[2,1]); PLOT2(고[1,1]); } Else{ PLOT1(저[1,1]); PLOT2(고[2,1]); }
프로필 이미지
너무조아
2017-07-09
155
글번호 111148
지표
답변완료

문의드립니다

7919번 답글에있는 첨부파일1,2.3.4번이 손상된 파일로 다운로드가 안됩니다 방법이 없는지요? 부탁드립니다 추가로 월봉시가 고가 저가 종가 함수도 부탁드립니다
프로필 이미지
매화산삼
2017-07-09
146
글번호 111147
지표
답변완료

문의드립니다

이평선 상승하때 빨강색 하락하때 파랑색 잘 부닥드립니다
프로필 이미지
용각산
2017-07-09
106
글번호 111146
지표