Trata-se de uma estratégia de acompanhamento de tendências baseada no cruzamento da média móvel, combinada com a gestão de stop loss/take profit e o efeito de alavancagem, com o objetivo de identificar tendências em vários mercados e maximizar os lucros.
A estratégia usa cruzamento de médias móveis rápidas e lentas como sinais de negociação.
Para filtrar as negociações de ruído de tendências menores, ele também usa uma MA de 200 dias como um filtro de tendência.
A estratégia usa paradas de negociação de intervalo. Após a entrada, os níveis de stop loss e take profit são definidos em porcentagem fixa, por exemplo, 1% stop loss e 1% take profit. As posições serão fechadas quando o preço atingir o stop loss ou take profit.
O efeito de alavancagem é empregado para amplificar os lucros de negociação.
Uma vantagem é que ele pode identificar tendências em vários mercados, incluindo criptomoedas, ações e futuros, tornando a estratégia amplamente aplicável.
O uso do cruzamento MA rápido/lento e do filtro de tendência pode identificar melhor a direção da tendência e alcançar uma boa taxa de ganho nos mercados de tendência.
As paradas de negociação de intervalo ajudam a controlar a perda de uma única negociação dentro do intervalo suportável, permitindo um funcionamento estável da estratégia.
O efeito de alavancagem amplifica os lucros comerciais, fazendo pleno uso da vantagem da estratégia.
O design de interface visual com diferentes cores de fundo para mercados de touro/urso oferece uma visão intuitiva do mercado.
A estratégia segue a tendência e pode ter um desempenho inferior em mercados agitados e limitados a intervalos.
Os níveis devem ser ajustados com base na volatilidade específica do mercado.
A alavancagem amplifica o tamanho da posição, bem como os riscos.
A natureza atrasada das médias móveis pode causar atrasos nos sinais de negociação.
Teste diferentes combinações de parâmetros e selecione os comprimentos MA rápidos/lentos ideais.
Incorporar outros indicadores ou modelos como sinais de filtro para melhorar a precisão, por exemplo, paradas ATR, RSI, etc.
Pesquise outras ferramentas de identificação de tendências como o ADX para melhorar ainda mais a capacidade de captura de tendências.
Usar modelos de aprendizagem de máquina para otimizar os sinais de estratégia e encontrar pontos de entrada/saída mais eficazes.
Considere o stop loss/take profit dinâmico baseado na volatilidade e nas condições de mercado para paradas mais sensatas.
A estratégia emprega uma abordagem sistemática de tendência e usa paradas/toma lucro e alavancagem para controlar o risco e aumentar os lucros.
/*backtest start: 2023-09-10 00:00:00 end: 2023-10-10 00:00:00 period: 2h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //////////////////////////////////////////////////////////////////////////////// // Bozz Strategy // Developed for Godstime // Version 1.1 // 11/28/2021 //////////////////////////////////////////////////////////////////////////////// //@version=4 // strategy("Bozz Strategy", "", true, default_qty_type=strategy.percent_of_equity, default_qty_value=100, margin_long=0, margin_short=0) // ----------------------------- Inputs ------------------------------------- // source_ma_type = input("EMA", "Source MA Type", options=["SMA", "EMA"]) source_ma_length = input(50, "Source MA Length") fast_ma_length = input(20, "Fast MA Length") slow_ma_length = input(50, "Slow MA Length") use_trend_filter = input(true, "Trend Filter") trend_filter_ma_type = input("EMA", "Trend Filter MA Type", options=["SMA", "EMA"]) trend_filter_ma_length = input(200, "Trend Filter MA Period") show_mas = input(true, "Show MAs") swing_trading_mode = input(false, "Swing Trading") // -------------------------- Calculations ---------------------------------- // fast_ma = ema(close, fast_ma_length) slow_ma = ema(close, slow_ma_length) source_ma = source_ma_type == "EMA"? ema(close, source_ma_length): sma(close, source_ma_length) trend_filter_ma = trend_filter_ma_type == "EMA"? ema(close, trend_filter_ma_length): sma(close, trend_filter_ma_length) // --------------------------- Conditions ----------------------------------- // uptrend = not use_trend_filter or close > trend_filter_ma buy_cond = crossover(fast_ma, slow_ma) and uptrend downtrend = not use_trend_filter or close < trend_filter_ma sell_cond = crossunder(fast_ma, slow_ma) and downtrend // ---------------------------- Plotting ------------------------------------ // bgcolor(use_trend_filter and downtrend? color.red: use_trend_filter? color.green: na) plot(show_mas? fast_ma: na, "Fast MA", color.green) plot(show_mas? slow_ma: na, "Slow MA", color.red) plot(show_mas? source_ma: na, "Source MA", color.purple) plot(show_mas? trend_filter_ma: na, "Trend Filter MA", color.blue) // ---------------------------- Trading ------------------------------------ // // Inputs sl_perc = input(1.0, "Stop Loss (in %)", group="Backtest Control")/100 tp_perc = input(1.0, "Take Profit (in %)", group="Backtest Control")/100 leverage = input(10, "Leverage", maxval=100, group="Backtest Control") bt_start_time = input(timestamp("2021 01 01"), "Backtest Start Time", input.time, group="Backtest Control") bt_end_time = input(timestamp("2021 12 31"), "Backtest End Time", input.time, group="Backtest Control") // Trading Window in_trading_window = true trade_qty = (strategy.equity * leverage) / close // Long Side strategy.entry("Long Entry", strategy.long, when=buy_cond and in_trading_window) long_tp = strategy.position_avg_price * (1 + tp_perc) long_sl = strategy.position_avg_price * (1 - sl_perc) if not swing_trading_mode strategy.exit("Long Exit", "Long Entry", limit=long_tp, stop=long_sl) // Short Side strategy.entry("Short Entry", strategy.short, when=sell_cond and in_trading_window) short_tp = strategy.position_avg_price * (1 - tp_perc) short_sl = strategy.position_avg_price * (1 + sl_perc) if not swing_trading_mode strategy.exit("Short Exit", "Short Entry", limit=short_tp, stop=short_sl) // End of trading window close strategy.close_all(when=not in_trading_window)