
Cette stratégie utilise les prix formés par les moyennes mobiles binaires ((EMA) pour identifier les occasions de retournement avec une forte probabilité. Il ne s’agit pas d’une simple stratégie de traversée de la moyenne, mais de la recherche d’un moment où les prix rebondissent de l’EMA et forment une dynamique forte.
Le principe central de cette stratégie est de rechercher des signaux d’entrée en identifiant les situations où le prix rebondit de l’EMA. Il utilise des EMA de 12 cycles et de 21 cycles pour créer des zones de négociation supérieures et inférieures et déterminer la direction de la tendance du marché en fonction de la position relative de l’EMA.
Lorsque l’EMA12 > EMA21 est dans un environnement de hausse (la zone verte), nous cherchons des opportunités. Les conditions sont les suivantes: la ligne d’ombre inférieure touche la zone EMA, formant une forte hausse (une entité plus grande que la ligne d’ombre inférieure), la ligne d’ombre supérieure est minimisée (moins de 2% de la zone de la courbe), le prix de clôture est supérieur aux deux EMA, la première n’est pas tombée en dessous de la zone inférieure, et plusieurs courbes consécutives maintiennent la tendance à la hausse.
Lorsque l’EMA12 < EMA21 est en baisse (la zone rouge), nous cherchons des opportunités de dépréciation. Les conditions de dépréciation sont les suivantes: la ligne supérieure de prix touche la zone EMA, formant une forte courbe baissière (une entité plus grande que la ligne supérieure de l’ombre), la ligne inférieure est minimisée (moins de 2% de la plage de la courbe), le prix de clôture est inférieur aux deux EMA, la première courbe n’est pas terminée au-dessus de la zone supérieure, et plusieurs courbes consécutives maintiennent la tendance baissière.
Le système de gestion des risques de la stratégie a un rapport de risque/rendement fixe, par défaut de 3: 1, le stop loss est défini sur le haut/bas de la colonne précédente, le stop loss est calculé automatiquement en fonction du rapport de risque/rendement.
Cette stratégie présente plusieurs avantages notables:
Potentiel de victoire élevé: la stratégie permet d’identifier des opportunités de trading avec une forte probabilité de réussite en capturant la dynamique dynamique de la tendance après le rebond de la bande EMA.
Règles claires d’entrée et de sortie: la stratégie offre des conditions de transaction claires, réduisant l’influence du jugement subjectif et des décisions émotionnelles.
Une bonne gestion des risques: un rapport de risque/rendement fixe et un arrêt automatique des pertes permettent de contrôler le risque de chaque transaction.
La tendance suit l’avantage: la stratégie consiste à négocier uniquement dans le sens de la tendance dominante, en évitant le risque élevé d’opérations à contre-courant.
Fonctionne sur plusieurs périodes: la stratégie fonctionne efficacement sur différentes périodes, offrant des options de trading flexibles.
Système d’alerte complet: fonction d’alerte intégrée aux signaux de transaction détaillés pour vous assurer de ne pas manquer une opportunité de transaction.
Aide visuelle: affiche intuitivement les signaux de transaction et les conditions de l’état en changeant la couleur du fond et en indiquant les balises.
Malgré la bonne conception de cette stratégie, les risques potentiels sont les suivants:
Risque de marché oscillant: dans un marché oscillant ou oscillant, les bandes EMA peuvent devenir serrées, produisant des signaux fréquents mais de mauvaise qualité, entraînant des pertes continues.
Risque de saut en hauteur: les marchés peuvent sauter après une nouvelle ou un événement majeur, ce qui peut entraîner des pertes supérieures aux attentes.
Optimisation excessive des paramètres: l’optimisation excessive des paramètres de la stratégie peut entraîner une adaptation de la courbe, ce qui rend la stratégie moins performante dans les transactions sur disque dur.
Délai d’identification de la tendance: L’EMA, en tant qu’indicateur de retard, peut réagir lentement aux virages de tendance, ce qui entraîne le manque d’un point d’entrée optimal ou un retard d’exit.
Risque de déclenchement d’un stop loss: le bruit du marché peut entraîner un retour de prix dans la direction prévue après le déclenchement d’un stop loss, entraînant des pertes inutiles.
Les solutions comprennent: la suspension des transactions dans un marché en crise; l’utilisation d’un filtre de volatilité pour éviter des signaux de mauvaise qualité; la confirmation de tendances en combinaison avec d’autres indicateurs; la réévaluation et l’optimisation périodiques des paramètres; l’utilisation d’un stop loss suivi.
Cette stratégie peut être optimisée dans les directions suivantes:
Gestion dynamique des risques: Ajuste automatiquement le ratio de rendement des risques et la taille des positions en fonction de la volatilité du marché, réduisant ainsi l’ouverture des risques dans un environnement à forte volatilité.
Les filtres supérieurs sont introduits: ils combinent l’indicateur ATR (Average True Range) pour filtrer les signaux de basse volatilité; ils ajoutent la confirmation de transaction pour vérifier l’efficacité du rebond des prix.
Analyse à plusieurs périodes: intégrer la direction de la tendance à des périodes plus élevées comme condition de filtrage supplémentaire, n’étant prise en compte que si plusieurs périodes de tendance sont cohérentes.
L’optimisation de l’apprentissage automatique: l’utilisation d’algorithmes d’apprentissage automatique pour ajuster dynamiquement les paramètres et adapter la meilleure combinaison de paramètres en fonction des différentes conditions du marché.
Suivi de la réalisation des arrêts de perte: après que les bénéfices atteignent un certain niveau, le mécanisme de suivi des arrêts de perte est mis en œuvre, bloquant une partie des bénéfices tout en permettant la poursuite de la tendance.
Stratégie de profit partiel: mise en œuvre d’une stratégie de profit partiel, réduction progressive de la position à différents prix cibles, optimisation de la performance globale du retour sur risque.
Ces orientations d’optimisation peuvent améliorer la robustesse, l’adaptabilité et la rentabilité à long terme des stratégies.
La stratégie de négociation de la dynamique de rebond des bandes de la moyenne mobile à deux indices est un système de négociation intégré combinant l’analyse technique, l’identification des tendances graphiques et une gestion rigoureuse des risques. Elle capte les opportunités de marché avec une dynamique explosive en identifiant les points de rebond à haute probabilité des prix à partir de la bande EMA. Le principal avantage de la stratégie réside dans ses règles de négociation claires, son cadre de rendement au risque fixe et ses exigences de cohérence des tendances, ce qui la rend adaptée à tous les types d’environnement de marché et de périodes de cycle.
Malgré certains risques potentiels, les traders peuvent améliorer encore la stabilité et la rentabilité de leur stratégie en mettant en œuvre les mesures d’optimisation recommandées. Cette stratégie est particulièrement adaptée aux traders qui recherchent une méthode de négociation systématique, disciplinée et à risque contrôlé.
/*backtest
start: 2025-05-26 00:00:00
end: 2025-06-02 00:00:00
period: 5m
basePeriod: 5m
exchanges: [{"eid":"Futures_Binance","currency":"ETH_USDT"}]
*/
//@version=5
strategy("Enhanced EMA Band Rejection Strategy", overlay=true, initial_capital=10000, default_qty_type=strategy.percent_of_equity, default_qty_value=10)
// Input parameters
ema12_length = input.int(12, title="EMA 12 Length")
ema21_length = input.int(21, title="EMA 21 Length")
max_wick_percent = input.float(2.0, title="Max Wick % at High/Low", minval=0.0, maxval=10.0)
risk_reward_ratio = input.float(3.0, title="Risk/Reward Ratio (R)", minval=1.0, maxval=10.0)
trend_consistency_bars = input.int(5, title="Trend Consistency Required (Bars)", minval=1, maxval=20)
// Notification Settings
enable_notifications = input.bool(true, title="Enable Notifications", group="Notifications")
notify_on_entry = input.bool(true, title="Notify on Trade Entry", group="Notifications")
notify_on_exit = input.bool(true, title="Notify on Trade Exit", group="Notifications")
notify_on_setup = input.bool(false, title="Notify on Potential Setup (Pre-Entry)", group="Notifications")
notify_on_failed_conditions = input.bool(false, title="Notify on Failed Conditions", group="Notifications")
// Calculate EMAs
ema12 = ta.ema(close, ema12_length)
ema21 = ta.ema(close, ema21_length)
// Determine upper and lower EMA bands
ema_upper = math.max(ema12, ema21)
ema_lower = math.min(ema12, ema21)
// Plot EMAs
plot(ema12, color=color.blue, linewidth=2, title="EMA 12")
plot(ema21, color=color.red, linewidth=2, title="EMA 21")
// Calculate candle components
body_size = math.abs(close - open)
upper_wick = high - math.max(open, close)
lower_wick = math.min(open, close) - low
candle_range = high - low
// Calculate wick percentages
upper_wick_percent = candle_range > 0 ? (upper_wick / candle_range) * 100 : 0
lower_wick_percent = candle_range > 0 ? (lower_wick / candle_range) * 100 : 0
// Determine EMA trend direction
ema_bullish = ema12 > ema21 // Green bands - bullish trend
ema_bearish = ema12 < ema21 // Red bands - bearish trend
// Check trend consistency for required number of bars
bullish_consistency_check = true
bearish_consistency_check = true
for i = 0 to trend_consistency_bars - 1
ema12_past = ta.ema(close[i], ema12_length)
ema21_past = ta.ema(close[i], ema21_length)
if ema12_past <= ema21_past
bullish_consistency_check := false
if ema12_past >= ema21_past
bearish_consistency_check := false
// Final trend conditions with consistency requirement
ema_bullish_consistent = ema_bullish and bullish_consistency_check
ema_bearish_consistent = ema_bearish and bearish_consistency_check
// NEW RULE: Previous candle close position relative to bands
prev_close_above_upper_band = close[1] > ema_upper[1]
prev_close_below_lower_band = close[1] < ema_lower[1]
prev_close_within_bands = close[1] >= ema_lower[1] and close[1] <= ema_upper[1]
// Long setup conditions (only when EMAs are bullish/green consistently)
long_wick_condition = low <= ema_lower or (low <= ema_upper and low >= ema_lower)
long_body_condition = body_size >= lower_wick
long_wick_percent_condition = upper_wick_percent <= max_wick_percent
long_bullish_candle = close > open
long_trend_condition = ema_bullish_consistent // Only long when bands are consistently green
long_close_above_bands = close > ema_upper // NEW: Close must be above both EMAs
// Previous candle must not have closed below the lower band
long_prev_close_condition = not prev_close_below_lower_band
long_setup = long_wick_condition and long_body_condition and long_wick_percent_condition and long_bullish_candle and long_trend_condition and long_close_above_bands and long_prev_close_condition
// Short setup conditions (only when EMAs are bearish/red consistently)
short_wick_condition = high >= ema_upper or (high >= ema_lower and high <= ema_upper)
short_body_condition = body_size >= upper_wick
short_wick_percent_condition = lower_wick_percent <= max_wick_percent
short_bearish_candle = close < open
short_trend_condition = ema_bearish_consistent // Only short when bands are consistently red
short_close_below_bands = close < ema_lower // NEW: Close must be below both EMAs
// Previous candle must not have closed above the upper band
short_prev_close_condition = not prev_close_above_upper_band
short_setup = short_wick_condition and short_body_condition and short_wick_percent_condition and short_bearish_candle and short_trend_condition and short_close_below_bands and short_prev_close_condition
// Entry conditions
var float long_sl = na
var float short_sl = na
var float long_tp = na
var float short_tp = na
if long_setup and strategy.position_size == 0
strategy.entry("Long", strategy.long)
long_sl := low
risk_amount = close - long_sl
long_tp := close + (risk_amount * risk_reward_ratio)
label.new(bar_index, low, "LONG", style=label.style_label_up, color=color.green, size=size.small)
// Entry Notification
if enable_notifications and notify_on_entry
alert("🟢 LONG ENTRY SIGNAL\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Price: " + str.tostring(close, "#.####") + "\n" +
"Stop Loss: " + str.tostring(long_sl, "#.####") + "\n" +
"Take Profit: " + str.tostring(long_tp, "#.####") + "\n" +
"Risk/Reward: " + str.tostring(risk_reward_ratio, "#.##") + "R\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
if short_setup and strategy.position_size == 0
strategy.entry("Short", strategy.short)
short_sl := high
risk_amount = short_sl - close
short_tp := close - (risk_amount * risk_reward_ratio)
label.new(bar_index, high, "SHORT", style=label.style_label_down, color=color.red, size=size.small)
// Entry Notification
if enable_notifications and notify_on_entry
alert("🔴 SHORT ENTRY SIGNAL\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Price: " + str.tostring(close, "#.####") + "\n" +
"Stop Loss: " + str.tostring(short_sl, "#.####") + "\n" +
"Take Profit: " + str.tostring(short_tp, "#.####") + "\n" +
"Risk/Reward: " + str.tostring(risk_reward_ratio, "#.##") + "R\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
// Exit conditions with fixed R:R
if strategy.position_size > 0
// Long position - fixed stop loss and take profit
strategy.exit("Long Exit", "Long", stop=long_sl, limit=long_tp)
// Exit Notifications
if enable_notifications and notify_on_exit
if close <= long_sl
alert("🛑 LONG STOP LOSS HIT\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Exit Price: " + str.tostring(close, "#.####") + "\n" +
"Loss: " + str.tostring(close - strategy.position_avg_price, "#.####") + "\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
if close >= long_tp
alert("🎯 LONG TAKE PROFIT HIT\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Exit Price: " + str.tostring(close, "#.####") + "\n" +
"Profit: " + str.tostring(close - strategy.position_avg_price, "#.####") + "\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
if strategy.position_size < 0
// Short position - fixed stop loss and take profit
strategy.exit("Short Exit", "Short", stop=short_sl, limit=short_tp)
// Exit Notifications
if enable_notifications and notify_on_exit
if close >= short_sl
alert("🛑 SHORT STOP LOSS HIT\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Exit Price: " + str.tostring(close, "#.####") + "\n" +
"Loss: " + str.tostring(strategy.position_avg_price - close, "#.####") + "\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
if close <= short_tp
alert("🎯 SHORT TAKE PROFIT HIT\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Exit Price: " + str.tostring(close, "#.####") + "\n" +
"Profit: " + str.tostring(strategy.position_avg_price - close, "#.####") + "\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
// Plot stop levels and take profit levels
plot(strategy.position_size > 0 ? long_sl : na, color=color.red, linewidth=2, style=plot.style_line, title="Long SL")
plot(strategy.position_size < 0 ? short_sl : na, color=color.red, linewidth=2, style=plot.style_line, title="Short SL")
plot(strategy.position_size > 0 ? long_tp : na, color=color.green, linewidth=2, style=plot.style_line, title="Long TP")
plot(strategy.position_size < 0 ? short_tp : na, color=color.green, linewidth=2, style=plot.style_line, title="Short TP")
// Additional Notification Logic
// Potential Setup Notifications (when most conditions are met but not all)
long_potential_setup = long_wick_condition and long_body_condition and long_wick_percent_condition and long_bullish_candle and long_trend_condition and long_prev_close_condition and not long_close_above_bands
short_potential_setup = short_wick_condition and short_body_condition and short_wick_percent_condition and short_bearish_candle and short_trend_condition and short_prev_close_condition and not short_close_below_bands
if enable_notifications and notify_on_setup and strategy.position_size == 0
if long_potential_setup
alert("⚠️ POTENTIAL LONG SETUP\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Price: " + str.tostring(close, "#.####") + "\n" +
"Status: Close needs to be above " + str.tostring(ema_upper, "#.####") + "\n" +
"Current Close: " + str.tostring(close, "#.####") + "\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
if short_potential_setup
alert("⚠️ POTENTIAL SHORT SETUP\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Price: " + str.tostring(close, "#.####") + "\n" +
"Status: Close needs to be below " + str.tostring(ema_lower, "#.####") + "\n" +
"Current Close: " + str.tostring(close, "#.####") + "\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
// Failed Conditions Notifications (for debugging)
if enable_notifications and notify_on_failed_conditions and strategy.position_size == 0
if long_wick_condition and long_body_condition and long_wick_percent_condition and long_bullish_candle and not long_trend_condition
alert("❌ LONG SETUP FAILED\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Reason: " + (not ema_bullish ? "EMA trend bearish" : "EMA trend not consistent") + "\n" +
"EMA12: " + str.tostring(ema12, "#.####") + "\n" +
"EMA21: " + str.tostring(ema21, "#.####") + "\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
if short_wick_condition and short_body_condition and short_wick_percent_condition and short_bearish_candle and not short_trend_condition
alert("❌ SHORT SETUP FAILED\n" +
"Symbol: " + syminfo.ticker + "\n" +
"Reason: " + (not ema_bearish ? "EMA trend bullish" : "EMA trend not consistent") + "\n" +
"EMA12: " + str.tostring(ema12, "#.####") + "\n" +
"EMA21: " + str.tostring(ema21, "#.####") + "\n" +
"Time: " + str.tostring(time), alert.freq_once_per_bar)
bgcolor(long_setup ? color.new(color.green, 90) : na, title="Long Setup")
bgcolor(short_setup ? color.new(color.red, 90) : na, title="Short Setup")
// Show when previous close condition fails
bgcolor(long_wick_condition and long_body_condition and long_wick_percent_condition and long_bullish_candle and long_trend_condition and prev_close_below_lower_band ? color.new(color.orange, 95) : na, title="Long Rejected by Prev Close")
bgcolor(short_wick_condition and short_body_condition and short_wick_percent_condition and short_bearish_candle and short_trend_condition and prev_close_above_upper_band ? color.new(color.orange, 95) : na, title="Short Rejected by Prev Close")
// Detailed debugging for failed conditions
long_all_conditions_except_prev = long_wick_condition and long_body_condition and long_wick_percent_condition and long_bullish_candle and long_trend_condition and long_close_above_bands
bgcolor(long_all_conditions_except_prev and prev_close_below_lower_band ? color.new(color.purple, 90) : na, title="Long Failed: Prev Close Below Band")
bgcolor(long_wick_condition and not long_body_condition ? color.new(color.yellow, 90) : na, title="Long Failed: Body Too Small")
bgcolor(long_wick_condition and long_body_condition and not long_wick_percent_condition ? color.new(color.blue, 90) : na, title="Long Failed: Upper Wick Too Big")
bgcolor(long_wick_condition and long_body_condition and long_wick_percent_condition and not long_bullish_candle ? color.new(color.gray, 90) : na, title="Long Failed: Not Bullish Candle")
bgcolor(long_wick_condition and long_body_condition and long_wick_percent_condition and long_bullish_candle and ema_bullish and not ema_bullish_consistent ? color.new(color.fuchsia, 90) : na, title="Long Failed: Trend Not Consistent")
bgcolor(long_wick_condition and long_body_condition and long_wick_percent_condition and long_bullish_candle and not ema_bullish ? color.new(color.maroon, 90) : na, title="Long Failed: EMA Trend Bearish")
bgcolor(long_wick_condition and long_body_condition and long_wick_percent_condition and long_bullish_candle and long_trend_condition and not long_close_above_bands ? color.new(color.lime, 90) : na, title="Long Failed: Close Not Above Bands")
// Similar debugging for shorts
short_all_conditions_except_prev = short_wick_condition and short_body_condition and short_wick_percent_condition and short_bearish_candle and short_trend_condition and short_close_below_bands
bgcolor(short_all_conditions_except_prev and prev_close_above_upper_band ? color.new(color.purple, 90) : na, title="Short Failed: Prev Close Above Band")
bgcolor(short_wick_condition and short_body_condition and short_wick_percent_condition and short_bearish_candle and short_trend_condition and not short_close_below_bands ? color.new(color.aqua, 90) : na, title="Short Failed: Close Not Below Bands")
// Enhanced table for debugging
if barstate.islast
var table debug_table = table.new(position.top_right, 2, 19, bgcolor=color.white, border_width=1)
table.cell(debug_table, 0, 0, "Condition", text_color=color.black, bgcolor=color.gray)
table.cell(debug_table, 1, 0, "Value", text_color=color.black, bgcolor=color.gray)
table.cell(debug_table, 0, 1, "Body Size", text_color=color.black)
table.cell(debug_table, 1, 1, str.tostring(body_size, "#.##"), text_color=color.black)
table.cell(debug_table, 0, 2, "Upper Wick", text_color=color.black)
table.cell(debug_table, 1, 2, str.tostring(upper_wick, "#.##"), text_color=color.black)
table.cell(debug_table, 0, 3, "Lower Wick", text_color=color.black)
table.cell(debug_table, 1, 3, str.tostring(lower_wick, "#.##"), text_color=color.black)
table.cell(debug_table, 0, 4, "Upper Wick %", text_color=color.black)
table.cell(debug_table, 1, 4, str.tostring(upper_wick_percent, "#.##") + "%", text_color=color.black)
table.cell(debug_table, 0, 5, "Lower Wick %", text_color=color.black)
table.cell(debug_table, 1, 5, str.tostring(lower_wick_percent, "#.##") + "%", text_color=color.black)
table.cell(debug_table, 0, 6, "EMA Upper", text_color=color.black)
table.cell(debug_table, 1, 6, str.tostring(ema_upper, "#.##"), text_color=color.black)
table.cell(debug_table, 0, 7, "EMA Lower", text_color=color.black)
table.cell(debug_table, 1, 7, str.tostring(ema_lower, "#.##"), text_color=color.black)
table.cell(debug_table, 0, 8, "R:R Ratio", text_color=color.black)
table.cell(debug_table, 1, 8, str.tostring(risk_reward_ratio, "#.##") + "R", text_color=color.black)
table.cell(debug_table, 0, 9, "Position", text_color=color.black)
table.cell(debug_table, 1, 9, strategy.position_size > 0 ? "LONG" : strategy.position_size < 0 ? "SHORT" : "NONE", text_color=color.black)
// NEW DEBUG INFO
table.cell(debug_table, 0, 10, "Prev Close", text_color=color.black)
table.cell(debug_table, 1, 10, str.tostring(close[1], "#.##"), text_color=color.black)
table.cell(debug_table, 0, 11, "Prev Above Upper", text_color=color.black)
table.cell(debug_table, 1, 11, prev_close_above_upper_band ? "YES" : "NO", text_color=color.black)
table.cell(debug_table, 0, 12, "Prev Below Lower", text_color=color.black)
table.cell(debug_table, 1, 12, prev_close_below_lower_band ? "YES" : "NO", text_color=color.black)
table.cell(debug_table, 0, 13, "Prev Within Bands", text_color=color.black)
table.cell(debug_table, 1, 13, prev_close_within_bands ? "YES" : "NO", text_color=color.black)
// NEW: Trend consistency info
table.cell(debug_table, 0, 14, "Bullish Consistent", text_color=color.black)
table.cell(debug_table, 1, 14, ema_bullish_consistent ? "YES" : "NO", text_color=color.black)
table.cell(debug_table, 0, 15, "Bearish Consistent", text_color=color.black)
table.cell(debug_table, 1, 15, ema_bearish_consistent ? "YES" : "NO", text_color=color.black)
table.cell(debug_table, 0, 16, "Consistency Bars", text_color=color.black)
table.cell(debug_table, 1, 16, str.tostring(trend_consistency_bars), text_color=color.black)
// NEW: Close position relative to bands
table.cell(debug_table, 0, 17, "Close Above Upper", text_color=color.black)
table.cell(debug_table, 1, 17, close > ema_upper ? "YES" : "NO", text_color=color.black)
table.cell(debug_table, 0, 18, "Close Below Lower", text_color=color.black)
table.cell(debug_table, 1, 18, close < ema_lower ? "YES" : "NO", text_color=color.black)