커뮤니티

예스랭귀지 Q&A

글쓰기
답변완료

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

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

문의드립니다

안녕하세요? 아래수식에서 현재 매수매도 신호가발생하는 다음봉에서 신호가발생하게되면 합니다 감사합니다 var : sindex1(0), sindex2(0), Lindex1(0), Lindex2(0); value1 = stochasticsD(12,5,5); Condition1 = value1 > value1[1] and value1[1] <= value1[2]; Condition2 = L > L[1] and L[1] <= L[2]; sindex1 = MRO(Condition1,15,1); sindex2 = MRO(Condition1,15,2); Lindex1 = MRO(Condition2,15,1); Lindex2 = MRO(Condition2,15,2); if value1[sindex1+1] > value1[sindex2+1] and L[Lindex1+1] < L[Lindex2+1] and Condition1 and lowest(L,5) == lowest(L,15) then buy(); //// var : sindex3(0), sindex4(0), Hindex1(0), Hindex2(0); Condition11 = value1 < value1[1] and value1[1] >= value1[2]; Condition12 = H < H[1] and H[1] >= H[2]; sindex3 = MRO(Condition11,15,1); sindex4 = MRO(Condition11,15,2); Hindex1 = MRO(Condition12,15,1); Hindex2 = MRO(Condition12,15,2); if value1[sindex3+1] < value1[sindex4+1] and H[Hindex1+1] > H[Hindex2+1] and Condition11 and Highest(H,5) == Highest(H,15) then sell();
프로필 이미지
새벽에
2022-02-14
1116
글번호 156225
시스템
답변완료

수식추가 부탁드립니다.

안녕하세요? 현재 진입부분에서, 전음봉 종가보다 진입음봉 종가가 작을때 매도 전양봉 종가보다 진입양봉 종가가 클떄 매수 이렇게 되어있는데, 전봉 종가와 진입봉 종가의 차이를 외부변수를 넣고싶습니다. 부탁드립니다. 감사합니다. input : 전음봉(2),전양봉(2),진입음봉(5),진입양봉(5); input : 익절틱수(50),손절틱수(50),진입횟수(3); 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 < 진입횟수 and C[1] == O[1]-전음봉*PriceScale and C == O-진입음봉*PriceScale and C < C[1] Then Sell(); if MarketPosition == 0 and entry < 진입횟수 and C[1] == O[1]+전양봉*PriceScale and C == O+진입양봉*PriceScale and C > C[1] Then Buy(); SetStopProfittarget(PriceScale*익절틱수,PointStop); SetStopLoss(PriceScale*손절틱수,PointStop);
프로필 이미지
대구어린울프
2022-02-14
1176
글번호 156224
시스템
답변완료

75815 수식 관련 질문 드립니다

안녕하세요 이전에 120틱봉 차트를 사용할 때 직전 600틱봉 3개가 양봉이고, 현재봉의 현재가가 HB 상향돌파시 매수 직전 600틱봉 3개가 음봉이고, 현재봉의 현재가가 LB 하향돌파시 매도 이걸 어떻게 만들지를 문의해 만들어주신 수식이 있는데 어떻게 작동하는지를 보다 이해가 안되 질문을 드리게 되었습니다 당시 답변주신 수식은 아래와 같고 이해 안되는 부분을 노트해 두었습니다 input : nbars(5),N(3); input : HB(14620), LB(14530) ; var : e60(0); var : D1(0),idx(0),TF(0),Po(0),Ne(0),cnt(0); Array : OO[20](0),CC[20](0); e60 = Ema(C,60); if Bdate != Bdate[1] Then { D1 = sdate; idx = 0; } Else idx = idx+1; => 오늘 00시부터 지금까지의 120틱봉 개수 카운트 => idx = 봉 개수 if D1 > 0 then { TF = idx%nbars; => 봉을 5개 단위로 자름 1,2,3,4,5/1,2,3,4,5 if Bdate != Bdate[1] or (Bdate == Bdate[1] and TF < TF[1]) Then => 120틱봉 5개 묶음의 첫번째 봉인 경우 { OO[0] = O; for cnt = 1 to 19 { OO[cnt] = OO[cnt-1][1]; CC[cnt] = CC[cnt-1][1]; } } CC[0] = C; => 조건 이후 실행부 전반이 무엇을 의미하는 것인지가 전체적으로 잘 모르겠고 => 특히 OO[cnt] = OO[cnt-1][1]; 이걸 잘 모르겠습니다. cnt가 1이면 OO[1] = OO[0][1];인데 OO[0][1]이 의미하는게 뭔가요? if OO[n] > 0 Then { Po = 0; Ne = 0; For cnt = 1 to n { if CC[cnt] > OO[cnt] Then Po = po +1; if CC[cnt] < OO[cnt] Then Ne = Ne +1; } if Po == n then Buy("L",AtStop,HB,2) ; if Ne == n then Sell("S",AtStop,LB,2) ; } } if marketposition > 0 Then { if e60 < HB Then ExitLong("exitL1",AtStop,HB-5); if e60 >= HB and CrossDown(close, e60) Then ExitLong("exitL2") ; } if marketposition < 0 Then { if e60 > LB Then ExitShort("exitS1",AtStop,HB+5); if e60 <= LB and CrossUp(close, e60) Then ExitShort("exitS2"); } 답변부탁드리겠습니다 감사합니다!
프로필 이미지
jshwang2
2022-02-14
1171
글번호 156223
시스템
답변완료

시스템 이상 검토의뢰

수고 하십니다 ! Input : Period1(1), Period2(15), Period3(30), Period4(60), Period5(120),period6(240),Period7(480), Period8(960), Period9(1920), Period10(3840),period11(7680); var : Sma1(0),Sma2(0),Sma3(0),Sma4(0),Sma5(0),sma6(0),Sma7(0),Sma8(0),Sma9(0),Sma10(0),sma11(0),OBVV(0),PositiveVolumeIndex(0),dpo(0); var:s(0); Sma1 = ma(C,Period1); Sma2 = ma(C,Period2); Sma3 = ma(C,Period3); Sma4 = ma(C,Period4); Sma5 = ma(C,Period5); sma6 = ma(c,period6); Sma7 = ma(C,Period7); Sma8 = ma(C,Period8); Sma9 = ma(C,Period9); Sma10 = ma(C,Period10); sma11 = ma(c,period11); var : T(0); var3 = ma(C,Period3); var4 = ma(C,Period4); var5 = ma(C,Period5); var6 = ma(C,Period6); var7 = ma(C,Period7); var8 = ma(C,Period8); var9 = ma(C,Period9); var10 = ma(C,Period10); input:n4(0); var1 = ma(C,30); Var2 = ma(C,60); if CrossUp(var1,Var2) and sma3 < sma4-PriceScale*1 and sma3 < sma6-PriceScale*6 Then { T = 1; S = Var2; if T[1] == -2 Then Buy(); } if CrossDown(var1,Var2) and sma3 > sma4+PriceScale*1 and sma3 > sma6 +PriceScale*20 Then { T = -1; S = Var2; if T[1] == 2 Then Sell(); } if T == 1 and C >= S+PriceScale*n4 Then T = 2; if T == -1 and C <= S-PriceScale*n4 Then T = -2; SetStopLoss(PriceScale*50,PointStop); 틱의 가격을 시스템에서 적용이 되지를 않아서 틱 가격을 여러숫자로 적용을 해봐도 안되네요! 그래서 0 으로 해봐도 안되어 다시 의뢰 드립니다. 정히 안되면 청산후 청산가격보다 10 틱 이상 상하로 가격차이가 나고 매매 신호가 적용이 될때 체결하는 것 으로 수식작성을 다시한번 부탁 드립니다 . 예를들면 이평선 3선과 4선이 크로즈업 하여 매수를 하고 10틱이 올라 수익이 났을때 청산을 하고 청산가격보다 상하로 10틱이상 차이가 나고 3선과 4선이 크로즈업을 할때는 매수를 3선과 4선이 크로즈다운 할때는 매도를 하고 10틱이상 수익이 날때 청산을 하는 수식으로 부탁 드립니다. 수고 하세요 !
프로필 이미지
tnsflwls
2022-02-14
1118
글번호 156222
시스템
답변완료

늘 고맙습니다

늘 고맙습니다 data2 를 사용하는데 현재가 >= 오늘 시가 <== 이것을 표현하고 싶습니다 closed(0) >= opend(0) 인가요 data2(closed(0)) >= data2(opend(0)) 인가요? 늘 고맙습니다 수고하세요
프로필 이미지
안미남
2022-02-14
983
글번호 156221
시스템
답변완료

수식

하기 수익에 대한 수정 부탁드립니다. plot1,plot2 수평선이 당일 발생분은 당일 종가까지만 생성되고 다음날에는 연장 되지 않도록 부탁드립니다. (이전일에 발생한것은 삭제가 아닙니다) 감사합니다. input : af(0.02), AFMAX(0.2); var : T(0),HH(0),LL(0),HD(0),HT(0),LD(0),LT(0),TL1(0),TL2(0),cnt(0),count(0); var : HH1(0),LL1(0),HD1(0),HT1(0),LD1(0),LT1(0),DarkGray(0); var : ni(0),nP(0),nN(0),tx1(0),tx2(0),hi(0),li(0); Var : Direction(0), SAR_Value(Close), AF_Value(.02), HighValue(High), LowValue(Low), EP(0),CSarv(0); if Index == 0 or Bdate != Bdate[1] Then { Direction = 0; SAR_Value = C; AF_Value = 0.02; HighValue = High; LowValue = Low; EP = 0; } if EP != 0 Then { if Direction == 1 then { EP = HighValue; SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value); if High > HighValue then { HighValue = High; AF_Value = AF_Value + AF; if AF_Value >= AFMAX then AF_Value = AFMAX; } if Close < SAR_Value then { Direction = -1; SAR_Value = EP; AF_Value = 0; EP = 0; LowValue = low; } } else { EP = LowValue; SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value); if Low < LowValue then { LowValue = Low; AF_Value = AF_Value + Af; if AF_Value >= AFMAX then AF_Value = AFMAX; } if Close > SAR_Value then { Direction = 1; SAR_Value = EP; AF_Value = 0; EP = 0; HighValue = High; } } CSarv = SAR_Value; } else { if SAR_Value != 0 && EP == 0 then { if Direction == 1 then { EP = HighValue; AF_Value = AF; SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value); if High > HighValue then { HighValue = High; AF_Value = AF_Value + AF; if AF_Value >= AFMAX then AF_Value = AFMAX; } } else { EP = LowValue; AF_Value = Af; SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value); if Low < LowValue then { LowValue = Low; AF_Value = AF_Value + AF; if AF_Value >= AFMAX then AF_Value = AFMAX; } } CSarv = SAR_Value; } else { if Direction == 0 then { if Close > Close[1] then Direction = 1; else if Close < Close[1] then Direction = -1; } else { if Direction == 1 then { if Close < Close[1] then { Direction = -1; SAR_Value = HighValue; CSarv = SAR_Value; } } if Direction == -1 then { if Close > Close[1] then { Direction = 1; SAR_Value = LowValue; CSarv = SAR_Value; } } } LowValue = min(Low, LowValue); HighValue = max(High, HighValue); } } //Plot10(CSarv); if (crossup(C,CSarv[1]) or crossup(C,CSarv[2]) or crossup(C,CSarv[3])) and (C >= CSarv or C >= CSarv[1]) Then value1 = CSarv; if (CrossDown(C,CSarv[1]) or CrossDown(C,CSarv[2]) or CrossDown(C,CSarv[3])) and (C <= CSarv or C <= CSarv[1]) Then value2 = CSarv; plot1(value1,"양수평"); plot2(value2,"음수평");
프로필 이미지
한국사람73
2022-02-13
1331
글번호 156220
지표
답변완료

수식 수정 요청

안녕하세요. true 라인이 먼저 생성 되었다가 고,저 라인이 만들어지면 바로 없어 지는데 반대 true라인이 생성 될때 까지 유지 될수 있도록 수식 수정 부탁 드립니다. 고,저 라인은 우측 끝까지 그려지지 않고 확정 캔들 까지만 그려지기 때문에 사용에 불편함이 있어서 입니다. Input:length(12); Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),TL2(0),TL3(0), Text1(0),처리구분(""),T(0),TL21(0),TL31(0); Array:고점[10,2](0),저점[10,2](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); TL_Delete(TL21); Text_Delete(Text1); } TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); TL2 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); // TL21 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+PriceScale*10,sDate[eBar],sTime[eBar],저점[1,1]+PriceScale*10); Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1], NumToStr(고점[1,1],2)); Text_SetStyle(Text1, 2, 1); TL_SetSize(TL2,3); TL_SetColor(TL2,REd); //저점 TL_SetSize(TL21,1); TL_SetColor(TL21,YELLOw); //저점 } } 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(TL2); TL_Delete(TL21); Text_Delete(Text1); } TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]); TL2 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],고점[1,1]); // TL21 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-PriceScale*10,sDate[eBar],sTime[eBar],고점[1,1]-PriceScale*10); Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],1)); Text_SetStyle(Text1, 2, 10); TL_SetSize(TL2,3); TL_SetColor(TL2,BLUe); TL_SetSize(TL21,1); TL_SetColor(TL21,YELLOw); } } TL_SetSize(TL1,1); TL_SetColor(TL1,GRAy); TL_Delete(TL3); TL_Delete(TL31); if T == 1 then { TL3 = TL_New(sDate[index-고점[1,2]],sTime[index-고점[1,2]],고점[1,1],sDate,sTime,고점[1,1]); // TL31 = TL_New(sDate[index-고점[1,2]],sTime[index-고점[1,2]],고점[1,1]-PriceScale*10,sDate,sTime,고점[1,1]-PriceScale*10); TL_SetColor(TL3,BLUe); TL_SetSize(TL3,3); TL_SetExtRight(TL3,true); TL_SetColor(TL31,YELLOw); TL_SetSize(TL31,1); TL_SetExtRight(TL31,true); } if T == -1 then { TL3 = TL_New(sDate[index-저점[1,2]],sTime[index-저점[1,2]],저점[1,1],sDate,sTime,저점[1,1]); // TL31 = TL_New(sDate[index-저점[1,2]],sTime[index-저점[1,2]],저점[1,1]+PriceScale*10,sDate,sTime,저점[1,1]+PriceScale*10); TL_SetColor(TL3,REd); //저점 TL_SetSize(TL3,3); TL_SetExtRight(TL3,true); TL_SetColor(TL31,YELLOw); //저점 TL_SetSize(TL31,1); TL_SetExtRight(TL31,true); } 감사합니다.
프로필 이미지
참아람
2022-02-13
1101
글번호 156219
지표
답변완료

문의 드립니다!

안녕하세요! 아래수식은 얼마전에 답변해주신것인데요 이것을 아래와같이 한번더 수정부탁드립니다 1, 아래 원본수식에서 plot2(var2+var3*0.500,"중심");<== 이부분만 남겨놓고 나머지 부분은 모두 삭제하여 일단 간략하게 수정해주시구요 2, 이 수정된 수식을 원본으로해서 아래와같이 다시한번 검토 부탁드립니다 * 아래 작성해주신 수식에서 음성신호는 발생되는듯하나 세로선이 나타나지않네요 즉, 1) data1(풋캔들)과 data2(콜캔들)을 설정한 교차챠트에서 2) 이 수식의 plot2 선과 챠트상의 data1 혹은 data2 캔들이 만날때마다 각각 모두 세로선과 알람신호가 발생되었으면합니다 (* 선의 두께와 색은 임의로 조정가능토록 부탁드립니다) 수고스러우시겠지만 한번더 검토 부탁드립니다!!! * 참고로 아래 작성해주신 수식에서 ***표시및 밑줄그은 부분이 혹시 data2가 아닌지요? (2군데 입니다) ----------------------------------------------------- 안녕하세요 예스스탁입니다. input : 색1(RED),굵기1(1); input : 색2(BLUE),굵기2(1); input : 색3(GREEN),굵기3(1); input : 색4(YELLOW),굵기4(1); var : d1month(0,Data1),d1nday(0,Data1),d1week(0,Data1); var : d1EX(false,Data1),d1HH(0,Data1),d1LL(0,Data1),d1OO(0,Data1),d1plot2(0,Data1); var : d1CC(0,Data1),d1DD(0,Data1),d1HH1(0,Data1),d1LL1(0,Data1),d1OO1(0,Data1),d1cond1(False,Data1); var : d1var1(0,Data1),d1var2(0,Data1),d1var3(0,Data1),d1var4(0,Data1),d1var5(0,Data1),d1var6(0,Data1); var : d2month(0,Data2),d2nday(0,Data2),d2week(0,Data2); var : d2EX(false,Data2),d2HH(0,Data2),d2LL(0,Data2),d2OO(0,Data2),d2plot2(0,Data1);==> *** 맨오른쪽 부분이 혹 Data2가 아닌지요? var : d2CC(0,Data2),d2DD(0,Data2),d2HH1(0,Data2),d2LL1(0,Data2),d2OO1(0,Data2),d2cond1(False,Data2); var : d2var1(0,Data2),d2var2(0,Data2),d2var3(0,Data2),d2var4(0,Data2),d2var5(0,Data2),d2var6(0,Data2); var : tl(0); #Data1 d1month = data1(int(date/100)-int(date/10000)*100); d1nday = data1(date - int(date/100)*100); d1week = data1(DayOfWeek(date)); #선물만기 #if d1Month%3 == 0 and d1nday >= 8 and d1nday <= 14 and d1week == 4 then if d1nday >= 8 and d1nday <= 14 and d1week == 4 then#옵션만기 d1EX = true; Else d1EX = false; if d1EX == false and d1EX[1] == true Then { d1Cond1 = true; d1DD = sDate; d1HH = data1(H); d1LL = data1(L); d1OO = data1(O); d1CC = data1(C); d1HH1 = d1HH[1]; d1LL1 = d1LL[1]; d1OO1 = d1OO[1]; } if d1Cond1 == true then { if data1(H) > d1HH Then d1HH = data1(H); if data1(L) < d1LL Then d1LL = data1(L); d1var1 = d1HH; d1var2 = d1LL; d1var3 = d1var1-d1var2; d1plot2 = d1var2+d1var3*0.500; plot1(d1var1,"Maxi"); plot2(d1var2+d1var3*0.500,"중심"); plot3(d1var2,"Mini"); if sDate == d1DD Then { d1Var4 = data1(OpenD(0)); d1Var5 = data1(HighD(0)); d1Var6 = data1(LowD(0)); } Plot4(d1Var4,"첫날시가",IFf(d1oo1 < data1(OpenD(0)) ,MAGENTA,BLUE)); if d1HH1 > 0 and d1LL1 > 0 Then { Plot5(d1HH1,"전월물최고"); Plot6(d1LL1,"전월물최저"); } } #Data1====> *** 이부분도 혹 data2가 아닌지요? ------ d2month = data2(int(date/100)-int(date/10000)*100); d2nday = data2(date - int(date/100)*100); d2week = data2(DayOfWeek(date)); #선물만기 #if d2Month%3 == 0 and d2nday >= 8 and d2nday <= 14 and d2week == 4 then if d2nday >= 8 and d2nday <= 14 and d2week == 4 then#옵션만기 d2EX = true; Else d2EX = false; if d2EX == false and d2EX[1] == true Then { d2Cond1 = true; d2DD = sDate; d2HH = data2(H); d2LL = data2(L); d2OO = data2(O); d2CC = data2(C); d2HH1 = d2HH[1]; d2LL1 = d2LL[1]; d2OO1 = d2OO[1]; } if d2Cond1 == true then { if data2(H) > d2HH Then d2HH = data2(H); if data2(L) < d2LL Then d2LL = data2(L); d2var1 = d2HH; d2var2 = d2LL; d2var3 = d2var1-d2var2; d2plot2 = d1var2+d1var3*0.500; plot7(d2var1,"Maxi"); plot8(d2var2+d2var3*0.500,"중심"); plot9(d2var2,"Mini"); if sDate == d2DD Then { d2Var4 = data2(OpenD(0)); d2Var5 = data2(HighD(0)); d2Var6 = data2(LowD(0)); } Plot10(d2Var4,"첫날시가",IFf(d2oo1 < data2(OpenD(0)) ,MAGENTA,BLUE)); if d2HH1 > 0 and d2LL1 > 0 Then { Plot11(d2HH1,"전월물최고"); Plot12(d2LL1,"전월물최저"); } } if Data1(CrossUp(h,d1plot2) or CrossDown(l,d1plot2)) Then { tl = TL_New_Self(sDate,sTime,0,sDate,sTime,99999999); TL_SetColor(tl,색1); TL_SetSize(Tl,굵기1); PlaySound(""); } if Data2(CrossUp(h,d1plot2) or CrossDown(l,d1plot2)) Then { tl = TL_New_Self(sDate,sTime,0,sDate,sTime,99999999); TL_SetColor(tl,색2); TL_SetSize(Tl,굵기2); PlaySound(""); } if Data1(CrossUp(h,d2plot2) or CrossDown(l,d2plot2)) Then { tl = TL_New_Self(sDate,sTime,0,sDate,sTime,99999999); TL_SetColor(tl,색3); TL_SetSize(Tl,굵기3); PlaySound(""); } if Data2(CrossUp(h,d2plot2) or CrossDown(l,d2plot2)) Then { tl = TL_New_Self(sDate,sTime,0,sDate,sTime,99999999); TL_SetColor(tl,색4); TL_SetSize(Tl,굵기4); PlaySound(""); } 즐거운 하루되세요 > 유로파54 님이 쓴 글입니다. > 제목 : 문의 드립니다! > 안녕하세요! 아래수식에서 plot2와 캔들이 만날때 세로선과 알람신호가 발생토록 부탁드립니다 * data1(풋)과 data2(콜)를 설정한 교차챠트의 2개캔들 모두에 이지표를 적용하고자 하는데요 이때 상대캔들과 이지표가 만날때도 세로선이 발생토록 부탁드립니다 즉, 콜캔들에 적용한 지표에 풋캔들이 만났을때와 이 반대의 경우도 해당됩니다 (* 선의 두께와 색은 임의로 조정가능토록 부탁드립니다) 항상 친절하고 자세히 도와주심에 진심으로 감사드립니다 ----------------------------------------------------- var : month(0),nday(0),week(0); var :EX(false),HH(0),LL(0),OO(0),CC(0),DD(0),HH1(0),LL1(0),OO1(0); month = int(date/100)-int(date/10000)*100; nday = date - int(date/100)*100; week = DayOfWeek(date); #선물만기 #if Month%3 == 0 and nday >= 8 and nday <= 14 and week == 4 then if nday >= 8 and nday <= 14 and week == 4 then#옵션만기 EX = true; Else EX = false; if EX == false and EX[1] == true Then{ Condition1 = true; DD = sDate; HH = H; LL = L; OO = O; CC = C; HH1 = HH[1]; LL1 = LL[1]; OO1 = OO[1]; } if Condition1 == true then { if H > HH Then HH = H; if L < LL Then LL = L; var1 = HH; var2 = LL; var3 = var1-var2; plot1(var1,"Maxi"); plot2(var2+var3*0.500,"중심"); plot3(var2,"Mini"); if sDate == DD Then { Var4 = DayOpen; Var5 = DayHigh; Var6 = DayLow; } Plot4(Var4,"첫날시가",IFf(oo1 < DayOpen(0) ,MAGENTA,BLUE)); if HH1 > 0 and LL1 > 0 Then { Plot5(HH1,"전월물최고"); Plot6(LL1,"전월물최저"); } }
프로필 이미지
유로파54
2022-02-13
853
글번호 156218
지표
답변완료

부탁 드립니다.

도움에 감사 드립니다. 그림과 같이 부탁 드립니다. input:선택(true); var :sum(0,data2); var7=data2(c); if bdate != Bdate[1] Then{ Var7=0; sum = 0;} sum = sum +var7; var:cond15(false); var91=151900; if (stime == var91 or (stime > var91 and stime[1] < var91)) then{ cond15 = 선택; } if (stime == var91 or (stime > var91 and stime[1] < var91 )) Then Cond15 = false; if cond15 == 선택 then{ Plot1(sum);} PlotBaseLine1(0);
프로필 이미지
yes
2022-02-12
1213
글번호 156217
지표