커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

시스템합성중에 잘안됩니다.

주시스템은 패턴매매인데 for함수때문인지 매수매도를 어디에 두어야 하는지 잘안됩니다. . 그림과 같이 빨간선일때는 매수신호만 가능. 파란선일때는 매도신호만 가능 파라볼릭 var1>0일때는 매수만 var1<0일때로 해서 매수매신호에 넣어봐도 신호가 안먹히는 것같습니다. ₩ 그리고 청산신호도 다이버전스를 이용하여 할려하는데 안먹힙니다. ㅠㅠ 필터로 pci를 쓰고 있는데 그것도 안먹히는 것같습니다. 도와주세요..감사합니다. Input:length(10); Var:j1(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL11(0), Text1(0),처리구분(""),Buysetup(0),sellsetup(0); Array:고점[10,2](0),저점[10,2](0); //가격,위치 // Input : af(0.002), maxAF(0.2); var1 = CSar(af,maxAF); if var1 > C Then Condition1=true; Else Condition1=False; // Variables: NCO(0); NCO = C - C[Length]; //pci input : Period(20); var : mo(0),cnt(0),P(0),UPsum(0),Dnsum(0),PCI(0); Array : Gredient[100](0),Updev[100](0),Dndev[100](0); P = Period-1; Mo = C-C[Period]; for cnt = 0 to P{ Gredient[cnt] = C[P]+Mo*(P-cnt)/P; } for cnt = 0 to P{ Updev[cnt] = 0; Dndev[cnt] = 0; if C[cnt] > Gredient[cnt] Then Updev[cnt] = C[cnt]-Gredient[cnt]; if C[cnt] < Gredient[cnt] Then Dndev[cnt] = Gredient[cnt]-C[cnt]; } upsum = 0; Dnsum = 0; for cnt = 0 to P{ upsum = upsum +Updev[cnt]; Dnsum = dnsum +dndev[cnt]; } PCI = upsum/(upsum+Dnsum)*100; Condition7 = pci<10 or pci>90 ; //패턴시작 처리구분 = ""; 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 { lastHiVal = H; If 고점[1,2] < 저점[1,2] Then { For j1 = 10 DownTo 2 { 고점[j1,1] = 고점[j1-1,1]; 고점[j1,2] = 고점[j1-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(TL11) == sDate[sBar] and TL_GetBeginTime(TL11) == sTime[sBar] Then { TL_Delete(TL11); Text_Delete(Text1); } TL11 = TL_New(sDate[sBar],sTime[sBar],저점[1,1], sDate[eBar],sTime[eBar],고점[1,1]); Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1], NumToStr(고점[1,1],2)); Text_SetStyle(Text1, 2, 1); if Condition7 and Condition1==True then Buy("b"); } } If 처리구분 == "저점처리" Then { lastLoVal = L; If 저점[1,2] < 고점[1,2] then { For j1 = 10 DownTo 2 { 저점[j1,1] = 저점[j1-1,1]; 저점[j1,2] = 저점[j1-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(TL11) == sDate[sBar] and TL_GetBeginTime(TL11) == sTime[sBar] Then { TL_Delete(TL11); Text_Delete(Text1); } TL11 = TL_New(sDate[sBar],sTime[sBar],고점[1,1], sDate[eBar],sTime[eBar],저점[1,1]); Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1], NumToStr(저점[1,1],2)); Text_SetStyle(Text1, 2, 0); if Condition7 and Condition1==False Then Sell("s"); } } inPUT : RsiPeriod(13),PLPeriod(2),TSLPeriod(7), BandPeriod(34), 표준편차(1.6185); var :RSIV(0), RSIPL(0), TSL(0), MidBand(0), UpBand(0),DnBand(0) ; var : TL1(0), TL2(0), TLi1(0), TLi2(0), TX1(0), TX2(0), TX3(0), TX4(0), TX5(0), TX6(0); RSIV = RSI(RSIPeriod); RSIPL = ma(RSIV,PLPeriod); //RSI_Price_Line TSL = ma(RSIV,TSLPeriod); //Trade_Signal_Line MidBand = ma(RSIV,BandPeriod); //Volatility_Band UpBand = MidBand + (표준편차 * std(RSIV, BandPeriod)); //Volatility_Band_Up DnBand = MidBand - (표준편차 * std(RSIV, BandPeriod)); //Volatility_Band_Down # if RSIPL > RSIPL[1] and RSIPL[1] < RSIPL[2] and RSIPL < 50 then { //스토캐스틱 상승반전 var1 = RSIPL[1]; var2 = var1[1]; var3 = C[1]; var4 = var3[1]; var5 = sdate[1]; var6 = var5[1]; var7 = stime[1]; var8 = var7[1]; if var1 > var2 and var3 < var4 then //지표값은 높아지고 종가는 낮아지고 var9 = 1; } else var9 = 0; if var9 == 1 then { //TL1 = TL_New(var6,var8,var4,var5,var7,var3); //TLi1= TL_New_self(var6,var8,var2,var5,var7,var1); TX1 = Text_new(var5, var7, L, "★"); //TL_SetSize(TL1, 2); //TL_SetColor(TL1, Red); //TL_SetSize(TLi1, 2); //TL_SetColor(TLi1, Red); //Text_SetColor(Tx1,Magenta); //Text_SetStyle(Tx1,0,0); } if CrossUp(RSIPL, DnBand) then { TX3 = Text_new(sdate, stime, L, "▲"); //Text_SetColor(Tx3,rgb(160,70,255)); //Text_SetStyle(Tx3,2,0); } if RSIPL < RSIPL[1] and RSIPL[1] > RSIPL[2] and RSIPL > 50 then {//스토캐스틱 하락반전 var11 = RSIPL[1]; var12 = var11[1]; var13 = C[1]; var14 = var13[1]; var15 = sdate[1]; var16 = var15[1]; var17 = stime[1]; var18 = var17[1]; if var11 < var12 and var13 > var14 then //지표값은 낮아지고 종가는 높아지고 var19 = 1; } else var19 = 0; if var19 == 1 then { //TL2 = TL_New(var16,var18,var14,var15,var17,var13); //TLi2= TL_New_self(var16,var18,var12,var15,var17,var11); TX2 = Text_new(var15, var17, H, "★"); //TL_SetSize(TL2, 2); //TL_SetColor(TL2, blue); //TL_SetSize(TLi2, 2); //TL_SetColor(TLi2, blue); //Text_SetColor(Tx2,Lcyan); //Text_SetStyle(Tx2,0,1); } if CrossDown(RSIPL, UpBand) then { TX4 = Text_new(sdate, stime, H, "▼"); //Text_SetColor(Tx4,Rgb(0,255,0)); //Text_SetStyle(Tx4,2,1); } # //plot1(RSIPL, "RSIPL",Lgreen,def,0); //plot2(TSL,"TSL",red,def,0); //plot3(MidBand,"MidBand",magenta,def,0); //plot4(UpBand,"UpBand",blue,def,0); //plot5(DnBand,"DnBand",blue,def,0); //if CrossUp(RSIPL,DnBand) then //plot6(RSIPL, "상향돌파시점"); //if CrossDown(RSIPL, UpBand) then //plot7(RSIPL, "하향이탈시점"); //if var9 == 1 then //plot8(RSIPL, "상승다이버전스"); //if var19 == 1 then //plot9(RSIPL, "하락다이버전스"); if var19 == 1 then ExitLong("매수청"); if var9 == 1 then ExitShort("매도청"); if NCO<-50 Then ExitLong("매수손"); if NCO>50 Then ExitShort("매도손");
프로필 이미지
코샘매쓰
2020-12-14
1239
글번호 144685
시스템
답변완료

검색식 재문의드립니다

안녕하십니까 어제 수식 세가지 적어주신것 감사히 받아보았습니다 다름이 아니라 제가 아래와 같은 value2~5의 지표식을 사용하다가 작성해주신 검색식들을 대입해보니 작동하지 않아서 제가 어디서 실수를 했나 싶어서 여쭤봅니다 --------------------------------------------- var : count(0),mav(0); if value1 <= 0 and SwingHigh(1,h,10,10,21) != -1 Then{ var1 = H[1]; var2 = Var1[1]; value1 = 1; if var1 > var2 and var2 > 0 and var3 > var4 and var4 > 0 Then value2 = var1; } if value1 >= 0 and SwingLow(1,L,10,10,21) != -1 Then{ var3 = L[1]; var4 = Var3[1]; value1 = -1; if var3 < var4 and var4 > 0 and var1 < var2 and var2 > 0 Then value3 = var3; } if value9 <=0 and swinghigh(1,h,30,30,61) != -1 Then{ Var5 = h[1]; Var6 = Var5[1]; Value9 = 1; if Var5 > var6 and Var6 > 0 and Var7 > Var8 and Var8 > 0 Then Value4 = Var5; } if value9 >=0 and swinglow(1,l,30,30,61) != -1 Then{ Var7 = l[1]; Var8 = Var7[1]; value9 = -1; if Var7 < Var8 and Var8 > 0 and Var5 < Var6 and Var6 > 0 Then Value5 = Var7; } mav = ma(C,120); count = 0; if Value2 < mav and value2 != value2[1] Then count = count+1; if value3 < mav and value3 != Value3[1] Then count = count+1; if value4 < mav and value4 != Value4[1] Then count = count+1; if value5 < mav and Value5 != Value5[1] Then count = count+1; if count >= 1 Then Find(1); 번거로우시겠지만 어디가 잘못되었는지 첨삭 한번 부탁드리겠습니다..
프로필 이미지
하누왕
2020-12-14
1167
글번호 144684
검색
답변완료

문의드립니다.

안녕하세요. 문의드립니다. 제가 적용하고자 하는 수식을 과거 차트에 백테스트 해보고 싶은데요. 어떻게 하면 되는지 좀 알려주세요. 그냥 지나간 차트를 보면 잘 맞지 않는 경우가 있고 오랜기간 볼 수 없는거 같아서요. 틱봉하고 분봉 보고 싶은데 방법 있을까요??
프로필 이미지
새론시작
2020-12-14
939
글번호 144683
시스템

정이품송 님에 의해서 삭제되었습니다.

프로필 이미지
정이품송
2020-12-14
1
글번호 144682
종목검색

정이품송 님에 의해서 삭제되었습니다.

프로필 이미지
정이품송
2020-12-14
0
글번호 144681
종목검색

정이품송 님에 의해서 삭제되었습니다.

프로필 이미지
정이품송
2020-12-14
1
글번호 144680
종목검색

정이품송 님에 의해서 삭제되었습니다.

프로필 이미지
정이품송
2020-12-14
0
글번호 144679
종목검색

정이품송 님에 의해서 삭제되었습니다.

프로필 이미지
정이품송
2020-12-14
0
글번호 144678
종목검색

정이품송 님에 의해서 삭제되었습니다.

프로필 이미지
정이품송
2020-12-14
0
글번호 144677
종목검색