
Esta estratégia é um sistema de negociação quantitativa que combina o método estatístico Z-Score, o indicador RSI relativamente forte e o indicador Supertrend. A estratégia busca oportunidades de alta probabilidade de negociação no mercado, monitorando o desvio estatístico dos preços, combinando indicadores de momentum e confirmação de tendências. A estratégia não só consegue capturar oportunidades de superaquecimento do mercado, mas também pode filtrar sinais falsos através da confirmação de tendências, permitindo negociações bidirecionais em muitos espaços.
A lógica central da estratégia baseia-se na sinergia de três principais indicadores técnicos: primeiro, medir o grau de desvio do preço atual em relação à média histórica através do cálculo de um Z-score no preço, usando uma média móvel e um diferencial padrão de 75 ciclos. Quando o Z-score é superior a 1,1 ou inferior a -1,1, indica-se um desvio estatístico significativo no preço.
Trata-se de uma estratégia de negociação quantitativa que combina métodos estatísticos e análise técnica para aumentar a confiabilidade das negociações por meio da confirmação de múltiplos sinais. O principal benefício da estratégia reside em seus modelos matemáticos objetivos e mecanismos de controle de risco perfeitos, mas também é necessário prestar atenção à otimização de parâmetros e à adaptabilidade do mercado.
/*backtest
start: 2024-01-01 00:00:00
end: 2024-11-26 00:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("Z-Score Long and Short Strategy with Supertrend", overlay=true)
// Inputs for Z-Score
len = input.int(75, "Z-Score Lookback Length")
z_long_threshold = 1.1 // Threshold for Z-Score to open long
z_short_threshold = -1.1 // Threshold for Z-Score to open short
// Z-Score Calculation
z = (close - ta.sma(close, len)) / ta.stdev(close, len)
// Calculate Driver RSI
driver_rsi_length = input.int(14, "Driver RSI Length") // Input for RSI Length
driver_rsi = ta.rsi(close, driver_rsi_length) // Calculate the RSI
// Supertrend Parameters
atrPeriod = input.int(11, "ATR Length", minval=1)
factor = input.float(2.0, "Factor", minval=0.01, step=0.01)
// Supertrend Calculation
[supertrend, direction] = ta.supertrend(factor, atrPeriod)
// Conditions for Long and Short based on Z-Score
z_exceeds_long = z >= z_long_threshold and driver_rsi > 60
z_exceeds_short = z <= z_short_threshold and driver_rsi < 40
// Entry Conditions
if (z_exceeds_long and direction < 0) // Enter Long if Z-Score exceeds threshold and Supertrend is down
strategy.entry("Long", strategy.long)
label.new(bar_index, low, text="Open Long", style=label.style_label_up, color=color.green, textcolor=color.white, size=size.small)
alert("Open Long", alert.freq_once_per_bar) // Alert for Long entry
if (z_exceeds_short and direction > 0) // Enter Short if Z-Score exceeds threshold and Supertrend is up
strategy.entry("Short", strategy.short)
label.new(bar_index, high, text="Open Short", style=label.style_label_down, color=color.red, textcolor=color.white, size=size.small)
alert("Open Short", alert.freq_once_per_bar) // Alert for Short entry
// Plot Supertrend
upTrend = plot(direction < 0 ? supertrend : na, "Up Trend", color=color.green, style=plot.style_linebr)
downTrend = plot(direction > 0 ? supertrend : na, "Down Trend", color=color.red, style=plot.style_linebr)
fill(upTrend, downTrend, color=color.new(color.green, 90), fillgaps=false)
// Alert conditions for Supertrend changes (optional)
alertcondition(direction[1] > direction, title='Downtrend to Uptrend', message='The Supertrend value switched from Downtrend to Uptrend')
alertcondition(direction[1] < direction, title='Uptrend to Downtrend', message='The Supertrend value switched from Uptrend to Downtrend')