
この戦略は,馬重量平均価格 (GWAP) と動態分析を組み合わせた定量取引システムである.これは,歴史的価格データに馬重量処理を行い,短期動態指標と組み合わせて価格動向を予測する.戦略の核心は,馬因子を利用して,近期価格により高い重量配分を行うことで,近期市場動向に対する感性を高めることにある.
戦略は主に2つの核心理学の理論に基づいています:動量効果と馬重量定価.動量方面では,戦略は金融市場における価格トレンドの継続特性を利用します.重量方面では,馬因子 ((取値範囲0.5-1.5) を使って,歴史価格に指数級の衰退加重を加えます.具体的には,戦略は,GWAPを基準価格として計算して,価格がGWAPの上にあり,連続して3サイクル上昇傾向にあるときに多ポジションを開くか,逆に空ポジションを開く.
この戦略は,馬重量と動量分析を組み合わせて,市場動向のスマートな追跡を実現する.その核心的な優位性は,市場状況の動向に応じて重量配分を調整することができ,高い計算効率を維持することにある.一定の市場リスクとパラメータのセンシビリティの問題があるものの,継続的な最適化と改善により,戦略は,良い応用見通しを持っている.
/*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)