커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

수식

안녕하세요. 하기 수식 부탁 드립니다. Price Channel 20봉 중에서........ 1. 양봉 중애서 몸통이 가장 큰 양봉 고가,저가,시가,종가 표시 2. 음봉 중애서 몸통이 가장 큰 음봉 고가,저가,시가,종가 표시 감사합니다.
프로필 이미지
한국사람73
2021-12-10
1122
글번호 154357
지표
답변완료

문의

항상 많은 도움 감사합니다. 아래 두가지 지표를 잘 쓰고 있긴한데 수치는 맞는데 알람소리가 안 나요. 다른 지표들은 알람소리가 잘 나는데.... 수치는 맞으니까 아쉬운대로 계속 쓰다가 답답해서 다시 문의 드립니다. 알람소리 나게 부탁드립니다. 1.월고 월저 기준가 input : 입력일(20211210),Per(3); var : 기준가(0,Data2),월고(0,Data2),월저(0,Data2); var : cond1(False,Data2),cond2(False,Data2),cond3(False,Data2); if data2(sdate == 입력일) Then 기준가 = data2(lowD(0)); if data2(sdate >= 입력일) Then { if Data2(월고 == 0 or (월고 > 0 and H > 월고)) Then 월고 = data2(h); if data2(월저 == 0 or (월저 > 0 and L < 월저)) Then 월저 = data2(l); } if 기준가 > 0 Then Plot1(기준가); if 월고 > 0 Then Plot2(월고); if 월저 > 0 Then Plot3(월저); Cond1 = Data2(C<=기준가*(1+Per/100) and C >= 기준가*(1-Per/100)); Cond2 = Data2(C<=월고*(1+Per/100) and C >= 월고*(1-Per/100)); Cond3 = Data2(C<=월저*(1+Per/100) and C >= 월저*(1-Per/100)); if cond1 == true and cond1[1] == False Then PlaySound("C:₩예스트레이더₩data₩Sound₩accept.wav"); if cond2 == true and cond2[1] == False Then PlaySound("C:₩예스트레이더₩data₩Sound₩accept.wav"); if cond3 == true and cond3[1] == False Then PlaySound("C:₩예스트레이더₩data₩Sound₩accept.wav"); 2.특정일 저가 input : 날짜(20211210),Per1(3); var : D2L(0,data2),scond1(False,Data2); if data2(sdate == 날짜) Then { D2L = data2(LowD(0)); } plot1(D2L); scond1 = Data2(C) <= D2L*(1+Per1/100) and Data2(C) >= D2L*(1-Per1/100); if scond1 == true and scond1[1] == true Then PlaySound("C:₩예스트레이더₩data₩sound₩accept.wav");
프로필 이미지
육각수
2021-12-10
1002
글번호 154356
지표
답변완료

수식 부탁드립니다

var : entry(0); if bdate != bdate[1] Then entry = 0; if (MarketPosition != 0 and MarketPosition != MarketPosition[1]) or (MarketPosition == MarketPosition[1] and TotalTrades > TotalTrades[1]) Then entry = entry+1; if MarketPosition <= 0 and entry < 1 Then buy("b",atlimit,dayhigh-PriceScale*35); if MarketPosition == 1 Then exitlong("bx",atlimit,lowest(L,BarsSinceEntry)+PriceScale*30); if MarketPosition >= 0 and entry < 1 Then sell("s",atlimit,daylow+PriceScale*100); if MarketPosition == -1 Then ExitShort("sx",atlimit,Highest(H,BarsSinceEntry)-PriceScale*120); if sdate != sdate[1] Then SetStopEndofday(04000); if bdate != bdate[1] Then SetStopEndofday(0); --------------------------------- 위 수식어에 추가 입니다. 매매시간 : 오전 10시부터 익일 04시 손 절 : 20틱
프로필 이미지
푸른
2021-12-10
820
글번호 154355
시스템
답변완료

수식 부탁드립니다.

1. 지표 손절값을 기준으로.. 예를들어 50틱일 경우 - 매수 진입 후 직전 3개 봉(연속 음봉) 기준으로 첫번째 봉 시가와 세번째 봉 종가의 차이가 50틱일 경우 다음 봉 진입시 손절 - 매도 진입시에도 진입 후 직전 3개 봉(연속 양봉) 기준으로 첫번째 봉 시가와 세번째 봉 종가의 차이가 50틱일 경우 손절하는 수식 부탁드립니다. 2. 그리고 아래 지표 수식이 의미하는 내용이 무엇인지 설명 부탁드립니다. input:b_time1(000000),e_time1(240000), stoK_p11(100),stoK_p12(6),stoK_p13(6), ma_p11(25),ma_p12(5),ma_p13(15),ma_p14(100), ma_p15(10),ma_p16(20),ma_p17(15); Var:stoK(0),stoD(0),TRIXv(0),TRIXsig(0),T(0); If b_time1 <= Time and Time <= e_time1 Then { stoK = StochasticsK(stoK_p11,stoK_p12); stoD = StochasticsD(stoK_p11,stoK_p12,stoK_p13); If countif(ma(C,ma_p11)[1] < ma(C,ma_p11),1) == 1 and (ma(C,ma_p12)[1] <= ma(C,ma_p13)[1] and ma(C,ma_p12) > ma(C,ma_p13)) and countif(ma(C,ma_p14)[1] < ma(C,ma_p14),1) == 1 and countif(ma(C,ma_p15)[1] < ma(C,ma_p15),1) == 1 and countif(ma(C,ma_p16)[1] < ma(C,ma_p16),1) == 1 and countif(ma(C,ma_p17)[1] < ma(C,ma_p17),1) == 1 Then { T = 1; } If countif(ma(C,ma_p11)[1] > ma(C,ma_p11),1) == 1 and (ma(C,ma_p12)[1] >= ma(C,ma_p13)[1] and ma(C,ma_p12) < ma(C,ma_p13)) and countif(ma(C,ma_p14)[1] > ma(C,ma_p14),1) == 1 and countif(ma(C,ma_p15)[1] > ma(C,ma_p15),1) == 1 and countif(ma(C,ma_p16)[1] > ma(C,ma_p16),1) == 1 and countif(ma(C,ma_p17)[1] > ma(C,ma_p17),1) == 1 Then { T = -1; } plot1(iff(T==1,100,iff(T==-1,-100,0))); plotbaseline1(0); }
프로필 이미지
미완
2021-12-10
924
글번호 154354
시스템

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

프로필 이미지
thrupass
2021-12-09
0
글번호 154353
지표
답변완료

재질문 드립니다. 텍스트가 반대로 움직입니다.ㅠ

input : 소숫점표시자리수(2),글자크기(12); var : tl1(0),tl2(0),tl3(0),tl4(0); var : tl5(0),tl6(0),tl7(0),tl8(0); var : tx1(0),tx2(0),tx3(0),tx4(0); var : tx5(0),tx6(0),tx7(0),tx8(0); plot1(dayopen(0),"당일시가"); plot2((DayHigh(1)+DayLow(1))/2,"전일중심"); plot3(DayHigh(1),"전일고가"); plot4(DayLow(1),"전일저가"); plot5(DayClose(1),"전일종가"); plot5((DayHigh(0)+DayLow(0))/2,"전일종가"); if Bdate != Bdate[1] Then { var1 = sDate; Var2 = sTime; tl1 = TL_New(sDate,sTime,DayOpen,NextBarSdate,NextBarStime,DayOpen); tl2 = TL_New(sDate,sTime,DayHigh,NextBarSdate,NextBarStime,DayHigh); tl3 = TL_New(sDate,sTime,DayLow,NextBarSdate,NextBarStime,DayLow); tl4 = TL_New(sDate,sTime,(DayHigh+DayLow)/2,NextBarSdate,NextBarStime,(DayHigh+DayLow)/2); tl5 = TL_New(sDate,sTime,DayClose(1),NextBarSdate,NextBarStime,DayClose(1)); tl6 = TL_New(sDate,sTime,DayHigh(1),NextBarSdate,NextBarStime,DayHigh(1)); tl7 = TL_New(sDate,sTime,DayLow(1),NextBarSdate,NextBarStime,DayLow(1)); tl8 = TL_New(sDate,sTime,(DayHigh(1)+DayLow(1))/2,NextBarSdate,NextBarStime,(DayHigh(1)+DayLow(1))/2); } Else { TL_setend(tl1,sDate,sTime,DayOpen); if DayHigh(0) != DayHigh(0)[1] Then { TL_SetBegin(tl2,var1,Var2,DayHigh); TL_SetBegin(tl4,var1,Var2,(DayHigh+DayLow)/2); } if DayLow(0) != DayLow(0)[1] Then { TL_SetBegin(tl3,var1,Var2,DayLow); TL_SetBegin(tl4,var1,Var2,(DayHigh+DayLow)/2); } TL_setend(tl2,sDate,sTime,DayHigh); TL_setend(tl3,sDate,sTime,DayLow); TL_setend(tl4,sDate,sTime,(DayHigh+DayLow)/2); TL_setend(tl5,sDate,sTime,DayClose(1)); TL_setend(tl6,sDate,sTime,DayHigh(1)); TL_setend(tl7,sDate,sTime,DayLow(1)); TL_setend(tl8,sDate,sTime,(DayHigh(1)+DayLow(1))/2); } Text_Delete(tx1); Text_Delete(tx2); Text_Delete(tx3); Text_Delete(tx4); Text_Delete(tx5); Text_Delete(tx6); Text_Delete(tx7); Text_Delete(tx8); tx1 = Text_New(NextBarSdate,NextBarStime,DayOpen," 당일시가"+NumToStr(DayOpen,소숫점표시자리수)); tx4 = Text_New(NextBarSdate,NextBarStime,(DayHigh+DayLow)/2," 당일중심"+NumToStr((DayHigh+DayLow)/2,소숫점표시자리수)); tx5 = Text_New(NextBarSdate,NextBarStime,DayClose(1)," 전일종가"+NumToStr(DayClose(1),소숫점표시자리수)); tx6 = Text_New(NextBarSdate,NextBarStime,DayHigh(1)," 전일고가"+NumToStr(DayHigh(1),소숫점표시자리수)); tx7 = Text_New(NextBarSdate,NextBarStime,DayLow(1)," 전일저가"+NumToStr(DayLow(1),소숫점표시자리수)); tx8 = Text_New(NextBarSdate,NextBarStime,(DayHigh(1)+DayLow(1))/2," 전일중심"+NumToStr((DayHigh(1)+DayLow(1))/2,소숫점표시자리수)); Text_SetSize(tx1,글자크기); Text_SetSize(tx2,글자크기); Text_SetSize(tx3,글자크기); Text_SetSize(tx4,글자크기); Text_SetSize(tx5,글자크기); Text_SetSize(tx6,글자크기); Text_SetSize(tx7,글자크기); Text_SetSize(tx8,글자크기); 일전에 도와주셔서 사용중인 지표식입니다. 말씀하신거처럼 빈칸을 추가해보았으나 도리어 텍스트가 왼쪽으로 이동하여 봉을 더 가리게 되는군요. 제가 잘못바꾼건지 모르겠습니다. 도와주세요!! /// 추가질문 종목차트 하단으로 위치하는 지표창위치를 종목차트 상단으로 바꾸는게 가능한지요? 가능하다면 알려주십시오.
프로필 이미지
에이오드
2021-12-09
729
글번호 154352
지표
답변완료

청산 후 재진입3(Lcount 구별)

손절이후 당일 저점 1번째 돌파시 변수 적용 결과를 살펴보았습니다.(첨부파일) 387.24 저점을 돌파할 때 진입해야는데 다른 지점에서 진입합니다. 살펴주십시요. input : n(1); var : cnt(0),count(0); Count = 0 ; for cnt = 0 to 10 { if EntryDate(cnt) == sdate then Count = Count + 1; } input : 갭하락(1.5),손절진입(50),트레진입(50),최소진입(50); input : loss(0.5),trail(1.5),최소가격(0.4),봉갯수(150); if c < DayOpen - 갭하락 and count < n Then Sell("s"); SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 Then { if TotalTrades > TotalTrades[1] Then count = 0; if daylow(0) < DayLow(0)[1] Then count = count+1; if IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and count == 손절진입 Then Sell("손절진입"); if IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and count == 트레진입 Then Sell("트레진입"); if IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and count == 최소진입 Then Sell("최소진입"); } *********************************************************************************** 안녕하세요 예스스탁입니다. CountIf가 현재봉에서 청산봉까지 루프를 반복하게 되므로 다른 방법으로 작성하면 아래와 같습니다. var : count(0); SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 Then { if TotalTrades > TotalTrades[1] Then count = 0; if daylow(0) < DayLow(0)[1] Then count = count+1; if IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and count == 3 Then Sell(); if IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and count == 2 Then Sell(); if IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and count == 1 Then Sell(); } 즐거운 하루되세요 > 목마와숙녀 님이 쓴 글입니다. > 제목 : 문의 > 답변 수식 고맙습니다. 그런데... 아래 수식을 사용하면 수식 추가 이전보다 시뮬레이션 속도가 현저히 느려지는데요. 이유가 있을까요? 피시 메모리는 동일한 조건에서 비교했습니다. 속도를 고려한 다른 수식은 없겠는지요? *************************************************************************** SetStopLoss(loss,PercentStop); SetStopTrailing(trail,0,PercentStop,1); SetStopInactivity(최소가격,봉갯수,PercentStop); if MarketPosition == 0 and IsExitName("StopLoss",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 3 Then Sell(); if MarketPosition == 0 and IsExitName("StopTrailing",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 2 Then Sell(); if MarketPosition == 0 and IsExitName("StopInactivity",1) == true and ExitDate(1) == sDate and CountIf(daylow(0) < DayLow(0)[1],BarsSinceExit(1)) == 1 Then Sell();
프로필 이미지
목마와숙녀
2021-12-16
762
글번호 154351
시스템
답변완료

디버그시 차트값 참조?/외부파일 참조가 가능한가요?

안녕하세요! 수식 작성 중에 어떨 때는 실제 데이터가 뭐가 들어 있는지 식을 실행해서보고 싶을 때가 있는데요, 그때 예를 들면 RSI함수를 화면에 무슨 숫자값들이 들어 있는지 혹은 제가 쓴 함수가 값들이 제가 원하는 대로 잘 들어 있는지 확인은 어떻게 하나요? (또 이때 숫자값을 문자열로 변환은 어떻게하는지요?) messagelog함수인가 그것은 위의 상황에 안되는 경우가 있어서 질문드립니다. 그냥 차트에 띄워서 보는 방법 밖에 없나요? 즉 그 전에 코드 에디터에서 실제 차트 데이터를 숫자들이 잘 들어 있거나 작동 잘하는지 보고 싶습니다. 그리고 궁금한 것은 예스랭귀지에서 csv파일을 출력은 메뉴얼에서 봤는데 읽는 것은 없나요? 아니면 외부 html이나 크롤링 함수들은 지원을 하는지요? 감사합니다.
프로필 이미지
nirvana
2021-12-09
689
글번호 154350
시스템
답변완료

부탁드립니다.

언제나 감사드립니다. 1. Index나 dayindex 대신에 그 상황이 발생한 시각을 지정할 수 있는지요. stime이 무슨 뜻인지 모르지만, 그런 식으로 표현할 방법이 없는지요. 특정시각 이후에 그 일이 일어난 것을 부수조건으로 설정코자 하는데, 분봉의 크기에 따라 다른 dayindex를 지정하기가 번거러워서 그럽니다. 부탁드립니다. If condition1[1]==false and condition1==true Then{ var1=Index; } 대신 If condition1[1]==false and condition1==true Then{ var1=발생시분초; } 2. 분봉에서 매수조건이 맞을 때 그날의 종가에 자동진입하게끔 시스템식을 작성하려면 어떻게 해야 하는지요. If stime==152500 and 매수조건1 Then{ buy("b1"); } If stime==152500 and 매수조건2 Then{ buy("b2"); } 이런 식으로 해도 되는지요. 3. 중복진입이 가능할 때 첫매수일로부터 5거래일 후의 정오에 자동청산한다면 어떻게 시스템식을 작성해야 하는지요. setstopendofday같은 별도의 용어가 있는지요. 4.. 위에서 매수후 5일이내의 최고점에서 팔았다고 가정할 경우에 그 시각 이전까지의 최대손실을 알 수 있는 방법이 있다면 부탁드리겠습니다. 시스템 성과를 정확히 알고 싶어서 그럽니다. 부탁드립니다. 즉 매수후 5일이내의 기간중에 최고점에서 팔았다고 가정할 경우의 수익과 최고점을 가기까지에 겪는 최대손실을 알고자 함입니다. 사후적인 검증에 의해서 기간내의 최고점에서 청산한 것으로 전제하여 그때까지의 성과와 최대손실을 성과보고서에서 확인할 방법은 없는지요. 청산목표 설정에 참고하고자 함입니다. 부탁드립니다. 5. 분봉그래프에서 같은종목의 일봉그래프를 매번 수정하지 않고 data2로 설정하는 방법은 없는지요. 6. 분봉그래프에서 일평균거래량 구하기 (1) 19일간의 dayvolume(1)의 평균을 구하는 지수식을 어떻게 표현하는지요. (2) 상장한지 20거래일이 안 된 경우 경과된 날짜만큼의 dayvolume(1)의 평균은 어떻게 구하는지요. 7. 선물에서 bids-asks의 당일 시초가를 나타낼 수 있는 방법이 있는지요.
프로필 이미지
묘선낭자
2021-12-10
580
글번호 154349
시스템