この戦略は,ボリンジャーバンドの上下線をベースに,価格がボリンジャーバンドの上下線を突破してロング,下下線を突破してショートになるタイミングを決定する.これはトレンドトラッキングタイプの戦略に属します.
この戦略は,極端な価格帯を決定するためにボリンジャーバンドの中部/上部/下部レールを利用する. 中部レールは過去25期間の閉じる価格の単純な移動平均である. 上部と下部レールは中部レールの上下の一つの標準偏差である.価格が上部または下部レールを破ると,ブレイクアウトと異常な価格行動があることを示し,取引決定に使用することができる.
価格が下のレールを下回る場合はロング.価格が上のレール上回る場合はショート.ロングする場合は,ストップロスをエントリー価格 × ストップロスの因数に設定し,エントリー価格 × テイクロブの因数に利益を取ります.
この戦略には,不要な取引を避けるために24時間あたり1つの信号のみを許可するなどの補助規則も含まれています.
リスク管理
概要すると,これは異常な価格とトレンドを追跡するためにボリンジャー帯を使用する単純なトレンド追跡戦略です.パラメータ最適化,リスク制御,シグナルフィルタリングの改善に余地がありますが,コアアイデアはシンプルで明確で,学習のための初心者戦略として適しています.
/*backtest start: 2023-11-18 00:00:00 end: 2023-12-18 00:00:00 period: 1h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("I11L OIL Bot",overlay=true, initial_capital=1000000,default_qty_value=1000000,default_qty_type=strategy.cash,commission_type=strategy.commission.percent,commission_value=0.00) leverage = input.float(1,"Leverage (x)",step=1) SL_Factor = 1 - input.float(1,"Risk Capital per Trade (%)", minval=0.1, maxval=100, step=0.05) / 100 / leverage TP_Factor = input.float(2, step=0.1) invertBuyLogic = input.bool(false) lookbackDistance = input.int(25) devMult = input.float(2,step=0.1) var lastSellHour = 0 var disableAdditionalBuysThisDay = false if(time > lastSellHour + 1000 * 60 * 60 * 6) disableAdditionalBuysThisDay := false if(strategy.position_size != strategy.position_size[1]) disableAdditionalBuysThisDay := true lastSellHour := time source = close //Trade Logic basis = ta.sma(source, lookbackDistance) dev = devMult * ta.stdev(source, lookbackDistance) upper = basis + dev lower = basis - dev isBuy = ta.crossunder(source, upper) isBuyInverted = ta.crossover(source, lower) plot(upper, color=color.white) plot(lower, color=color.white) strategy.initial_capital = 50000 if((invertBuyLogic ? isBuyInverted : isBuy) and not(disableAdditionalBuysThisDay)) strategy.entry("Long", strategy.long, (strategy.initial_capital / close) * leverage) if(strategy.position_size > 0) strategy.exit("SL Long", "Long", stop=strategy.position_avg_price * SL_Factor) strategy.close("Long", when=close > strategy.position_avg_price * (1 + (1 - SL_Factor) * TP_Factor), comment="TP Long")