
এই কৌশলটি K লাইনের উপর ভিত্তি করে উচ্চ এবং নিম্ন ডেটা ডিজাইন করে। প্রবণতার বিপরীত দিকটি সন্ধান করার জন্য। এন্ট্রিগুলি পরে এটিআর সূচক অনুসারে একটি স্টপ লাইন সেট করে এবং স্টপ লস ট্র্যাক করে। কৌশলটি ঝুঁকি-ফেরতের অনুপাতের ভিত্তিতে টার্গেট অবস্থানগুলি গণনা করে এবং টার্গেট পৌঁছে যাওয়ার পরে বা বন্ধ হয়ে যাওয়ার পরে পজিশনটি সরিয়ে দেয়।
এই কৌশলটির প্রবেশের সংকেতগুলি উচ্চ এবং নিম্ন পয়েন্টগুলি থেকে আসে। একটি কে লাইনের ওপেন মূল্য সর্বনিম্ন মূল্যের সমান হলে একটি কেনার সংকেত উত্পন্ন হয়, এবং ওপেন মূল্য সর্বোচ্চ মূল্যের সমান হলে একটি বিক্রয় সংকেত উত্পন্ন হয়, যা নির্দেশ করে যে প্রবণতা বিপরীত হওয়ার সুযোগ থাকতে পারে।
এন্ট্রিগুলি পরে এটিআর সূচকের উপর ভিত্তি করে গতিশীল ট্র্যাকিং স্টপ লস গণনা করবে। কেনার পরে স্টপ লস লাইনটি সর্বশেষ এন রুট কে লাইনের মধ্যে সর্বনিম্ন দামের জন্য 1x এটিআর হ্রাস করে; বিক্রয়ের পরে স্টপ লস লাইনটি সর্বশেষ এন রুট কে লাইনের মধ্যে সর্বোচ্চ দামের জন্য 1x এটিআর যোগ করে। স্টপ লাইনটি গতিশীলভাবে আপডেট হবে, ট্র্যাকিং দাম চলবে।
টার্গেট মুনাফা নির্ধারিত রিস্ক-রিটার্ন অনুপাত অনুসারে গণনা করা হয়। কেনা টার্গেট মূল্য হল এন্ট্রি মূল্য যোগ করা হয়েছে ((এন্ট্রি মূল্য এবং স্টপ লস মূল্যের পার্থক্যের ঝুঁকি রিটার্নের গুণিতক); বিক্রি টার্গেট মূল্য হল এন্ট্রি মূল্য বিয়োগ ((স্টপ লস মূল্য এবং এন্ট্রি মূল্যের পার্থক্যের ঝুঁকি রিটার্নের গুণিতক)) ।
যখন দাম স্টপ লস বা টার্গেট প্রাইসে পৌঁছায় তখন প্লেইন অর্ডার জারি করা হয়।
এই কৌশলটির সুবিধাগুলো হলঃ
এন্ট্রি সিগন্যাল সহজ, পরিষ্কার, সহজেই বিচার করা যায়, এবং একাধিক কম্পন এড়ানো যায়।
ডায়নামিক এটিআর স্টপ লস, সর্বাধিক মুনাফা লক করুন, উচ্চ-নিম্ন-নিম্ন অনুসরণ করা এড়িয়ে চলুন।
রিস্ক রিটার্ন কন্ট্রোল, মুনাফা অবশিষ্টাংশ এবং অতি সংক্ষিপ্ত লাইন অপারেশন এড়ানো।
বিভিন্ন জাতের জন্য উপযুক্ত, সহজেই অপ্টিমাইজ করা যায়।
এই কৌশলটির কিছু ঝুঁকিও রয়েছেঃ
এন্ট্রিস সিগন্যালের মধ্যে কিছু দেরী থাকতে পারে, যার ফলে এন্ট্রিস সিগন্যালের সর্বোত্তম অবস্থানটি মিস করা হতে পারে।
স্টপ লস মূল্য খুব কাছাকাছি বা খুব হালকা, এবং আপনি মুনাফা বা মুনাফা হারাতে পারেন।
এই মডিউলটি কোন প্রবণতা নির্ণয় করে না, এবং ঝড়ের সময় এটি সহজেই ধরা পড়ে।
রাতারাতি গুদাম নির্মাণের জন্য কোন ব্যবস্থা নেই।
অনুকূলিতকরণঃ
অন্যান্য সূচকগুলির সাথে মিলিত হয়ে ট্রেন্ডের মূল্যায়ন করুন, যাতে অস্থিরতার উপর আরবিটেশন এড়ানো যায়।
এটিআর প্যারামিটারগুলি সামঞ্জস্য করুন বা স্টপ লিনিয়ারের অপ্টিমাইজেশনের জন্য ওভাররাইড কন্ট্রোল যুক্ত করুন।
প্রবণতা বিচার বা ফিল্টার মডিউল যোগ করুন, এন্ট্রিগুলির ত্রুটি হ্রাস করুন।
একটি নির্দিষ্ট জাতের রাতের আস্তানার ব্যবস্থা করার জন্য একটি রাতের আস্তানার মডিউল যোগ করুন।
এই কৌশলটি সামগ্রিকভাবে সহজ এবং সরাসরি, এন্ট্রিগুলির সংকেত পরিষ্কার, ক্ষতির ধারণাটি যুক্তিসঙ্গত, ঝুঁকি নিয়ন্ত্রণ করা হয়েছে। তবে কিছু সীমাবদ্ধতা রয়েছে, যেমন প্রবণতা বিচার করা অসম্ভব, সংকেত বিলম্বিত ইত্যাদি। এই সমস্যাগুলি ভবিষ্যতের অপ্টিমাইজেশনের জন্য দিকনির্দেশনা দেয়। আরও সূচক বিচার এবং ঝুঁকি নিয়ন্ত্রণ মডিউলগুলির সাথে মিলিত হয়ে এই কৌশলটি আরও কার্যকর হতে পারে এবং আরও সাধারণ হয়ে উঠতে পারে।
/*backtest
start: 2024-01-01 00:00:00
end: 2024-01-31 23:59:59
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
// Open-High-Low strategy
strategy('Strategy: OLH', shorttitle="OLH", overlay=true )
// Inputs
slAtrLen = input.int(defval=14, title="ATR Period for placing SL", group="StopLoss settings")
showSLLines = input.bool(defval=false, title="Show SL lines in chart", tooltip="Show SL lines also as dotted lines in chart. Note: chart may look untidy.", group="Stolploss settings")
// Trade related
rrRatio = input.float(title='Risk:Reward', step=0.1, defval=2.0, group="Trade settings")
endOfDay = input.int(defval=1500, title="Close all trades, default is 3:00 PM, 1500 hours (integer)", group="Trade settings")
mktAlwaysOn = input.bool(defval=true, title="Markets that never closed (Crypto, Forex, Commodity)", tooltip="Some markers never closes. For those cases, make this checked.", group="Trade settings")
lotSize = input.int(title='Lot Size', step=1, defval=1, group="Trade settings")
// Utils
green(open, close) => close > open ? true : false
red(open, close) => close < open ? true : false
body(open, close) => math.abs(open - close)
lowerwick = green(open, close) ? open - low : close - low
upperwick = green(open, close) ? high - close : high - open
crange = high - low
crangep = high[1] - low[1] // previous candle's candle-range
bullish = close > open ? true : false
bearish = close < open ? true : false
// Trade signals
longCond = barstate.isconfirmed and (open == low)
shortCond = barstate.isconfirmed and (open == high)
// For SL calculation
atr = ta.atr(slAtrLen)
highestHigh = ta.highest(high, 7)
lowestLow = ta.lowest(low, 7)
longStop = showSLLines ? lowestLow - (atr * 1) : na
shortStop = showSLLines ? highestHigh + (atr * 1) : na
plot(longStop, title="Buy SL", color=color.green, style=plot.style_cross)
plot(shortStop, title="Sell SL", color=color.red, style=plot.style_cross)
// Trade execute
h = hour(time('1'), syminfo.timezone)
m = minute(time('1'), syminfo.timezone)
hourVal = h * 100 + m
totalTrades = strategy.opentrades + strategy.closedtrades
if (mktAlwaysOn or (hourVal < endOfDay))
// Entry
var float sl = na
var float target = na
if (longCond)
strategy.entry("enter long", strategy.long, lotSize, limit=na, stop=na, comment="Enter Long")
sl := longStop
target := close + ((close - longStop) * rrRatio)
alert('Buy:' + syminfo.ticker + ' ,SL:' + str.tostring(math.floor(sl)) + ', Target:' + str.tostring(target), alert.freq_once_per_bar)
if (shortCond)
strategy.entry("enter short", strategy.short, lotSize, limit=na, stop=na, comment="Enter Short")
sl := shortStop
target := close - ((shortStop - close) * rrRatio)
alert('Sell:' + syminfo.ticker + ' ,SL:' + str.tostring(math.floor(sl)) + ', Target:' + str.tostring(target), alert.freq_once_per_bar)
// Exit: target or SL
if ((close >= target) or (close <= sl))
strategy.close("enter long", comment=close < sl ? "Long SL hit" : "Long target hit")
if ((close <= target) or (close >= sl))
strategy.close("enter short", comment=close > sl ? "Short SL hit" : "Short target hit")
else if (not mktAlwaysOn)
// Close all open position at the end if Day
strategy.close_all(comment = "Close all entries at end of day.")