
এটি একটি মাল্টি টাইম সাইকেল ট্রেডিং কৌশল যা চার্ট-ব্যান্ড তত্ত্বের উপর ভিত্তি করে তৈরি করা হয়েছে। এই কৌশলটি সম্ভাব্য ট্রেডিং সুযোগগুলি সনাক্ত করার জন্য মূলত চার্ট-ব্যান্ড এবং উচ্চতর সময়কালের দামের ব্যাপ্তি বিশ্লেষণ করে। এই কৌশলটি একটি ট্রেডিং ভলিউম ফিল্টার এবং একটি গতিশীল স্টপ লস মেশিনকে সংহত করে যাতে পূর্ববর্তী উচ্চ-নিম্ন পয়েন্টগুলির উপর বিরতি দিয়ে ট্রেন্ডিং সুযোগগুলি ধরা যায়।
এই কৌশলটির মূল বিষয় হল, উচ্চতর সময়সীমার (ডিফল্ট ৪ ঘন্টা) মধ্যে মূল্য বিপর্যয় দেখা দেয়। বিশেষ করেঃ
এটি একটি কাঠামোগত, যুক্তিসঙ্গতভাবে সুস্পষ্ট, বহু-সময়কালীন ট্রেডিং কৌশল। উচ্চতর সময়কালের দামের আচরণ বিশ্লেষণ করে সম্ভাব্য প্রবণতাযুক্ত সুযোগগুলি সন্ধান করার জন্য, ঝুঁকি ব্যবস্থাপনা এবং ফিল্টারিং প্রক্রিয়াগুলিকে একীভূত করে। কৌশলটির মূল সুবিধা হ’ল এর অভিযোজনযোগ্যতা এবং স্কেলযোগ্যতা, সহজ প্যারামিটার সমন্বয় দ্বারা বিভিন্ন বাজার পরিবেশের সাথে খাপ খাইয়ে নেওয়া যায়। যদিও কিছু অন্তর্নিহিত ঝুঁকি রয়েছে, প্রস্তাবিত অপ্টিমাইজেশন দিকটি কৌশলটির স্থায়িত্ব এবং নির্ভরযোগ্যতা আরও বাড়িয়ে তুলতে পারে।
/*backtest
start: 2025-01-18 00:00:00
end: 2025-02-17 00:00:00
period: 6h
basePeriod: 6h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=6
strategy("Candle Range Theory Strategy", overlay=true)
// Input parameters
var string HTF = input.timeframe("240", "Higher Timeframe (Minutes)") // 4H default
var float stopLossMultiplier = input.float(1.5, "Stop Loss Multiplier", minval=0.5)
var bool useVolFilter = input.bool(false, "Use Volume Filter")
var float volThreshold = input.float(1.5, "Volume Threshold Multiplier", minval=1.0)
// Function to get higher timeframe data
getHtfData(src) =>
request.security(syminfo.tickerid, HTF, src)
// Calculate volume condition once per bar
var bool volCondition = true
if useVolFilter
float vol = getHtfData(volume)
float avgVol = ta.sma(vol, 20)
volCondition := vol > avgVol * volThreshold
// Get HTF candle data
htf_open = getHtfData(open)
htf_high = getHtfData(high)
htf_low = getHtfData(low)
htf_close = getHtfData(close)
// Store previous candle data
var float h1 = na // High of Candle 1
var float l1 = na // Low of Candle 1
var float h2 = na // High of Candle 2
var float l2 = na // Low of Candle 2
var float prevClose = na
// Track setup conditions
var string setupType = na
var float triggerLevel = na
var float targetLevel = na
var float stopLevel = na
// Update candle data - fixed time function usage
var bool isNewBar = false
isNewBar := ta.change(request.security(syminfo.tickerid, HTF, time)) != 0
if isNewBar
h1 := h2
l1 := l2
h2 := htf_high[1]
l2 := htf_low[1]
prevClose := htf_close[1]
// Identify setup conditions
if not na(h1) and not na(h2) and not na(prevClose)
if (h2 > h1 and prevClose < h1) // Short setup
setupType := "short"
triggerLevel := l2
targetLevel := l1
stopLevel := h2 + (h2 - l1) * stopLossMultiplier
else if (l2 < l1 and prevClose > l1) // Long setup
setupType := "long"
triggerLevel := h2
targetLevel := h1
stopLevel := l2 - (h1 - l2) * stopLossMultiplier
else
setupType := na
triggerLevel := na
targetLevel := na
stopLevel := na
// Entry conditions using pre-calculated volume condition - fixed line breaks
bool longCondition = setupType == "long" and high > triggerLevel and not na(triggerLevel) and volCondition
bool shortCondition = setupType == "short" and low < triggerLevel and not na(triggerLevel) and volCondition
// Execute trades
if longCondition
strategy.entry("Long", strategy.long, comment="Long Entry")
strategy.exit("Long Exit", "Long", limit=targetLevel, stop=stopLevel)
if shortCondition
strategy.entry("Short", strategy.short, comment="Short Entry")
strategy.exit("Short Exit", "Short", limit=targetLevel, stop=stopLevel)
// Plot signals - fixed plotshape parameters
plotshape(series=longCondition, title="Long Signal", location=location.belowbar, color=color.green, style=shape.triangleup)
plotshape(series=shortCondition, title="Short Signal", location=location.abovebar, color=color.red, style=shape.triangledown)
plot(triggerLevel, "Trigger Level", color=color.yellow, style=plot.style_circles)
plot(targetLevel, "Target Level", color=color.blue, style=plot.style_circles)
plot(stopLevel, "Stop Level", color=color.red, style=plot.style_circles)