ウィリアムズ・インサイド・デイ・ブレイクアウト戦略

INSIDE DAY BREAKOUT STOP LOSS FPO
作成日: 2025-10-11 16:55:28 最終変更日: 2025-10-11 16:55:28
コピー: 0 クリック数: 212
2
フォロー
319
フォロワー

ウィリアムズ・インサイド・デイ・ブレイクアウト戦略 ウィリアムズ・インサイド・デイ・ブレイクアウト戦略

この戦略は何をしているのか?

この戦略は,株式市場で”猫と猫を隠す”ゲームをするようなものだ! 市場が”内包日” (“今日の波動は,昨日の波動に完全に包まれている”) を起こすとき,それはまるで市場が大作りをして,大きな爆発を準備しているかのようだ!

この戦略は,特に月曜日,木曜日,金曜日の”金取引日”を狙って, “耐えられない”突破の瞬間を捉えるためのものです.

策略の核心的な論理は単純です.

市場が圧縮されたスプリングのようなものだと想像してみてください.

  • 昨日は”内包の日”でした (前日に完全に包まれていた)
  • 前の日は晴れでした (多頭は興奮しました)
  • 今日,取引開始価格は, 重要なレジスタンス値を下回った.

価格が過去3サイクルで最も高い値を突破すると,レバレッジが放たれたように,戦略は,すぐに入場し,多額の投資をします!

リスク管理: 2つのセキュリティロック

固定ストップ ポイント・ストップ・損失やパーセンテージ・ストップ・損失の選択は, “損失上限”を設定したようなもので,決して貪欲ではありません!

FPOの法律からの脱退 これは,市場が反省するのを待つことなく, “さようなら,受け取る”という知恵のようなものです!✨

なぜ特定の取引日を選んだのか?

戦略は,月曜日,木曜日,金曜日で取引する,これはランダムではない!

  • 月曜日:新しい週の方向づけ
  • 木曜日:重要なデータ発表日
  • 金曜日: 資金調達の日

物語を語るための”平穏な日”である火曜日と水曜日を避けてください!

この戦略は誰に適しているのか?

この戦略は,明瞭な入場シグナル,明瞭なストップ・ロズル,そして賢明な利回り退出の仕組みを備えています.

市場は弹のようなもので, 強く押せば高く弾ける!

ストラテジーソースコード
/*backtest
start: 2025-01-01 00:00:00
end: 2025-10-09 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BNB_USDT","balance":500000}]
*/

//@version=5
strategy("Larry Williams Bonus Track Pattern", overlay=true)

//──────────────────────────────────
// Inputs
//──────────────────────────────────
useDayFilter = input.bool(true, "Trade only Mon/Thu/Fri")
sl_type      = input.string("Points", "Stop Loss Type", options=["Points","Percent"])
sl_value     = input.float(1.0, "Stop Loss Value (points or %)", step=0.1, minval=0.0)
debugPlot    = input.bool(false, "Show Levels")

//──────────────────────────────────
// DAILY SERIES for SIGNAL
//──────────────────────────────────
hD = request.security(syminfo.tickerid, "D", high,  lookahead=barmerge.lookahead_off)
lD = request.security(syminfo.tickerid, "D", low,   lookahead=barmerge.lookahead_off)
oD = request.security(syminfo.tickerid, "D", open,  lookahead=barmerge.lookahead_off)
cD = request.security(syminfo.tickerid, "D", close, lookahead=barmerge.lookahead_off)

// Inside bar (yesterday) and prior bar (two days ago) is bullish
inside_prev         = hD[1] < hD[2] and lD[1] > lD[2]
prev_of_inside_bull = cD[2] > oD[2]

// Relevant highs: inside (t-1) + two prior bars (t-2, t-3)
inside_high        = hD[1]
max_pre_inside_two = math.max(hD[2], hD[3])
entry_stop_price   = math.max(inside_high, max_pre_inside_two)   // highest of the last 3 bars

//──────────────────────────────────
// DAILY LOGIC (first bar of the day)
//──────────────────────────────────
isNewDay = ta.change(time("D"))     // true on the FIRST bar of each day
dayOpen  = open                      // real daily open
dow      = dayofweek                 // day of week (works intraday)

passDay  = not useDayFilter or (dow == dayofweek.monday or dow == dayofweek.thursday or dow == dayofweek.friday)
open_ok  = dayOpen < inside_high and dayOpen < max_pre_inside_two

// Valid setup ONLY for the day immediately after the inside bar
longSetupToday = isNewDay and passDay and inside_prev and prev_of_inside_bull and open_ok

//──────────────────────────────────
// Helper function to create a “day identifier” as a numeric value
//──────────────────────────────────
getDayId() =>
    year(time) * 10000 + month(time) * 100 + dayofmonth(time)

//──────────────────────────────────
// Pending order management / exact entry the day after inside bar
//──────────────────────────────────
var float entryPrice = na
var int entryDayId = na

if isNewDay
    // Cancel any pending stop from the previous day (TIF: 1 day)
    strategy.cancel("LE")

    // If today is the next day after inside and open is valid:
    if longSetupToday and strategy.position_size == 0
        if dayOpen >= entry_stop_price
            // Gap above stop → enter at MARKET on today’s open
            strategy.entry("LE", strategy.long)
        else
            // No gap → place a STOP valid only for today
            strategy.entry("LE", strategy.long, stop=entry_stop_price)

// Record the entry day when position opens
enteredNow = strategy.position_size > 0 and strategy.position_size[1] == 0
if enteredNow
    entryPrice := strategy.position_avg_price
    entryDayId := getDayId()

//──────────────────────────────────
// Fixed Stop Loss
//──────────────────────────────────
if strategy.position_size > 0
    avg = strategy.position_avg_price
    sl_price = sl_type == "Points" ? (avg - sl_value) : (avg * (1.0 - sl_value/100.0))
    strategy.exit(id="SL", from_entry="LE", stop=sl_price)
else
    strategy.cancel("SL")

//──────────────────────────────────
// FPO: Close on the FIRST profitable open AFTER entry day
// (never on the same day)
//──────────────────────────────────
if isNewDay and strategy.position_size > 0 and not na(entryDayId)
    if getDayId() > entryDayId and dayOpen > strategy.position_avg_price
        strategy.close("LE", comment="FPO")

//──────────────────────────────────
// Optional Plots
//──────────────────────────────────
plot(debugPlot ? inside_high        : na, "Inside High (D-1)")
plot(debugPlot ? max_pre_inside_two : na, "High (D-2/D-3)")
plot(debugPlot ? entry_stop_price   : na, "Entry (max of last 3 highs)", linewidth=2)