SRブレイクアウト戦略


作成日: 2024-05-15 16:30:14 最終変更日: 2024-05-15 16:30:14
コピー: 1 クリック数: 568
1
フォロー
1617
フォロワー

SRブレイクアウト戦略

概要

SR Breakout Strategyは,LonesomeTheBlueのブレイクアウトファインダー指数に基づいて開発されたサポート・レジスタンス・ブレークアウト戦略である.この戦略の主な考え方は,閉盘価格がサポート・レジスタンス・レベルを突破したかどうかを判断することによって多額のまたは空調の信号を生成することである.デフォルトは8時間のK線に基づいているが,4時間のK線にはより優越したパラメータ設定がある.この戦略は,支持・レジスタンス・レベルを決定するためにピボットハイとピボットローの関数を使用し,最高価格と最低価格を使用してブレークアウトを判断する.この戦略は,ストップ・ロズとストップを設定している.

戦略原則

  1. pivothighとpivotlowの関数は,それぞれ過去一定周期における高点と低点を計算し,配列に保存する.
  2. 現在の閉盤価格がレジスタンス値より高いかどうかを判断し,そうであれば,看板の突破として判断し,多値シグナルを生成する.
  3. 現在の閉盤価格がサポート値以下であるかどうかを判断し,そうであれば,下落の突破として判断し,空調信号を生成する.
  4. 取引シグナルが生成された後,設定されたストップ・ストップ・スロープの比率に基づいてストップ・ストップ・価格とストップ・スロープ価格を計算し,対応するストップ・ストップ・オーダーとストップ・オーダーを設定する.
  5. 突破方向に応じて,対応する突破区間を描画する.

戦略的優位性

  1. 支持・抵抗を突破することは,戦場での基礎を備えた,古典的な取引戦略である.
  2. ピボットハイとピボットローの関数を使用してサポートとレジスタンス位置を計算することで,突破状況をより正確に捉えることができます.
  3. この戦略のコード構造は明確で,高点と低点を配列に格納することで,簡単に反省と最適化が可能である.
  4. ストップ・ロズとストップ・ストップが設定され,リスクが比較的によく管理されます.

戦略リスク

  1. 支柱のレジスタンスブレイク戦略は,揺れ動いている状況でうまく機能せず,頻繁に偽のブレイクアウトが起こりやすい.
  2. 固定のストップ・ストップ比率は,異なる状況に適応できない可能性があり,リスク・利益の不均衡を引き起こす.
  3. この戦略は,取引量などの他の重要な指標を考慮せず,価格要因のみを考慮し,重要な信号を逃している可能性があります.

戦略最適化の方向性

  1. 信号の正確性と信頼性を高めるために,交差量,MACDなどの技術指標の導入を考慮することができます.
  2. 止損と停止の場合は,移動止損または動的止損止損比率を使用することを検討し,異なる状況により適した対応を行うことができます.
  3. トレンドフィルター,波動率フィルターなどのフィルタリング条件を導入することは考えられます.
  4. サポートとレジスタンス位置の最適化を考慮することができる.例えば,自己適応周期の使用,フィボナッチ級の導入などである.

要約する

SRブレークアウトストラテジー (SR Breakout Strategy) は,古典的なレジスタンス突破思考に基づいた取引戦略で,ピボットハイとピボットローの関数を用いてサポートとレジスタンスを計算し,閉店価格がこれらの位置を突破するかどうかを判断して取引信号を生成する.この戦略の優点は,思考が明確で,実行しやすく,最適化できるという点にある.しかしながら,この戦略には,振動的な状況で不良なパフォーマンスや,固定されたストップダメージの割合がもたらす可能性があるリスクなどのリスクも存在している.将来,技術指標,ストップダメージの,過条件,サポートレジスタンス最適化などの観点から,この戦略の最適化と改善を考慮して,安定性と収益性を向上させることができる.

ストラテジーソースコード
/*backtest
start: 2024-05-07 00:00:00
end: 2024-05-14 00:00:00
period: 10m
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/
// © LonesomeTheBlue © chanu_lev10k

//@version=5
strategy('SR Breakout Strategy', overlay=true, max_bars_back=500, max_lines_count=400)
prd = input.int(defval=5, title='Period', minval=2)
bo_len = input.int(defval=71, title='Max Breakout Length', minval=30, maxval=300)
cwidthu = input.float(defval=3., title='Threshold Rate %', minval=1., maxval=10) / 100
mintest = input.int(defval=2, title='Minimum Number of Tests', minval=1)
bocolorup = input.color(defval=color.blue, title='Breakout Colors', inline='bocol')
bocolordown = input.color(defval=color.red, title='', inline='bocol')
// lstyle = input.string(defval=line.style_solid, title='Line Style')
issl = input.bool(title='SL', inline='linesl1', group='Stop Loss / Take Profit:', defval=false)
slpercent = input.float(title=', %', inline='linesl1', group='Stop Loss / Take Profit:', defval=18.0, minval=0.0, step=0.1)
istp = input.bool(title='TP', inline='linetp1', group='Stop Loss / Take Profit:', defval=false)
tppercent = input.float(title=', %', inline='linetp1', group='Stop Loss / Take Profit:', defval=18.0, minval=0.0, step=0.1)

//width
lll = math.max(math.min(bar_index, 300), 1)
float h_ = ta.highest(lll)
float l_ = ta.lowest(lll)
float chwidth = (h_ - l_) * cwidthu

// check if PH/PL
ph = ta.pivothigh(prd, prd)
pl = ta.pivotlow(prd, prd)

//keep Pivot Points and their locations in the arrays
var phval = array.new_float(0)
var phloc = array.new_int(0)
var plval = array.new_float(0)
var plloc = array.new_int(0)

// keep PH/PL levels and locations
if bool(ph)
    array.unshift(phval, ph)
    array.unshift(phloc, bar_index - prd)
    if array.size(phval) > 1  // cleanup old ones
        for x = array.size(phloc) - 1 to 1 by 1
            if bar_index - array.get(phloc, x) > bo_len
                array.pop(phloc)
                array.pop(phval)

if bool(pl)
    array.unshift(plval, pl)
    array.unshift(plloc, bar_index - prd)
    if array.size(plval) > 1  // cleanup old ones
        for x = array.size(plloc) - 1 to 1 by 1
            if bar_index - array.get(plloc, x) > bo_len
                array.pop(plloc)
                array.pop(plval)

// check bullish cup
float bomax = na
int bostart = bar_index
num = 0
hgst = ta.highest(prd)[1]
if array.size(phval) >= mintest and close > open and close > hgst
    bomax := array.get(phval, 0)
    xx = 0
    for x = 0 to array.size(phval) - 1 by 1
        if array.get(phval, x) >= close
            break
        xx := x
        bomax := math.max(bomax, array.get(phval, x))
        bomax
    if xx >= mintest and open <= bomax
        for x = 0 to xx by 1
            if array.get(phval, x) <= bomax and array.get(phval, x) >= bomax - chwidth
                num += 1
                bostart := array.get(phloc, x)
                bostart
        if num < mintest or hgst >= bomax
            bomax := na
            bomax

// if not na(bomax) and num >= mintest
//     line.new(x1=bar_index, y1=bomax, x2=bostart, y2=bomax, color=bocolorup)
//     line.new(x1=bar_index, y1=bomax - chwidth, x2=bostart, y2=bomax - chwidth, color=bocolorup)
//     line.new(x1=bostart, y1=bomax - chwidth, x2=bostart, y2=bomax, color=bocolorup)
//     line.new(x1=bar_index, y1=bomax - chwidth, x2=bar_index, y2=bomax, color=bocolorup)

plotshape(not na(bomax) and num >= mintest, location=location.belowbar, style=shape.triangleup, color=bocolorup, size=size.small)
//alertcondition(not na(bomax) and num >= mintest, title='Breakout', message='Breakout')

// check bearish cup
float bomin = na
bostart := bar_index
num1 = 0
lwst = ta.lowest(prd)[1]
if array.size(plval) >= mintest and close < open and close < lwst
    bomin := array.get(plval, 0)
    xx = 0
    for x = 0 to array.size(plval) - 1 by 1
        if array.get(plval, x) <= close
            break
        xx := x
        bomin := math.min(bomin, array.get(plval, x))
        bomin
    if xx >= mintest and open >= bomin
        for x = 0 to xx by 1
            if array.get(plval, x) >= bomin and array.get(plval, x) <= bomin + chwidth
                num1 += 1
                bostart := array.get(plloc, x)
                bostart
        if num1 < mintest or lwst <= bomin
            bomin := na
            bomin

// if not na(bomin) and num1 >= mintest
//     line.new(x1=bar_index, y1=bomin, x2=bostart, y2=bomin, color=bocolordown)
//     line.new(x1=bar_index, y1=bomin + chwidth, x2=bostart, y2=bomin + chwidth, color=bocolordown)
//     line.new(x1=bostart, y1=bomin + chwidth, x2=bostart, y2=bomin, color=bocolordown)
//     line.new(x1=bar_index, y1=bomin + chwidth, x2=bar_index, y2=bomin, color=bocolordown)

plotshape(not na(bomin) and num1 >= mintest, location=location.abovebar, style=shape.triangledown, color=bocolordown, size=size.small)

//alertcondition(not na(bomin) and num1 >= mintest, title='Breakdown', message='Breakdown')
//alertcondition(not na(bomax) and num >= mintest or not na(bomin) and num1 >= mintest, title='Breakout or Breakdown', message='Breakout or Breakdown')

// Long Short conditions
longCondition = not na(bomax) and num >= mintest
if longCondition
    strategy.entry('Long', strategy.long)
shortCondition = not na(bomin) and num1 >= mintest
if shortCondition
    strategy.entry('Short', strategy.short)

// Entry price / Take Profit / Stop Loss
//entryprice = strategy.position_avg_price
entryprice = ta.valuewhen(condition=longCondition or shortCondition, source=close, occurrence=0)
pm = longCondition ? 1 : shortCondition ? -1 : 1 / math.sign(strategy.position_size)
takeprofit = entryprice * (1 + pm * tppercent * 0.01)
stoploss = entryprice * (1 - pm * slpercent * 0.01)
strategy.exit(id='Exit Long', from_entry='Long', stop=issl ? stoploss : na, limit=istp ? takeprofit : na, alert_message='Exit Long')
strategy.exit(id='Exit Short', from_entry='Short', stop=issl ? stoploss : na, limit=istp ? takeprofit : na, alert_message='Exit Short')