OPEN-SOURCE SCRIPT

Supply and Demand Visible Range [LuxAlgo]

The Supply and Demand Visible Range indicator displays areas & levels on the user's chart for the visible range using a novel volume-based method. The script also makes use of intra-bar data to create precise Supply & Demand zones.

🔶 SETTINGS

  • Threshold %: Percentage of the total visible range volume used as a threshold to set supply/demand areas. Higher values return wider areas.
  • Resolution: Determines the number of bins used to find each area. Higher values will return more precise results.
  • Intra-bar TF: Timeframe used to obtain intra-bar data.


🔶 USAGE

snapshot

The supply/demand areas and levels displayed by the script are aimed at providing potential supports/resistances for users. The script's behavior makes it recalculate each time the visible chart interval/range changes, as such this script is more suited as a descriptive tool.

Price reaching a supply (upper) area that might have been tested a few times might be indicative of a potential reversal down, while price reaching a demand (lower) area that might have been tested a few times could be indicative of a potential reversal up.

snapshot

The width of each area can also indicate which areas are more liquid, with thinner areas indicating more significant liquidity.

snapshot

The user can control the width of each area using the Threshold % setting, with a higher setting returning wider areas. The precision setting can also return wider supply/demand areas if very low values are used and has the benefit of improving the script execution time at the cost of precision.

snapshot

The Supply and Demand Zones indicator returns various levels. The solid-colored levels display the average of each area, while dashed colored lines display the weighted averages of each area. These weighted averages can highlight more liquid price levels within the supply/demand areas.

Central solid/dashed lines display the average between the areas' averages and weighted averages.

🔶 DETAILS

Each supply/demand area is constructed from volume data. The calculation is done as follows:

  • The accumulated volume within the chart visible range is calculated.
  • The chart visible range is divided into N bins of equal width (where N is the resolution setting)
  • Calculation start from the highest visible range price value for the supply area, and lowest value for the demand area.
  • The volume within each bin after the starting calculation level is accumulated, once this accumulated volume is equal or exceed the threshold value (p % of the total visible range volume) the area is set.


Each bin volume accumulation within an area is displayed on the left, this can help indicate how fast volume accumulates within an area.

🔶 LIMITATIONS

The script execution time is dependent on all of the script's settings, using more demanding settings might return errors so make sure to be aware of the potential scenarios that might make the script exceed the allowed execution time:

  • Having a chart's visible range including a high number of bars.
  • Using a high number of bins (high resolution value) will increase computation time, this can be worsened by using a high threshold %.
  • Using very low intra-bar timeframe can drastically increase computation time but can also simply throw an error if the chart timeframe is high.


Users facing issues can lower the resolution value or use the chart timeframe for intra-bar data.
supply_and_demandsupplydemandanalyticsSupply ZoneSupport and ResistancesupportandresistancezonesVolume

Open-source script

In true TradingView spirit, the author of this script has published it open-source, so traders can understand and verify it. Cheers to the author! You may use it for free, but reuse of this code in publication is governed by House rules. You can favorite it to use it on a chart.

Want to use this script on a chart?


Get access to our exclusive tools: luxalgo.com

Join our 150k+ community: discord.gg/lux

All content provided by LuxAlgo is for informational & educational purposes only. Past performance does not guarantee future results.
Also on:

Disclaimer