
रणनीति एक मात्रात्मक ट्रेडिंग प्रणाली है जो बहु-समय चक्र तरलता केंद्र बिंदु का पता लगाने पर आधारित है। यह तीन अलग-अलग समय चक्रों (१५ मिनट, १ घंटे और ४ घंटे) के मूल्य व्यवहार का विश्लेषण करके महत्वपूर्ण समर्थन और प्रतिरोध स्तरों की पहचान करता है और इस आधार पर व्यापारिक निर्णय लेता है। प्रणाली में धन प्रबंधन सुविधाओं को एकीकृत किया गया है, जिसमें एक निश्चित राशि के लिए स्टॉप-स्टॉप-लॉस सेटिंग्स शामिल हैं, जबकि एक सहज दृश्य प्रतिक्रिया प्रदान करते हैं जो व्यापारियों को बाजार की संरचना को बेहतर ढंग से समझने में मदद करते हैं।
इस रणनीति का मुख्य उद्देश्य है कि कई समय चक्रों में कीमतों के केंद्र बिंदुओं का पता लगाया जाए। प्रत्येक समय चक्र के लिए, सिस्टम उच्च और निचले बिंदुओं को निर्धारित करने के लिए K-रेखाओं का उपयोग करता है। जब कोई नया केंद्र बिंदु होता है, तो सिस्टम कई सिग्नल उत्पन्न करता है; जब कोई नया केंद्र बिंदु होता है, तो सिस्टम एक खाली सिग्नल उत्पन्न करता है। ट्रेडों को निष्पादित करने के लिए, एक निश्चित राशि का स्टॉप-लॉस प्रबंधन किया जाता है, और डॉलर की राशि को पैसे के लिए एसएल पॉइंट्स फ़ंक्शन द्वारा संबंधित बिंदुओं में परिवर्तित किया जाता है।
बहु-समय चक्र तरलता नोड गर्मी आरेखण रणनीति एक संरचित, तर्कसंगत और स्पष्ट व्यापार प्रणाली है। यह बहुआयामी बाजार विश्लेषण और सख्त जोखिम प्रबंधन के माध्यम से व्यापारियों के लिए एक विश्वसनीय व्यापारिक ढांचा प्रदान करता है। हालांकि कुछ अंतर्निहित जोखिम और सीमाएं हैं, लेकिन निरंतर अनुकूलन और सुधार के माध्यम से, रणनीति को विभिन्न बाजार स्थितियों में स्थिर प्रदर्शन बनाए रखने की उम्मीद है।
/*backtest
start: 2024-11-19 00:00:00
end: 2024-12-18 08:00:00
period: 4h
basePeriod: 4h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
// This Pine Script™ code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © pmotta41
//@version=5
strategy("GPT Session Liquidity Heatmap Strategy", overlay=true)
// Inputs
timeframe1 = input.timeframe("15", title="Intraday Timeframe 1")
timeframe2 = input.timeframe("60", title="Intraday Timeframe 2")
timeframe3 = input.timeframe("240", title="Higher Timeframe")
leftBars = input.int(7, title="Left Bars for Pivot", minval=2, maxval=20)
rightBars = input.int(7, title="Right Bars for Pivot", minval=2, maxval=20)
takeProfitDollar = input(200, title="Take Profit $$")
stopLossDollar = input(100, title="Stop Loss $$")
// Pivot Detection Function
detectPivot(highs, lows, left, right) =>
pivotHigh = ta.pivothigh(highs, left, right)
pivotLow = ta.pivotlow(lows, left, right)
[pivotHigh, pivotLow]
// Get Pivots from Different Timeframes
[pivotHigh1, pivotLow1] = request.security(syminfo.tickerid, timeframe1, detectPivot(high, low, leftBars, rightBars))
[pivotHigh2, pivotLow2] = request.security(syminfo.tickerid, timeframe2, detectPivot(high, low, leftBars, rightBars))
[pivotHigh3, pivotLow3] = request.security(syminfo.tickerid, timeframe3, detectPivot(high, low, leftBars, rightBars))
// Plot Pivots
plotshape(series=pivotHigh1, title="Pivot High 1", location=location.abovebar, color=color.red, style=shape.labeldown, text="H1")
plotshape(series=pivotLow1, title="Pivot Low 1", location=location.belowbar, color=color.green, style=shape.labelup, text="L1")
plotshape(series=pivotHigh2, title="Pivot High 2", location=location.abovebar, color=color.red, style=shape.labeldown, text="H2")
plotshape(series=pivotLow2, title="Pivot Low 2", location=location.belowbar, color=color.green, style=shape.labelup, text="L2")
plotshape(series=pivotHigh3, title="Pivot High 3", location=location.abovebar, color=color.red, style=shape.labeldown, text="H3")
plotshape(series=pivotLow3, title="Pivot Low 3", location=location.belowbar, color=color.green, style=shape.labelup, text="L3")
// Strategy Logic
buyCondition = pivotLow1 or pivotLow2 or pivotLow3
sellCondition = pivotHigh1 or pivotHigh2 or pivotHigh3
if (buyCondition)
strategy.entry("Buy", strategy.long)
if (sellCondition)
strategy.entry("Sell", strategy.short)
// Function to Convert $$ to Points for Stop Loss and Take Profit
moneyToSLPoints(money) =>
strategy.position_size != 0 ? (money / syminfo.pointvalue / math.abs(strategy.position_size)) / syminfo.mintick : na
p = moneyToSLPoints(takeProfitDollar)
l = moneyToSLPoints(stopLossDollar)
// Exit Conditions
strategy.exit("Exit Buy", from_entry="Buy", profit=p, loss=l)
strategy.exit("Exit Sell", from_entry="Sell", profit=p, loss=l)
// Visualization for Stop Loss and Take Profit Levels
pointsToPrice(pp) =>
na(pp) ? na : strategy.position_avg_price + pp * math.sign(strategy.position_size) * syminfo.mintick
tp = plot(pointsToPrice(p), style=plot.style_linebr, color=color.green, title="Take Profit Level")
sl = plot(pointsToPrice(-l), style=plot.style_linebr, color=color.red, title="Stop Loss Level")
avg = plot(strategy.position_avg_price, style=plot.style_linebr, color=color.blue, title="Entry Price")
fill(tp, avg, color=color.new(color.green, 90), title="Take Profit Area")
fill(avg, sl, color=color.new(color.red, 90), title="Stop Loss Area")
// Background for Gain/Loss
gainBackground = strategy.position_size > 0 and close > strategy.position_avg_price
lossBackground = strategy.position_size > 0 and close < strategy.position_avg_price
bgcolor(gainBackground ? color.new(color.green, 90) : na, title="Gain Background")
bgcolor(lossBackground ? color.new(color.red, 90) : na, title="Loss Background")