커뮤니티

트렌드 쓰리바닥

프로필 이미지
고성
2022-12-28 12:27:16
1293
글번호 164931
답변완료
inputs: ATRLength(15), Strength(18), 폭(0.25); input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2); input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2); var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0); var : idx(0),hh(0),ll(0),EP1(0),EP2(0); var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0); var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0); Ep1 = 2/(ATRLength+1); Ep2 = 2/(Strength+1); idx = idx+1; if idx < ATRLength Then { hh = DayHigh; ll = daylow; } Else { hh = Highest(High, ATRLength); ll = Lowest(Low, ATRLength); } if idx < Strength Then { h1 = DayHigh; l1 = daylow; } Else { h1 = Highest(High, Strength); l1 = Lowest(Low, Strength); } hl = hh-ll; if idx == 1 Then { ema1 = hl; ema2 = h; ema3 = l; } Else { ema1 = hl * EP1 + ema1 * (1-EP1); ema2 = h * EP2 + ema2 * (1-EP2); ema3 = l * EP2 + ema3 * (1-EP2); } atrv = ema1; avgv = (ema2+ema3)/2; upv = avgv + ATRv; dnv = avgv - ATRv; if idx >= 2 then { if c > upv[1] and c > h1[1] then trend = 1; else if c < dnv[1] and c < l1[1] then trend = -1; if trend < 0 and trend[1] > 0 then flag=1; else flag=0; if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0; if trend > 0 and dnv < dnv[1] then dnv=dnv[1]; if trend < 0 and upv > upv[1] then upv=upv[1]; if flag == 1 then upv = avgv + ATRv; if flagh == 1 then dnv = avgv - ATRv; if trend == 1 then ST = dnv; else ST = upv; STrend = trend; } Plot1(st,"SuperTrend",iff(strend == 1,red,blue)); if Trend != Trend[1] Then { if Trend == 1 Then { var1 = h; var2 = var1[1]; TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999); TL_SetColor(TL,Red); TL_SetSize(TL,0.5); tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx,Red); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Magenta); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Lime); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } } Else { Var3 = l; Var4 = Var3[1]; tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx,Blue); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Cyan); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Green); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } } } Else { if Trend == 1 Then { if h > var1 Then var1 = h; } if Trend == -1 Then { if l < var3 Then var3 = l; } } if Trend != Trend[1] Then { if Trend == 1 Then { h2 = h; h3 = h2[1]; h4 = h3[1]; if L4 > 0 and max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then { tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx1,Black); Text_SetSize(tx1,20); Text_SetStyle(tx1,2,2); } } Else { L2 = l; l3 = l2[1]; l4 = l3[1]; } } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then L2 = l; } } Condition1 = False; if max(l3,l4) <= min(l3,l4)+0.25 Then { Condition1 = true; tx3 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx3,Orange); Text_SetSize(tx3,10); Text_SetStyle(tx3,2,2); } if Condition1 == true and l2 < max(L3,l4)-0.25 Then { Condition1 = False; Text_Delete(tx3); } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then { L2 = l; if Condition1 == true and l2 < max(L3,l4)-0.25 Then { Condition1 = False; Text_Delete(tx3); } } } } 0.25p 내에서 쓰리바닥을 형성하는지 실시간으로 보기위한 수식을 190줄 아래에 추가했는데 오류가 나오네요. 수정 부탁합니다. 1.트렌드 선이 음전환될 때, 직전저점과 전전저점의 차이가 상하 무관하게 0.25p 이내이면 트렌드 음선 상단에 동그라미 표시.두 저점 차이가 0.25p 이상이면 무표시. 2.동그라미 삭제 시점:직전저점과 전전저점중에 높은 저점을 기준으로 하여 a.아래로 0.25p 도달하기 전에 양전환시. b.계속 하락하여 -0.25p를 하향 붕괴할 때. 늘 감사합니다.
지표
답변 3
프로필 이미지

예스스탁 예스스탁 답변

2022-12-28 14:47:00

안녕하세요 예스스탁입니다. inputs: ATRLength(15), Strength(18), 폭(0.25); input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2); input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2); var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0); var : idx(0),hh(0),ll(0),EP1(0),EP2(0); var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0); var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0); Ep1 = 2/(ATRLength+1); Ep2 = 2/(Strength+1); idx = idx+1; if idx < ATRLength Then { hh = DayHigh; ll = daylow; } Else { hh = Highest(High, ATRLength); ll = Lowest(Low, ATRLength); } if idx < Strength Then { h1 = DayHigh; l1 = daylow; } Else { h1 = Highest(High, Strength); l1 = Lowest(Low, Strength); } hl = hh-ll; if idx == 1 Then { ema1 = hl; ema2 = h; ema3 = l; } Else { ema1 = hl * EP1 + ema1 * (1-EP1); ema2 = h * EP2 + ema2 * (1-EP2); ema3 = l * EP2 + ema3 * (1-EP2); } atrv = ema1; avgv = (ema2+ema3)/2; upv = avgv + ATRv; dnv = avgv - ATRv; if idx >= 2 then { if c > upv[1] and c > h1[1] then trend = 1; else if c < dnv[1] and c < l1[1] then trend = -1; if trend < 0 and trend[1] > 0 then flag=1; else flag=0; if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0; if trend > 0 and dnv < dnv[1] then dnv=dnv[1]; if trend < 0 and upv > upv[1] then upv=upv[1]; if flag == 1 then upv = avgv + ATRv; if flagh == 1 then dnv = avgv - ATRv; if trend == 1 then ST = dnv; else ST = upv; STrend = trend; } Plot1(st,"SuperTrend",iff(strend == 1,red,blue)); if Trend != Trend[1] Then { if Trend == 1 Then { var1 = h; var2 = var1[1]; TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999); TL_SetColor(TL,Red); TL_SetSize(TL,0.5); tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx,Red); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Magenta); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Lime); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } } Else { Var3 = l; Var4 = Var3[1]; tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx,Blue); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Cyan); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Green); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } } } Else { if Trend == 1 Then { if h > var1 Then var1 = h; } if Trend == -1 Then { if l < var3 Then var3 = l; } } if Trend != Trend[1] Then { if Trend == 1 Then { h2 = h; h3 = h2[1]; h4 = h3[1]; if L4 > 0 and max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then { tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx1,Black); Text_SetSize(tx1,20); Text_SetStyle(tx1,2,2); } if Condition1 == true and max(l2,l3,l4) > min(l2,l3,l4)+폭 Then { Condition1 = False; Text_Delete(tx3); } } Else #음전환 { L2 = l; l3 = l2[1]; l4 = l3[1]; Condition1 = False; if L4 > 0 and max(l3,l4) <= min(L3,L4)+폭 Then { tx3 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx3,Orange); Text_SetSize(tx3,10); Text_SetStyle(tx3,2,2); Condition1 = true; } if Condition1 == true and l2 < max(l3,l4)-폭 Then { Condition1 = False; Text_Delete(tx3); } } } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then { L2 = l; if Condition1 == true and l2 < max(l3,l4)-폭 Then { Condition1 = False; Text_Delete(tx3); } } } } 즐거운 하루되세요 > 고성 님이 쓴 글입니다. > 제목 : 트렌드 쓰리바닥 > inputs: ATRLength(15), Strength(18), 폭(0.25); input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2); input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2); var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0); var : idx(0),hh(0),ll(0),EP1(0),EP2(0); var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0); var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0); Ep1 = 2/(ATRLength+1); Ep2 = 2/(Strength+1); idx = idx+1; if idx < ATRLength Then { hh = DayHigh; ll = daylow; } Else { hh = Highest(High, ATRLength); ll = Lowest(Low, ATRLength); } if idx < Strength Then { h1 = DayHigh; l1 = daylow; } Else { h1 = Highest(High, Strength); l1 = Lowest(Low, Strength); } hl = hh-ll; if idx == 1 Then { ema1 = hl; ema2 = h; ema3 = l; } Else { ema1 = hl * EP1 + ema1 * (1-EP1); ema2 = h * EP2 + ema2 * (1-EP2); ema3 = l * EP2 + ema3 * (1-EP2); } atrv = ema1; avgv = (ema2+ema3)/2; upv = avgv + ATRv; dnv = avgv - ATRv; if idx >= 2 then { if c > upv[1] and c > h1[1] then trend = 1; else if c < dnv[1] and c < l1[1] then trend = -1; if trend < 0 and trend[1] > 0 then flag=1; else flag=0; if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0; if trend > 0 and dnv < dnv[1] then dnv=dnv[1]; if trend < 0 and upv > upv[1] then upv=upv[1]; if flag == 1 then upv = avgv + ATRv; if flagh == 1 then dnv = avgv - ATRv; if trend == 1 then ST = dnv; else ST = upv; STrend = trend; } Plot1(st,"SuperTrend",iff(strend == 1,red,blue)); if Trend != Trend[1] Then { if Trend == 1 Then { var1 = h; var2 = var1[1]; TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999); TL_SetColor(TL,Red); TL_SetSize(TL,0.5); tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx,Red); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Magenta); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Lime); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } } Else { Var3 = l; Var4 = Var3[1]; tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx,Blue); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Cyan); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Green); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } } } Else { if Trend == 1 Then { if h > var1 Then var1 = h; } if Trend == -1 Then { if l < var3 Then var3 = l; } } if Trend != Trend[1] Then { if Trend == 1 Then { h2 = h; h3 = h2[1]; h4 = h3[1]; if L4 > 0 and max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then { tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx1,Black); Text_SetSize(tx1,20); Text_SetStyle(tx1,2,2); } } Else { L2 = l; l3 = l2[1]; l4 = l3[1]; } } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then L2 = l; } } Condition1 = False; if max(l3,l4) <= min(l3,l4)+0.25 Then { Condition1 = true; tx3 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx3,Orange); Text_SetSize(tx3,10); Text_SetStyle(tx3,2,2); } if Condition1 == true and l2 < max(L3,l4)-0.25 Then { Condition1 = False; Text_Delete(tx3); } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then { L2 = l; if Condition1 == true and l2 < max(L3,l4)-0.25 Then { Condition1 = False; Text_Delete(tx3); } } } } 0.25p 내에서 쓰리바닥을 형성하는지 실시간으로 보기위한 수식을 190줄 아래에 추가했는데 오류가 나오네요. 수정 부탁합니다. 1.트렌드 선이 음전환될 때, 직전저점과 전전저점의 차이가 상하 무관하게 0.25p 이내이면 트렌드 음선 상단에 동그라미 표시.두 저점 차이가 0.25p 이상이면 무표시. 2.동그라미 삭제 시점:직전저점과 전전저점중에 높은 저점을 기준으로 하여 a.아래로 0.25p 도달하기 전에 양전환시. b.계속 하락하여 -0.25p를 하향 붕괴할 때. 늘 감사합니다.
프로필 이미지

고성

2022-12-28 15:56:28

> 예스스탁 님이 쓴 글입니다. > 제목 : Re : 트렌드 쓰리바닥 > 안녕하세요 예스스탁입니다. inputs: ATRLength(15), Strength(18), 폭(0.25); input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2); input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2); var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0); var : idx(0),hh(0),ll(0),EP1(0),EP2(0); var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0); var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0); Ep1 = 2/(ATRLength+1); Ep2 = 2/(Strength+1); idx = idx+1; if idx < ATRLength Then { hh = DayHigh; ll = daylow; } Else { hh = Highest(High, ATRLength); ll = Lowest(Low, ATRLength); } if idx < Strength Then { h1 = DayHigh; l1 = daylow; } Else { h1 = Highest(High, Strength); l1 = Lowest(Low, Strength); } hl = hh-ll; if idx == 1 Then { ema1 = hl; ema2 = h; ema3 = l; } Else { ema1 = hl * EP1 + ema1 * (1-EP1); ema2 = h * EP2 + ema2 * (1-EP2); ema3 = l * EP2 + ema3 * (1-EP2); } atrv = ema1; avgv = (ema2+ema3)/2; upv = avgv + ATRv; dnv = avgv - ATRv; if idx >= 2 then { if c > upv[1] and c > h1[1] then trend = 1; else if c < dnv[1] and c < l1[1] then trend = -1; if trend < 0 and trend[1] > 0 then flag=1; else flag=0; if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0; if trend > 0 and dnv < dnv[1] then dnv=dnv[1]; if trend < 0 and upv > upv[1] then upv=upv[1]; if flag == 1 then upv = avgv + ATRv; if flagh == 1 then dnv = avgv - ATRv; if trend == 1 then ST = dnv; else ST = upv; STrend = trend; } Plot1(st,"SuperTrend",iff(strend == 1,red,blue)); if Trend != Trend[1] Then { if Trend == 1 Then { var1 = h; var2 = var1[1]; TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999); TL_SetColor(TL,Red); TL_SetSize(TL,0.5); tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx,Red); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Magenta); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Lime); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } } Else { Var3 = l; Var4 = Var3[1]; tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx,Blue); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Cyan); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Green); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } } } Else { if Trend == 1 Then { if h > var1 Then var1 = h; } if Trend == -1 Then { if l < var3 Then var3 = l; } } if Trend != Trend[1] Then { if Trend == 1 Then { h2 = h; h3 = h2[1]; h4 = h3[1]; if L4 > 0 and max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then { tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx1,Black); Text_SetSize(tx1,20); Text_SetStyle(tx1,2,2); } if Condition1 == true and max(l2,l3,l4) > min(l2,l3,l4)+폭 Then { Condition1 = False; Text_Delete(tx3); } } Else #음전환 { L2 = l; l3 = l2[1]; l4 = l3[1]; Condition1 = False; if L4 > 0 and max(l3,l4) <= min(L3,L4)+폭 Then { tx3 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx3,Orange); Text_SetSize(tx3,10); Text_SetStyle(tx3,2,2); Condition1 = true; } if Condition1 == true and l2 < max(l3,l4)-폭 Then { Condition1 = False; Text_Delete(tx3); } } } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then { L2 = l; if Condition1 == true and l2 < max(l3,l4)-폭 Then { Condition1 = False; Text_Delete(tx3); } } } } 즐거운 하루되세요 > 고성 님이 쓴 글입니다. > 제목 : 트렌드 쓰리바닥 > inputs: ATRLength(15), Strength(18), 폭(0.25); input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2); input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2); var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0); var : idx(0),hh(0),ll(0),EP1(0),EP2(0); var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0); var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0); Ep1 = 2/(ATRLength+1); Ep2 = 2/(Strength+1); idx = idx+1; if idx < ATRLength Then { hh = DayHigh; ll = daylow; } Else { hh = Highest(High, ATRLength); ll = Lowest(Low, ATRLength); } if idx < Strength Then { h1 = DayHigh; l1 = daylow; } Else { h1 = Highest(High, Strength); l1 = Lowest(Low, Strength); } hl = hh-ll; if idx == 1 Then { ema1 = hl; ema2 = h; ema3 = l; } Else { ema1 = hl * EP1 + ema1 * (1-EP1); ema2 = h * EP2 + ema2 * (1-EP2); ema3 = l * EP2 + ema3 * (1-EP2); } atrv = ema1; avgv = (ema2+ema3)/2; upv = avgv + ATRv; dnv = avgv - ATRv; if idx >= 2 then { if c > upv[1] and c > h1[1] then trend = 1; else if c < dnv[1] and c < l1[1] then trend = -1; if trend < 0 and trend[1] > 0 then flag=1; else flag=0; if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0; if trend > 0 and dnv < dnv[1] then dnv=dnv[1]; if trend < 0 and upv > upv[1] then upv=upv[1]; if flag == 1 then upv = avgv + ATRv; if flagh == 1 then dnv = avgv - ATRv; if trend == 1 then ST = dnv; else ST = upv; STrend = trend; } Plot1(st,"SuperTrend",iff(strend == 1,red,blue)); if Trend != Trend[1] Then { if Trend == 1 Then { var1 = h; var2 = var1[1]; TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999); TL_SetColor(TL,Red); TL_SetSize(TL,0.5); tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx,Red); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Magenta); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Lime); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } } Else { Var3 = l; Var4 = Var3[1]; tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx,Blue); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Cyan); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Green); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } } } Else { if Trend == 1 Then { if h > var1 Then var1 = h; } if Trend == -1 Then { if l < var3 Then var3 = l; } } if Trend != Trend[1] Then { if Trend == 1 Then { h2 = h; h3 = h2[1]; h4 = h3[1]; if L4 > 0 and max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then { tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx1,Black); Text_SetSize(tx1,20); Text_SetStyle(tx1,2,2); } } Else { L2 = l; l3 = l2[1]; l4 = l3[1]; } } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then L2 = l; } } Condition1 = False; if max(l3,l4) <= min(l3,l4)+0.25 Then { Condition1 = true; tx3 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx3,Orange); Text_SetSize(tx3,10); Text_SetStyle(tx3,2,2); } if Condition1 == true and l2 < max(L3,l4)-0.25 Then { Condition1 = False; Text_Delete(tx3); } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then { L2 = l; if Condition1 == true and l2 < max(L3,l4)-0.25 Then { Condition1 = False; Text_Delete(tx3); } } } } 0.25p 내에서 쓰리바닥을 형성하는지 실시간으로 보기위한 수식을 190줄 아래에 추가했는데 오류가 나오네요. 수정 부탁합니다. 1.트렌드 선이 음전환될 때, 직전저점과 전전저점의 차이가 상하 무관하게 0.25p 이내이면 트렌드 음선 상단에 동그라미 표시.두 저점 차이가 0.25p 이상이면 무표시. 2.동그라미 삭제 시점:직전저점과 전전저점중에 높은 저점을 기준으로 하여 a.아래로 0.25p 도달하기 전에 양전환시. b.계속 하락하여 -0.25p를 하향 붕괴할 때. 늘 감사합니다. 재문의:추가한 수식의 동그라미가 실시간 삭제가 안됩니다. (기존 다른 동그라미는 보존)
프로필 이미지

예스스탁 예스스탁 답변

2022-12-28 16:25:44

안녕하세요 예스스탁입니다. 양전환되면 별도조건없이 삭제하게 수정해 드립니다. inputs: ATRLength(15), Strength(18), 폭(0.25); input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2); input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2); var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0); var : idx(0),hh(0),ll(0),EP1(0),EP2(0); var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0); var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0); Ep1 = 2/(ATRLength+1); Ep2 = 2/(Strength+1); idx = idx+1; if idx < ATRLength Then { hh = DayHigh; ll = daylow; } Else { hh = Highest(High, ATRLength); ll = Lowest(Low, ATRLength); } if idx < Strength Then { h1 = DayHigh; l1 = daylow; } Else { h1 = Highest(High, Strength); l1 = Lowest(Low, Strength); } hl = hh-ll; if idx == 1 Then { ema1 = hl; ema2 = h; ema3 = l; } Else { ema1 = hl * EP1 + ema1 * (1-EP1); ema2 = h * EP2 + ema2 * (1-EP2); ema3 = l * EP2 + ema3 * (1-EP2); } atrv = ema1; avgv = (ema2+ema3)/2; upv = avgv + ATRv; dnv = avgv - ATRv; if idx >= 2 then { if c > upv[1] and c > h1[1] then trend = 1; else if c < dnv[1] and c < l1[1] then trend = -1; if trend < 0 and trend[1] > 0 then flag=1; else flag=0; if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0; if trend > 0 and dnv < dnv[1] then dnv=dnv[1]; if trend < 0 and upv > upv[1] then upv=upv[1]; if flag == 1 then upv = avgv + ATRv; if flagh == 1 then dnv = avgv - ATRv; if trend == 1 then ST = dnv; else ST = upv; STrend = trend; } Plot1(st,"SuperTrend",iff(strend == 1,red,blue)); if Trend != Trend[1] Then { if Trend == 1 Then { var1 = h; var2 = var1[1]; TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999); TL_SetColor(TL,Red); TL_SetSize(TL,0.5); tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx,Red); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Magenta); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Lime); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } } Else { Var3 = l; Var4 = Var3[1]; tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx,Blue); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Cyan); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Green); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } } } Else { if Trend == 1 Then { if h > var1 Then var1 = h; } if Trend == -1 Then { if l < var3 Then var3 = l; } } if Trend != Trend[1] Then { if Trend == 1 Then { h2 = h; h3 = h2[1]; h4 = h3[1]; if L4 > 0 and max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then { tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx1,Black); Text_SetSize(tx1,20); Text_SetStyle(tx1,2,2); } Text_Delete(tx3); } Else #음전환 { L2 = l; l3 = l2[1]; l4 = l3[1]; Condition1 = False; if L4 > 0 and max(l3,l4) <= min(L3,L4)+폭 Then { tx3 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx3,Orange); Text_SetSize(tx3,10); Text_SetStyle(tx3,2,2); Condition1 = true; } if Condition1 == true and l2 < max(l3,l4)-폭 Then { Condition1 = False; Text_Delete(tx3); } } } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then { L2 = l; if Condition1 == true and l2 < max(l3,l4)-폭 Then { Condition1 = False; Text_Delete(tx3); } } } } 즐거운 하루되세요 > 고성 님이 쓴 글입니다. > 제목 : Re : Re : 트렌드 쓰리바닥 > > 예스스탁 님이 쓴 글입니다. > 제목 : Re : 트렌드 쓰리바닥 > 안녕하세요 예스스탁입니다. inputs: ATRLength(15), Strength(18), 폭(0.25); input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2); input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2); var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0); var : idx(0),hh(0),ll(0),EP1(0),EP2(0); var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0); var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0); Ep1 = 2/(ATRLength+1); Ep2 = 2/(Strength+1); idx = idx+1; if idx < ATRLength Then { hh = DayHigh; ll = daylow; } Else { hh = Highest(High, ATRLength); ll = Lowest(Low, ATRLength); } if idx < Strength Then { h1 = DayHigh; l1 = daylow; } Else { h1 = Highest(High, Strength); l1 = Lowest(Low, Strength); } hl = hh-ll; if idx == 1 Then { ema1 = hl; ema2 = h; ema3 = l; } Else { ema1 = hl * EP1 + ema1 * (1-EP1); ema2 = h * EP2 + ema2 * (1-EP2); ema3 = l * EP2 + ema3 * (1-EP2); } atrv = ema1; avgv = (ema2+ema3)/2; upv = avgv + ATRv; dnv = avgv - ATRv; if idx >= 2 then { if c > upv[1] and c > h1[1] then trend = 1; else if c < dnv[1] and c < l1[1] then trend = -1; if trend < 0 and trend[1] > 0 then flag=1; else flag=0; if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0; if trend > 0 and dnv < dnv[1] then dnv=dnv[1]; if trend < 0 and upv > upv[1] then upv=upv[1]; if flag == 1 then upv = avgv + ATRv; if flagh == 1 then dnv = avgv - ATRv; if trend == 1 then ST = dnv; else ST = upv; STrend = trend; } Plot1(st,"SuperTrend",iff(strend == 1,red,blue)); if Trend != Trend[1] Then { if Trend == 1 Then { var1 = h; var2 = var1[1]; TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999); TL_SetColor(TL,Red); TL_SetSize(TL,0.5); tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx,Red); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Magenta); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Lime); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } } Else { Var3 = l; Var4 = Var3[1]; tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx,Blue); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Cyan); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Green); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } } } Else { if Trend == 1 Then { if h > var1 Then var1 = h; } if Trend == -1 Then { if l < var3 Then var3 = l; } } if Trend != Trend[1] Then { if Trend == 1 Then { h2 = h; h3 = h2[1]; h4 = h3[1]; if L4 > 0 and max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then { tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx1,Black); Text_SetSize(tx1,20); Text_SetStyle(tx1,2,2); } if Condition1 == true and max(l2,l3,l4) > min(l2,l3,l4)+폭 Then { Condition1 = False; Text_Delete(tx3); } } Else #음전환 { L2 = l; l3 = l2[1]; l4 = l3[1]; Condition1 = False; if L4 > 0 and max(l3,l4) <= min(L3,L4)+폭 Then { tx3 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx3,Orange); Text_SetSize(tx3,10); Text_SetStyle(tx3,2,2); Condition1 = true; } if Condition1 == true and l2 < max(l3,l4)-폭 Then { Condition1 = False; Text_Delete(tx3); } } } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then { L2 = l; if Condition1 == true and l2 < max(l3,l4)-폭 Then { Condition1 = False; Text_Delete(tx3); } } } } 즐거운 하루되세요 > 고성 님이 쓴 글입니다. > 제목 : 트렌드 쓰리바닥 > inputs: ATRLength(15), Strength(18), 폭(0.25); input : 쌍바닥상1(2),쌍바닥상2(0),쌍바닥하1(1),쌍바닥하2(2); input : 쌍봉상1(2),쌍봉상2(1),쌍봉하1(0),쌍봉하2(2); var : STrend(0),ATRv(0), avgv(0), dnv(0), upv(0), trend(1), flag(0), flagh(0), ST(0),hl(0); var : idx(0),hh(0),ll(0),EP1(0),EP2(0); var : ema1(0),ema2(0),ema3(0),h1(0),h2(0),h3(0),h4(0),L1(0),l2(0),l3(0),l4(0); var :tx(0),tl(0),tx1(0),tx2(0),tx11(0),tx12(0),tx3(0); Ep1 = 2/(ATRLength+1); Ep2 = 2/(Strength+1); idx = idx+1; if idx < ATRLength Then { hh = DayHigh; ll = daylow; } Else { hh = Highest(High, ATRLength); ll = Lowest(Low, ATRLength); } if idx < Strength Then { h1 = DayHigh; l1 = daylow; } Else { h1 = Highest(High, Strength); l1 = Lowest(Low, Strength); } hl = hh-ll; if idx == 1 Then { ema1 = hl; ema2 = h; ema3 = l; } Else { ema1 = hl * EP1 + ema1 * (1-EP1); ema2 = h * EP2 + ema2 * (1-EP2); ema3 = l * EP2 + ema3 * (1-EP2); } atrv = ema1; avgv = (ema2+ema3)/2; upv = avgv + ATRv; dnv = avgv - ATRv; if idx >= 2 then { if c > upv[1] and c > h1[1] then trend = 1; else if c < dnv[1] and c < l1[1] then trend = -1; if trend < 0 and trend[1] > 0 then flag=1; else flag=0; if trend > 0 and trend[1] < 0 then flagh = 1; else flagh = 0; if trend > 0 and dnv < dnv[1] then dnv=dnv[1]; if trend < 0 and upv > upv[1] then upv=upv[1]; if flag == 1 then upv = avgv + ATRv; if flagh == 1 then dnv = avgv - ATRv; if trend == 1 then ST = dnv; else ST = upv; STrend = trend; } Plot1(st,"SuperTrend",iff(strend == 1,red,blue)); if Trend != Trend[1] Then { if Trend == 1 Then { var1 = h; var2 = var1[1]; TL = TL_New_Self(sDate,sTime,var1,sDate,sTime,99999999); TL_SetColor(TL,Red); TL_SetSize(TL,0.5); tx = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx,Red); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var4 > 0 and var3 <= Var4+PriceScale*쌍바닥상1 and var3 >= Var4+PriceScale*쌍바닥상2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Magenta); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } if Var4 > 0 and var3 <= Var4-PriceScale*쌍바닥하1 and var3 >= Var4-PriceScale*쌍바닥하2 Then { tx11 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx11,Lime); Text_SetSize(tx11,30); Text_SetStyle(tx11,2,2); } } Else { Var3 = l; Var4 = Var3[1]; tx = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx,Blue); Text_SetSize(tx,20); Text_SetStyle(tx,2,2); if Var2 > 0 and var1 <= Var2+PriceScale*쌍봉상1 and var1 >= Var2+PriceScale*쌍봉상2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Cyan); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } if Var2 > 0 and var1 <= Var2-PriceScale*쌍봉하1 and var1 >= Var2-PriceScale*쌍봉하2 Then { tx12 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx12,Green); Text_SetSize(tx12,30); Text_SetStyle(tx12,2,2); } } } Else { if Trend == 1 Then { if h > var1 Then var1 = h; } if Trend == -1 Then { if l < var3 Then var3 = l; } } if Trend != Trend[1] Then { if Trend == 1 Then { h2 = h; h3 = h2[1]; h4 = h3[1]; if L4 > 0 and max(L2,l3,l4) <= min(L2,l3,l4)+폭 Then { tx1 = Text_New_Self(sDate,sTime, st-PriceScale*0,"●"); Text_SetColor(tx1,Black); Text_SetSize(tx1,20); Text_SetStyle(tx1,2,2); } } Else { L2 = l; l3 = l2[1]; l4 = l3[1]; } } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then L2 = l; } } Condition1 = False; if max(l3,l4) <= min(l3,l4)+0.25 Then { Condition1 = true; tx3 = Text_New_Self(sDate,sTime, st+PriceScale*0,"●"); Text_SetColor(tx3,Orange); Text_SetSize(tx3,10); Text_SetStyle(tx3,2,2); } if Condition1 == true and l2 < max(L3,l4)-0.25 Then { Condition1 = False; Text_Delete(tx3); } Else { if Trend == 1 Then { if h > h2 Then h2 = h; } if Trend == -1 Then { if l < L2 Then { L2 = l; if Condition1 == true and l2 < max(L3,l4)-0.25 Then { Condition1 = False; Text_Delete(tx3); } } } } 0.25p 내에서 쓰리바닥을 형성하는지 실시간으로 보기위한 수식을 190줄 아래에 추가했는데 오류가 나오네요. 수정 부탁합니다. 1.트렌드 선이 음전환될 때, 직전저점과 전전저점의 차이가 상하 무관하게 0.25p 이내이면 트렌드 음선 상단에 동그라미 표시.두 저점 차이가 0.25p 이상이면 무표시. 2.동그라미 삭제 시점:직전저점과 전전저점중에 높은 저점을 기준으로 하여 a.아래로 0.25p 도달하기 전에 양전환시. b.계속 하락하여 -0.25p를 하향 붕괴할 때. 늘 감사합니다. 재문의:추가한 수식의 동그라미가 실시간 삭제가 안됩니다. (기존 다른 동그라미는 보존)