ドンチャンチャネルとラリーウィリアムズビッグトレードインデックス戦略


作成日: 2024-04-12 17:27:25 最終変更日: 2024-04-12 17:27:25
コピー: 7 クリック数: 2820
1
フォロー
1617
フォロワー

ドンチャンチャネルとラリーウィリアムズビッグトレードインデックス戦略

概要

この戦略は,唐津通道,ラリー・ウィリアムズ大取引指数 (LWTI) と取引量移動平均の3つの指標を組み合わせて取引を行う.価格が唐津通道を突破すると,LWTIは緑色で,取引量が移動平均より大きいときに多行し,価格が唐津通道の下線を突破すると,LWTIは赤色で,取引量が移動平均線より大きいときに空にする.戦略は,ポジションを開設した後,価格がストップまたはストップオフの位置に触れたとき,または価格が唐津通道の中央軌道に戻ったときに平仓する.同じトレンド方向内で再開設を防ぐために,この戦略は,取引数を使用し,価格が唐津通道の中央軌道に突破した後にのみ,再びポジションを開設することを許可する.

戦略原則

  1. 唐通道:価格が通路を突破すると多行信号が生成され,下行軌道を突破すると空行信号が生成される.
  2. ラリー・ウィリアムズ大取引指数:LWTIは,緑色であれば多額の取引が認められ,赤色であれば空白のみが認められる.
  3. 取引量:現在の取引量が取引量移動平均より大きい場合にのみ,ポジションを開設することが許される.
  4. トレードカウンター:同じトレンドの方向で繰り返しポジションを開くのを防止し,価格が唐通路の中間軌道を破った後にのみ,再びポジションを開くことを許可する.
  5. ストップ・ストラスト: ポジション開設時にATRに基づいてストップ・ストラスト距離を計算し,ストップ・ストラスト距離はストップ・ストラスト距離を倍したリスク・利益比である.

戦略的優位性

  1. 複数の指標を組み合わせて取引信号を共同確認することで,偽信号を効果的にフィルターして信号の質を向上させることができる.
  2. ダイナミックストップローズ - 変動率に応じてダイナミックにストップローズ距離を調整することで,市場の変化によりうまく適応することができる.
  3. トレードカウンターで同じトレンドで繰り返しポジションを開くのを防ぐこと,取引頻度を制御する.
  4. リスク・利益比ストップ - 既定のリスク・利益比のストップポジションを設定し,利益の余地がリスクより大きいようにする.

戦略リスク

  1. パラメータリスク - 異なるパラメータ設定は戦略のパフォーマンスに大きく影響し,異なる市場特性と周期に応じて最適化する必要があります.
  2. 波動性市場リスク - 波動性市場環境で,頻繁に波動することが,戦略が頻繁に空調して,不良なパフォーマンスを引き起こす可能性があります.
  3. トレンドリスク - トレンドが持続しない場合,頻繁に平仓が起こり,損失が増加する可能性があります.
  4. ブラック・スワン・リスク - 極端な状況では指標が失敗し,戦略がうまく機能しない.

戦略最適化の方向性

  1. 異なる品種と周期に対してパラメータを最適化して,最適なパラメータの組み合わせを見つけます.
  2. 平均線や動態指標などのトレンドフィルタリング条件を追加し,トレンドが明確であるときにのみポジションを開き,震動環境下での取引数を減らす.
  3. 震災の都市環境では,範囲突破戦略を考慮することができます.
  4. ストップ・ストップ・損失の論理を最適化して,移動ストップや尾行ストップなどの方法を導入する.
  5. 極端な状況では,固定資金管理や最大回収制限などの措置を考慮することができます.

要約する

唐津通路とラリー・ウィリアムズ大取引指数戦略は,典型的なトレンド追跡取引戦略である.唐津通路によってトレンドの方向を捉え,LWTI,取引量などの指標をフィルターする信号,ダイナミックなストップ・ストップ・損失,リスクコントロールの厳格さなど,全体として,安定した収益を持つ戦略の枠組みである.しかし,この戦略は,パラメータに比較的敏感であり,不安定な市場環境で不良なパフォーマンスを発揮し,トレンド型市場で使用することを推奨する.実用的なアプリケーションでは,取引の指標と市場の特徴,パラメータと論理のさらなる最適化,そして厳格な資金管理と組み合わせて,良好な安定した収益を得るために必要な.

ストラテジーソースコード
/*backtest
start: 2024-04-04 00:00:00
end: 2024-04-11 00:00:00
period: 1m
basePeriod: 1m
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/
// © DillonGrech
//
//This is a Donchian Channel Trading Strategy which was found through the 
//YouTube channel TradingLab. 
//
//This Strategy uses the Donchian Channel, Larry Williams Large Trade Index,
//and Volume with Moving Average indicators for long and short trades.
//
//Strategy will enter based off indicator entry conditions and will not
//re-enter a trade until the price crosses through the Donchian Channel
//basis line (to prevent re-entering trades in same trend). Strategy will
//exit at stop loss or take profit, or when price crosses donchian basis.
//
//The strategy has been coded by Dillon Grech as part of his YouTube channel
//and a detailed video can be found on his channel at:
//https://www.youtube.com/c/DillonGrech
//https://www.youtube.com/watch?v=5IFe2Vjf61Y
//Source code and template files can be found on his GitHub at:
//https://github.com/Dillon-Grech
//==============================================================================
//@version=5
strategy("Donchian Channel Strategy [DillonGrech]", overlay=true, margin_long=100, margin_short=100)

//==============================================================================
//DONCHIAN CHANNEL
//==============================================================================
//Allow user to select whether they would like to use indicator
Don_Input = input(true, title='Use Donchian Channel?', group = "Donchian Settings")

//Indicator
don_length = input.int(96, minval = 1, group = "Donchian Settings")
don_lower  = ta.lowest(don_length)
don_upper  = ta.highest(don_length)
don_basis  = math.avg(don_upper, don_lower)
plot(don_basis,     "Don Basis", color = #FF6D00)
u = plot(don_upper, "Don Upper", color = #2962FF)
l = plot(don_lower, "Don Lower", color = #2962FF)
fill(u, l, color = color.rgb(33, 150, 243, 95), title = "Background")

//Conditions - Enter trades when there is a cross of price and previous donchian channel value
Ind_1_L = Don_Input == false ? false : ta.crossover(close,don_upper[1])
Ind_1_S = Don_Input == false ? false : ta.crossunder(close,don_lower[1])

//==============================================================================
//LARRY WILLIAMS LARGE TRADE INDEX (LWTI) - LOXX
//==============================================================================
//Allow user to select whether they would like to use indicator
LWTI_Input = input(true, title='Use LWTI?', group = "LWTI Settings")

//Indicator
greencolor = #2DD204
redcolor = #D2042D 

variant(type, src, len) =>
    sig = 0.0
    if type == "SMA"
        sig := ta.sma(src, len) 
    else if type == "EMA"
        sig := ta.ema(src, len) 
    else if type == "WMA"
        sig := ta.wma(src, len)   
    else if type == "RMA"
        sig := ta.rma(src, len)  
    sig
    
LWTI_per = input.int(25, "Period", group = "LWTI Settings")
LWTI_smthit = input.bool(false, "Smooth LWPI?", group = "LWTI Settings")
LWTI_type = input.string("SMA", "Smoothing Type", options = ["EMA", "WMA", "RMA", "SMA"], group = "LWTI Settings")
LWTI_smthper = input.int(20, "Smoothing Period", group = "LWTI Settings")

LWTI_ma = ta.sma(close - nz(close[LWTI_per]), LWTI_per)
LWTI_atr = ta.atr(LWTI_per)
LWTI_out = LWTI_ma/LWTI_atr * 50 + 50
LWTI_out := LWTI_smthit ? variant(LWTI_type, LWTI_out, LWTI_smthper) : LWTI_out

LWTI_colorout = LWTI_out > 50 ? greencolor : redcolor

//Conditions - Enter on color of indicator
Ind_2_L = LWTI_Input == false ? true : LWTI_colorout == greencolor
Ind_2_S = LWTI_Input == false ? true : LWTI_colorout == redcolor

//==============================================================================
//VOLUME INDICATOR
//==============================================================================
//Allow user to select whether they would like to use indicator
Vol_Input = input(true, title='Use Volume?', group = "Volume Settings")

//Indicator
Vol_Ma_Period = input.int(30,"Volume MA Period", group = "Volume Settings")
Vol_Ma = ta.sma(volume,Vol_Ma_Period)

//Conditions - Enter when volume is greater than moving average
Ind_3_L = Vol_Input == false ? true : volume > Vol_Ma
Ind_3_S = Vol_Input == false ? true : volume > Vol_Ma

//==============================================================================
//DONCHIAN CHANNEL TRADE COUNTER
//==============================================================================
//Stores whether a trade has been taken, and resets when there is a cross of price and donchain basis
Trade_Counter = float(0)
Don_Basis_Cross = ta.cross(don_basis[1], close)
if strategy.position_size!=0
    Trade_Counter := 1
else if Don_Basis_Cross
    Trade_Counter := 0
else 
    Trade_Counter := Trade_Counter[1]

Plot_Trade_Counter = input.bool(false, "Plot Trade Position Counter?", group = "Plot Settings")
plotchar(Plot_Trade_Counter and Trade_Counter == 0 ? true : false, color = na, text = '0')
plotchar(Plot_Trade_Counter and Trade_Counter == 1 ? true : false, color = na, text = '1')

//==============================================================================
//ENTRY CONDITIONS
//==============================================================================
entry_long  = strategy.position_size<=0 and Ind_1_L and Ind_2_L and Ind_3_L and Trade_Counter[1] == 0
entry_short = strategy.position_size>=0 and Ind_1_S and Ind_2_S and Ind_3_S and Trade_Counter[1] == 0

if(entry_long)
    strategy.entry("Long Entry", strategy.long)
if(entry_short)
    strategy.entry("Short Entry", strategy.short)

//==============================================================================
// TAKE PROFIT AND STOP LOSS CONDITIONS
//==============================================================================
Stop_Input   = input(true, title='Use Stop Loss?', group = "Risk Settings")
Profit_Input = input(true, title='Use Take Profit?', group = "Risk Settings")
Profit_RR = input.float(2.0,"Risk Reward Profit Target", group = "Risk Settings")

//Store Price on new entry signal
Entry_Price = strategy.opentrades.entry_price(strategy.opentrades - 1)

//Store Donchain Channel Basis value on new entry signal
Entry_Don_Basis = float(0.0)
if strategy.position_size == 0 or entry_long or entry_short
    Entry_Don_Basis := don_basis
else
    Entry_Don_Basis := Entry_Don_Basis[1]

//Get stop loss distance
Stop_Distance = math.abs(Entry_Price - Entry_Don_Basis)*1.02

//For Long Trades, find the stop loss level
Stop_L = float(0.0)
if Stop_Input == true
    Stop_L := Entry_Price - Stop_Distance
else
    na

//For Long Trades, find the profit level
Profit_L = float(0.0)
if Profit_Input == true
    Profit_L := Entry_Price + Stop_Distance*Profit_RR
else
    na

//For Short Trades, find the stop loss level
Stop_S = float(0.0)
if Stop_Input == true
    Stop_S   := Entry_Price + Stop_Distance
else
    na

//For Short Trades, find the profit level
Profit_S = float(0.0)
if Profit_Input == true
    Profit_S := Entry_Price - Stop_Distance*Profit_RR
else
    na

//Plot profit and stop loss levels for long and short trades
plot(strategy.position_size > 0 ? Profit_L : na, color=color.lime, style=plot.style_linebr, linewidth=2)
plot(strategy.position_size > 0 ? Stop_L : na,   color=color.red,  style=plot.style_linebr, linewidth=2)
plot(strategy.position_size < 0 ? Profit_S : na, color=color.lime, style=plot.style_linebr, linewidth=2)
plot(strategy.position_size < 0 ? Stop_S : na,   color=color.red,  style=plot.style_linebr, linewidth=2)

//==============================================================================
//EXIT ORDERS
//==============================================================================
//Exit long trades
if Stop_Input
    strategy.exit(id = 'Exit Long', from_entry ='Long Entry', comment='Long Stop',  stop = Stop_L)

if Profit_Input
    strategy.exit(id = 'Exit Long', from_entry ='Long Entry', comment='Long Profit', limit = Profit_L)

//Exit short trades
if Stop_Input
    strategy.exit(id = 'Exit Short', from_entry ='Short Entry', comment='Short Stop', stop = Stop_S)

if Profit_Input
    strategy.exit(id = 'Exit Short', from_entry ='Short Entry', comment='Short Profit', limit = Profit_S)

//==============================================================================
//CLOSE ORDERS
//==============================================================================
exit_long  = close < don_basis
exit_short = close > don_basis

if(exit_long)
    strategy.close("Long Entry", comment='Long Close', qty_percent=100)
if(exit_short)
    strategy.close("Short Entry", comment='Short Close', qty_percent=100)