3つのEMAストカスティックRSIクロスオーバーゴールデンクロス戦略

作者: リン・ハーンチャオチャン,日付: 2024-01-26 16:07:34
タグ:

img

概要

3つのEMAストカスティックRSIクロスオーバーゴールデンクロス戦略は,トレンドフォローする戦略である.この戦略は,3つのEMA指標とストカスティック相対強度指数を組み合わせて,2つの指標のクロスオーバーに基づいてエントリー信号を決定する.

戦略の論理

この戦略の信号決定は次の論理に基づいています.

  1. トレンドを決定する EMA は 3 つあります.上部にある 8 日間 EMA,中部にある 14 日間 EMA,下部にある 50 日間 EMA が上昇傾向を形成し,逆向きは下落傾向を形成します.

  2. 短くは考えられない.

利点分析

この二重指標決定の戦略の主な利点は以下の通りである.

  1. ATRはスマートストップ・ロストで 利益のロックを取ります

  2. シンプルで明快な戦略論理 分かりやすく実行できます

リスク分析

この戦略の主なリスクは,

  1. 統合に脆弱である. 3つのEMAが横向市場で複数のクロスを発生させる場合,頻繁なオープン/閉鎖オーダーは取引リスクをもたらす.これは,EMAパラメータを最適化するか,他のフィルターを追加することによって解決できる.

  2. ショートチャンスがない.ロングだけが底部リバウンドのチャンスを逃す.下落傾向のショートを見つけるためにMACDを追加することを検討してください.

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

主な最適化方向は以下の通りである.

  1. EMA パラメータを最適化して 傾向の決定を改善する

  2. ダウントレンドを決定し,ショートチャンスを増やすためにMACDなどを追加します.

  3. ATRのような変動指標を追加してストップとリミットを改善します

  4. 音量を増やして 偽の突破を避ける

  5. パラメータ最適化のために機械学習を活用する.

結論


/*backtest
start: 2024-01-01 00:00:00
end: 2024-01-25 00:00:00
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=4

strategy(title="Stoch RSI Crossover Strat + EMA", shorttitle="Stoch RSI Cross + EMA Strat", overlay = true)

// Time Range
FromMonth=input(defval=1,title="FromMonth",minval=1,maxval=12)
FromDay=input(defval=1,title="FromDay",minval=1,maxval=31)
FromYear=input(defval=2020,title="FromYear",minval=2017)
ToMonth=input(defval=1,title="ToMonth",minval=1,maxval=12)
ToDay=input(defval=1,title="ToDay",minval=1,maxval=31)
ToYear=input(defval=9999,title="ToYear",minval=2017)
start=timestamp(FromYear,FromMonth,FromDay,00,00)
finish=timestamp(ToYear,ToMonth,ToDay,23,59)
window()=>true

// See if this bar's time happened on/after start date
afterStartDate = time >= start and time<=finish?true:false

//STOCH RSI
smoothK = input(3, minval=1)
smoothD = input(3, minval=1)
lengthRSI = input(14, minval=1)
lengthStoch = input(14, minval=1)
src = input(close, title="RSI Source")

rsi1 = rsi(src, lengthRSI)
k = sma(stoch(rsi1, rsi1, rsi1, lengthStoch), smoothK)
d = sma(k, smoothD)

//ATR
lengthATR = input(title="ATR Length", defval=14, minval=1)
atr = atr(lengthATR)

//MULTI EMA
emasrc = close, 
len1 = input(8, minval=1, title="EMA 1")
len2 = input(14, minval=1, title="EMA 2")
len3 = input(50, minval=1, title="EMA 3")

ema1 = ema(emasrc, len1)
ema2 = ema(emasrc, len2)
ema3 = ema(emasrc, len3)

col1 = color.lime
col2 = color.blue
col3 = color.orange

//EMA Plots
//plot(ema1, title="EMA 1", linewidth=1, color=col1)
//plot(ema2, title="EMA 2", linewidth=1, color=col2)
//plot(ema3, title="EMA 3", linewidth=1, color=col3)

crossup = k[0] > d[0] and k[1] <= d[1]
emapos = ema1 > ema2 and ema2 > ema3 and close > ema1
barbuy = crossup and emapos

//plotshape(crossup, style=shape.triangleup, location=location.belowbar, color=color.white)
plotshape(barbuy, style=shape.triangleup, location=location.belowbar, color=color.green)

longloss = sma(open, 1)
//plot(longloss, color=color.red)

//Buy and Sell Factors
profitfactor = input(title="Profitfactor", type=input.float, step=0.1, defval=2)
stopfactor = input(title="Stopfactor", type=input.float, step=0.1, defval=3)
bought = strategy.position_size[1] < strategy.position_size
longcondition = barbuy

if (longcondition) and (afterStartDate) and strategy.opentrades < 1
    strategy.entry("Long", strategy.long)

if (afterStartDate) and strategy.opentrades > 0
    barsbought = barssince(bought)
    profit_level = strategy.position_avg_price + (atr*profitfactor)
    stop_level = strategy.position_avg_price - (atr*stopfactor)
    strategy.exit("Take Profit/ Stop Loss", "Long", stop=stop_level[barsbought], limit=profit_level[barsbought])









もっと