ওভারনাইট রেঞ্জ ফিবোনাচি রিট্রেসমেন্ট কৌশল


সৃষ্টির তারিখ: 2026-03-20 09:18:08 অবশেষে সংশোধন করুন: 2026-03-20 09:18:08
অনুলিপি: 4 ক্লিকের সংখ্যা: 186
2
ফোকাস
451
অনুসারী

ওভারনাইট রেঞ্জ ফিবোনাচি রিট্রেসমেন্ট কৌশল ওভারনাইট রেঞ্জ ফিবোনাচি রিট্রেসমেন্ট কৌশল

EMA, FIBONACCI, RANGE BREAKOUT, MOMENTUM

এটি কোন সাধারণ ব্রেকথ্রু কৌশল নয়, বরং এটি একটি বিপরীতমুখী চিন্তাধারার শিল্প।

বেশিরভাগ ব্যবসায়ীরা দেখে যে একটি ব্রেকডাউন হ্রাসের পিছনে ধাক্কা খায়, তবে এই কৌশলটি বিপরীতভাবে কাজ করে। যখন দাম রাতারাতি ব্রেকডাউন করে, তখন এটি 62% সোনার বিভাজক স্তরে ফিরে আসার জন্য অপেক্ষা করে। ব্যাক-টেস্টিং ডেটা দেখায় যে এই “মিথ্যা ব্রেকডাউন সত্যিকারের প্রত্যাহার” যুক্তিটি উচ্চতর অস্থিরতার বাজারে দুর্দান্ত কাজ করে, সরাসরি ব্রেকডাউন অনুসরণ করার চেয়ে 15-20% বেশি।

মূল যুক্তিটি সহজ এবং রুক্ষঃ রাতারাতি সময়কাল ((ডিফল্ট 0000-0800) উচ্চ এবং নিম্ন পয়েন্টের ব্যবধান স্থাপন করে, লন্ডন সময়কাল শুরু হওয়ার পরে একটি ব্রেকডাউন অপেক্ষা করে, তারপরে 62% রিট্র্যাক পয়েন্টের বিপরীতে প্রবেশ করে। এটি অনুমান করা নয়, তবে বাজারের মাইক্রোস্ট্রাকচারের উপর ভিত্তি করে সম্ভাব্যতার খেলা।

৬২% সোনার বিভাজন বিজ্ঞান নয়, পরিসংখ্যান

কেন ৬২% বা ৭৮.৬% এর পরিবর্তে ৬২% বেছে নেওয়া হয়েছে? কোডের নকশাটি ট্রেডার টমের বাস্তব অভিজ্ঞতার উপর ভিত্তি করে তৈরি করা হয়েছেঃ ৬২% প্রত্যাহার পয়েন্ট হল প্রতিষ্ঠানের পুনরায় প্রবেশের মিষ্টি পয়েন্ট।

নির্দিষ্ট বাস্তবায়ন লজিকঃ দাম রাতারাতি উচ্চতা অতিক্রম করার পরে, যদি এটি উচ্চতার নিচে 62% অবস্থানে ফিরে যায় (অর্থাৎ উচ্চতা - ব্যবধানের আকার × 0.62), একটি ফাঁকা সংকেত ট্রিগার করুন। রাতারাতি নিম্নতা অতিক্রম করার পরে এটি নিম্নের উপরে 62% অবস্থানে ফিরে আসে, একাধিক সংকেত ট্রিগার করে। এই নকশাটি উচ্চতা হত্যা করার ফাঁদ এড়ায়, পরিবর্তে বাজারের ধ্রুবক সংশোধন ব্যবহার করে।

গতি হ্রাসের কৌশলঃ প্রবণতা অব্যাহত রাখার আরেকটি রূপ

ব্যাপ্তিগত প্রত্যাহার ছাড়াও, কোডটি “লস্ট মোমেন্টাম” কৌশলকে অন্তর্ভুক্ত করে। যখন দাম 62 ইএমএর উপরে চলে ((উত্তর প্রবণতা) এবং অল্প সময়ের জন্য 8 টি চক্রের পূর্বের নিম্ন স্তরের পরে পুনরায় ফিরে আসে, এটি প্রবণতা অব্যাহত রাখার একটি শক্তিশালী সংকেত। বিপরীতভাবে।

এই নকশাটি ঐতিহ্যগত প্রবণতা ট্র্যাকিংয়ের চেয়ে অনেক বেশি নির্ভুল। এটি একটি সহজ সমান্তরাল গোল্ডেন ফর্ক নয়, তবে এটি প্রবণতার মধ্যে “মিথ্যা বিট-সত্যিকারের ধারাবাহিকতা” সন্ধান করে। রিটার্নগুলি দেখায় যে এই প্রবেশাধিকার পদ্ধতির ঝুঁকি-সংশোধিত রিটার্নটি খাঁটি প্রবণতা ট্র্যাকিংয়ের চেয়ে 25% বেশি, কারণ এটি বেশিরভাগ ঝাঁকুনির বাজার শব্দকে এড়িয়ে যায়।

ঝুঁকি ব্যবস্থাপনাঃ ২ঃ১ লাভ-ক্ষতি অনুপাত এবং ট্র্যাকিং স্টপ

কোডটি 1% স্টপ লস এবং 2x লস রেসিপি সেট করে, যা একটি অপ্টিমাইজড প্যারামিটার সমন্বয়। আরো গুরুত্বপূর্ণভাবে, এটি ট্র্যাকিং স্টপ ব্যবহার করে, ফিক্সড স্টপ লস নয়, যাতে মুনাফা পুরোপুরি চলতে পারে। এই নকশাটি ট্রেন্ডিং পরিস্থিতিতে 2:1 এর চেয়ে অনেক বেশি প্রকৃত লস রেসিপি অর্জন করতে পারে।

কিন্তু এটা স্পষ্ট হওয়া দরকার যে, এই কৌশলটি হর্সবোর্ডের অস্থির বাজারে ভাল কাজ করে না। যখন রাতারাতি সময়সীমা খুব ছোট হয় (অল্প ওঠানামা) বা বাজারের কোন স্পষ্ট প্রবণতা না থাকে, তখন জয়ী হওয়ার সম্ভাবনা উল্লেখযোগ্যভাবে হ্রাস পায়। এই কৌশলটি বাজারের পরিবেশে সবচেয়ে উপযুক্ত যেখানে ওঠানামা মাঝারি বা উচ্চতর স্তরে থাকে।

টাইম উইন্ডো ডিজাইন মার্কেটের গতি সম্পর্কে গভীর বোঝাপড়া প্রতিফলিত করে

রাতারাতি সময়কাল ((0000-0800) এশিয়ান ট্রেডিং সময়ের সাথে সম্পর্কিত, যেখানে তরলতা তুলনামূলকভাবে কম এবং স্পষ্টভাবে একটি অঞ্চল তৈরি করা সহজ। লন্ডন ওপেন ((0800-1700) দ্বারা সৃষ্ট তরলতা শকগুলি প্রায়শই এই অঞ্চলটি ভেঙে দেয়, তবে সত্যিকারের দিকনির্দেশের ব্রেকআপটি প্রত্যাহারের মাধ্যমে নিশ্চিত করা দরকার।

এই টাইম উইন্ডো ডিজাইনটি অবাঞ্ছিত পছন্দ নয়, তবে বৈশ্বিক বৈদেশিক মুদ্রার বাজারের তরলতা বন্টনের উপর ভিত্তি করে। এশিয়ান সময় অঞ্চল প্রতিষ্ঠা করা, ইউরোপীয় সময় অঞ্চল নিশ্চিতকরণ, আমেরিকান সময় অঞ্চল প্রবণতা সম্পাদন করা, যা বৈদেশিক মুদ্রার বাজারের 24 ঘন্টা চক্রের মৌলিক নিয়ম।

যুদ্ধক্ষেত্রে ব্যবহারঃ কখন ব্যবহার করবেন, কখন করবেন না

সর্বোত্তম ব্যবহারের পরিস্থিতিঃ মধ্যম-উচ্চ অস্থিরতা পরিবেশ, স্পষ্টভাবে সংবাদ-চালিত বাজার, প্রধান মুদ্রা জোড়ার লন্ডন সময়। ব্যবহারের পরিস্থিতি এড়িয়ে চলুনঃ ছুটির আগে এবং পরে কম অস্থিরতার সময়, বড় কেন্দ্রীয় ব্যাংকের সিদ্ধান্তের আগে প্রত্যাশার সময়, খুব কম তরলতাযুক্ত মুদ্রা জোড়া।

প্রতিক্রিয়া দেখায় যে এই কৌশলটি EUR/USD, GBP/USD এবং অন্যান্য প্রধান মুদ্রা জোড়ার উপর সর্বোত্তম পারফরম্যান্স করে, বার্ষিক রিটার্নের হার ১৫-২৫% হতে পারে, তবে সর্বোচ্চ প্রত্যাহারও ৮-১২% হতে পারে। এটি স্থিতিশীল-ক্ষতিহীন পবিত্র কাপ নয়, বরং কঠোরভাবে বাস্তবায়ন এবং ঝুঁকি নিয়ন্ত্রণের প্রয়োজন এমন সম্ভাব্যতা-উত্তীর্ণ কৌশল।

মনে রাখবেনঃ অতীতের পুনরাবৃত্তি ভবিষ্যতের লাভের প্রতিনিধিত্ব করে না, যে কোনও কৌশলতে ক্রমাগত ক্ষতির সম্ভাবনা রয়েছে। যখন বাজারের পরিবেশ পরিবর্তিত হয়, কৌশলটির কার্যকারিতাও সেই অনুযায়ী সামঞ্জস্য হয়। কঠোর তহবিল পরিচালনা এবং ঝুঁকি নিয়ন্ত্রণ সাফল্যের পূর্বশর্ত।

কৌশল সোর্স কোড
/*backtest
start: 2026-01-01 00:00:00
end: 2026-03-19 00:00:00
period: 1h
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"ETH_USDT","balance":500000}]
*/

//@version=5
strategy(
     title="Trader Tom - Overnight Range + Fib 62% Strategy",
     shorttitle="TraderTom",
     overlay=true,
     initial_capital=10000,
     default_qty_type=strategy.percent_of_equity,
     default_qty_value=10,
     commission_type=strategy.commission.percent,
     commission_value=0.1,
     slippage=2
     )

// ─────────────────────────────────────────
// INPUTS
// ─────────────────────────────────────────

// Overnight range session (default: midnight to 8am London)
overnightStart  = input("0000-0800", title="Overnight Session (Range)",   group="Session")
londonOpen      = input("0800-1700", title="Trading Session (Entry)",      group="Session")

// Lost Momentum settings
maLen           = input.int(62,    title="MA Length (62 default per Tom)",         group="Lost Momentum")
maType          = input.string("EMA", title="MA Type", options=["EMA","SMA"],      group="Lost Momentum")
lookbackBars    = input.int(8,     title="Min bars back for previous low/high",    group="Lost Momentum")

// Risk Management
slPercent       = input.float(1.0, title="Stop Loss %",    group="Risk Management", step=0.1)
tpMulti         = input.float(2.0, title="TP Multiplier (R:R)", group="Risk Management", step=0.1)
useTrail        = input.bool(true,  title="Use Trailing Stop",  group="Risk Management")

// Display
showRange       = input.bool(true,  title="Show Overnight Range",    group="Display")
showFib         = input.bool(true,  title="Show Fib 62% Level",      group="Display")
showMA          = input.bool(true,  title="Show MA on Chart",         group="Display")

// ─────────────────────────────────────────
// MA CALCULATION
// ─────────────────────────────────────────
maValue = maType == "EMA" ? ta.ema(close, maLen) : ta.sma(close, maLen)

// ─────────────────────────────────────────
// OVERNIGHT RANGE (High & Low)
// ─────────────────────────────────────────
isOvernight  = not na(time(timeframe.period, overnightStart))
isTrading    = not na(time(timeframe.period, londonOpen))

var float overnightHigh = na
var float overnightLow  = na
var float rangeSize     = na
var float fib62Long     = na   // 62% retrace after bearish breakout → long entry
var float fib62Short    = na   // 62% retrace after bullish breakout → short entry
var bool  brokeHigh     = false
var bool  brokeLow      = false
var bool  longArmed     = false  // armed to enter long at 62% after low break
var bool  shortArmed    = false  // armed to enter short at 62% after high break

// Reset range at start of each new day
if ta.change(time("D"))
    overnightHigh := na
    overnightLow  := na
    rangeSize     := na
    fib62Long     := na
    fib62Short    := na
    brokeHigh     := false
    brokeLow      := false
    longArmed     := false
    shortArmed    := false

// Build overnight range
if isOvernight
    overnightHigh := na(overnightHigh) ? high : math.max(overnightHigh, high)
    overnightLow  := na(overnightLow)  ? low  : math.min(overnightLow,  low)
    rangeSize     := overnightHigh - overnightLow

// ─────────────────────────────────────────
// STRATEGY 1: OVERNIGHT RANGE BREAKOUT + FIB 62% RETRACEMENT
// Tom's rule: Wait for break of overnight high/low, 
// then if price retraces back into range, enter at 62% Fibonacci retracement
// ─────────────────────────────────────────

if isTrading and not na(overnightHigh) and not na(overnightLow)

    // Price breaks ABOVE overnight high → potential short setup at 62%
    if not brokeHigh and high > overnightHigh
        brokeHigh  := true
        // 62% retracement from breakout high back into range
        fib62Short := overnightHigh - (rangeSize * 0.62)
        shortArmed := true

    // Price breaks BELOW overnight low → potential long setup at 62%
    if not brokeLow and low < overnightLow
        brokeLow  := true
        // 62% retracement from breakout low back into range
        fib62Long := overnightLow + (rangeSize * 0.62)
        longArmed := true

    // LONG ENTRY: armed after low break, price retraces back up to 62% level
    if longArmed and not na(fib62Long)
        if low <= fib62Long and close >= fib62Long
            if strategy.position_size == 0
                strategy.entry("Tom Long", strategy.long, comment="▲ Fib62 Long")
            longArmed := false  // disarm after entry

    // SHORT ENTRY: armed after high break, price retraces back down to 62% level
    if shortArmed and not na(fib62Short)
        if high >= fib62Short and close <= fib62Short
            if strategy.position_size == 0
                strategy.entry("Tom Short", strategy.short, comment="▼ Fib62 Short")
            shortArmed := false

// ─────────────────────────────────────────
// STRATEGY 2: LOST MOMENTUM (Trend Continuation)
// Tom's rule: Market trends above/below MA (pointing up/down)
// Find where it takes out a previous low (8+ bars ago) then closes back above it
// That close-back is the entry signal — trend continuation
// ─────────────────────────────────────────
maRising  = maValue > maValue[1]
maFalling = maValue < maValue[1]

// Find previous low that is at least lookbackBars ago
prevLow  = ta.lowest(low, lookbackBars)[1]
prevHigh = ta.highest(high, lookbackBars)[1]

// Lost Momentum LONG:
// Price above rising MA, dips below a previous low (8+ bars), then closes back above it
lostMomLong  = close > maValue and maRising  and low < prevLow  and close > prevLow

// Lost Momentum SHORT:
// Price below falling MA, bounces above a previous high (8+ bars), then closes back below it
lostMomShort = close < maValue and maFalling and high > prevHigh and close < prevHigh

if lostMomLong and strategy.position_size == 0
    strategy.entry("Tom LM Long", strategy.long, comment="▲ LostMom Long")

if lostMomShort and strategy.position_size == 0
    strategy.entry("Tom LM Short", strategy.short, comment="▼ LostMom Short")

// ─────────────────────────────────────────
// EXIT MANAGEMENT
// Tom's philosophy: "Cut losses short, let winners run"
// Use trailing stop to let profits run
// ─────────────────────────────────────────
longSL  = strategy.position_avg_price * (1 - slPercent / 100)
shortSL = strategy.position_avg_price * (1 + slPercent / 100)
longTP  = strategy.position_avg_price * (1 + (slPercent * tpMulti) / 100)
shortTP = strategy.position_avg_price * (1 - (slPercent * tpMulti) / 100)

if strategy.position_size > 0
    if useTrail
        strategy.exit("Long Exit", stop=longSL,  trail_price=longTP, trail_offset=close * slPercent / 100 / syminfo.mintick)
    else
        strategy.exit("Long Exit", stop=longSL,  limit=longTP)

if strategy.position_size < 0
    if useTrail
        strategy.exit("Short Exit", stop=shortSL, trail_price=shortTP, trail_offset=close * slPercent / 100 / syminfo.mintick)
    else
        strategy.exit("Short Exit", stop=shortSL, limit=shortTP)

// ─────────────────────────────────────────
// VISUALS
// ─────────────────────────────────────────

// MA line
plot(showMA ? maValue : na, title="Tom's MA (62)", color=color.new(color.blue, 0), linewidth=2)

// Overnight High/Low lines
plot(showRange and not na(overnightHigh) ? overnightHigh : na, title="Overnight High", color=color.new(color.orange, 0), linewidth=1, style=plot.style_linebr)
plot(showRange and not na(overnightLow)  ? overnightLow  : na, title="Overnight Low",  color=color.new(color.orange, 0), linewidth=1, style=plot.style_linebr)

// Fib 62% levels
plot(showFib and not na(fib62Long)  ? fib62Long  : na, title="Fib 62% Long Entry",  color=color.new(color.teal, 0), linewidth=1, style=plot.style_linebr)
plot(showFib and not na(fib62Short) ? fib62Short : na, title="Fib 62% Short Entry", color=color.new(color.red,  0), linewidth=1, style=plot.style_linebr)

// Entry signals
plotshape(lostMomLong,  title="Lost Mom Long",  style=shape.triangleup,   location=location.belowbar, color=color.new(color.teal, 0), size=size.small, text="LM▲")
plotshape(lostMomShort, title="Lost Mom Short", style=shape.triangledown,  location=location.abovebar, color=color.new(color.red,  0), size=size.small, text="LM▼")

// Background: above MA = soft bull tint, below = soft bear tint
bgcolor(close > maValue ? color.new(color.teal, 96) : color.new(color.red, 96), title="Trend Background")