Chiến lược này là một hệ thống giao dịch toàn diện kết hợp nhiều chỉ số kỹ thuật, bao gồm đám mây Ichimoku, chỉ số sức mạnh tương đối (RSI), chênh lệch hội tụ trung bình chuyển động (MACD), chênh lệch khung thời gian cao hơn (HTF) và chéo trung bình chuyển động biểu thức (EMA).
Nguyên tắc cốt lõi của chiến lược là xác nhận tín hiệu giao dịch thông qua phân tích kỹ thuật đa lớp. Nó sử dụng các thành phần Ichimoku Cloud để xác định xu hướng thị trường tổng thể, kết hợp RSI để đánh giá các điều kiện mua quá mức / bán quá mức thị trường, sử dụng MACD để xác định sự thay đổi động lực xu hướng và nắm bắt các tín hiệu đảo ngược xu hướng tiềm năng thông qua sự khác biệt của HTF RSI và MACD. Ngoài ra, chiến lược kết hợp EMA50 và EMA100 chéo chéo để xác nhận, cùng với EMA200 như một bộ lọc xu hướng chính, tạo ra một hệ thống xác nhận giao dịch đa lớp.
Chiến lược này xây dựng một hệ thống giao dịch tương đối hoàn chỉnh thông qua sự phối hợp của nhiều chỉ số kỹ thuật. Sức mạnh của nó nằm trong cơ chế xác nhận tín hiệu đa chiều của nó, đồng thời cũng phải đối mặt với những thách thức trong tối ưu hóa tham số và khả năng thích nghi thị trường. Thông qua các hướng tối ưu hóa được đề xuất, chiến lược có tiềm năng để tăng cường hiệu suất của nó hơn nữa trong các môi trường thị trường khác nhau trong khi duy trì độ bền của nó.
/*backtest start: 2024-01-17 00:00:00 end: 2025-01-16 00:00:00 period: 3h basePeriod: 3h exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT","balance":49999}] */ //@version=6 strategy("Ichimoku + RSI + MACD + HTF Divergence + EMA Cross Strategy", overlay=true) // تنظیمات تایمفریم بالاتر htf_timeframe = input.timeframe("D", title="تایمفریم بالاتر") // تنظیمات پارامترهای ایچیموکو tenkan_period = input(9, title="Tenkan Sen Period") kijun_period = input(26, title="Kijun Sen Period") senkou_span_b_period = input(52, title="Senkou Span B Period") displacement = input(26, title="Displacement") // محاسبه خطوط ایچیموکو tenkan_sen = (ta.highest(high, tenkan_period) + ta.lowest(low, tenkan_period)) / 2 kijun_sen = (ta.highest(high, kijun_period) + ta.lowest(low, kijun_period)) / 2 senkou_span_a = (tenkan_sen + kijun_sen) / 2 senkou_span_b = (ta.highest(high, senkou_span_b_period) + ta.lowest(low, senkou_span_b_period)) / 2 chikou_span = close // قیمت بسته شدن فعلی // رسم خطوط ایچیموکو plot(tenkan_sen, color=color.blue, title="Tenkan Sen") plot(kijun_sen, color=color.red, title="Kijun Sen") plot(senkou_span_a, offset=displacement, color=color.green, title="Senkou Span A") plot(senkou_span_b, offset=displacement, color=color.orange, title="Senkou Span B") plot(chikou_span, offset=-displacement, color=color.purple, title="Chikou Span") // رنگآمیزی ابر ایچیموکو fill(plot(senkou_span_a, offset=displacement, color=color.green, title="Senkou Span A"), plot(senkou_span_b, offset=displacement, color=color.orange, title="Senkou Span B"), color=senkou_span_a > senkou_span_b ? color.new(color.green, 90) : color.new(color.red, 90), title="Cloud") // تنظیمات RSI rsi_length = input(14, title="RSI Length") rsi_overbought = input(70, title="RSI Overbought Level") rsi_oversold = input(30, title="RSI Oversold Level") // محاسبه RSI rsi_value = ta.rsi(close, rsi_length) // تنظیمات MACD fast_length = input(12, title="MACD Fast Length") slow_length = input(26, title="MACD Slow Length") signal_smoothing = input(9, title="MACD Signal Smoothing") // محاسبه MACD [macd_line, signal_line, hist_line] = ta.macd(close, fast_length, slow_length, signal_smoothing) // شناسایی واگراییها در تایمفریم بالاتر f_find_divergence(src, lower, upper) => var int divergence = na // تعریف نوع متغیر بهصورت صریح if (src >= upper and src[1] < upper) divergence := 1 // واگرایی نزولی else if (src <= lower and src[1] > lower) divergence := -1 // واگرایی صعودی divergence // محاسبه RSI و MACD در تایمفریم بالاتر htf_rsi_value = request.security(syminfo.tickerid, htf_timeframe, rsi_value) htf_macd_line = request.security(syminfo.tickerid, htf_timeframe, macd_line) // شناسایی واگراییها در تایمفریم بالاتر htf_rsi_divergence = f_find_divergence(htf_rsi_value, rsi_oversold, rsi_overbought) htf_macd_divergence = f_find_divergence(htf_macd_line, 0, 0) // فیلتر روند با EMA 200 ema_200 = ta.ema(close, 200) // اضافه کردن EMA 50 و 100 ema_50 = ta.ema(close, 50) ema_100 = ta.ema(close, 100) // کراسهای EMA ema_cross_up = ta.crossover(ema_50, ema_100) // کراس صعودی EMA 50 و 100 ema_cross_down = ta.crossunder(ema_50, ema_100) // کراس نزولی EMA 50 و 100 // شرایط ورود و خروج long_condition = (close > senkou_span_a and close > senkou_span_b) and // قیمت بالای ابر (rsi_value > 50) and // RSI بالای 50 (macd_line > signal_line) and // MACD خط سیگنال را قطع کرده (htf_rsi_divergence == -1 or htf_macd_divergence == -1) and // واگرایی صعودی در تایمفریم بالاتر (close > ema_200) and // قیمت بالای EMA 200 (ema_cross_up) // کراس صعودی EMA 50 و 100 short_condition = (close < senkou_span_a and close < senkou_span_b) and // قیمت زیر ابر (rsi_value < 50) and // RSI زیر 50 (macd_line < signal_line) and // MACD خط سیگنال را قطع کرده (htf_rsi_divergence == 1 or htf_macd_divergence == 1) and // واگرایی نزولی در تایمفریم بالاتر (close < ema_200) and // قیمت زیر EMA 200 (ema_cross_down) // کراس نزولی EMA 50 و 100 // نمایش نقاط ورود در چارت plotshape(series=long_condition, title="Buy Signal", location=location.belowbar, color=color.green, style=shape.labelup, text="BUY", size=size.small) plotshape(series=short_condition, title="Sell Signal", location=location.abovebar, color=color.red, style=shape.labeldown, text="SELL", size=size.small) // اجرای استراتژی if (long_condition) strategy.entry("Long", strategy.long) if (short_condition) strategy.entry("Short", strategy.short)