この戦略は,複数の移動平均値に基づいたトレンドフォローシステムで,トレンド強度確認と波動性キャプチャメカニズムを組み合わせています. 5,25および75期間のトリプル移動平均値システムをコアとして利用し,ADX指標を通じて強いトレンドをフィルターし,タイムリーな利益を得るために急速な波動性モニタリングシステムを統合しています.この多層取引メカニズムは,市場のトレンドを効果的に特定し,適切なタイミングで取引を実行します.
戦略は3つの基本的メカニズムに基づいて機能します.
特別取引規則
適応パラメータを導入する:
強化された傾向の確認:
利益/損失を最適化する:
市場環境分類:
この戦略は,複数の移動平均値,トレンド強度確認,および変動監視の次元を通じて完全な取引システムを構築する.その主な利点は,複数のレベルの確認メカニズムと柔軟なリスク管理システムにあります.提供された最適化提案を通じて,戦略は適応性と安定性をさらに高めることができます.実用的な応用では,トレーダーは特定の市場の特徴に応じてパラメータを最適化し,合理的なマネジメント戦略と組み合わせることをお勧めします.
/*backtest start: 2024-10-01 00:00:00 end: 2024-10-31 23:59:59 period: 2h basePeriod: 2h exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("5SMA-25SMA Crossover Strategy with ADX Filter and Sudden Move Profit Taking", overlay=true) // パラメータの設定 sma5 = ta.sma(close, 5) sma25 = ta.sma(close, 25) sma75 = ta.sma(close, 75) // ADXの計算 length = 14 tr = ta.tr(true) plus_dm = ta.rma(math.max(ta.change(high), 0), length) minus_dm = ta.rma(math.max(-ta.change(low), 0), length) tr_sum = ta.rma(tr, length) plus_di = 100 * plus_dm / tr_sum minus_di = 100 * minus_dm / tr_sum dx = 100 * math.abs(plus_di - minus_di) / (plus_di + minus_di) adx = ta.rma(dx, length) // ロングとショートのエントリー条件 longCondition = ta.crossover(sma5, sma25) and close > sma75 and adx > 20 shortCondition = ta.crossunder(sma5, sma25) and close < sma75 and adx > 20 // 急激な変動を検知する条件(ここでは、前のローソク足に比べて0.6%以上の値動きがあった場合) suddenMove = math.abs(ta.change(close)) > close[1] * 0.006 // ポジション管理 if (longCondition) strategy.entry("Long", strategy.long) if (shortCondition) strategy.entry("Short", strategy.short) // 急激な変動があった場合、ポジションを利益確定(クローズ)する if (strategy.position_size > 0 and suddenMove) strategy.close("Long") if (strategy.position_size < 0 and suddenMove) strategy.close("Short") // エグジット条件 if (strategy.position_size > 0 and shortCondition) strategy.close("Long") if (strategy.position_size < 0 and longCondition) strategy.close("Short") // SMAとADXのプロット plot(sma5, color=color.blue, title="5SMA") plot(sma25, color=color.red, title="25SMA") plot(sma75, color=color.green, title="75SMA") plot(adx, color=color.orange, title="ADX") hline(20, "ADX Threshold", color=color.gray, linestyle=hline.style_dotted)