
یہ حکمت عملی ایک ٹریڈنگ سسٹم ہے جس میں گرانویل ٹرینڈ ریورس تھیوری اور MACD اشارے کے ملٹی سگنل کی تصدیق کی گئی ہے۔ حکمت عملی کا بنیادی خیال قیمتوں اور اوسط سے متعلق تعلقات کے ذریعہ ممکنہ رجحان کی واپسی کا فیصلہ کرنا ہے ، اور MACD اشارے کے ملٹی سگنل کی توثیق کا استعمال کرتے ہوئے تجارت کی وشوسنییتا کو یقینی بنانا ہے۔ یہ طریقہ نہ صرف مؤثر طریقے سے رجحانات کی شروعات کی نشاندہی کرسکتا ہے ، بلکہ متعدد تصدیق کے طریقہ کار کے ذریعہ جھوٹے سگنل کے خطرے کو بھی کم کرسکتا ہے۔
اس حکمت عملی کے نفاذ کے عمل کو چار اہم مراحل میں تقسیم کیا گیا ہے۔
اسٹاپ نقصان کی ترتیب میں ریورس K لائن طول موج پر مبنی متحرک ایڈجسٹمنٹ کا طریقہ استعمال کیا گیا ہے ، جس میں اسٹاپ نقصان کو ریورس K لائن کی کم سے کم حد پر رکھا گیا ہے ، اور اسٹاپ نقصان کو ریورس K لائن طول موج کے 1.618 گنا پر رکھا گیا ہے ، جو فبونیکی توسیع کے اصول کے مطابق ہے۔
اس حکمت عملی نے کلاسیکی تکنیکی تجزیہ کی تھیوری اور جدید مقداری تجارت کے طریقوں کو ملا کر ایک نسبتا complete مکمل تجارتی نظام تشکیل دیا ہے۔ متعدد سگنل کی تصدیق کا میکانزم بہتر تجارت کی وشوسنییتا فراہم کرتا ہے ، اور متحرک رسک مینجمنٹ کا طریقہ بھی حکمت عملی کو اچھی طرح سے موزوں بناتا ہے۔ اگرچہ کچھ پسماندگی کے مسائل ہیں ، لیکن اس حکمت عملی میں مسلسل اصلاح اور پیرامیٹرز کی ایڈجسٹمنٹ کے ذریعہ بہتر استعمال کی قیمت اور ترقی کی صلاحیت موجود ہے۔
/*backtest
start: 2024-02-21 00:00:00
end: 2025-02-18 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("Granville + MACD Strategy", overlay=true, initial_capital=100000, default_qty_type=strategy.percent_of_equity, default_qty_value=10)
// ■ Parameter Settings
emaPeriod = input.int(20, "EMA Period for Granville", minval=1)
fastLen = input.int(12, "MACD Fast Period", minval=1)
slowLen = input.int(26, "MACD Slow Period", minval=1)
signalLen = input.int(9, "MACD Signal Period", minval=1)
// ■ Calculate EMA (for Granville reversal detection)
ema_val = ta.ema(close, emaPeriod)
// ■ Granville Reversal Detection (e.g., price crosses above EMA from below)
granvilleReversal = ta.crossover(close, ema_val)
// ■ Calculate MACD
[macdLine, signalLine, _] = ta.macd(close, fastLen, slowLen, signalLen)
// ■ State management variables (to manage state transitions)
var bool granvilleDone = false // Reversal bar confirmed flag
var float granvilleLow = na // Low of the reversal bar (used for SL)
var float granvilleRange = na // Range of the reversal bar (used for TP calculation)
var bool macdGC_done = false // First MACD Golden Cross confirmed
var int goldenCrossBar = na // Bar index of the first MACD Golden Cross
var float initialMacdHigh = na // MACD value at the Golden Cross (used for break detection)
var bool breakoutDone = false // MACD line breaks the initial Golden Cross MACD value
// ■ (1) Granville Reversal Detection
if granvilleReversal
granvilleDone := true
granvilleLow := low // Low of the reversal bar (SL)
granvilleRange := high - low // Range of the reversal bar (used for TP calculation)
// Reset MACD-related states
macdGC_done := false
breakoutDone := false
initialMacdHigh := na
goldenCrossBar := na
// ■ (2) MACD Golden Cross (first signal) detection
if granvilleDone and (not macdGC_done) and ta.crossover(macdLine, signalLine)
macdGC_done := true
goldenCrossBar := bar_index
initialMacdHigh:= macdLine
// ■ (3) Check if MACD line breaks the initial MACD value at the Golden Cross
if macdGC_done and (not breakoutDone) and (macdLine > initialMacdHigh)
breakoutDone := true
// ■ (4) When MACD retests and crosses above the signal line again, it's the entry timing
// ※ Check for a crossover after the first Golden Cross bar
entryCondition = granvilleDone and macdGC_done and breakoutDone and (bar_index > goldenCrossBar) and ta.crossover(macdLine, signalLine)
// ■ TP and SL settings at entry
if entryCondition
entryPrice = close
tpPrice = entryPrice + granvilleRange * 1.618
slPrice = granvilleLow
strategy.entry("Long", strategy.long)
strategy.exit("Exit Long", from_entry="Long", stop=slPrice, limit=tpPrice)
// Reset states after entry (for the next entry)
granvilleDone := false
macdGC_done := false
breakoutDone := false
initialMacdHigh := na
goldenCrossBar := na
// ■ Plotting (for reference)
// Display the EMA on the price chart (with fixed title)
plot(ema_val, color=color.orange, title="EMA (20)")
// Plot MACD and Signal in a separate window (with fixed titles)
plot(macdLine, color=color.blue, title="MACD")
plot(signalLine, color=color.red, title="Signal")