커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

교차차트

옵션에서 data1 콜, data2 풋 이렇게 겹친후 data1 콜 시가 Line 빨간색 data2 풋 시가 Line 파란색 (콜 시가 + 풋 시가) / 2 Line 흰색 이렇게 자동 계산 되게 나오게 할 수 있나요?? data1 vs data2 만들어서 그 수식참고해서 data3 vs data4 쭉 만드려고 합니다
프로필 이미지
구조대
2019-07-02
319
글번호 129965
지표
답변완료

수식에 조금 변화를 주려고 합니다

안녕하세요. 지난번에는 아래와 같이 추세선 진입 시스템을 만들어 주셨는데요. 해외선물 미국채를 거래하다 보니 가격 입력하는 부분에서 32진수, 64진수를 변환하려니 상당히 귀찮네요. 그래서 생각한 것이 날짜, 시간 그리고 '가격을 입력하는 것이 아니라 고점(또는 저점)을 입력하는 방식'으로 추세선을 만들고 싶습니다. input: 시작일자(20181113), 시작시간(90000), 시작고저(a), 연결일자(20181113), 연결시간(120000), 연결고저(b); 위의 방식으로 시간까지 나왔으면 해당캔들은 지정되었으니 이제 고저점 선택만 입력하는 거죠. 어차피 고점이냐 저점이냐만 선택할 것이므로... a면 고점을 자동으로 잡아주고, b면 저점을 자동으로 잡아주면 좋겠습니다. ------아래 ------- 날짜,시간,가격을 지정해 추세선을 만들고 해당 추세선이 아이디를 변수에 저장한 이후에 TL_GetValue함수로 아이디 지정해 값을 가져와 사용하시면 됩니다. input: 시작일자(20181113), 시작시간(90000), 시작가격(266.55), 연결일자(20181113), 연결시간(120000), 연결가격(267.10); var : TL(0); if sdate == 연결일자 and stime == 연결시간 Then { TL = TL_New(시작일자,시작시간,시작가격,연결일자,연결시간,연결가격); TL_SetExtRight(TL,True); Condition1 = true; } if Condition1 == true then { if C >= TL_GetValue(TL,sdate,stime) and C[1] < TL_GetValue(TL,sdate[1],stime[1]) Then buy(); if C <= TL_GetValue(TL,sdate,stime) and C[1] > TL_GetValue(TL,sdate[1],stime[1]) Then sell(); } ----------------
프로필 이미지
마인드마스터
2019-07-02
284
글번호 129964
시스템
답변완료

수식확인 부탁드립니다

아래 시스템은 파동상승 T==1 조건만족시 최종저가 (TL15,blue)에서 5틱 상승시 매수 진입 최종고가에서 5틱 하락시 매수청산 수식으로 작성한것입니다. 시스템 실행시(챠트상 지표의 blue, red 참조) 최종저가에서 5틱 이상 하여 (8 틱 10 틱 상승후) 진입 하는경우 파동 하락(T== -1)시 매수진입 하는 경우가 발생 합니다. 원인과 수정 가능하다면 수식의 수정 부탁 드립니다. input:length(20); Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""), TL1(0),Text1(0),TL2(0),TL3(0),TL4(0),TL5(0),TL12(0),TL13(0),TL14(0),TL15(0),T(0); Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime #==========================================# HH = IFF(0==1,C,H); LL = IFF(0==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 { T = 1; 최종고가 = 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 == 1 Then { Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1],2)); Text_SetStyle(Text1, 0, 1); Text_SetColor(Text1,BLACK); } TL_SetSize(TL1,1); TL_SetColor(TL1,gray); } 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 == 1 Then { Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]); Text_SetString(Text1,NumToStr(고[1,1],2)); } } 최종꼭지점 = "고점"; } #==========================================# If 처리구분 == "저점처리" Then { T = -1; 최종저가 = 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 == 1 Then { Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1],2)); Text_SetStyle(Text1, 0, 0); Text_SetColor(Text1,BLACK); } TL_SetSize(TL1,1); TL_SetColor(TL1,gray); } 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 == 1 Then { Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]); Text_SetString(Text1,NumToStr(저[1,1],2)); } } 최종꼭지점 = "저점"; } if T == -1 and T[1] != -1 Then{ TL2 = TL_New(고[2,3],고[2,4],고[2,1],sdate,stime,고[2,1]); TL_Delete(TL3); TL3 = TL_New(고[1,3],고[1,4],고[1,1],sdate,stime,고[1,1]); TL_SetExtRight(TL3,true); TL_SetSize(TL2,3); TL_SetColor(TL2,RED); TL_SetSize(TL3,3); TL_SetColor(TL3,RED); TL12 = TL_New(고[2,3],고[2,4],고[2,1],sdate,stime,고[2,1]); TL_Delete(TL13); TL13 = TL_New(고[1,3],고[1,4],고[1,1],sdate,stime,고[1,1]); TL_SetExtRight(TL13,true); TL_SetSize(TL12,1); TL_SetColor(TL12,RED); TL_SetSize(TL13,1); TL_SetColor(TL13,RED); } if T == 1 and T[1] != 1 Then{ TL4= TL_New(저[2,3],저[2,4],저[2,1],sdate,stime,저[2,1]); TL_Delete(TL5); TL5= TL_New(저[1,3],저[1,4],저[1,1],sdate,stime,저[1,1]); TL_SetExtRight(TL5,true); TL_SetSize(TL4,3); TL_SetColor(TL4,blue); TL_SetSize(TL5,3); TL_SetColor(TL5,blue); TL14= TL_New(저[2,3],저[2,4],저[2,1],sdate,stime,저[2,1]); TL_Delete(TL15); TL15= TL_New(저[1,3],저[1,4],저[1,1],sdate,stime,저[1,1]); TL_SetExtRight(TL15,true); TL_SetSize(TL14,1); TL_SetColor(TL14,blue); TL_SetSize(TL15,1); TL_SetColor(TL15,blue); } if T == 1 Then buy("b",AtStop,저[1,1]+PriceScale*5); if T == -1 Then ExitLong("bx",AtStop,고[1,1]-PriceScale*5);
프로필 이미지
뎅이요
2019-07-02
259
글번호 129963
시스템
답변완료

사용자함수 사용방법문의

사용자 함수중 조건지정방법이 있는함수들 변수상세설명좀 부탁합니다. (사용자함수는 설명이나 사용예가 전혀 없어서..) 예로 CountIF(찾을조건,20) > 5; 조건만족 20봉종 5이상.. Mtfma,correlation...
프로필 이미지
다낚아
2019-07-02
295
글번호 129961
사용자 함수
답변완료

어떻게 해야 하나요???

●●●선생님 수고많으십니다. 초보라 상세하게 구체적으로 부탁드립니다. 1.선언되지 않은 이름 ‘ChgRateZigZag’이 사용되었습니다. 2.선언되지 않은 이름 ‘IndiDivergence’이 사용되었습니다. 3.선언되지 않은 이름 ‘paintBar’이 사용되었습니다. 4.PlotPaintBar’는 ‘paintBar’에서만 쓸 수 있습니다. 오류가 떠는데 어떻게 해결할 수 있는지 부탁드립니다. ●●●그리고 소리지정시 띵띵 소리를 매수 혹은 매도 소리로 바꿀려면 어떻게 해야하는지도 상세하게 구체적으로 부탁드립니다. 정말 감사합니다.
프로필 이미지
무자대기
2019-07-02
368
글번호 129955
사용자 함수
답변완료

수식 문의드립니다.

안녕하세요. 수식문의 드립니다. 아래 조건으로 차트에 선으로 표현이 가능하도록 부탁드립니다. * 1개월 전의 시가, 고가, 저가, 중심가 * 당월의 시가, 고가, 저가, 중심가 * 4주전의 시가 ,고가, 저가, 중심가 * 3주전의 시가, 고가, 저가, 중심가 * 2주전의 시가, 고가, 저가, 중심가 * 1주전의 시가, 고가, 저가, 중심가 * 이번 주의 시가 고가 저가 중심가 도움에 항상 감사드립니다.
프로필 이미지
태양같이
2019-07-02
278
글번호 129954
지표
답변완료

많이 걸려있는 호가를 표시하는 지표

매수 매도 호가(위아래10개)중에 제일 많이 걸려있는 호가를 표시해주는 수식이 있나요
프로필 이미지
팔보채
2019-07-02
280
글번호 129953
지표
답변완료

문의

1. 위 차트와 같이 조건식을 넣어서 선 두 개를 그리고 두 선 사이에 색깔을 넣을 경우 현재 해당 공간과 직전 해당 공간 사이에 색깔 연결 띠가 연결됩니다 이 연결띠를 제거시키는 수식이 있을까요? 예를들면 수식의 적용을 당일로 제한시켜서 당일 색깔공간과 전일 색깔 공간을 차단시키는 수식 수식의 적용을 시간 단위로 제한시켜서 색깔공간 연결을 시간 단위로 차단시키는 수식 수식의 적용을 30분 단위로 제한시켜서 색깔공간 연결을 시간 단위로 차단시키는 수식 2. 당일 고가와 당일 저가의 진폭이 1.0 을 넘을 경우 당일 고가 위에 당일 고가를 표시하고 그 위에 당일 고가와 당일 저가 진폭을 표시한다 당일 저가 아래 당일 저가를 표시하고 그 아래 당일 고가와 당일 저가 진폭을 표시한다
프로필 이미지
회원
2019-07-02
334
글번호 129952
지표
답변완료

문의드립니다

Input:length(5); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),TL2(0),TL3(0),Text1(0),처리구분(""), TL_Val1(0),TL_Val2(0); Var:TL11(0),TL12(0),TL13(0),TL14(0),TL15(0),TL16(0),TL17(0),TL18(0),TL19(0),TL20(0),tx(0); Var:TL21(0),TL22(0),TL23(0),TL24(0),TL25(0),TL26(0),TL27(0),TL28(0),TL29(0),TL30(0),mav(0),T(0); Array:고점[10,2](0),저점[10,2](0); 처리구분 = ""; If Highest(H,length) == H and lastHiVal <> H and Lowest(L,length) == L and lastLoVal <> L Then { If 저점[1,1] > L Then 처리구분 = "저점처리"; If 고점[1,1] < H Then 처리구분 = "고점처리"; } Else If Highest(H,length) == H and lastHiVal <> H Then 처리구분 = "고점처리"; Else If Lowest(L,length) == L and lastLoVal <> L Then 처리구분 = "저점처리"; If 처리구분 == "고점처리" Then { lastHiVal = H; If 고점[1,2] < 저점[1,2] Then { For j = 10 DownTo 2 { 고점[j,1] = 고점[j-1,1]; 고점[j,2] = 고점[j-1,2]; } } If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then { 고점[1,1] = H; 고점[1,2] = Index; sBar = Index - 저점[1,2]; eBar = 0; If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then { TL_Delete(TL1); TL_Delete(TL11); Text_Delete(Text1); If 고점[3,1][1] < 고점[2,1][1] and 고점[2,1][1] > 고점[1,1][1] and 저점[2,1][1] < 저점[1,1][1] Then TL_Delete(TL2); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); // TL11 = TL_New(sDate[index-고점[2,2]],sTime[index-고점[2,2]],c[index-고점[2,2]],sDate[1],sTime[1],c[index-고점[2,2]]); //Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(고점[1,1],2)); PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav"); TL_SetColor(TL1,BLACK); //TL_SetColor(TL11,BLACK); TL_SetSize(TL1,1); //TL_SetSize(TL11,1); If 고점[3,1] < 고점[2,1] and 고점[2,1] > 고점[1,1] and 저점[2,1] < 저점[1,1] Then { sBar = Index - 저점[2,2]; eBar = Index - 저점[1,2]; } } } If 처리구분 == "저점처리" Then { lastLoVal = L; If 저점[1,2] < 고점[1,2] Then { For j = 10 DownTo 2 { 저점[j,1] = 저점[j-1,1]; 저점[j,2] = 저점[j-1,2]; } } If 저점[1,2] < 고점[1,2] or 저점[1,1] > L Then { 저점[1,1] = L; 저점[1,2] = Index; sBar = Index - 고점[1,2]; eBar = 0; If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then { TL_Delete(TL1); TL_Delete(TL11); Text_Delete(Text1); If 저점[2,1][1] < 저점[1,1][1] and 저점[2,1][1] < 저점[3,1][1] and 고점[2,1][1] > 고점[1,1][1] Then TL_Delete(TL3); } TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); //TL11 = TL_New(sDate[index-저점[2,2]],sTime[index-저점[2,2]],c[index-저점[2,2]],sDate[1],sTime[1],c[index-저점[2,2]]); //Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],2)); PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav"); TL_SetColor(TL1,BLACK); //TL_SetColor(TL11,BLACK); TL_SetSize(TL1,1); //TL_SetSize(TL11,1); If 저점[2,1] < 저점[1,1] and 저점[2,1] < 저점[3,1] and 고점[2,1] > 고점[1,1] Then { sBar = Index - 고점[2,2]; eBar = Index - 고점[1,2]; } } } mav = ma(C,20); TL_Delete(TL13); TL_Delete(TL14); TL_Delete(TL15); if 고점[1,2] > 저점[1,2] then { TL14 = TL_New(sDate[index-고점[1,2]],sTime[index-고점[1,2]],H[index-고점[1,2]]-PriceScale*3,sDate,sTime,H[index-고점[1,2]]-PriceScale*3); TL_SetColor(TL13,GRAY); TL_SetSize(TL13,0); TL_SetExtRight(TL13,true); TL_SetColor(TL14,GREEN); TL_SetSize(TL14,3); TL_SetExtRight(TL14,true); TL_SetColor(TL15,GRAY); TL_SetSize(TL15,0); TL_SetExtRight(TL15,true); } if 고점[1,2] < 저점[1,2] then { TL15 = TL_New(sDate[index-저점[1,2]],sTime[index-저점[1,2]],L[index-저점[1,2]]+PriceScale*3,sDate,sTime,L[index-저점[1,2]]+PriceScale*3); TL_SetColor(TL13,GRAY); TL_SetSize(TL13,0); TL_SetExtRight(TL13,true); TL_SetColor(TL14,GRAY); TL_SetSize(TL14,0); TL_SetExtRight(TL14,true); TL_SetColor(TL15,YELLOW); TL_SetSize(TL15,3); TL_SetExtRight(TL15,true); } plot1(index-고점[1,2]); plot2(index-저점[1,2]); 위수식에서 수평선이 전봉시가부터 나오게 부탁드립니다
프로필 이미지
유선
2019-07-02
255
글번호 129951
지표