
A estratégia é um sistema de negociação baseado em médias móveis ponderadas pela liquidez. Ela mede a liquidez do mercado monitorando a relação entre flutuações de preço e volume de negociação, e constrói médias móveis rápidas e lentas com base nisso. Um sinal de compra é gerado quando a linha rápida cruza acima da linha lenta, e um sinal de venda é gerado quando ela cruza abaixo. A estratégia presta atenção especial a eventos de liquidez anormais e registra pontos-chave de preço por meio de matrizes, proporcionando assim oportunidades de negociação mais precisas.
O cerne da estratégia é medir a liquidez do mercado por meio da relação entre o volume de negociação e a variação de preço. As etapas específicas de implementação são as seguintes:
Esta é uma estratégia inovadora que combina análise de liquidez com indicadores técnicos, otimizando o sistema tradicional de cruzamento de médias móveis por meio do monitoramento de anomalias de liquidez do mercado. Embora tenha um bom desempenho em ambientes de mercado específicos, ainda precisa de mais otimização para melhorar a estabilidade e a aplicabilidade. É recomendável que os traders realizem testes suficientes antes do uso em tempo real e os combinem com outros indicadores para construir um sistema de negociação mais completo.
/*backtest
start: 2019-12-23 08:00:00
end: 2025-01-16 00:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT","balance":49999}]
*/
//Liquidity ignoring price location
//@version=6
strategy("Liquidity Weighted Moving Averages [AlgoAlpha]", overlay=true, commission_type=strategy.commission.percent, commission_value=0.1, slippage=3)
// Inputs
outlierThreshold = input.int(10, "Outlier Threshold Length")
fastMovingAverageLength = input.int(50, "Fast MA Length")
slowMovingAverageLength = input.int(100, "Slow MA Length")
start_date = input(timestamp("2018-01-01 00:00"), title="Start Date")
end_date = input(timestamp("2069-12-31 23:59"), title="End Date")
// Define liquidity based on volume and price movement
priceMovementLiquidity = volume / math.abs(close - open)
// Calculate the boundary for liquidity to identify outliers
liquidityBoundary = ta.ema(priceMovementLiquidity, outlierThreshold) + ta.stdev(priceMovementLiquidity, outlierThreshold)
// Initialize an array to store liquidity values when they cross the boundary
var liquidityValues = array.new_float(5)
// Check if the liquidity crosses above the boundary and update the array
if ta.crossover(priceMovementLiquidity, liquidityBoundary)
array.insert(liquidityValues, 0, close)
if array.size(liquidityValues) > 5
array.pop(liquidityValues)
// Calculate the Exponential Moving Averages for the close price at the last liquidity crossover
fastEMA = ta.ema(array.size(liquidityValues) > 0 ? array.get(liquidityValues, 0) : na, fastMovingAverageLength)
slowEMA = ta.ema(array.size(liquidityValues) > 0 ? array.get(liquidityValues, 0) : na, slowMovingAverageLength)
// Trading Logic
in_date_range = true
buy_signal = ta.crossover(fastEMA, slowEMA) and in_date_range
sell_signal = ta.crossunder(fastEMA, slowEMA) and in_date_range
// Strategy Entry and Exit
if (buy_signal)
strategy.entry("Buy", strategy.long)
if (sell_signal)
strategy.close("Buy")
// Plotting
fastPlot = plot(fastEMA, color=fastEMA > slowEMA ? color.new(#00ffbb, 50) : color.new(#ff1100, 50), title="Fast EMA")
slowPlot = plot(slowEMA, color=fastEMA > slowEMA ? color.new(#00ffbb, 50) : color.new(#ff1100, 50), title="Slow EMA")
// Create a fill between the fast and slow EMA plots with appropriate color based on crossover
fill(fastPlot, slowPlot, fastEMA > slowEMA ? color.new(#00ffbb, 50) : color.new(#ff1100, 50))