
移動平均線交差戦略は,移動平均線をベースにしたシンプルで効果的な量的な取引戦略である.この戦略は,高速移動平均線と遅い移動平均線の交差を買入と売却の信号として利用する.高速線が下方から遅い線を突破すると,買入の信号が生じ,高速線が上方から下方から遅い線を突破すると,売却の信号が生じます.
この戦略の核心的な論理は,市場動向を判断するために移動平均を利用することです.移動平均は,それ自体が,乱流のランダムな市場騒音の機能を持っています.急速な移動平均は,最新のトレンドを反映して,価格の変化により迅速に反応します.ゆっくりとした移動平均は,最新の価格変化に反応し,中長期のトレンドを表します.
具体的には,この戦略は,まず速動平均線sig1と遅動平均線sig2を定義し,それからsig1とsig2の交差関係に基づいて買賣点を判断する.sig1が下からsig2を突破すると買買のシグナルlongConditionが生じ,sig1が上から下からsig2を突破すると売売のシグナルshortConditionが生じます.この戦略は,次に,購入と売却の条件を満たした注文を設定し,ストップ・ロズとストップ・アウト・オーダーを設定する.
この戦略の利点は明らかです.
この戦略にはリスクもあります.
改善策として:
移動平均線交差戦略は,全体として,論理的にシンプルで実用的な量化戦略である.パラメータ調整と適切な最適化により,さまざまな市場環境で安定した利益を上げることができる.量化トレーダーの重点研究と適用に値する.
/*backtest
start: 2023-11-14 00:00:00
end: 2023-11-16 04:00:00
period: 1m
basePeriod: 1m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=3
// Simple yet effective MA cross strategy.
// You'll have to tune the parameters to get an optimal win ratio.
// If JPY or XAU or any other currency with pips defined as the
// second decimal digit are involved, do not forget to set the respective flag on.
//
// Created by vitelot/yanez/Vts, who's the same fellow with different user names
// December 2018 -- Merry Xmas
//
strategy("MA cross strategy Vts", overlay=true, initial_capital=1000, currency="EUR", pyramiding=0)
yr = input(2016, title="Starting year to analyse")
src = input(close, title="Source")
maType = input( defval="EMA", title="MA Type", options=["SMA","EMA","HMA","McG","WMA"])
//
isJPY = input(false, title="Is JPY or XAU involved?") // JPY and Gold have the pips defined as the 2 decimal digit
maPar1 = input(26, minval=1, title="MA fast period")
maPar2 = input(51, minval=2, title="MA slow period")
atrPar = input(14,minval=1, title="ATR period")
atrMulSL = input(1.5, title="SL ATR multiplicator")
atrMulTP = input(1.0, title="TP ATR multiplicator")
hma(sig, n) => // Hull moving average definition
wma( 2*wma(sig,round(n/2))-wma(sig,n), round(sqrt(n)))
mcg(sig,length) => // Mc Ginley MA definition
mg = 0.0
mg := na(mg[1]) ? ema(sig, length) : mg[1] + (sig - mg[1]) / (length * pow(sig/mg[1], 4))
ma(t,sig,len) =>
if t =="SMA"
sma(sig,len)
else
if t == "EMA"
ema(sig,len)
else
if t == "HMA"
hma(sig,len)
else
if t == "McG" // Mc Ginley
mcg(sig,len)
else
wma(sig,len)
sig1 = ma(maType, src, maPar1)
sig2 = ma(maType, src, maPar2)
tickFactor = isJPY? 1e3: 1e5
sl = atrMulSL*atr(atrPar)*tickFactor
tp = atrMulTP*atr(atrPar)*tickFactor
plot(sig1, color=aqua, title="MA1", linewidth=2)
plot(sig2, color=orange, title="MA2", linewidth=2)
longCondition = crossunder(sig2, sig1) and year>=yr // change the >= to == if you like exact years not a range
if (longCondition)
strategy.entry("Long", strategy.long, qty=1) // exit trade when SL and TP are hit
strategy.exit("Exit Long", "Long", loss=sl, profit=tp)
if (crossunder(sig1, sig2)) // or when the short condition is met
strategy.close("Long")
shortCondition = crossover(sig2,sig1) and year>=yr // change the >= to == if you like exact years not a range
if (shortCondition)
strategy.entry("Short", strategy.short, qty=1)
strategy.exit("Exit Short", "Short", loss=sl, profit=tp)
if (crossover(sig1,sig2))
strategy.close("Short")