커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

문의드립니다.

안녕하세요. 아래의 식은 국내선물 3계약을 매수하여 분할 청산하는 수식입니다. "매수익절1" 과 "매수익절2"는 청산 가격과 수량을 명시하고 있고, "매수최종청산"는 5이평선과 20이평선이 데드크로스하는 시점에 "보유하고 있는 모든 수량"을 청산하는 것을 목적으로 하고 있습니다. 오류 없이 제대로 작성된 수식인지 검증 부탁그리겠습니다. 감사합니다. -------------------------------------------------------------------------------------- var1 = ma(C,5); var2 = ma(C,20); if 조건 then { Buy("매수",onclose,def,3); SetStopLoss(0.55,PointStop); } if MarketPosition == 1 Then{ if IsEntryName("매수") == true Then ExitLong("매수익절1",Atlimit,Dayopen()+1.0,"갭상0.7선_매수",1,1); ExitLong("매수익절2",Atlimit,Dayopen()+1.5,"갭상0.7선_매수",1,1); If CrossDown(var1,var2) Then ExitLong("매수최종청산") }
프로필 이미지
맘속의행복
2017-09-18
116
글번호 112864
시스템
답변완료

문의드립니다.

주가가 90일 이동평균선 위에 있을 경우 Chaikin Oscillator가 -에서 +로 전환하는 경우 매수 주가가 90일 이동평균선 아래에 있을 때 Chaikin Oscillator가 +에서 -로 전환하는 경우 매도 수식작성 부탁드립니다.
프로필 이미지
바샤샤
2017-09-18
104
글번호 112863
시스템
답변완료

기존 프로그램 수정과 그외 질문

질문1. 2개의 차트(data1과 data2)의 5이평선 간의 상관계수를 구하는 프로그램을 구합니다. 즉, 현재 봉 포함 과거 30봉까지의 두 5이평선 간의 상관관계 값(&#66585;)을 구하고자 합니다. 두 변량 x, y 는 동일 시간대 봉에 대하여 5이평선 주가입니다. 즉, x는 data1 이평선의 주가, y는 data2 이평선의 주가입니다. 상관관계 값(&#66585;)을 구하는 공식은 파일로 첨부합니다. 질문2. 아래는 지그재그 선을 그리며 고점 꼭지점(상승을 지속하고 고가 형성 후 하락하는 시점) 주가와 저점 꼭지점(하락을 지속하다가 주가를 형성 후 상승으로 전환하는 시점)을 차트 상에 찍어 주는 프로그램입니다. 이 프로그램을 수정하여 각 꼭지점을 프린트문(print)으로 엑셀파일에 C드라이브의 K폴드에 다음과 같이 저장하는 프로그램을 구합니다. ---------------------------------------------------- 데이터발생일시 주가 형태 ---------------------------------------------------- 2017. 09. 19. 12:0000 308.112 고점 꼭지점 2017. 09. 19. 12:0200 307.012 저점 꼭지점 : : #==========================================# # 지 표 명 : 고저라인 지그재그 파동선 # 버 전 : 1.2 # 작 성 자 : 수식지왕 # 블 로 그 : http://yahoosir.blog.me # 업데이트 : 2017-03-10 #==========================================# Input:length(10),종가사용여부(0),파동선두께(2),수치표시(1); Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(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,1] = LL; } Condition1 = Highest(HH,length) == HH and 최종고가 <> HH; Condition2 = Lowest (LL,length) == LL and 최종저가 <> LL; 처리구분 = ""; 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 { 최종고가 = HH; // 신규고점을 체크하기 위해 저장 If 최종꼭지점 == "저점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = HH; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; 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,RED); } Else If 고[1,1] < HH Then // 1번 고점보다 높은 고가 출현 { 고[1,1] = HH; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; 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 { 최종저가 = LL; If 최종꼭지점 == "고점" then { For j = 10 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = LL; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; 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,BLUE); } Else If 저[1,1] > LL then { 저[1,1] = LL; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; 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)); } } 최종꼭지점 = "저점"; } 감사합니다.
프로필 이미지
구천룡
2017-09-18
262
글번호 112859
지표
답변완료

부탁드립니다

수고하십니다 1.9시 시가4번째양봉고가. 9시 시가4번째음봉저가표시 2.고점에서4번째음봉 종가,저가표시
프로필 이미지
파생돌이
2017-09-18
121
글번호 112857
지표
답변완료

문의드립니다.

수식지왕님의 피보나치 되돌림 지표입니다. 상승파동 하락파동에 따른 피보나치 되돌림 비율을 선으로 나타낸 지표인데요 이걸 시스템으로 만들고 싶습니다. 예들들어 상승파동끝나고 조정나올때(되돌림) 61.8%선에서 매수하고 100%선을 이탈하면 매도스위칭입니다. 하락파동이 끝나고 상승나올때 되돌림 61.8%선에서 매도하고 100%선을 돌파하면 매수스위칭입니다. kbjmhlove@naver.com 이메일로 답변부탁드립니다. 감사합니다. #==========================================# # 지 표 명 : 피보나치되돌림 # 작 성 자 : 수식지왕 # 블 로 그 : http://yahoosir.blog.me #==========================================# Input:length(30),파동선두께(0.5),수치표시(1); Var:j(0),jj(0),최종고가(0),최종저가(0),최종변곡점(""),처리구분(""), TL1(0); Array:고[5,4](0),저[5,4](0); // 1:가격, 2:Index, 3:sDate, 4:sTime #==========================================# If Index == 0 Then { 고[1,1] = H; 저[1,1] = L; } Condition1 = Highest(H,length) == H and 최종고가 <> H; Condition2 = Lowest (L,length) == L and 최종저가 <> L; 처리구분 = ""; If Condition1 and Condition2 Then // 기간고점과 기간저점 동시 발생 { If 최종변곡점 == "저점" Then 처리구분 = "고점처리"; // 저 - 고 순으로 처리 Else 처리구분 = "저점처리"; // 고 - 저 순으로 처리 } Else If Condition1 Then 처리구분 = "고점처리"; Else If Condition2 Then 처리구분 = "저점처리"; #==========================================# If 처리구분 == "고점처리" Then { 최종고가 = H; // 신규고점을 체크하기 위해 저장 If 최종변곡점 == "저점" Then { For j = 5 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = H; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); /// 상승파동 TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,MAGENTA); } Else If 고[1,1] < H Then // 1번 고점보다 높은 고가 출현 { 고[1,1] = H; 고[1,2] = Index; 고[1,3] = sDate; 고[1,4] = sTime; TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]); } 최종변곡점 = "고점"; } #==========================================# If 처리구분 == "저점처리" Then { 최종저가 = L; If 최종변곡점 == "고점" then { For j = 5 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = L; 저[1,2] = Index; 저[1,3] = sDate; 저[1,4] = sTime; TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); /// 하락파동 TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,CYAN); } Else If 저[1,1] > L then { 저[1,1] = L; 저[1,3] = sDate; 저[1,4] = sTime; 저[1,2] = Index; TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]); } 최종변곡점 = "저점"; } #==========================================# Array: fr[7,4](0); // 1:비율, 2:값, 3:라인번호, 4:텍스트번호 If Index == 0 Then { fr[1,1] = 0; fr[2,1] = 0.326; fr[3,1] = 0.500; fr[4,1] = 0.618; fr[5,1] = 1.000; fr[6,1] = 1.500; fr[7,1] = 2.000; } If 최종변곡점[1] == "고점" and 최종변곡점 == "저점" Then // 상승파동 추세가 바뀔 때 피보나치 라인을 계산 { for j = 1 to 7 { //If fr[j,3] > 0 Then TL_Delete(fr[j,3]); // 하락파동에 대한 상승 기존 피보나치 라인은 지우고 fr[j,2] = 고[1,1] - ((고[1,1] - 저[2,1]) * fr[j,1]); // 하락 목표 피보나치 비율을 곱해서 계산 fr[j,3] = TL_New(저[2,3],저[2,4],fr[j,2],sDate,sTime,fr[j,2]); // 상승파에 대한 하락목표 라인을 생성 TL_SetColor(fr[j,3],LMAGENTA); // 하락 피보나치 목표 라인 색표현 If 수치표시 == 1 Then { If fr[j,4] > 0 Then Text_Delete(fr[j,4]); // 기존의 텍스트는 지우고 젤 뒤에것만 둔다 fr[j,4] = Text_New(저[2,3],저[2,4],fr[j,2]," (" + NumToStr(fr[j,1]*100,1) + "%) " + NumToStr(fr[j,2],2)); /// 피보나치 텍스트 생성 Text_SetStyle(fr[j,4], 1, 2); // 왼쪽,중앙 Text_SetColor(fr[j,4],LMAGENTA); /// 수치값 색표현 } } } Else If 최종변곡점[1] == "저점" and 최종변곡점 == "고점" Then // 하락파동 추세가 바뀔 때 피보나치 라인 계산 { for j = 1 to 7 { // If fr[j,3] > 0 Then TL_Delete(fr[j,3]); // 상승파동에 대한 하락 기존 피보나치 라인은 지우고 fr[j,2] = 저[1,1] + ((고[2,1] - 저[1,1]) * fr[j,1]); // 상승목표 피보나치 비율을 곱해서 계산 fr[j,3] = TL_New(고[2,3],고[2,4],fr[j,2],sDate,sTime,fr[j,2]); // 상승목표 라인을 생성 TL_SetColor(fr[j,3],CYAN); // 피보나치 라인 색표현 If 수치표시 == 1 Then { If fr[j,4] > 0 Then Text_Delete(fr[j,4]); // 기존의 텍스트는 지우고 젤 뒤에것만둔다. fr[j,4] = Text_New(고[2,3],고[2,4],fr[j,2]," (" + NumToStr(fr[j,1]*100,1) + "%) " + NumToStr(fr[j,2],2)); // 피보나치 비율을 곱해서 계산 Text_SetStyle(fr[j,4], 1, 2); Text_SetColor(fr[j,4],CYAN); } } } //Else //{ // for j = 1 to 7 // { // TL_SetEnd(fr[j,3],sDate,sTime,fr[j,2]); // } //}
프로필 이미지
불바다
2017-09-18
198
글번호 112856
시스템
답변완료

순위정하는 수식이 형식이 맞나좀 봐주십시요

For tempi11 = 1 to 25 { tempmax11 = -999; tempmax12 = -999; For tempi1 = 1 to 25 { if ( tempmax11 < ivf[tempi1] ) then { tempmax11 = ivf[tempi1]; tempmax12 = ivfm[tempi1]; tempIndex1 = tempi1; } } NTHVALUE1[tempi11] = tempmax12/tempmax11; ivf[tempIndex1] = -999; }
프로필 이미지
이지화
2017-09-18
129
글번호 112855
지표

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

프로필 이미지
carlos
2017-09-18
10
글번호 112854
시스템
답변완료

수식변경

> 안녕하세요. 아래의 지표를 선이 아닌 수평선으로 표시하고 싶습니다. var1 = ma(C,20); var2 = ma(H,20); var3 = ma(L,20); plot1(var1); plot2(var2); plot3(var3);
프로필 이미지
알리섬
2017-09-18
117
글번호 112853
지표
답변완료

메타의 수식을 예스차트로 옮길수 있나요?

메타의 mq4파일을 예스차트의 수식으로 옮기고 싶은데 가능할까요?
프로필 이미지
만두기
2017-09-18
112
글번호 112851
검색