高頻度平均回帰戦略 固定ストップロスと利益目標を使用したレンジ取引システム

RSI BB VWMA ATR
作成日: 2025-04-01 10:51:20 最終変更日: 2025-04-01 10:51:20
コピー: 3 クリック数: 645
2
フォロー
319
フォロワー

高頻度平均回帰戦略 固定ストップロスと利益目標を使用したレンジ取引システム 高頻度平均回帰戦略 固定ストップロスと利益目標を使用したレンジ取引システム

概要

高周波平均回帰戦略は,市場における短期的な変動を捕捉するために設計された専門的な量化取引システムである.戦略の核心は,ブリン帯 ((Bollinger Bands),相対的に強い指標 ((RSI) と取引量重加減移動平均 ((VWMA) の組み合わせに基づいており,価格が平均から偏った極端な状況を識別することによって,潜在的な回帰の機会を探しています.この戦略は,固定されたパーセントのストップ・ロズと利益の目標を採用し,同時に,自主的なリスク管理機構を組み合わせることで,異なる市場条件下で安定性を保っています.

戦略原則

策略の核心原則は,平均値の回帰理論に基づいている.つまり,価格は短期的には平均値から逸脱する可能性があるが,長期的には回帰する傾向にある.具体的には,以下のいくつかの重要なステップによって実現される.

  1. 技術指標設定基本信号システムとして20期,標準差2.5のブリン帯,5期RSI指標,50期VWMAを使用している.

  2. 入学条件のデザイン

    • 多頭厳格条件:RSIが25以下 ((超売り),ブリン帯下線より低い価格がVWMAより高い
    • 空頭厳格条件:RSIが75以上 (超買い),ブリン帯より高い値が上線するが,VWMAより低い
    • 多頭ラジカル条件:RSIを30以下で,価格を中下軌道より低い状態で使用する
    • 空頭激進条件:RSIが70以上で,価格が中上線より高いという緩やかな条件を使用
  3. リスク管理機構

    • 固定比率ストップ:価格の1%に設定
    • 固定比率の利益:価格の2%に設定
    • 自律的なストップ・ローズ倍数:市場の波動性により調整され,波動時間大は2で,波動時間大は1.5
    • 最大のストップ・ロスの制限:20の最小価格変動単位
  4. 命令実行の論理

    • 厳格な条件の入場 標準のストップと利益のレベル
    • 激進条件の入場は,より大きなストップ損失 ((1.2倍) とより小さな利益目標 ((0.8倍) を使用する

この設計により,戦略は,オーバーバイ/オーバーセール条件を認識しながら,取引量重み付けの移動平均をトレンドフィルターとして使用し,強いトレンドの逆転取引を回避することができます.

戦略的優位性

この戦略は,コードを深く分析することで,以下の重要な利点が示されています.

  1. 双重確認メカニズムブルイン帯の突破とRSIの超買い/超売り状態を組み合わせると,偽信号の可能性が低下する.

  2. トレンドフィルター:VWMAを追加トレンド確認として使用し,強いトレンドで誤った平均回帰取引を避ける.

  3. リスクの自己適応: 波動率指数の動的調整によるストップダメージ倍数,高波動市場においてより大きな呼吸スペースを提供する.

  4. 固定パーセントのリスクコントロール: 1%のストップ・ローズと2%のリターン・ローズで,リスクとリターンの割合を1:2に保ち,健全な資金管理の原則に従います.

  5. 取引モデルの柔軟性厳格な入場条件と激進的な入場条件の両方を提供し,トレーダーは市場状況と個人リスクの好みに応じて適切な取引方法を選択することができます.

  6. ビジュアルサポート: グラフ上のマーカーとインジケーターを通して,入場点と重要な価格レベルをトレーダーに直感的に把握できるようにする.

  7. 最大止損制限: 価格単位20の最大ストップを設定することで,極端な市場条件で過大な損失を避ける.

戦略リスク

この戦略は合理的に設計されていますが,注意すべきリスク要因は以下の通りです.

  1. 平均回帰の破綻リスク: 強いトレンド市場では,価格が平均値から継続的に偏って戻らない場合があり,継続的な損失を引き起こす. 解決方法: トレンド強度フィルターを追加し,明確なトレンド市場では,戦略を一時停止する.

  2. 市場過度取引を整理する:高周波戦略は,市場を整理する際に取引信号を過剰に発生させ,取引コストを増やす可能性があります. 解決策:取引間隔制御または信号品質評価システムを導入する.

  3. リスク不適合の固定パーセント: 異なる価格変動の特徴を持つ市場段階において,固定パーセントは過大または過小である可能性があります. 解決策: ストップ・ロズと利益パーセントを,歴史的変動率に基づいて自動的に調整します.

  4. アクセスモードのリスク激進条件は取引の機会を多く提供するが,偽信号率も高い. 解決方法:激進信号に追加の確認条件を加えるか,資金使用率を下げる.

  5. 取引コストの影響:高周波戦略の収益性は取引コストに侵食されやすい. 解決方法:入場条件を最適化して取引回数を減らすか,取引コストに合わせて収益目標を調整する.

戦略最適化の方向性

この戦略は,以下の方向から最適化できます.

  1. 動態参数調整: RSIとブリン帯のパラメータを市場状況に基づいて自動調整するように設定できます.例えば,高い波動期により広いブリン帯とより極端なRSI値を使用することで,戦略の適応性が向上します.

  2. 市場環境のフィルター: 市場型識別ロジックを追加し,トレンド市場が特定されたときに戦略パラメータを一時停止または修正し,平均値の回帰に適さない市場環境での取引を避ける.

  3. タイムフィルターの最適化: タイムフィルターを追加し,重要な経済データ発表や市場流動性の低い時期を回避し,信号の質を向上させる.

  4. 部分ポジション管理: 入場・出場の階段を導入し,異なる価格レベルで倉庫を建設し,平均入場・出場価格を改善する.

  5. 取引の持続時間制御: 取引ごとに最大保有時間を設定し,無効信号が長期にわたって資金を占めるのを防ぎます.

  6. 関連市場の確認関連市場や指数のシグナルを取引確認として統合し,戦略の強さを高める.

  7. 機械学習の最適化: 機械学習技術を活用して入場パラメータとリスク管理パラメータを最適化することで,戦略が歴史データに基づいて最適なパラメータの組み合わせを自動的に調整できるようにする.

これらの最適化方向の実施は,戦略の適応性と安定性を著しく向上させ,特に異なる市場環境でのパフォーマンスを向上させるでしょう.

要約する

この高頻度均等回帰戦略は,技術指標,二重入場条件,インテリジェントリスク管理を巧妙に組み合わせることで,完全な取引システムを形成しています.戦略の核心的な優位性は,リスク制御機構と信号フィルタリングシステムで,取引頻度と信号品質を効果的にバランスします.いくつかの固有の均等回帰戦略リスクがあるものの,推奨された最適化方向,特に市場環境の適応性改善と動的パラメータ調整により,戦略の安定性と長期的なパフォーマンスをさらに向上させることができます.短期市場の変動を把握しようとするトレーダーにとって,この戦略は,構造化された枠組みを提供し,特に波動期間の市場での適用に適しています.

ストラテジーソースコード
/*backtest
start: 2025-01-01 00:00:00
end: 2025-03-31 00:00:00
period: 1h
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"ETH_USDT"}]
*/

//@version=6
strategy("XAU/USD High-Frequency Mean Reversion with Fixed SL and TP", overlay=true, initial_capital=10000, default_qty_type=strategy.percent_of_equity, default_qty_value=1, commission_value=0.04)

// === 1. BASIC INDICATORS ===
[bbUpper, bbMiddle, bbLower] = ta.bb(close, 20, 2.5)  // Wider Bollinger Bands
rsi = ta.rsi(close, 5)
vwma = ta.vwma(close, 50)

// === 2. EXTENDED PARAMETERS (INCREASED SIGNALS) ===
rsiOverbought = input(75, "RSI Overbought")  // Increased from 72 to 75
rsiOversold = input(25, "RSI Oversold")     // Decreased from 28 to 25

bbMidUpper = bbMiddle + (bbUpper - bbMiddle) * 0.5
bbMidLower = bbMiddle - (bbMiddle - bbLower) * 0.5

// === 3. ENTRY CONDITIONS ===
longStrict = rsi <= rsiOversold and close <= bbLower and close > vwma
shortStrict = rsi >= rsiOverbought and close >= bbUpper and close < vwma

// Expanded signal (higher risk)
longAggressive = rsi <= rsiOversold + 5 and close <= bbMidLower and close > vwma
shortAggressive = rsi >= rsiOverbought - 5 and close >= bbMidUpper and close < vwma

// === 4. ADAPTIVE RISK MANAGEMENT ===
atr = ta.atr(14)  // ATR over 14 periods to measure volatility
volatility = ta.stdev(close, 14)  // Standard deviation of closing prices

useAdaptiveSL = input(true, "Use Adaptive SL")  // Enable Adaptive Stop Loss
slMultiplier = useAdaptiveSL ? (volatility > ta.sma(volatility, 20) ? 2 : 1.5) : 1.8  // Adjust SL based on volatility

stopLoss = atr * slMultiplier  // Stop Loss dynamically adjusts based on ATR and volatility

// === 5. FIXED STOP LOSS & TAKE PROFIT SETTINGS ===
// Fixed Stop Loss and Take Profit ratios (e.g., 1% Stop Loss and 2% Take Profit)
stopLossPercentage = 0.01  // 1% Stop Loss
takeProfitPercentage = 0.02  // 2% Take Profit

// Calculate Stop Loss and Take Profit levels based on percentage
fixedStopLoss = close * stopLossPercentage
fixedTakeProfit = close * takeProfitPercentage

// === 6. LIMIT STOP LOSS TO 20 PIPS ===
// Maximum Stop Loss of 20 pips (for XAU/USD, 1 pip = 0.01)
// Ensure Stop Loss does not exceed 20 pips
maxStopLoss = 20 * syminfo.mintick  // Maximum Stop Loss = 20 pips
finalStopLoss = math.min(stopLoss, maxStopLoss)  // Use SL that does not exceed 20 pips

// === 7. EXECUTION OF TRADES ===
if (longStrict)
    strategy.entry("Long Strict", strategy.long, stop=close-finalStopLoss, limit=close+fixedTakeProfit)
if (shortStrict)
    strategy.entry("Short Strict", strategy.short, stop=close+finalStopLoss, limit=close-fixedTakeProfit)
if (longAggressive and strategy.position_size == 0)
    strategy.entry("Long Aggressive", strategy.long, stop=close-finalStopLoss*1.2, limit=close+fixedTakeProfit*0.8)
if (shortAggressive and strategy.position_size == 0)
    strategy.entry("Short Aggressive", strategy.short, stop=close+finalStopLoss*1.2, limit=close-fixedTakeProfit*0.8)

// === 8. DISPLAY ===
// Remove TP/SL markers and labels, keeping only buy/sell signals
plot(bbUpper, "BB Upper", color=color.blue)
plot(bbLower, "BB Lower", color=color.blue)
plot(bbMidUpper, "BB Mid-Upper", color=color.new(color.blue, 70), style=plot.style_circles)
plot(bbMidLower, "BB Mid-Lower", color=color.new(color.blue, 70), style=plot.style_circles)

plotshape(longStrict, "Buy Strict", shape.labelup, location.belowbar, color=color.new(#00FF00, 0), text="STRICT\nBUY", size=size.small)
plotshape(shortStrict, "Sell Strict", shape.labeldown, location.abovebar, color=color.new(#FF0000, 0), text="STRICT\nSELL", size=size.small)
plotshape(longAggressive, "Buy Aggressive", shape.triangleup, location.belowbar, color=color.new(#00AAFF, 0), size=size.small)
plotshape(shortAggressive, "Sell Aggressive", shape.triangledown, location.abovebar, color=color.new(#FFAA00, 0), size=size.small)