यह रणनीति एक निश्चित अवधि में मूल्य और मात्रा के वितरण का विश्लेषण करके खरीद और बिक्री संकेत उत्पन्न करने के लिए वॉल्यूम हीटमैप और वास्तविक समय की कीमत को जोड़ती है। रणनीति पहले वर्तमान मूल्य और एक निर्धारित मूल्य सीमा प्रतिशत के आधार पर कई मूल्य स्तरों की गणना करती है। फिर यह एक पिछली अवधि में प्रत्येक मूल्य स्तर पर खरीद और बिक्री मात्रा की गणना करती है और संचयी खरीद और बिक्री मात्रा की गणना करती है। संचयी खरीद और बिक्री मात्रा के आधार पर लेबल का रंग निर्धारित किया जाता है। इसके अलावा, रणनीति वास्तविक समय की मूल्य वक्र को प्लॉट करती है। इसके अलावा, रणनीति में ईएमए और वीडब्ल्यूएपी जैसे संकेतक शामिल हैं जो मूल्य और मात्रा के साथ उनके संबंध के आधार पर खरीद और बिक्री संकेत उत्पन्न करते हैं। एक खरीद संकेत तब उत्पन्न होता है जब खरीद शर्तें पूरी हो जाती हैं, और कोई पिछला संकेत नहीं हुआ है। एक बिक्री संकेत तब उत्पन्न होता है जब बिक्री शर्तें पूरी हो जाती हैं, या लगातार दो लाल मोमबत्तियां हैं, और कोई पिछला संकेत नहीं हुआ है।
यह रणनीति वॉल्यूम हीटमैप, रीयल-टाइम मूल्य और कई तकनीकी संकेतकों को मिलाकर एक निश्चित संदर्भ मूल्य प्रदान करके खरीद और बिक्री संकेत उत्पन्न करती है। रणनीति का लाभ मूल्य और वॉल्यूम वितरण को सहज रूप से प्रदर्शित करने और संकेत उत्पन्न करने के लिए कई कारकों को व्यापक रूप से ध्यान में रखने की क्षमता में निहित है। हालांकि, रणनीति में कुछ सीमाएं और जोखिम भी हैं, जैसे कि पैरामीटर सेटिंग्स का प्रभाव, संकेतकों की पिछड़ी प्रकृति, और प्रवृत्ति बाजारों पर निर्भरता। इसलिए, व्यावहारिक अनुप्रयोगों में, रणनीति के और अनुकूलन और सुधार की आवश्यकता होती है, जैसे कि अधिक संकेतकों को पेश करना, संकेत स्थितियों को अनुकूलित करना, जोखिम नियंत्रण को बढ़ाना, आदि, रणनीति की मजबूती और लाभप्रदता में सुधार करना।
/*backtest start: 2024-04-01 00:00:00 end: 2024-04-30 23:59:59 period: 1h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Buy and Sell Volume Heatmap with Real-Time Price Strategy", overlay=true, default_qty_type=strategy.percent_of_equity, default_qty_value=10) // Settings for Volume Heatmap lookbackPeriod = input.int(100, title="Lookback Period") baseGreenColor = input.color(color.green, title="Buy Volume Color") baseRedColor = input.color(color.red, title="Sell Volume Color") priceLevels = input.int(10, title="Number of Price Levels") priceRangePct = input.float(0.01, title="Price Range Percentage") labelSize = input.string("small", title="Label Size", options=["tiny", "small", "normal", "large"]) showLabels = input.bool(true, title="Show Volume Labels") // Initialize arrays to store price levels, buy volumes, and sell volumes var float[] priceLevelsArr = array.new_float(priceLevels) var float[] buyVolumes = array.new_float(priceLevels) var float[] sellVolumes = array.new_float(priceLevels) // Calculate price levels around the current price for i = 0 to priceLevels - 1 priceLevel = close * (1 + (i - priceLevels / 2) * priceRangePct) // Adjust multiplier for desired spacing array.set(priceLevelsArr, i, priceLevel) // Calculate buy and sell volumes for each price level for i = 0 to priceLevels - 1 level = array.get(priceLevelsArr, i) buyVol = 0.0 sellVol = 0.0 for j = 1 to lookbackPeriod if close[j] > open[j] if close[j] >= level and low[j] <= level buyVol := buyVol + volume[j] else if close[j] <= level and high[j] >= level sellVol := sellVol + volume[j] array.set(buyVolumes, i, buyVol) array.set(sellVolumes, i, sellVol) // Determine the maximum volumes for normalization maxBuyVolume = array.max(buyVolumes) maxSellVolume = array.max(sellVolumes) // Initialize cumulative buy and sell volumes for the current bar cumulativeBuyVol = 0.0 cumulativeSellVol = 0.0 // Calculate colors based on the volumes and accumulate volumes for the current bar for i = 0 to priceLevels - 1 buyVol = array.get(buyVolumes, i) sellVol = array.get(sellVolumes, i) cumulativeBuyVol := cumulativeBuyVol + buyVol cumulativeSellVol := cumulativeSellVol + sellVol // Determine the label color based on which volume is higher labelColor = cumulativeBuyVol > cumulativeSellVol ? baseGreenColor : baseRedColor // Initialize variables for plotshape var float shapePosition = na var color shapeColor = na if cumulativeBuyVol > 0 or cumulativeSellVol > 0 if showLabels labelText = "Buy: " + str.tostring(cumulativeBuyVol) + "\nSell: " + str.tostring(cumulativeSellVol) label.new(x=bar_index, y=high + (high - low) * 0.02, text=labelText, color=color.new(labelColor, 0), textcolor=color.white, style=label.style_label_down, size=labelSize) else shapePosition := high + (high - low) * 0.02 shapeColor := labelColor // Plot the shape outside the local scope plotshape(series=showLabels ? na : shapePosition, location=location.absolute, style=shape.circle, size=size.tiny, color=shapeColor) // Plot the real-time price on the chart plot(close, title="Real-Time Price", color=color.blue, linewidth=2, style=plot.style_line) // Mpullback Indicator Settings a = ta.ema(close, 9) b = ta.ema(close, 20) e = ta.vwap(close) volume_ma = ta.sma(volume, 20) // Calculate conditions for buy and sell signals buy_condition = close > a and close > e and volume > volume_ma and close > open and low > a and low > e // Ensure close, low are higher than open, EMA, and VWAP sell_condition = close < a and close < b and close < e and volume > volume_ma // Store the previous buy and sell conditions var bool prev_buy_condition = na var bool prev_sell_condition = na // Track if a buy or sell signal has occurred var bool signal_occurred = false // Generate buy and sell signals based on conditions buy_signal = buy_condition and not prev_buy_condition and not signal_occurred sell_signal = sell_condition and not prev_sell_condition and not signal_occurred // Determine bearish condition (close lower than the bottom 30% of the candle's range) bearish = close < low + (high - low) * 0.3 // Add sell signal when there are two consecutive red candles and no signal has occurred two_consecutive_red_candles = close[1] < open[1] and close < open sell_signal := sell_signal or (two_consecutive_red_candles and not signal_occurred) // Remember the current conditions for the next bar prev_buy_condition := buy_condition prev_sell_condition := sell_condition // Update signal occurred status signal_occurred := buy_signal or sell_signal // Plot buy and sell signals plotshape(buy_signal, title="Buy", style=shape.labelup, location=location.belowbar, color=color.green, text="Buy", textcolor=color.white) plotshape(sell_signal, title="Sell", style=shape.labeldown, location=location.abovebar, color=color.red, text="Sell", textcolor=color.white) // Strategy entry and exit if buy_signal strategy.entry("Buy", strategy.long) if sell_signal strategy.entry("Sell", strategy.short)