커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

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

프로필 이미지
아침
2023-03-23
137
글번호 167476
시스템
답변완료

수식 부탁 드립니다.

키움수식 예스로 변환 부탁합니다. 1.매수신호:highest(v,20) == v 2.매수신호:bb=valuewhen(1,if(aa,1,0),O); crossup(c,bb) && O<C 항상 건강하세요.
프로필 이미지
사냥꾼
2023-03-23
1034
글번호 167475
시스템
답변완료

전환 쌍바닥

Input : 전환(0.2); Var:j(0),jj(0),HH(0),LL(0),hiBar(0),loBar(0),최종꼭지점(""),처리구분(""), TL1(0),TX1(0); Array:고[10,4](0),저[10,4](0); var : box(0),BB(False); HH = H; LL = L; If Index == 0 Then { 고[1,1] = HH; 고[1,2] = 0; 고[1,3] = sDate; 고[1,4] = sTime; 저[1,1] = LL; 저[1,2] = 0; 저[1,3] = sDate; 저[1,4] = sTime; } If Index > 0 Then { hiBar = hiBar + 1; loBar = loBar + 1; } If HH[hiBar] < HH Then hiBar = 0; If LL[loBar] > LL Then loBar = 0; Condition1 = 저[1,1]+전환 <= HH and hiBar == 0; Condition2 = 고[1,1]-전환 >= LL and loBar == 0; 처리구분 = ""; 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 { If 최종꼭지점 == "저점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = HH[hiBar]; 고[1,2] = Index - hiBar; 고[1,3] = sDate[hiBar]; 고[1,4] = sTime[hiBar]; hiBar = -1; loBar = -1; TL1 = TL_New_Self(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); TL_SetSize(TL1,2); TL_SetColor(TL1,RED); Text_Delete(tx1-1); TX1 = Text_New_Self(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1]-저[1,1],2)); Text_SetSize(tx1,30); Text_SetColor(Tx1,Red); Text_SetStyle(tx1,1,1); Text_SetBold(tx1,1); } Else If 고[1,1] < HH[hiBar] Then { 고[1,1] = HH[hiBar]; 고[1,2] = Index - hiBar; 고[1,3] = sDate[hiBar]; 고[1,4] = sTime[hiBar]; hiBar = -1; loBar = -1; TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]); Text_SetString(TX1,NumToStr(고[1,1]-저[1,1],2)); Text_SetLocation(TX1,고[1,3],고[1,4],고[1,1]); } 최종꼭지점 = "고점"; Plot1(고[1,1]); NoPlot(2); } If 처리구분 == "저점처리" Then { If 최종꼭지점 == "고점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = LL[loBar]; 저[1,2] = Index - loBar; 저[1,3] = sDate[loBar]; 저[1,4] = sTime[loBar]; hiBar = -1; loBar = -1; TL1 = TL_New_Self(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); TL_SetSize(TL1,2); TL_SetColor(TL1,BLUE); Text_Delete(tx1-1); TX1 = Text_New_Self(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1]-고[1,1],2)); Text_SetSize(tx1,30); Text_SetColor(Tx1,Blue); Text_SetStyle(tx1,1,0); Text_SetBold(tx1,1); bb = False; if bb == False and 저[1,1] <= 고[1,1]-0.5 and 고[1,1] > 0 Then { bb= true; box = Box_New_Self(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); Box_SetColor(box,Lime); Box_SetFill(box,true,70); } } Else If 저[1,1] > LL[loBar] Then { 저[1,1] = LL[loBar]; 저[1,2] = Index - loBar; 저[1,3] = sDate[loBar]; 저[1,4] = sTime[loBar]; hiBar = -1; loBar = -1; TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]); Text_SetString(TX1,NumToStr(저[1,1]-고[1,1],2)); Text_SetLocation(TX1,저[1,3],저[1,4],저[1,1]); if bb == true Then Box_SetEnd(box,저[1,3],저[1,4],저[1,1]); Else { if bb == False and 저[1,1] <= 고[1,1]-0.5 and 고[1,1] > 0 Then { bb= true; box = Box_New_Self(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); Box_SetColor(box,Lime); Box_SetFill(box,true,70); } } } 최종꼭지점 = "저점"; Plot2(저[1,1]); NoPlot(1); } a.추세선이 음전환되면 동그라미 표시. (가) 양전환되거나, (나) 직저 깨진 후 직전저점으로부터 -3틱 도달시 삭제. b.쌍바닥 : 당일 고점 -0.7p 아래에서 추세선 직저와 상1틱 ~ 하2틱 사이에 쌍바닥이면 동그라미 표시. c.쌍봉 : 직고와 상0틱 ~ 하1틱 사이에 쌍봉이면 동그라미 표시. 상하 변수 따로 따로 설정. 감사합니다.
프로필 이미지
고성
2023-03-24
1424
글번호 167472
지표
답변완료

수식 문의드립니다.

매수된 종목이 5% 이상 상승시, 30분봉상 주가가 10일선을 이탈할때 매도하는 수식을 만들고 싶습니다.
프로필 이미지
망고맨
2023-03-23
1508
글번호 167471
시스템
답변완료

수식문의드립니다

수고하십니다 첨부한 그림을 응용하여 매수(매도)신호 발생시 stoploss, targetpoint 를 TL 선으로 진입가-목표가/진입가-손절가 사이를 그림처럼 바탕색을 넣을 수 있는 수식을 부탁드립니다. 포지션이 청산되면 TL 선이 없어지도록하는 수식을 부탁드립니다. 예) 이동평균선(20) 을 상향돌파시 매수 손절선=최근5개봉저가 목표가= 진입가 + ( (진입가-손절가)*1.5)
프로필 이미지
당일선물
2023-03-23
1867
글번호 167470
지표
답변완료

제1조건과 제2조건을 동시에 만족하는 식

안녕하세요? 추세도 있으면서 변동성도 좋을때에 수직선을 긋는 식을 만들고 싶은데 잘 안됩니다. 수정 좀 부탁드립니다. ======================================================================= //============== TDI(추세지표) ===============// input : len1(20),len2(40); var : mt(0),sum1(0),sum2(0),TDI(0),T(0); mt = Abs(C-C[len1-1]); sum1 = AccumN(mt,len1); sum2 = AccumN(mt,len2); TDI = sum1-(sum2-sum1); If TDI[0] > TDI[1] Then { T = 1; } //============== ATR(변동성지표) ===============// Input : Period(14),SigPeriod(9); var : AvgTrueRange(0,Data1),ATRsig(0,Data1); Var : TL1(0),TL2(0),TL3(0),TL4(0),TL5(0),TL6(0),TL7(0),TL8(0),TL9(0),TL10(0); AvgTrueRange = Data1(ATR(Period)); ATRsig = ema(Data1(ATR(Period)),SigPeriod); //=========================================// If T==1 and cRossUp(AvgTrueRange, ATRsig) Then { TL1 = TL_New(sdate,stime,99999999,sdate,stime,0); TL_SetColor(TL1,ReD); TL_SetSize(TL1,0); PlaySound("C:₩EugeneYesTrader₩Bin10₩data₩Sound₩@거래량증가시작변동성확때시작"); }
프로필 이미지
매버릭
2023-03-23
1340
글번호 167468
지표
답변완료

수식 문의드립니다.

1. 일봉 저가가 5일선을 데드크로스 후, 30분봉상 5선이 10선을 골든크로스할 때 매수 2. 일봉 저가가 5일선 데드크로스 후, 30분봉상 20선을 골든크로스 할때 매수 1번 조건일때 1차매수, 2번 조건일 때 2차매수하고 익절 5%, 손절 5% 수식을 만들고 싶습니다. 항상 감사합니다.
프로필 이미지
망고맨
2023-03-23
2124
글번호 167460
시스템
답변완료

피라미딩별청산2

피라미딩 적용했을 때 a,b 진입 후 a는 xb1 b는 xb2로 청산하는 수식을 작성했는데 a,b 모두 xb1으로 청산됩니다. b는 xb2로 청산되게 수식 수정 부탁드립니다. ****************************************************************************** input:st1(101000),butd21(100),butd31(10000); input:st2(103000),butd22(2000),butd32(12500); input : exst(103000),ex하락1(99999),ex하락2(99999); var : T1(0),entry(0); if Bdate != Bdate[1] Then T1 = TotalTrades; if MarketPosition == 0 Then entry = TotalTrades-T1; Else entry = (TotalTrades-T1)+1; if MarketPosition == 0 and sTime>=st1 and entry==0 and !(data2(c<Highd(0)-butd21)) and !(data3(c>Lowd(0)+butd31)) Then Buy("a"); if MarketPosition == 1 then { if MaxEntries==1 and sTime>=st2 and entry==1 and !(data2(c<Highd(0)-butd22)) and !(data3(c>Lowd(0)+butd32)) Then Buy("b"); } var : Tcond(false,Data2),h2(0,Data2),L2(0,Data2); if Data2(Bdate != Bdate[1]) Then Tcond = False; if Data2((sdate != sdate[1] and stime >= exst) or (sdate == sdate[1] and stime >= exst and stime[1] < exst)) Then { Tcond = true; h2 = Data2(h); l2 = Data2(l); } if Tcond == true Then { if Data2(H) > h2 Then h2 = Data2(h); if Data2(L) < l2 Then l2 = Data2(l); if MarketPosition == 1 and IsEntryName("a") and data2(c<h2-ex하락1) then exitlong("xb1"); if MarketPosition == 1 and IsEntryName("b") and data2(c<h2-ex하락2) then exitlong("xb2"); }
프로필 이미지
목마와숙녀
2023-04-24
1419
글번호 167458
시스템
답변완료

문의 드립니다.

안녕하세요. 당일 포함한 10 ATR 를 구하고 W 값에 저장 당일 최저가 에서 하락하면 하락한 값만큼 W 값 에서 마이너스 시키고 W1에 저장 (저장값에 0.3을 더하거나 뺄수 있음) 당일 최고가 에서 상승한 가격을 W 에 더한값이 W2(저장값에 0.3을 더하거나 뺄수 있음) W가격 화면에 플릇으로 표시 당일최저가 -W1 값 플릇 으로 표시 당일최고가 +W2 값 플릇 으로 표시
프로필 이미지
월드맨
2023-03-23
1471
글번호 167457
지표