Esta estratégia usa o VWAP (Volume Weighted Average Price) do prazo diário como um sinal para entrar e sair das negociações. Quando o preço de fechamento cruza acima do VWAP, ele desencadeia uma entrada longa com o stop loss definido no mínimo das velas anteriores se estiver abaixo do VWAP, e o preço alvo definido 3 pontos acima do preço de entrada. Por outro lado, quando o preço de fechamento cruza abaixo do VWAP, ele desencadeia uma entrada curta com o stop loss definido no máximo das velas anteriores se estiver acima do VWAP, e o preço alvo definido 3 pontos abaixo do preço de entrada. Esta estratégia não inclui uma condição de saída, então as negociações permanecem abertas até que o sinal oposto ocorra.
Ao utilizar dados VWAP de intervalo de tempo para determinar tendências e alavancar perdas de parada dinâmicas e lucros fixos, a estratégia pode capturar efetivamente os mercados em tendência, controlar os riscos de retirada e bloquear os lucros em tempo hábil.
Esta estratégia utiliza dados VWAP de intervalo de tempo para determinação de tendências e desencadeamento de sinais, empregando stop loss dinâmicos e lucros fixos para controlar riscos e bloquear lucros. É uma estratégia de negociação quantitativa simples e eficaz. Através de otimizações na filtragem de tendências, take profit dinâmico, dimensionamento de posições e seleção de sessões de negociação, a robustez e o potencial de lucro da estratégia podem ser melhorados. No entanto, ao aplicar a estratégia na prática, deve-se prestar atenção às características do mercado, custos de negociação e otimização de parâmetros para alcançar uma melhor estratégia de desempenho.
/*backtest start: 2024-03-06 00:00:00 end: 2024-03-07 00:00:00 period: 45m basePeriod: 5m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy('Pine Script Tutorial Example Strategy 1', overlay=true, initial_capital=1000, default_qty_value=100, default_qty_type=strategy.percent_of_equity) // fastEMA = ta.ema(close, 24) // slowEMA = ta.ema(close, 200) // Higher Time Frame float sl = na float tgt = na posSize = 1 vwap_1d = request.security(syminfo.tickerid, "1D", ta.vwap(close)) // plot(vwap_1d) // To avoid differences on historical and realtime bars, you can use this technique, which only returns a value from the higher timeframe on the bar after it completes: // indexHighTF = barstate.isrealtime ? 1 : 0 // indexCurrTF = barstate.isrealtime ? 0 : 1 // nonRepaintingVWAP = request.security(syminfo.tickerid, "1D", close[indexHighTF])[indexCurrTF] // plot(nonRepaintingVWAP, "Non-repainting VWAP") enterLong = ta.crossover(close, vwap_1d) exitLong = ta.crossunder(close, vwap_1d) enterShort = ta.crossunder(close, vwap_1d) exitShort = ta.crossover(close, vwap_1d) if enterLong sl := low[1]>vwap_1d ?low[1]:vwap_1d tgt:=close+3 strategy.entry("EL", strategy.long, qty=posSize) strategy.exit('exitEL', 'EL', stop=sl, limit=tgt) if enterShort sl := high[1]<vwap_1d ?high[1]:vwap_1d tgt := close-3 strategy.entry("ES", strategy.short, qty=posSize) strategy.exit('exitES', 'ES', stop=sl, limit=tgt) // if exitLong // strategy.close("EL") // if exitShort // strategy.close("ES") // goLongCondition1 = ta.crossover(close, vwap_1d) // timePeriod = time >= timestamp(syminfo.timezone, 2021, 01, 01, 0, 0) // notInTrade = strategy.position_size <= 0 // if goLongCondition1 and timePeriod and notInTrade // stopLoss = low[1] // takeProfit = close+3 // strategy.entry('long', strategy.long) // strategy.exit('exit', 'long', stop=stopLoss, limit=takeProfit) plot(close, color=color.new(#00c510, 0)) plot(vwap_1d, color=color.new(#f05619, 0)) plot(sl, color=color.new(#fbff00, 0)) plot(tgt, color=color.new(#00e1ff, 0))