この戦略は,スティーブ・カーニッシュによって開発されたCCTボリンガーバンド振動器 (CCTBO) 指標に基づいています.これは,トレーリングストップメカニズムと組み合わせた移動平均値の価格ブレイクを検出することによって価格逆転を特定します.
この戦略は,CCTBBOの値を計算するために高価格をソースデータとして使用する.オシレーターは -200〜200の間に変動する. 0 は平均価格マイナス2標準偏差,100 は平均価格プラス2標準偏差を表す.オシレーターがEMA線を越えたり,EMA線を下回ったときに取引シグナルが生成される.特に,オシレーターがEMA線を越えたり,それらの間の距離が設定されたマーゲン値よりも大きいとき,ロングポジションが開かれる.オシレーターがEMAラインを下回り,距離がネガティブ設定値未満になったとき,ショートポジションが開かれる.ポジションのマーゲンサイズは設定されたパーセントに応じて計算される.さらに,戦略は,価格変化の百分比またはティック動きの数をベースとしたトレリングストップロスを使用し,ポジションを退出する.
リスク管理
戦略は以下の側面で最適化できます.
概要すると,これはCCTボリンジャーバンド指標を使用して価格逆転を特定するための定量的な取引戦略です.特定の利点がありますが,改善の余地もあります.パラメータを最適化し,フィルターを追加し,機能エンジニアリングを使用し,機械学習を導入することで,この戦略の安定性と収益性がさらに向上できます.
/*backtest start: 2023-11-15 00:00:00 end: 2023-11-17 11:00:00 period: 45m basePeriod: 5m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=2 // This strategy is based on the CCT Bollinger Band Oscillator (CCTBO) // developed by Steve Karnish of Cedar Creek Trading and coded by LazyBear. // Indicator is available here https://www.tradingview.com/v/iA4XGCJW/ strategy("Strategy CCTBBO v2 | Fadior", shorttitle="Strategy CCTBBO v2", pyramiding=0, precision=2, calc_on_order_fills=false, initial_capital=1000, default_qty_type=strategy.percent_of_equity, currency="USD", default_qty_value=100, overlay=false) length_stddev=input(title="Stddev loopback period",defval=20) length_ema=input(title="EMA period", defval=2) margin=input(title="Margin", defval=0, type=float, step=0.1) price = input(title="Source", defval=high) digits= input(title="Number of digits",defval=2,step=1,minval=2,maxval=6) offset = input(title="Trailing offset (0.01 = 1%) :", defval=0.013, type=float, step=0.01) pips= input(title="Offset in ticks ?",defval=false,type=bool) src=request.security(syminfo.tickerid, "1440", price) cctbbo=100 * ( src + 2*stdev( src, length_stddev) - sma( src, length_stddev ) ) / ( 4 * stdev( src, length_stddev ) ) ul=hline(150, color=gray, editable=true) ll=hline(-50, color=gray) hline(50, color=gray) fill(ul,ll, color=green, transp=90) plot(style=line, series=cctbbo, color=blue, linewidth=2) plot(ema(cctbbo, length_ema), color=red) d = digits == 2 ? 100 : digits == 3 ? 1000 : digits == 4 ? 10000 : digits == 5 ? 100000 : digits == 6 ? 1000000 : na TS = 1 TO = pips ? offset : close*offset*d CQ = 100 TSP = TS TOP = (TO > 0) ? TO : na longCondition = crossover(cctbbo, ema(cctbbo, length_ema)) and cctbbo - ema(cctbbo, length_ema) > margin if (longCondition) strategy.entry("Long", strategy.long) strategy.exit("Close Long", "Long", qty_percent=CQ, trail_points=TSP, trail_offset=TOP) shortCondition = crossunder(cctbbo, ema(cctbbo, length_ema)) and cctbbo - ema(cctbbo, length_ema) < -margin if (shortCondition) strategy.entry("Short", strategy.short) strategy.exit("Close Short", "Short", qty_percent=CQ, trail_points=TSP, trail_offset=TOP)