Estratégia de negociação de linha de parada móvel adaptativa

Autora:ChaoZhang, Data: 2024-02-21 16:07:20
Tags:

img

Resumo

A ideia central desta estratégia é usar a média móvel T3 e a parada de rastreamento adaptativa ATR para capturar pontos de entrada e saída ao longo da tendência.

Princípio da estratégia

A estratégia consiste no indicador T3, no indicador ATR e no mecanismo ATR trailing stop.

A média móvel T3 é uma média móvel suavizada que pode reduzir o atraso da curva e fazê-la responder mais rapidamente às mudanças de preço. Um sinal de compra é gerado quando o preço atravessa a média móvel de baixo. Um sinal de venda é gerado quando o preço atravessa de cima.

O indicador ATR é usado para calcular o grau de volatilidade do mercado e definir níveis de stop loss. Quanto maior o valor ATR, maior a volatilidade do mercado e uma perda de stop mais ampla deve ser definida.

O mecanismo de stop trailing do ATR ajusta a posição da linha de stop loss com base nos valores do ATR em tempo real, de modo que a linha de stop loss possa seguir o movimento do preço e permanecer dentro de um intervalo razoável.

Ao utilizar o T3 para determinar a direção, o ATR para calcular a volatilidade e o mecanismo de parada de atraso do ATR, esta estratégia obtém uma captura de tendência e um controlo de risco relativamente eficientes.

Vantagens

As vantagens desta estratégia incluem:

  1. A aplicação da linha T3 melhora a precisão das tendências de captura.

  2. O indicador ATR calcula dinamicamente a volatilidade do mercado, tornando os níveis de stop loss e take profit mais razoáveis.

  3. O mecanismo ATR trailing stop permite que a linha de stop loss acompanhe o movimento dos preços em tempo real para um controlo eficaz do risco.

  4. Integra indicadores e mecanismos de stop loss para alcançar a negociação automatizada de rastreamento de tendências.

  5. Pode conectar-se a plataformas de negociação externas através de webhook para execução automatizada de ordens.

Riscos e soluções

Há também alguns riscos com esta estratégia:

  1. Definições incorretas do parâmetro T3 podem perder melhores oportunidades de tendência. Diferentes parâmetros do ciclo podem ser testados para encontrar os valores ideais.

  2. O cálculo impreciso do valor ATR pode levar a uma distância de stop loss demasiado grande ou demasiado pequena para controlar eficazmente o risco.

  3. Em flutuações violentas, a linha de stop loss pode ser quebrada, resultando em perdas excessivas.

  4. Aumentar adequadamente a distância de parada do ATR pode ajudar.

Orientações de otimização

A estratégia pode ser otimizada nos seguintes aspectos:

  1. Otimizar o parâmetro T3 para encontrar o ciclo de suavização mais adequado.

  2. Ensaiar diferentes parâmetros do ciclo ATR para calcular o valor ATR que melhor reflita a volatilidade do mercado.

  3. Otimizar o intervalo flexível da distância de paragem traseira do ATR para evitar paradas excessivamente sensíveis.

  4. Adicionar filtros apropriados para evitar frequentes negociações em mercados de serras.

  5. Incorporar indicadores de avaliação de tendências para melhorar a precisão da rentabilidade direcional.

  6. Usar métodos de aprendizagem de máquina para otimizar automaticamente parâmetros.

Conclusão

Esta estratégia integra o uso da linha T3 para determinar a direção da tendência, o indicador ATR para calcular paradas/alvos e o mecanismo ATR para ajustar a distância de parada.


/*backtest
start: 2024-01-21 00:00:00
end: 2024-02-20 00:00:00
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=5
strategy(title='UT Bot Alerts (QuantNomad) Strategy', overlay=true)
T3 = input(100)//600
// Input for Long Settings
// Input for Long Settings


xPrice3 = close
xe1 = ta.ema(xPrice3, T3)
xe2 = ta.ema(xe1, T3)
xe3 = ta.ema(xe2, T3)
xe4 = ta.ema(xe3, T3)
xe5 = ta.ema(xe4, T3)
xe6 = ta.ema(xe5, T3)

b3 = 0.7
c1 = -b3*b3*b3
c2 = 3*b3*b3+3*b3*b3*b3
c3 = -6*b3*b3-3*b3-3*b3*b3*b3
c4 = 1+3*b3+b3*b3*b3+3*b3*b3
nT3Average = c1 * xe6 + c2 * xe5 + c3 * xe4 + c4 * xe3

//plot(nT3Average, color=color.white, title="T3")

// Buy Signal - Price is below T3 Average
buySignal3 = xPrice3 < nT3Average
sellSignal3 = xPrice3 > nT3Average
// Inputs
a = input(1, title='Key Value. "This changes the sensitivity"')
c = input(50, title='ATR Period')
h = input(true, title='Signals from Heikin Ashi Candles')
riskRewardRatio = input(1, title='Risk Reward Ratio')

xATR = ta.atr(c)
nLoss = a * xATR

src = h ? request.security(ticker.heikinashi(syminfo.tickerid), timeframe.period, close, lookahead=barmerge.lookahead_off) : close

xATRTrailingStop = 0.0
iff_1 = src > nz(xATRTrailingStop[1], 0) ? src - nLoss : src + nLoss
iff_2 = src < nz(xATRTrailingStop[1], 0) and src[1] < nz(xATRTrailingStop[1], 0) ? math.min(nz(xATRTrailingStop[1]), src + nLoss) : iff_1
xATRTrailingStop := src > nz(xATRTrailingStop[1], 0) and src[1] > nz(xATRTrailingStop[1], 0) ? math.max(nz(xATRTrailingStop[1]), src - nLoss) : iff_2

pos = 0
iff_3 = src[1] > nz(xATRTrailingStop[1], 0) and src < nz(xATRTrailingStop[1], 0) ? -1 : nz(pos[1], 0)
pos := src[1] < nz(xATRTrailingStop[1], 0) and src > nz(xATRTrailingStop[1], 0) ? 1 : iff_3

xcolor = pos == -1 ? color.red : pos == 1 ? color.green : color.blue

ema = ta.ema(src, 1)
above = ta.crossover(ema, xATRTrailingStop)
below = ta.crossunder(ema, xATRTrailingStop)

buy = src > xATRTrailingStop and above
sell = src < xATRTrailingStop and below

barbuy = src > xATRTrailingStop
barsell = src < xATRTrailingStop

plotshape(buy, title='Buy', text='Buy', style=shape.labelup, location=location.belowbar, color=color.new(color.green, 0), textcolor=color.new(color.white, 0), size=size.tiny)
plotshape(sell, title='Sell', text='Sell', style=shape.labeldown, location=location.abovebar, color=color.new(color.red, 0), textcolor=color.new(color.white, 0), size=size.tiny)

barcolor(barbuy ? color.new(color.green, 90) : na)
barcolor(barsell ? color.new(color.red, 90) : na)

var float entryPrice = na
var float takeProfitLong = na
var float stopLossLong = na
var float takeProfitShort = na
var float stopLossShort = na

if buy and buySignal3
    entryPrice := src
    takeProfitLong := entryPrice + nLoss * riskRewardRatio
    stopLossLong := entryPrice - nLoss
    takeProfitShort := na
    stopLossShort := na

if sell and sellSignal3
    entryPrice := src
    takeProfitShort := entryPrice - nLoss * riskRewardRatio
    stopLossShort := entryPrice + nLoss
    takeProfitLong := na
    stopLossLong := na

// Strategy order conditions
acct = "Sim101"
ticker = "ES 12-23"
qty = 1

OCOMarketLong = '{ "alert": "OCO Market Long", "account": "' + str.tostring(acct) + '", "ticker": "' + str.tostring(ticker) + '", "qty": "' + str.tostring(qty) + '", "take_profit_price": "' + str.tostring(takeProfitLong) + '", "stop_price": "' + str.tostring(stopLossLong) + '", "tif": "DAY" }'
OCOMarketShort = '{ "alert": "OCO Market Short", "account": "' + str.tostring(acct) + '", "ticker": "' + str.tostring(ticker) + '", "qty": "' + str.tostring(qty) + '", "take_profit_price": "' + str.tostring(takeProfitShort) + '", "stop_price": "' + str.tostring(stopLossShort) + '", "tif": "DAY" }'
CloseAll = '{ "alert": "Close All", "account": "' + str.tostring(acct) + '", "ticker": "' + str.tostring(ticker) + '" }'

strategy.entry("Long", strategy.long, when=buy and buySignal3, alert_message=OCOMarketLong)
strategy.entry("Short", strategy.short, when=sell and sellSignal3, alert_message=OCOMarketShort)

// Setting the take profit and stop loss for long trades
strategy.exit("Take Profit/Stop Loss", "Long", stop=stopLossLong, limit=takeProfitLong,alert_message=CloseAll)

// Setting the take profit and stop loss for short trades
strategy.exit("Take Profit/Stop Loss", "Short", stop=stopLossShort, limit=takeProfitShort,alert_message=CloseAll)

// Plot trade setup boxes
bgcolor(buy ? color.new(color.green, 90) : na, transp=0, offset=-1)
bgcolor(sell ? color.new(color.red, 90) : na, transp=0, offset=-1)

longCondition = buy and not na(entryPrice)
shortCondition = sell and not na(entryPrice)

// var line longTakeProfitLine = na
// var line longStopLossLine = na
// var line shortTakeProfitLine = na
// var line shortStopLossLine = na

// if longCondition
//     longTakeProfitLine := line.new(bar_index, takeProfitLong, bar_index + 1, takeProfitLong, color=color.green, width=2)
//     longStopLossLine := line.new(bar_index, stopLossLong, bar_index + 1, stopLossLong, color=color.red, width=2)
//     // label.new(bar_index + 1, takeProfitLong, str.tostring(takeProfitLong, "#.#####"), color=color.green, style=label.style_none, textcolor=color.green, size=size.tiny)
//     // label.new(bar_index + 1, stopLossLong, str.tostring(stopLossLong, "#.#####"), color=color.red, style=label.style_none, textcolor=color.red, size=size.tiny)

// if shortCondition
//     shortTakeProfitLine := line.new(bar_index, takeProfitShort, bar_index + 1, takeProfitShort, color=color.green, width=2)
//     shortStopLossLine := line.new(bar_index, stopLossShort, bar_index + 1, stopLossShort, color=color.red, width=2)
//     // label.new(bar_index + 1, takeProfitShort, str.tostring(takeProfitShort, "#.#####"), color=color.green, style=label.style_none, textcolor=color.green, size=size.tiny)
//     // label.new(bar_index + 1, stopLossShort, str.tostring(stopLossShort, "#.#####"), color=color.red, style=label.style_none, textcolor=color.red, size=size.tiny)

alertcondition(buy, 'UT Long', 'UT Long')
alertcondition(sell, 'UT Short', 'UT Short')


Mais.