이 전략은 윌리엄스 이중 기하급수적 이동 평균과 이치모쿠 킨코 호 (Ichimoku Kinkou Hyo) 를 결합하여 각각의 장점을 활용하고 거래 결정의 정확도를 향상시키기 위해 두 가지 기술 지표를 결합합니다. 윌리엄스 이중 기하급수적 이동 평균은 가격 변화의 추세를 완전히 반영 할 수 있으며 이치모쿠 킨코 호 (Ichimoku Kinkou Hyo) 는 트렌드 전환에 대한 조기 경고를 제공할 수 있습니다.
윌리엄스 이중 기하급수적 이동 평균은 빠른 라인과 느린 라인을 포함합니다. 빠른 라인은 공식으로 계산됩니다: 2 * ((n/2 기간 가중화 이동 평균), 느린 라인은: n 기간 가중화 이동 평균으로 계산됩니다. 빠른 라인이 아래에서 느린 라인의 위를 넘으면 구매 신호입니다. 위에서 아래를 넘으면 판매 신호입니다.
이치모쿠 킨코 호는 네 가지 구성 요소로 구성되어 있습니다. 텐칸 센, 키
이 전략은 두 지표의 강점을 결합합니다. 첫 번째 결정 요소는 윌리엄스 지표의 신호이며 두 번째는 이치모쿠 킨코 히오의 확인이며, 잘못된 신호를 효과적으로 필터링하고 의사 결정 정확도를 향상시킵니다.
이 전략은 트렌드 방향을 판단하는 윌리엄스 지표의 능력과 반전 초기 경고를 제공하는 Ichimoku Kinkou Hyo의 능력을 완전히 활용하여 거래 결정의 정확성을 크게 향상시킵니다. 매개 변수 조정 및 다른 지표와 결합하는 등의 추가 최적화는 시장 변화에 적응하기 위해 지속 가능한 개선이 가능합니다.
/*backtest start: 2024-01-01 00:00:00 end: 2024-01-31 23:59:59 period: 1h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=3 strategy("Hull MA-X + Ichimoku Kinko Hyo", shorttitle="Hi", overlay=true, default_qty_type=strategy.percent_of_equity, max_bars_back=1000, default_qty_value=100, calc_on_order_fills= true, calc_on_every_tick=true, pyramiding=0) keh=input(title="Double HullMA",defval=12, minval=1) n2ma=2*wma(close,round(keh/2)) nma=wma(close,keh) diff=n2ma-nma sqn=round(sqrt(keh)) n2ma1=2*wma(close[1],round(keh/2)) nma1=wma(close[1],keh) diff1=n2ma1-nma1 sqn1=round(sqrt(keh)) n1=wma(diff,sqn) n2=wma(diff1,sqn) b=n1>n2?lime:red c=n1>n2?green:red d=n1>n2?red:green TenkanSenPeriods = input(9, minval=1, title="Tenkan Sen Periods") KijunSenPeriods = input(24, minval=1, title="Kijun Sen Periods") SenkouSpanBPeriods = input(51, minval=1, title="Senkou Span B Periods") displacement = input(24, minval=1, title="Displacement") donchian(len) => avg(lowest(len), highest(len)) TenkanSen = donchian(TenkanSenPeriods) KijunSen = donchian(KijunSenPeriods) SenkouSpanA = avg(TenkanSen, KijunSen) SenkouSpanB = donchian(SenkouSpanBPeriods) SenkouSpanH = max(SenkouSpanA[displacement - 1], SenkouSpanB[displacement - 1]) SenkouSpanL = min(SenkouSpanA[displacement - 1], SenkouSpanB[displacement - 1]) ChikouSpan = close[displacement-1] Hullfast=plot(n1,color=c) Hullslow=plot(n2,color=c) plot(cross(n1, n2) ? n1:na, style = circles, color=b, linewidth = 4) plot(cross(n1, n2) ? n1:na, style = line, color=d, linewidth = 3) plot(TenkanSen, color=blue, title="Tenkan Sen", linewidth = 2) plot(KijunSen, color=maroon, title="Kijun Sen", linewidth = 3) plot(close, offset = -displacement, color=orange, title="Chikou Span", linewidth = 2) sa=plot (SenkouSpanA, offset = displacement, color=green, title="Senkou Span A", linewidth = 2) sb=plot (SenkouSpanB, offset = displacement, color=red, title="Senkou Span B", linewidth = 3) fill(sa, sb, color = SenkouSpanA > SenkouSpanB ? green : red) longCondition = n1>n2 and close>n2 and close>ChikouSpan and close>SenkouSpanH and (TenkanSen>KijunSen or close>KijunSen) if (longCondition) strategy.entry("Long",strategy.long) shortCondition = n1<n2 and close<n2 and close<ChikouSpan and close<SenkouSpanL and (TenkanSen<KijunSen or close<KijunSen) if (shortCondition) strategy.entry("Short",strategy.short) closelong = n1<n2 and close<n2 and (TenkanSen<KijunSen or close<TenkanSen or close<KijunSen or close<SenkouSpanL) if (closelong) strategy.close("Long") closeshort = n1>n2 and close>n2 and (TenkanSen>KijunSen or close>TenkanSen or close>KijunSen or close>SenkouSpanH) if (closeshort) strategy.close("Short")