
এই কৌশলটি প্রযুক্তিগত বিশ্লেষণের উপর ভিত্তি করে একটি প্রবণতা বিরতি ট্রেডিং সিস্টেম। এটি গতিশীলভাবে দামের উচ্চতা এবং নিম্নতা সনাক্ত করে, একটি আপ এবং ডাউন প্রবণতা লাইন তৈরি করে এবং যখন দামটি ট্রেন্ড লাইনটি ভেঙে যায় তখন মাল্টি-হোল্ডার পজিশনে প্রবেশ করে। কৌশলটি ঝুঁকি নিয়ন্ত্রণ এবং মুনাফা লক করার জন্য একটি গতিশীল স্টপ লস প্রক্রিয়া ব্যবহার করে। এটি একটি ক্লাসিক প্রযুক্তিগত বিশ্লেষণ ট্রেডিং পদ্ধতির একটি প্রোগ্রাম বাস্তবায়ন, বিশেষত যখন একটি পতনশীল প্রবণতা সমাপ্তির কাছাকাছি হয় তখন বিপরীত সুযোগগুলি ধরার জন্য উপযুক্ত।
এই কৌশলটির মূল ধারণাগুলি নিম্নলিখিত মূল পদক্ষেপগুলি নিয়ে গঠিতঃ
এটি একটি যুক্তিসঙ্গত প্রবণতা ট্রেডিং কৌশল যা প্রচলিত প্রযুক্তিগত বিশ্লেষণ পদ্ধতিগুলিকে প্রোগ্রামিংয়ের মাধ্যমে বাস্তবায়িত করে। কৌশলটির সুবিধা হ’ল বাজারের কাঠামোটি স্বয়ংক্রিয়ভাবে সনাক্ত করতে এবং সম্ভাব্য প্রবণতা বিপরীত সুযোগগুলি ক্যাপচার করতে সক্ষম হওয়া। তবে একই সাথে মিথ্যা ব্রেকআপ এবং প্যারামিটার অপ্টিমাইজেশনের মতো বিষয়গুলিতেও মনোযোগ দেওয়া দরকার। আরও অপ্টিমাইজেশন এবং পরিমার্জনের মাধ্যমে, কৌশলটি প্রকৃত ব্যবসায়ের ক্ষেত্রে আরও ভাল প্রভাব ফেলবে বলে আশা করা হচ্ছে।
/*backtest
start: 2025-04-11 00:00:00
end: 2025-07-10 00:00:00
period: 10m
basePeriod: 10m
exchanges: [{"eid":"Binance","currency":"BTC_USDT","balance":200000}]
*/
// This Pine Script™ code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
//@version=6
strategy("Falling Wedge Strategy by Nitin", overlay=true)
// Input parameters
leftBars = input.int(5, "Left Bars for Pivot", minval=1, maxval=20)
rightBars = input.int(5, "Right Bars for Pivot", minval=1, maxval=20)
takeProfitPercent = input.float(6, "Take Profit %", minval=0.1, maxval=100)/100
stopLossPercent = input.float(2, "Stop Loss %", minval=0.1, maxval=100)/100
// Global variables
var float buyPrice = na
// Detect pivot highs and lows
ph = ta.pivothigh(leftBars, rightBars)
pl = ta.pivotlow(leftBars, rightBars)
// Track last two pivot highs
var float[] highs = array.new_float()
var int[] highIndices = array.new_int()
if not na(ph)
array.unshift(highs, ph)
array.unshift(highIndices, bar_index[rightBars])
if array.size(highs) > 2
array.pop(highs)
array.pop(highIndices)
// Track last two pivot lows
var float[] lows = array.new_float()
var int[] lowIndices = array.new_int()
if not na(pl)
array.unshift(lows, pl)
array.unshift(lowIndices, bar_index[rightBars])
if array.size(lows) > 2
array.pop(lows)
array.pop(lowIndices)
// Calculate trendlines and detect falling wedge pattern
isFallingWedge = false
var float currentUpper = na
var float currentLower = na
if array.size(highs) >= 2 and array.size(lows) >= 2
h1 = array.get(highs, 0)
h2 = array.get(highs, 1)
i1 = array.get(highIndices, 0)
i2 = array.get(highIndices, 1)
l1 = array.get(lows, 0)
l2 = array.get(lows, 1)
j1 = array.get(lowIndices, 0)
j2 = array.get(lowIndices, 1)
m_upper = (h1 - h2) / (i1 - i2)
m_lower = (l1 - l2) / (j1 - j2)
currentUpper := h2 + m_upper * (bar_index - i2)
currentLower := l2 + m_lower * (bar_index - j2)
// Falling wedge pattern condition
isFallingWedge := h1 < h2 and l1 < l2 and m_upper < m_lower and m_upper < 0 and m_lower < 0
// Trading strategy execution
if isFallingWedge and ta.crossover(close, currentUpper) and strategy.position_size == 0
strategy.entry("Buy", strategy.long)
buyPrice := close
strategy.exit("Take Profit/Stop Loss", "Buy", stop=buyPrice * (1 - stopLossPercent), limit=buyPrice * (1 + takeProfitPercent))
// Plotting
plot(strategy.position_size > 0 ? buyPrice * (1 - stopLossPercent) : na, "Stop Loss", color=color.red, linewidth=2)
plot(strategy.position_size > 0 ? buyPrice * (1 + takeProfitPercent) : na, "Take Profit", color=color.green, linewidth=2)