এই কৌশলটি বাজারের বিপরীতমুখী পয়েন্টগুলি সনাক্ত করতে এবং সেগুলির উপর ভিত্তি করে ট্রেডিং সিদ্ধান্ত নেওয়ার জন্য পিভট পয়েন্টগুলি ব্যবহার করে। যখন বাম দিকে শেষ 4টি মোমবাতিতে পিভট হাই গঠিত হয়, তখন কৌশলটি একটি দীর্ঘ অবস্থানে প্রবেশ করে; যখন বাম দিকে শেষ 4টি মোমবাতিতে পিভট লো গঠিত হয়, তখন কৌশলটি একটি শর্ট অবস্থানে প্রবেশ করে। স্টপ লসটি প্রবেশ মূল্যের উপরে বা নীচে এক টিক আকারে (সিমিনফো.মিন্টিক) সেট করা হয়। দুটি প্রস্থান শর্ত রয়েছেঃ 1) পরবর্তী বিপরীত পিভট পয়েন্ট উপস্থিত হলে প্রস্থান; 2) ভাসমান ক্ষতি 30% এ পৌঁছলে প্রস্থান করুন।
এই কৌশলটি পিভট পয়েন্ট সূচকের উপর ভিত্তি করে একটি দ্বি-নির্দেশমূলক ট্রেডিং সিস্টেম তৈরি করে, পিভট হাইসে দীর্ঘ এবং পিভট লোসে সংক্ষিপ্ত হয়ে বাজারের বিপরীতমুখী সুযোগগুলি ক্যাপচার করে। কৌশলটির একটি নির্দিষ্ট তাত্ত্বিক ভিত্তি এবং ব্যবহারিক মূল্য রয়েছে, তবে পিভট পয়েন্ট সূচকের সীমাবদ্ধতার কারণে, কৌশলটি প্রকৃত অপারেশনে কিছু ঝুঁকি এবং চ্যালেঞ্জের মুখোমুখি হতে পারে। পিভট পয়েন্ট সূচক প্রকার, পরামিতি, ফিল্টারিং শর্ত, স্টপ লস এবং মুনাফা গ্রহণ ইত্যাদি অপ্টিমাইজ করার মাধ্যমে কৌশলটির দৃust়তা এবং লাভজনকতা আরও উন্নত করার আশা করা হচ্ছে।
/*backtest start: 2023-04-24 00:00:00 end: 2024-04-29 00:00:00 period: 1d basePeriod: 1h exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Pivot Reversal Strategy with Pivot Exit", overlay=true) leftBars = input(4) rightBars = input(2) var float dailyEquity = na // Reset equity to $10,000 at the beginning of each day isNewDay = ta.change(time("D")) != 0 if (isNewDay) dailyEquity := 10000 // Calculate pivot highs and lows swh = ta.pivothigh(leftBars, rightBars) swl = ta.pivotlow(leftBars, rightBars) // Define long entry condition swh_cond = not na(swh) hprice = 0.0 hprice := swh_cond ? swh : hprice[1] le = false le := swh_cond ? true : (le[1] and high > hprice ? false : le[1]) // Enter long position if long entry condition is met if (le) strategy.entry("PivRevLE", strategy.long, comment="EnterLong", stop=hprice + syminfo.mintick) // Define short entry condition swl_cond = not na(swl) lprice = 0.0 lprice := swl_cond ? swl : lprice[1] se = false se := swl_cond ? true : (se[1] and low < lprice ? false : se[1]) // Enter short position if short entry condition is met if (se) strategy.entry("PivRevSE", strategy.short, comment="EnterShort", stop=lprice - syminfo.mintick) // Exit condition: Exit at the next pivot point exitAtNextPivot() => if strategy.opentrades > 0 if strategy.position_size > 0 // Exiting long position at next pivot low if not na(swl) strategy.exit("ExitLong", "PivRevLE", stop=swl - syminfo.mintick) else // Exiting short position at next pivot high if not na(swh) strategy.exit("ExitShort", "PivRevSE", stop=swh + syminfo.mintick) // Call exitAtNextPivot function exitAtNextPivot() // Exit condition: Exit if profit is less than 30% exitIfProfitLessThanThirtyPercent() => if strategy.opentrades > 0 if strategy.position_size > 0 // Calculate profit percentage for long position profit_percentage_long = (close - strategy.position_avg_price) / strategy.position_avg_price * 100 // Exiting long position if profit is less than 30% if profit_percentage_long < -30 strategy.close("PivRevLE") else // Calculate profit percentage for short position profit_percentage_short = (strategy.position_avg_price - close) / strategy.position_avg_price * 100 // Exiting short position if profit is less than 30% if profit_percentage_short < -30 strategy.close("PivRevSE") // Call exitIfProfitLessThanThirtyPercent function exitIfProfitLessThanThirtyPercent()