Esta estratégia é um sistema de negociação de rastreamento de impulso baseado no indicador de Bollinger Bands. Identifica oportunidades de ruptura potenciais monitorando a relação entre o preço e a banda superior de Bollinger e fecha posições quando o preço cai abaixo da banda inferior. As bandas de Bollinger consistem em três linhas: a banda média (média móvel), as bandas superior e inferior (calculadas usando desvio padrão).
A lógica central da estratégia baseia-se nos seguintes pontos:
Esta é uma estratégia de tendência baseada em bandas de Bollinger, capturando as tendências do mercado observando a relação entre o preço e as bandas. A estratégia é bem projetada com boa adaptabilidade e mecanismos de gerenciamento de risco. Através das direções de otimização sugeridas, a estabilidade e lucratividade da estratégia podem ser ainda melhoradas. É particularmente adequado para mercados voláteis, mas os comerciantes precisam ajustar parâmetros e medidas de controle de risco de acordo com as condições reais.
/*backtest start: 2019-12-23 08:00:00 end: 2025-01-04 08:00:00 period: 1d basePeriod: 1d exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy(title="Demo GPT - Bollinger Bands Strategy", overlay=true, initial_capital=100000, commission_type=strategy.commission.percent, commission_value=0.1, slippage=3) // Inputs length = input.int(20, minval=1, title="Length") maType = input.string("SMA", "Basis MA Type", options=["SMA", "EMA", "SMMA (RMA)", "WMA", "VWMA"]) src = input(close, title="Source") mult = input.float(2.0, minval=0.001, maxval=50, title="StdDev") offset = input.int(0, "Offset", minval=-500, maxval=500) startDate = input(timestamp('01 Jan 2018 00:00 +0000'), title="Start Date") endDate = input(timestamp('31 Dec 2069 23:59 +0000'), title="End Date") // Moving Average Function ma(source, length, _type) => switch _type "SMA" => ta.sma(source, length) "EMA" => ta.ema(source, length) "SMMA (RMA)" => ta.rma(source, length) "WMA" => ta.wma(source, length) "VWMA" => ta.vwma(source, length) // Calculations basis = ma(src, length, maType) dev = mult * ta.stdev(src, length) upper = basis + dev lower = basis - dev // Plotting plot(basis, "Basis", color=#2962FF, offset=offset) p1 = plot(upper, "Upper", color=#F23645, offset=offset) p2 = plot(lower, "Lower", color=#089981, offset=offset) fill(p1, p2, title="Background", color=color.rgb(33, 150, 243, 95)) // Strategy Logic inTradeWindow = true longCondition = close > upper and inTradeWindow exitCondition = close < lower and inTradeWindow if (longCondition) strategy.entry("Long", strategy.long, qty=1) if (exitCondition) strategy.close("Long")