커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

요청합니다

수식지왕님의 피보나치팬입니다. 팬의 두께와 색상변경 옵션을 넣어주세요. 감사합니다. #==========================================# # 지 표 명 : 피보나치 팬(Fans) # 작 성 자 : 수식지왕 # 블 로 그 : http://yahoosir.blog.me #==========================================# Input:length(10),기준일(20110101),파동선두께(2); Var:j(0),jj(0),jjj(0),최종고가(0),최종저가(0),최종변곡점(""),처리구분(""), TL1(0); Array:고[5,4](0),저[5,4](0), // 1:가격, 2:Index, 3:sDate, 4:sTime 역사적고점[5](0),역사적저점[5](0); #==========================================# 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,RED); } 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 기준일 <= Date and 역사적고점[1] < 고[1,1] Then { For jjj = 1 To 4 { 역사적고점[jjj] = 고[1,jjj]; } } 최종변곡점 = "고점"; } #==========================================# 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,BLUE); } 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]); } If 기준일 <= Date and ( 역사적저점[1] > 저[1,1] or 역사적저점[1] == 0 ) Then { For jjj = 1 To 4 { 역사적저점[jjj] = 저[1,jjj]; 역사적고점[jjj] = 0; // 역사적 고점 초기화 } } 최종변곡점 = "저점"; } #==========================================# Var:기울기(0); Array:fr[7,4](0); // 1:비율, 2:값, 3:라인번호, 4:텍스트번호 If Index == 0 Then { fr[1,1] = 0; fr[2,1] = 0.236; fr[3,1] = 0.382; fr[4,1] = 0.50; fr[5,1] = 0.618; fr[6,1] = 0.764; fr[7,1] = 1; } If 역사적고점[1] > 0 and 역사적저점[1] > 0 Then { If 역사적고점[1][1] != 역사적고점[1] or 역사적저점[1][1] != 역사적저점[1] Then { 기울기 = (역사적고점[1] - 역사적저점[1]) / (역사적고점[2] - 역사적저점[2]); for j = 1 to 7 { If fr[j,3] > 0 Then TL_Delete(fr[j,3]); // 기존의 라인은 지우고 fr[j,2] = 기울기 * fr[j,1] * (index - 역사적저점[2]) + 역사적저점[1]; // 피보나치 비율을 곱해서 계산 fr[j,3] = TL_New(역사적저점[3],역사적저점[4],역사적저점[1],sDate,sTime,fr[j,2]); // 라인을 생성 } } Else { for j = 1 to 7 { fr[j,2] = 기울기 * fr[j,1] * (index - 역사적저점[2]) + 역사적저점[1]; TL_SetEnd(fr[j,3],sDate,sTime,fr[j,2]); } } }
프로필 이미지
왕팡
2019-09-24
285
글번호 132202
지표
답변완료

수식부탁드립니다

$,안녕하세요, 아래수식을 첨부파일처럼 과열(A) 침체(B)구간일때 경보음이 발생하게 하고싶습니다 도움부탁드립니다. Input : Period(9); var : Relative(0); Relative = RSI(Period); Plot1(Relative, "RSI"); PlotBaseLine1(30, "기준선 30"); PlotBaseLine2(70, "기준선 70"); PlotBaseLine3(50); $,도움주심에 늘 고맙습니다.
프로필 이미지
회원
2019-09-24
330
글번호 132201
지표
답변완료

문의 드립니다.

키움 수식인데요... 예스로 변환좀 부탁드립니다. 1번수식 수식4 m=ma(c,기간,종류); valuewhen(1,m>m(1),m) 수식5 ma(c,기간,종류) 2번수식 수식4 ma(c,기간,종류) 수식5 m=ma(c,기간,종류); valuewhen(1,m<m(1),m) 지표조건 기간 40 종류 단순 이렇게 한개의 지표고요..... 또다른 지표입니다. 이것도 변환 부탁드립니다. 1번수식 수식4 a=ma(c,기간,종류); a+a*(비율/100) 수식5 ma(c,기간,종류) 2번수식 수식4 a=ma(c,기간,종류) 수식5 ma(c,기간,종류); a-a*(비율/100) 지표조건 기간 40 종류 단순 비율 0.025 이렇게 입니다. 매번 감사합니다.
프로필 이미지
로꼬로꼬
2019-09-24
267
글번호 132200
지표

화명동시기 님에 의해서 삭제되었습니다.

프로필 이미지
화명동시기
2019-09-24
10
글번호 132199
사용자 함수
답변완료

시스템 수식문의

inputs: ATRLength(9), ATRMult(1), Strength(9); vars: strend(0),st(0); st = SuperTrend(ATRLength, ATRMult, Strength, strend); Plot1(st+atr(ATRLength)*ATRMult,"Up",iff(strend == 1,red,blue)); Plot2(st-atr(ATRLength)*ATRMult,"Down",iff(strend == 1,red,blue)); Plot3(st,"SuperTrend",iff(strend == 1,red,blue)); 위 지표에서 각각 plot1 plot2 plot3으로 구분하여 red선이 나올때는 매수,blue선이 나올때는 매도신호 표시부탁드립니다.
프로필 이미지
이대표
2019-09-24
197
글번호 132198
시스템
답변완료

지표식

> data1과 data2의 종가합산액의 평균값과 10% 상,하위 값의 라인을 보여주는 지표식 부탁드립니다. > 가능하다면 특정일 이후부터로 지정할 수 있도록 날짜를 변수로 포함시켜주셨으면 합니다. ** 감사합니다.
프로필 이미지
rodney
2019-09-24
188
글번호 132195
지표
답변완료

second second[1] 회수와 nday평균

var : S1(0),S2(0),ST(0),E1(0),E2(0),ET(0),second(0); S1 = TimeToMinutes(stime)*60; S2 = FracPortion(stime/100)*100; ST = S1+S2; E1 = TimeToMinutes(time)*60; E2 = FracPortion(time/100)*100; ET = E1+E2; if sdate == date Then Second = ET-ST; Else Second = 86400-ST+ET; if second < second[1] and C > O Then buy(); if second < second[1] and C < O Then sell(); 위 수식의 거래횟수를 제한하는 input을 추가해주세요. input : n(5); var : sum(0),cnt(0); sum = 0; for cnt = 1 to n { sum = sum + (DayHigh(cnt)-daylow(cnt)); } var1 = sum/n; if crossup(C, dayopen() + var1*1.04) then buy(); if crossdown(C, dayopen() - var1*0.96) then sell(); 거래일 n이 평균값을 구하는 n과 동일하게 사용하는 수식입니다. 거래일 n은 그대로 하고 평균값이 아니고 나누기를 위한 임의의 m을 사용하는 수식으로 수정바랍니다. input : n(5),m(5)
프로필 이미지
목마와숙녀
2019-11-01
221
글번호 132192
시스템
답변완료

문의드립니다.

안녕하세요 예스글로벌이나 예스스팟 거래내역 log 화일을 설정하여 각각 거래내역을 확인할 수 있는지 ? 설정방법은 어떻게 되는지 알고 싶습니다. 매일 거래가 끝난후에 확인하려고 합니다. 답변 부탁드립니다. 감사합니다.
프로필 이미지
워싱턴
2019-09-24
169
글번호 132183
시스템
답변완료

지표식

안녕하세요 아래 지표식 해서좀 부탁드립니다 Input:period(10); var:j(0),HH(0),LL(0),MM(0),sum(0); Value1 = C; HH = Value1[period-1]; LL = Value1[period-1]; MM = (HH+LL)/2; sum = Value1[period-1]-MM; for j = period - 2 DownTo 0 { if HH < Value1[j] then HH = Value1[j]; if LL > Value1[j] then LL = Value1[j]; MM = (HH+LL)/2; sum = sum + (Value1[j]-MM); } plot1(abs(sum));
프로필 이미지
달마7
2019-09-24
191
글번호 132167
지표