アダプティブな指数関数移動平均線に基づくアダプティブSMIエルゴジック取引戦略

作者: リン・ハーンチャオチャン, 日付: 2023-12-18 10:34:55
タグ:

img

概要

この記事では,アダプティブ指数関数移動平均線 (AEMA) 線に基づく定量的な取引戦略の詳細な分析を行います.この戦略は,シグナルラインとして機能する指数関数移動平均線とともに,ストーカスティックモメントインデックス (SMI) インディケーターのエルゴジック形式を利用し,取引の成功実行の可能性を向上させるために,カスタマイズ可能な過剰購入/過剰売却の値を含んでいます.

戦略原則

ストラテジーは,異なる長さの2つのSMIを使用し,一つは短く,もう一つは長く,それらの間のスパン差が取引信号を生成する. さらに,ストラテジーは,指数移動平均をシグナルラインとしても利用する.短い期間のSMIが長い期間のSMAを横切るときは長く,反対が起こるときに短くなります. 偽のシグナルをフィルタリングするために,SMIが過剰販売ラインの下にあり,信号線も過剰販売ラインの下にある場合にのみ,ロングエントリーシグナルが表示されます. 短いエントリーシグナルには,SMIが過剰購入ラインの上,信号ラインも過剰購入ライン上にある必要があります. この二重条件設定は,戦略を突然の出来事に敏感にしますが,誤ったブレイクも効果的に避けます.

利点

この戦略の最大の利点は,適応性にある.この戦略は,異なる市場環境に応じて,長期および短期基準を動的に調整するために,カスタマイズ可能なオーバーバイト/オーバーセールドの限界値を使用する.このメカニズムは,戦略パラメータを最適化し,より幅広い市場状況に適応することを可能にします.また,SMIのエルゴジック形式は,戦略の敏感性とタイムリー性を向上させます.従来のSMIと比較して,ノイズ削減が高く,遅延が小さい. これにより,戦略は突然のイベントに迅速に対応し,短期間の取引機会を把握することができます.

リスク

この戦略の最大のリスクは,パラメータ設定に依存することである.不適切なパラメータ設定は,多くの無効な取引信号を容易に生成することができる.また,パルス型指標として,SMIは,乱雑なランダムな市場でうまく機能しない.この戦略は,極端な価格変動による暴力的なトレンド逆転にも容易に巻き込まれる可能性がある.これらのリスクを制御するために,異なる市場環境に合わせてパラメータを調整しながら,厳格なリスク管理措置を採用することが推奨される.いくつかの実行可能な最適化方向性は,以下に提案される.

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

戦略にはまだいくつかの最適化可能な側面があります.第一に,最適なパラメータペアを見つけるためにSMA長さの異なる組み合わせをテストすることができます.第二に,ストップ損失は,取引損失を制御するためのエントリーポイントに近いと考えることができます.第三に,RSIやボリンジャーバンドなどの他の指標は,ダイナミックなオーバーバイト/オーバーセールラインを設定するために組み合わせることができます.第四に,パラメータは機械学習アルゴリズムを通じて自動的に最適化できます.第五に,戦略は安定性を向上させるために多要素モデルに統合することができます.

結論

この記事では,適応型SMIエルゴジック取引戦略の原則,利点,リスク,最適化方向について深く分析した.適応的な値と指数移動平均値によるシグナルフィルタリングを使用することにより,戦略は短期間の市場機会を効果的に把握することができる.一定のパラメータ依存性にもかかわらず,厳格なリスク制御と多次元最適化により,戦略は依然としてかなりの実用的な価値を有している.この戦略は,定量的な取引慣行において重要な役割を果たし,取引決定に効果的なサポートを提供できると考えられている.


/*backtest
start: 2023-12-10 00:00:00
end: 2023-12-17 00:00:00
period: 3m
basePeriod: 1m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

// © DraftVenture

//@version=5
strategy(title="Adaptive SMI Ergodic Strategy", shorttitle="Adaptive SMI Strategy", overlay = false)
longlen = input.int(12, minval=1, title="Long Length")
shortlen = input.int(5, minval=1, title="Short Length")
siglen = input.int(5, minval=1, title="Signal Line Length")
overS = input.float(-0.4, title = "Oversold", step = 0.01)
overB = input.float(0.4, title = "Overbought", step = 0.01)
erg = ta.tsi(close, shortlen, longlen)
sig = ta.ema(erg, siglen)
plot(erg, color = color.yellow, title = "SMI")
plot(sig, color = color.purple, title="Signal")
hline(0, title = "Zero", color = color.gray, linestyle = hline.style_dotted)
h0 = hline(overB, color = color.gray, title = "Overbought Threshold")
h1 = hline(overS, color = color.gray, title = "Oversold Threshold")
fill(h0, h1, color=color.rgb(25, 117, 192, 90), title = "Background")

longEntry = ta.crossover(erg, sig) and erg > overS and sig < overS
shortEntry = ta.crossunder(erg, sig) and erg < overB and sig > overB

if longEntry
    strategy.entry("Long", strategy.long)

if shortEntry
    strategy.entry("Short", strategy.short)

// ______ _________ 
// ___  //_/__  __ \
// __  ,<  __  /_/ /
// _  /| | _  ____/ 
// /_/ |_| /_/   

もっと