
Die Strategie ist ein quantitatives Handelssystem, das Puma-Wert-Durchschnittspreise (GWAP) und Dynamik-Analysen kombiniert. Sie wird durch Puma-Wertbehandlung von historischen Preisdaten und in Verbindung mit kurzfristigen Dynamikindikatoren verwendet, um Preisbewegungen vorherzusagen. Im Mittelpunkt der Strategie steht die Nutzung des Puma-Faktors für eine höhere Gewichtsverteilung auf kurzfristige Preise, um die Sensibilität für kurzfristige Marktbewegungen zu erhöhen.
Die Strategie basiert hauptsächlich auf zwei Kernpsychologien: der Dynamik-Effekt und der Puma-Gewichtung. Bei der Dynamik nutzt die Strategie die Eigenschaften der Fortsetzung der Preisentwicklung in den Finanzmärkten. Bei der Gewichtung wird der historischen Preis durch den Puma-Faktor (Bewertungsbereich 0.5-1.5) mit einer Index-Abnahme gewichtet.
Die Strategie ermöglicht die intelligente Verfolgung von Markttrends durch die Kombination von Puma-Gewichten und Dynamik-Analysen. Ihr zentraler Vorteil liegt in der Fähigkeit, die Gewichtsverteilung an die dynamischen Marktbedingungen anzupassen, während eine hohe Recheneffizienz beibehalten wird. Obwohl es bestimmte Probleme mit Marktrisiken und Parameter-Sensitivität gibt, hat die Strategie gute Anwendungsmöglichkeiten durch kontinuierliche Optimierung und Verbesserung.
/*backtest
start: 2024-02-18 00:00:00
end: 2025-02-16 08:00:00
period: 6h
basePeriod: 6h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=6
strategy("BTC Future Gamma-Weighted Momentum Model (BGMM)", shorttitle="BGMM", overlay=true,
default_qty_type=strategy.cash, default_qty_value=50000,
slippage=1, commission_value=0.01)
// Inputs
length = input.int(60, "Length for GWAP Calculation")
gamma_factor = input.float(0.75, "Gamma Weight Factor", minval=0.5, maxval=1.5, step=0.01)
// Helper Functions
var float cumulative_weighted_price = na
var float cumulative_weight = na
price = (high + low + close) / 3 // Typical price as a baseline
gamma_weights = array.new_float(length, 0.0)
price_series = array.new_float(length, na)
// Populate Arrays for Calculation
if bar_index >= length
for i = 0 to length - 1
weighted_gamma = math.pow(gamma_factor, i)
array.set(gamma_weights, i, weighted_gamma)
array.set(price_series, i, close[i])
// Compute GWAP
weighted_sum = 0.0
weight_total = 0.0
for i = 0 to length - 1
w = array.get(gamma_weights, i)
p = array.get(price_series, i)
weighted_sum := weighted_sum + p * w
weight_total := weight_total + w
GWAP = weight_total != 0 ? weighted_sum / weight_total : na
plot(GWAP, color=color.red, title="Gamma Weighted Average Price")
// Conditions for Trade Signals
long_condition = close > GWAP and close[1] > close[2] and close[2] > close[3]
short_condition = close < GWAP and close[1] < close[2] and close[2] < close[3]
// Strategy Logic
if long_condition
strategy.entry("Long", strategy.long)
if short_condition
strategy.entry("Short", strategy.short)