
Cette stratégie est un système de trading basé sur des moyennes mobiles pondérées par la liquidité. Elle mesure la liquidité du marché en surveillant la relation entre les fluctuations de prix et le volume des transactions, et construit des moyennes mobiles rapides et lentes sur cette base. Un signal d’achat est généré lorsque la ligne rapide croise la ligne lente, et un signal de vente est généré lorsqu’elle la croise en dessous. La stratégie accorde une attention particulière aux événements de liquidité anormaux et enregistre les points de prix clés via des tableaux, offrant ainsi des opportunités de trading plus précises.
Le cœur de la stratégie consiste à mesurer la liquidité du marché à travers le ratio entre le volume des transactions et la variation des prix. Les étapes spécifiques de mise en œuvre sont les suivantes :
Il s’agit d’une stratégie innovante qui combine l’analyse de liquidité avec des indicateurs techniques, optimisant le système traditionnel de croisement de moyennes mobiles en surveillant les anomalies de liquidité du marché. Bien qu’il fonctionne bien dans des environnements de marché spécifiques, il nécessite encore une optimisation supplémentaire pour améliorer la stabilité et l’applicabilité. Il est recommandé aux traders d’effectuer des tests suffisants avant une utilisation en temps réel et de les combiner avec d’autres indicateurs pour créer un système de trading plus complet.
/*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))