この戦略は,ボリンジャーバンドに基づいたモメンタムブレークアウト取引システムであり,主に価格と上部ボリンジャーバンドの関係を通じてトレンド機会を把握する.この戦略は,高度な波動性のある市場に特に適した市場波動性特性を特定するために標準偏差チャネルと組み合わせた適応型移動平均型選択メカニズムを使用する.
戦略の基本論理は次の主要な要素に基づいています 1. Bollinger Bands の中間帯を計算するために,カスタマイズ可能な移動平均値 (SMA,EMA,SMMA,WMA,VWMAを含む) を使用する. 2. 標準偏差倍数 (デフォルト2.0) を使って上部および下部帯の位置を動的に決定する. 3. 価格が上部帯を突破するとロングポジションに入る.これは強いブレイクトレンドの形成を示唆する. 4. 価格が下帯を下回るとポジションを退場し,上昇傾向の潜在的な終了を示唆する. 5. 取引コスト (0.1%) とスリップ (3ポイント) を含め,実際の取引条件をよりよく反映する.
このトレンドは,明確なロジックを持つ戦略を踏まえて,よく設計されたトレンドである.ボリンジャーバンドのダイナミックな性質を通じて市場の勢いを捉え,良いリスク制御メカニズムを含んでいる.この戦略は高度にカスタマイズ可能で,パラメータ調整を通じて異なる市場環境に適応することができる.ライブ取引の実施のために,戦略改善のための提案された最適化方向を組み込むと同時に,徹底的なパラメータ最適化とバックテストの検証を行うことが推奨される.
/*backtest start: 2019-12-23 08:00:00 end: 2024-12-11 08:00:00 period: 1d basePeriod: 1d exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Demo GPT - Bollinger Bands", overlay=true, initial_capital=10000, commission_type=strategy.commission.percent, commission_value=0.1, slippage=3, default_qty_type=strategy.percent_of_equity, default_qty_value=100) // Inputs length = input.int(20, minval=1, title="Length") maType = input.string("SMA", "Basis MA Type", options = ["SMA", "EMA", "SMMA (RMA)", "WMA", "VWMA"]) src = input(close, title="Source") mult = input.float(2.0, minval=0.001, maxval=50, title="StdDev") offset = input.int(0, "Offset", minval=-500, maxval=500) // Date range inputs startYear = input.int(2018, "Start Year", minval=1970, maxval=2100) startMonth = input.int(1, "Start Month", minval=1, maxval=12) startDay = input.int(1, "Start Day", minval=1, maxval=31) endYear = input.int(2069, "End Year", minval=1970, maxval=2100) endMonth = input.int(12, "End Month", minval=1, maxval=12) endDay = input.int(31, "End Day", minval=1, maxval=31) // Time range startTime = timestamp("GMT+0", startYear, startMonth, startDay, 0, 0) endTime = timestamp("GMT+0", endYear, endMonth, endDay, 23, 59) // Moving average function ma(source, length, _type) => switch _type "SMA" => ta.sma(source, length) "EMA" => ta.ema(source, length) "SMMA (RMA)" => ta.rma(source, length) "WMA" => ta.wma(source, length) "VWMA" => ta.vwma(source, length) // Calculate Bollinger Bands basis = ma(src, length, maType) dev = mult * ta.stdev(src, length) upper = basis + dev lower = basis - dev // Plot plot(basis, "Basis", color=#2962FF, offset=offset) p1 = plot(upper, "Upper", color=#F23645, offset=offset) p2 = plot(lower, "Lower", color=#089981, offset=offset) fill(p1, p2, title="Background", color=color.rgb(33, 150, 243, 95)) // Strategy logic: Only go long and flat inDateRange = time >= startTime and time <= endTime noPosition = strategy.position_size == 0 longPosition = strategy.position_size > 0 // Buy if close is above upper band if inDateRange and noPosition and close > upper strategy.entry("Long", strategy.long) // Sell/Exit if close is below lower band if inDateRange and longPosition and close < lower strategy.close("Long")