커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

부탁드려요

지표속성 차트표시에 나타나는 차트선택의 내용들을 (체크표시는 하되) 창에서 안보이게 할수도 있는지요?
프로필 이미지
왕팡
2020-07-16
2156
글번호 140714
지표
답변완료

수식질문드립니다.

항상 노고에 감사드립니다. 아래 수식은 전고전저돌파수식 만들어주신것인데,진입이 안되는 부위가 있어서 캡처해서 첨부사진에 올렸습니다. 진입안되는 부위는 제가 흰색화살표로 표시하였습니다. 그리고 노란색(전고점), 하늘색(전저점)의 폭이 50틱 이내일 경우만 진입하게 하고싶습니다. 감사합니다. Input:barCnt(5); Var:j(0),turnPntBit(""),TL1(0); Array:valArr[10](0),barArr[10](0),turnPntArr[10](""); // 봉이 새로 생겼으므로 봉개수 관리하는 변수들의 봉개수 값 1씩 증가 For j = 0 To 9 { barArr[j] = barArr[j] + 1; } // 고점조건 = 5-1-5에서 가운데 고가가 좌측 5봉과 우측 5봉 고가보다 높다 // 저점조건 = 5-1-5에서 가운데 저가가 좌측 5봉과 우측 5봉 저가보다 낮다 Condition1 = Highest(H,barCnt)[barCnt+1] <= H[barCnt] and H[barCnt] > Highest(H,barCnt); Condition2 = Lowest(L,barCnt)[barCnt+1] >= L[barCnt] and L[barCnt] < Lowest(L,barCnt); // 전환점구분 null값으로 초기화; // if 고점조건, 저점조건 동시 만족시 then // if 이전 고점,저점 범위를 모두 벗어났을 때 // 전환점구분 = 고저점; // else if 이전 고점을 갱신했다면 전환점구분 = 고점; // else if 이전 저점을 갱신했다면 전환점구분 = 저점; // else if 전환점배열의 현재(배열상 1번째)값이 고점이면 전환점구분 = 저점; // else if 전환점배열의 현재 값이 저점이면 전환점구분 = 고점; // else if 고점조건 만족하면 전환점구분 = 고점; // else if 저점조건 만족하면 전환전구분 = 저점; turnPntBit = ""; If Condition1 and Condition2 Then { If Max(valArr[1],valArr[2]) < H[barCnt] and Min(valArr[1],valArr[2]) > L[barCnt] Then turnPntBit = "HiLo"; Else If Max(valArr[1],valArr[2]) < H[barCnt] Then turnPntBit = "Hi"; Else If Min(valArr[1],valArr[2]) > L[barCnt] Then turnPntBit = "Lo"; Else If turnPntArr[1] == "Hi" Then turnPntBit = "Lo"; Else If turnPntArr[1] == "Lo" Then turnPntBit = "Hi"; } Else If Condition1 Then turnPntBit = "Hi"; Else If Condition2 Then turnPntBit = "Lo"; // if 전환점구분에 값이 있을 때만 아래 실행, 없으면 통과 If turnPntBit <> "" Then { // if 전환점구분이 고저점이면 then // 이전 파동은 연장시키고 아래에서 새로이 파동선을 추가토록 한다. If turnPntBit == "HiLo" Then { valArr[1] = IFF(turnPntArr[1] == "Hi",H[barCnt],L[barCnt]); barArr[1] = barCnt; TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); If turnPntArr[1] == "Hi" Then turnPntBit = "Lo"; Else turnPntBit = "Hi"; } // if 신규 전환점구분이 현재(전환점배열 1번째)와 다르면 then // 배열값들을 이전값으로 Move; If turnPntBit <> turnPntArr[1] Then { for j = 8 downto 1 { valArr[j+1] = valArr[j]; barArr[j+1] = barArr[j]; turnPntArr[j+1] = turnPntArr[j]; } } // if 전환점구분이 바뀌었거나 또는 // (전환점구분은 안바뀌었는데 // (이전 고점보다 높은 고점이 발생했거나 또는 // 이전 저점보다 낮은 저점이 발생했으면)) then If turnPntBit <> turnPntArr[1] or (turnPntBit == turnPntArr[1] and ((turnPntBit == "Hi" and valArr[1] < H[barCnt]) or (turnPntBit == "Lo" and valArr[1] > L[barCnt]))) Then { // 값 배열에는 고점 또는 저점을 대입; // 봉개수 배열에는 입력변수의 봉개수 대입; // 전환점 배열에 전환점구분값을 대입; valArr[1] = IFF(turnPntBit == "Hi",H[barCnt],L[barCnt]); barArr[1] = barCnt; turnPntArr[1] = turnPntBit; // if 이전봉대비 전환점구분이 바뀌었다면 추세선 새로 그리고; // else 전환점구분이 안바뀌었으면 값만 바뀐거므로 추세선 연장; If turnPntArr[1][1] <> turnPntArr[1][0] Then TL1 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2], sDate[barArr[1]],sTime[barArr[1]],valArr[1]); Else TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); } } TL_SetSize(TL1,2); TL_SetColor(TL1,GREEN); var : TL11(0),TL12(0); if turnPntArr[1][0] == "Hi" Then{ TL_Delete(TL11); TL11 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[1],sDate[barArr[1]],sTime[barArr[1]],valArr[1]); TL_SetExtRight(TL11,true); TL_SetColor(TL11,YELLOW); TL_SetSize(TL11,2); } if turnPntArr[1][0] == "Lo" Then{ TL_Delete(TL12); TL12 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[1],sDate[barArr[1]],sTime[barArr[1]],valArr[1]); TL_SetExtRight(TL12,true); TL_SetColor(TL12,CYAN); TL_SetSize(TL12,2); } if turnPntArr[1] == "Lo" and crossup(C,valArr[2]) Then buy(); if turnPntArr[1] == "Hi" and CrossDown(C,valArr[2]) Then sell();
프로필 이미지
고나리자
2020-07-16
2482
글번호 140712
시스템
답변완료

질문드립니다.

예를들면, 20이평과 60이평이 있을 때 20/60골든크로스 기간동안 형성된 봉들의 최고점과 최저점을 다음에 이어지는 20/60데드크로스 시작 시점부터 데드크로스가 끝나는 기간동안 그려주고, 그 데드크로스 기간동안 형성된 최고점과 최저점을 그 다음에 이어지는 골드크로스구간에 그려지는 식을 부탁드립니다.
프로필 이미지
아름다운아침
2020-07-16
2162
글번호 140708
지표
답변완료

질문드립니다

안녕하세요~~ 매수 매도(청산포함) 조건명령들중에~~~ ~이러~이러한것들을 실행하되~~~~~ 단 이것은 (하자마라!)제외!! 하란 수식명령은 어떻게합니까~?? 예를들면~~ Ma30 > Ma60 and Ma60 > ma100 and (MA150 < MA200) not!~~~~매수진입
프로필 이미지
째일
2020-07-16
1940
글번호 140707
시스템
답변완료

부탁드립니다.

-해외선물 분봉차트에서 당일 장이 개시되면 전일의 최저가 시간부터 종가를 누적하는 지표를 부탁드립니다.(예: 7.12일 12:00:00에 원유최저가격이었다면, 7.13일 원유시장이 개시 되면 7.12일 12:00:00부터 종가를 누적하는 식을 부탁드립니다).
프로필 이미지
예시
2020-07-16
1909
글번호 140706
지표
답변완료

부탁 드립니다.

도움에 감사 드립니다. 아래 수식1)을 양봉일때만의 거래량과 가격 곱의 합산,양봉 봉수로 나누기 (수식2), 음봉일때의의 거래량과 가격 곱의 합산,음봉 봉수로 나누기 (수식3)으로 수정 해본것입니다. 맞게 된것인지요? 여기서 또다른 질문은 예를 들어 n(100)개봉전에 양봉이 70개, 음봉이 30개가 있다고 가정한다면 수식2)에서 N1 이 자동산정, 70개로 수식3)에서 N2 가 자동산정, 30개로 계산되나요? 만약에 그렇지 않다면 수식2)에서 N1이 양봉의 갯수(70개) 만큼 var1 = accumn(C*V,N1); 이 합산되고 또 var2 = var1/N1에서 N1이 70개로 자동 산정되어 나누기 되도록 부탁 드립니다. 수식3)에서 N2가 음봉의 갯수(30개) 만큼 var2 = accumn(C*V,N2); 이 합산되고 또 var2 = var1/N2에서 N2가 30개로 자동 산정되어 나누기 되도록 부탁 드립니다. 수식1) input : n(100); var1 = accumn(C*V,N); var2 = var1/n; 수식2) 양봉일때 input : n1(100); if c>o then{ var1 = accumn(C*V,N1); var2 = var1/N1;} 수식3)음봉일때 input : n2(100); if c<o then{ var1 = accumn(C*V,N2); var2 = var1/N2;}
프로필 이미지
뮬리
2020-07-16
1899
글번호 140705
지표
답변완료

검색식 부탁합니다

지표: DMI (지표값 14) 검색식 : DMI가 30선 돌파시 검색 수식 부탁합니다
프로필 이미지
파워
2020-07-15
1876
글번호 140704
검색
답변완료

수정 부탁 드립니다.

1. 아래식에서 "최초매수" 후(보유중)에 추가매수 신호가 들어오면 "최초매수(전매수)" 가격 보다 같거나 아래(낮은가격)에 있을때만 추가매수 가 되게 하고 십습니다. 2. 아래식에서 보유중인 수량의 평균(Per) 목표가격이 된면 전부 청산하는 식이 맞는지 궁금 합니다. 3. 식을 이용하면 지정가로 매수 및 청산이 되는데 현재 가로 는 할수없는지, 차이가(장단점) 무엇인지 궁금합니다. 수정부탁 드립니다. if Tcond == true then { if MarketPosition == 0 and crossup(var9,var10) Then { Buy ("최초매수"); TL1 = TL_New(sdate,stime,c,NextBarSdate,nextbarstime,C); TL_SetColor(TL1,BLACK); TL_SetSize(TL1,1); TL2 = TL_New(sdate,stime,c*(1+Per/100),NextBarSdate,nextbarstime,C*(1+Per/100)); TL_SetColor(TL2,RED); TL_SetSize(TL2,1); }
프로필 이미지
백마날개
2020-07-15
1596
글번호 140703
시스템
답변완료

지표

지표입니다 검색 알람수식부탁드립니다 반복수식이라 검증된기본 수식만 알려주시면 나머지는 본인이 하겠읍니다 Input : 기준1(290), 이격1(2.5), 이격2(1.25), AA1(5); var3 = 기준1; var1=0; if var1 <= AA1 Then { plotbaseline1(Var3,"1"); plotbaseline2(Var3-이격2,"2"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline3(Var3-(이격1*1),"3"); plotbaseline4(Var3-(이격1*1)-이격2,"4"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline5(Var3-(이격1*2),"5"); plotbaseline6(Var3-(이격1*2)-이격2,"6"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline7(Var3-(이격1*3),"7"); plotbaseline8(Var3-(이격1*3)-이격2,"8"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline9(Var3-(이격1*4),"9"); plotbaseline10(Var3-(이격1*4)-이격2,"10"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline11(Var3-(이격1*5),"11"); plotbaseline12(Var3-(이격1*5)-이격2,"12"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline13(Var3-(이격1*6),"13"); plotbaseline14(Var3-(이격1*6)-이격2,"14"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline15(Var3-(이격1*7),"15"); plotbaseline16(Var3-(이격1*7)-이격2,"16"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline17(Var3-(이격1*8),"17"); plotbaseline18(Var3-(이격1*8)-이격2,"18"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline19(Var3-(이격1*9),"19"); plotbaseline20(Var3-(이격1*9)-이격2,"20"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline21(Var3-(이격1*10),"21"); plotbaseline22(Var3-(이격1*10)-이격2,"22"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline23(Var3-(이격1*11),"23"); plotbaseline24(Var3-(이격1*11)-이격2,"24"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline25(Var3-(이격1*12),"25"); plotbaseline26(Var3-(이격1*12)-이격2,"26"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline27(Var3-(이격1*13),"27"); plotbaseline28(Var3-(이격1*13)-이격2,"28"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline29(Var3-(이격1*14),"29"); plotbaseline30(Var3-(이격1*14)-이격2,"30"); var1 = var1 +1 ; } if var1 <= AA1 Then { plotbaseline31(Var3-(이격1*15),"31"); plotbaseline32(Var3-(이격1*15)-이격2,"32"); var1 = var1 +1 ; }
프로필 이미지
회원
2020-07-15
1761
글번호 140702
지표