커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

수식문의

매수 피라미딩 진입 이후 평균 수익율 3% 이후 1% 하락시 전량 청산 매도 피라미딩 진입 이후 평균 수익율 3% 이후 1% 하락시 전량 청산
프로필 이미지
에이드
2020-08-21
733
글번호 141631
시스템
답변완료

감사합니다

Input:length(10); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0), TL1(0),처리구분(""),T(0),TL2(0),TL3(0); var : hh(0),ll(0),ii(0),diff(0),TL41(0),TL42(0),TL43(0),TL44(0),TL45(0),TL46(0); Array:고점[10,5](0),저점[10,5](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 { T = 1; 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(TL2); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL_SetExtRight(TL2,False); TL2 = TL_New(sDate[1],sTime[1],고점[1,1],sdate,sTime,고점[1,1]); TL_SetColor(TL2,BLUE); TL_SetSize(TL2,2); 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 { T = -1; 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(TL3); } TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL_SetExtRight(TL3,False); TL3 = TL_New(sDate[1],sTime[1],저점[1,1],sdate,sTime,저점[1,1]); TL_SetColor(TL3,RED); TL_SetSize(TL3,2); If 저점[2,1] < 저점[1,1] and 저점[2,1] < 저점[3,1] and 고점[2,1] > 고점[1,1] Then { sBar = Index - 고점[2,2]; eBar = Index - 고점[1,2]; } } } TL_SetSize(TL1,0); TL_SetColor(TL1,YELLOW); TL_SetEnd(TL2,sdate,stime,고점[1,1]); TL_SetEnd(TL3,sdate,stime,저점[1,1]); TL_SetExtRight(TL2,true); TL_SetExtRight(TL3,true); if T != T[1] then { if T == 1 Then { HH = 고점[2,1]; LL = 저점[1,1]; ii = index-고점[2,2]; diff = abs(HH-LL); } Else { HH = 고점[1,1]; LL = 저점[2,1]; ii = index-저점[2,2]; diff = abs(HH-LL); } TL_Delete(TL41); TL_Delete(TL42); TL_Delete(TL43); TL_Delete(TL44); TL_Delete(TL45); TL_Delete(TL46); TL41 = TL_New(sdate[ii],stime[ii],LL+diff*2.00,sdate,stime,LL+diff*2.00); TL42 = TL_New(sdate[ii],stime[ii],LL+diff*2.618,sdate,stime,LL+diff*2.618); TL43 = TL_New(sdate[ii],stime[ii],LL+diff*3.618,sdate,stime,LL+diff*3.618); TL44 = TL_New(sdate[ii],stime[ii],HH-diff*2.00,sdate,stime,HH-diff*2.00); TL45 = TL_New(sdate[ii],stime[ii],HH-diff*2.618,sdate,stime,HH-diff*2.618); TL46 = TL_New(sdate[ii],stime[ii],HH-diff*3.618,sdate,stime,HH-diff*3.618); TL_SetExtRight(TL41,true); TL_SetExtRight(TL42,true); TL_SetExtRight(TL43,true); TL_SetExtRight(TL44,true); TL_SetExtRight(TL45,true); TL_SetExtRight(TL46,true); TL_SetSize(TL41,2); TL_SetSize(TL42,2); TL_SetSize(TL43,2); TL_SetSize(TL44,2); TL_SetSize(TL45,2); TL_SetSize(TL46,2); } if T == 1 and T != T[1] and 저점[1,1] > 저점[2,1] Then Buy(); ###### 화살표 로 수정부탁드립니다 #####
프로필 이미지
매치다2
2020-08-20
790
글번호 141630
시스템
답변완료

함수 수식 부탁드립니다

어떤 조건이후 봉갯수 카운트 하는 함수가 없는 듯 합니다. 예를 들어 BarsSince(crossup(C,ma(C,20)) 와 같은 함수 부탁드립니다. 꽤 편리할 텐대요. 수고하세요~
프로필 이미지
topliss
2020-08-20
862
글번호 141629
사용자 함수
답변완료

수식부탁 드립니다

혹서기 무더위에 매번 감사드립니다. 아래의 주봉 수식을 일봉의 수식으로 변환하여 주시기바랍니다 Input : N(20); var : Energe1(0),Energe2(0); Energe1 = accumN(H-O,N)/accumN(O-L,N)*100; Energe2 = accumN(H-C,N)/accumN(C-L,N)*100; if Energe1 > Energe2 Then find(1); 감사합니다
프로필 이미지
천년대로
2020-08-20
942
글번호 141627
지표
답변완료

문의드립니다

var : T(0); var1 = dayhigh; var2 = daylow; var3 = var1-var2; value1 = var1-var3*0.236; value2 = var1-var3*0.500; value3 = var1-var3*0.764; if T <= 0 And crossup(c,value1) then { T = 1; } if T >= 0 And crossdown(c,value1) then { T = -1; } if T <= 0 And crossup(c,value3) then { T = 1; } if T >= 0 And crossdown(c,value3) then { T = -1; } Plot1(1,"지표",iff(T==1,RED,GREEN)); 위수식으로 value1, value3 을 전일고가 ,전일저가로 수정부탁드립니다``미리감사드립니다
프로필 이미지
유선
2020-08-20
820
글번호 141626
검색

매너모드 님에 의해서 삭제되었습니다.

프로필 이미지
매너모드
2020-08-20
3
글번호 141625
시스템
답변완료

부탁 드립니다.

도움에 감사 드립니다. 1)타주기(분봉용_예를 들어 10분봉 차트에서 60분봉 지표), 2)타주기(일봉용_예를 들어 60분봉 차트에서 일봉 지표) 부탁 드립니다. 미리 경배로 감사 인사 올립니다. var : src(0),sp(0),dt(0); src = (H+L)/2; sp = (4*src + 3*src[1] + 2*src[2] + src[3]) / 10.0; if CurrentBar >= 1 then { dt = (.0962*sp + .5769*(sp[2])); } 참고지표1) input :ntime(60),P(10),sig(5); var : S1(0),D1(0),TM(0),TF(0),cnt(0); var : C1(0),CC(0),VV(0),idx(0),sum1(0),mav1(0),sum2(0),mav2(0); Array : value[100](0),diff[100](0); if Bdate != Bdate[1] Then { S1 = TimeToMinutes(stime); D1 = sdate; } if D1 > 0 then { if sdate == D1 Then TM = TimeToMinutes(stime)-S1; Else TM = TimeToMinutes(stime)+1440-S1; TF = TM%ntime; if Bdate != Bdate[1] or (Bdate == Bdate[1] and ntime > 1 and TF < TF[1]) or (Bdate == Bdate[1] and ntime > 1 and TM >= TM[1]+ntime) or (Bdate == Bdate[1] and ntime == 1 and TM > TM[1]) Then { idx = idx+1; C1 = CC[1]; VV = 0; For cnt = 1 to 99 { value[cnt] = value[cnt-1][1]; diff[cnt] = diff[cnt-1][1]; } }
프로필 이미지
뮬리
2020-08-20
870
글번호 141624
지표
답변완료

문의 드립니다.

노고에 감사드립니다. 수식 부탁드립니다. ---------------------------------------------------------------------------------------- ▶분봉1개에서 진입명과 손절, 청산명을 각각 달리해서 아래와 같이 여러번 진입하려고 합니다. 아래 횟수와 순서대로 부탁드립니다. ------------------------------------ *전봉고가를 상향돌파하면 즉시 매수진입. *전봉 시가 또는 종가를 하향돌파하면 즉시 매도스위칭. *전봉고가를 상향돌파하면 즉시 매수스위칭. *전봉 시가 또는 종가를 하향돌파하면 즉시 손절. *시가+전봉레인지*0.5 = 즉시 매수진입.(분봉적용) *현재봉 시가에 오면 즉시 손절. *손절되지 않으면 다음봉 시가에 모두 청산. ------------------------------------------ 감사합니다.
프로필 이미지
군고구마
2020-08-20
833
글번호 141617
시스템
답변완료

문의드립니다

Buy("",AtMarket); Sell("",AtMarket); 이렇게 하고 우선1호가로 지정해도 체결이 잘 안되는데 어떻게 하면 '바로바로' 체결할 수 있는지요? 문의드립니다.
프로필 이미지
pheno
2020-08-24
806
글번호 141608
시스템