複数の移動平均のクロスオーバー取引戦略

作者: リン・ハーンチャオチャン, 日付: 2023-12-06 17:10:00
タグ:

img

戦略の概要

この戦略は,複数の移動平均指標に基づいて取引信号を生成する.短期,中期,長期移動平均を同時に監視し,トレンド方向を決定するために,クロスオーバー状況に応じて取引信号を生成する.

戦略名

複数の移動平均のクロスオーバー戦略

戦略の論理

この戦略は,7日,13日および21日線を含む異なる期間の3つの移動平均を使用します.取引論理は以下の点に基づいています.

  1. 短期間の7日間のMAが中期間の13日間のMAを上向きに越え,長期間の21日間のMAが上向きに動いているとき,長い信号が生成されます.
  2. 短期間の7日間のMAが中期間の13日間のMAを下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値を下回る値

異なる時間枠の移動平均を組み合わせることで,戦略は市場の動向をより正確に判断し,誤った取引を回避することができます.

利点

  1. 複数のMAラインを使用することで,市場の動きをより正確に判断し,偽のブレイクアウトや短期的な市場の変動に誤導されないことができます.
  2. 傾向が明確であるときにのみシグナルが生成され,不必要な取引を削減し,取引コストを下げます.
  3. 柔軟なパラメータ設定 - 市場評価期間は,個人好みに基づいて,異なる製品や市場環境に合わせて調整できます.

リスク

  1. 市場が動揺している場合 誤った信号が頻繁に発生する可能性があります
  2. MAは,傾向を示す指標として,転換点を正確に特定することはできません.
  3. MAのクロスオーバーで信号が遅れた場合 利益の一部が失われる可能性があります
  4. 信号検証のための他の技術指標を導入し,MAパラメータを最適化することでリスクは軽減できる.

オプティマイゼーションの方向性

  1. 動揺する市場での取引を避けるために 動揺指標を組み込むことを検討します
  2. マシン学習モデルを使って MAパラメータを自動最適化してみてください
  3. ストップ・ロスの戦略を追加して 引き上げが拡大するときに 時間をかけて損失を削減します
  4. MAのクロスオーバーが起こる場合,スライドを減らすために制限命令を使用します.

結論

この戦略は,クロスオーバー関係に基づいて市場動向を決定するために,短期,中期,長期MAsを組み合わせ,比較的安定し効率的なトレンドフォロー戦略です.指標パラメータ,ストップロスのメカニズム,オーダー配置のさらなる改善は,勝ち率と収益性を高めるのに役立ちます.


/*backtest
start: 2022-11-29 00:00:00
end: 2023-12-05 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

// This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © Crypto-Oli

//@version=4
strategy("CryptOli 3 MAs long/short Backtest", initial_capital=5000, default_qty_type=strategy.percent_of_equity, default_qty_value=100, overlay=true)

// this is an educational Script - basicly its very simple - you can see how minimal changes impact results, thats why i posted it
// Credits to Quantnomad to publish tons of free educational script
// this Script is based on https://www.tradingview.com/script/0NgUadGr-Ultimate-MA-Cross-Indicator/ Quantnomads Ultimate MA Indicator 
// HA - Option for calcucaltion based on HA-Candles (very famous recently)
// Source Input - Option (Candletype for calculation, close, ohlc4 ect.) --- there are huge differences --- try it by your own

////////////////////////////////////////////////////////////////////////////////
// BACKTESTING RANGE

// From Date Inputs
fromDay = input(defval=1, title="From Day", minval=1, maxval=31)
fromMonth = input(defval=1, title="From Month", minval=1, maxval=12)
fromYear = input(defval=2015, title="From Year", minval=1970)

// To Date Inputs
toDay = input(defval=1, title="To Day", minval=1, maxval=31)
toMonth = input(defval=1, title="To Month", minval=1, maxval=12)
toYear = input(defval=2030, title="To Year", minval=1970)

// Calculate start/end date and time condition
startDate = timestamp(fromYear, fromMonth, fromDay, 00, 00)
finishDate = timestamp(toYear, toMonth, toDay, 00, 00)
time_cond = time >= startDate and time <= finishDate

////////////////////////////////////////////////////////////////////////////////

h = input(false, title = "Signals from Heikin Ashi Candles")

ma_type      = input(title = "MA Type",         type = input.string,  defval = "SMMA", options = ['SMA', 'EMA', 'WMA', 'VWMA', 'HMA', 'SMMA', 'DEMA'])
src = input(ohlc4)

short_ma_len = input(title = "Short MA Length", type = input.integer, defval = 7,     minval = 1)
short_ma_src = h ? security(heikinashi(syminfo.tickerid), timeframe.period, src, lookahead = false) : close
middle_ma_len  = input(title = "Middle MA Length",  type = input.integer, defval = 13,    minval = 2)
middle_ma_src = h ? security(heikinashi(syminfo.tickerid), timeframe.period, src, lookahead = false) : close
long_ma_len  = input(title = "Long MA Length",  type = input.integer, defval = 21,    minval = 2)
long_ma_src = h ? security(heikinashi(syminfo.tickerid), timeframe.period, src, lookahead = false) : close


tick_round(x) => 
    round(x / syminfo.mintick) * syminfo.mintick

// Set initial values to 0
short_ma = 0.0
middle_ma = 0.0
long_ma  = 0.0

// Simple Moving Average (SMA)
if ma_type == 'SMA' 
    short_ma := sma(short_ma_src, short_ma_len)
    middle_ma := sma(middle_ma_src, middle_ma_len)
    long_ma  := sma(long_ma_src,  long_ma_len)

// Exponential Moving Average (EMA)
if ma_type == 'EMA'
    short_ma := ema(short_ma_src, short_ma_len)
    middle_ma := ema(middle_ma_src, middle_ma_len)
    long_ma  := ema(long_ma_src,  long_ma_len)

// Weighted Moving Average (WMA)
if ma_type == 'WMA'
    short_ma := wma(short_ma_src, short_ma_len)
    middle_ma := wma(middle_ma_src, middle_ma_len)
    long_ma  := wma(long_ma_src,  long_ma_len)

// Hull Moving Average (HMA)
if ma_type == 'HMA'
    short_ma := wma(2*wma(short_ma_src, short_ma_len/2)-wma(short_ma_src, short_ma_len), round(sqrt(short_ma_len)))
    middle_ma := wma(2*wma(middle_ma_src, middle_ma_len/2)-wma(middle_ma_src, middle_ma_len), round(sqrt(middle_ma_len)))
    long_ma  := wma(2*wma(long_ma_src,  long_ma_len /2)-wma(long_ma_src,  long_ma_len),  round(sqrt(long_ma_len)))

// Volume-weighted Moving Average (VWMA)
if ma_type == 'VWMA'
    short_ma := vwma(short_ma_src, short_ma_len)
    middle_ma := vwma(middle_ma_src, middle_ma_len)
    long_ma  := vwma(long_ma_src,  long_ma_len)


// Smoothed Moving Average (SMMA)    
if ma_type == 'SMMA'
    short_ma := na(short_ma[1]) ? sma(short_ma_src, short_ma_len) : (short_ma[1] * (short_ma_len - 1) + short_ma_src) / short_ma_len
    middle_ma := na(middle_ma[1]) ? sma(middle_ma_src, middle_ma_len) : (middle_ma[1] * (middle_ma_len - 1) + middle_ma_src) / middle_ma_len
    long_ma  := na(long_ma[1])  ? sma(long_ma_src,  long_ma_len)  : (long_ma[1]  * (long_ma_len  - 1) + long_ma_src)  / long_ma_len

// Double Exponential Moving Average (DEMA)
if ma_type == 'DEMA'
    e1_short = ema(short_ma_src, short_ma_len)
    e1_middle = ema(middle_ma_src, middle_ma_len)
    e1_long  = ema(long_ma_src,  long_ma_len)
    
    short_ma := 2 * e1_short - ema(e1_short, short_ma_len)
    middle_ma := 2 * e1_middle - ema(e1_middle, middle_ma_len)
    long_ma  := 2 * e1_long  - ema(e1_long,  long_ma_len)

// Plot MAs
plot(short_ma, color = color.green,   linewidth = 1)
plot(middle_ma, color = color.yellow,   linewidth = 1)
plot(long_ma,  color = color.red, linewidth = 1)

if close>long_ma and short_ma>middle_ma and time_cond
    strategy.entry("Long", strategy.long)


if close<long_ma and short_ma<middle_ma and time_cond
    strategy.entry("Short", strategy.short)


もっと