Extrapolated Previous Trend [LuxAlgo]The Extrapolated Previous Trend indicator extrapolates the estimated linear trend of the prices within a previous interval to the current interval. Intervals can be user-defined. 
🔶  USAGE 
  
Returned lines can be used to provide a forecast of trends, assuming trends are persistent in sign and slope.
  
Using them as support/resistance can also be an effecting usage in case the trend in a new interval does not follow the characteristic of the trend in the previous interval.
The indicator includes a dashboard showing the degree of persistence between segmented trends for uptrends and downtrends. A higher value is indicative of more persistent trend signs.
  
A lower value could hint at an anti-persistent behavior, with uptrends over an interval often being followed by a down-trend and vice versa. We can invert candle colors to determine future trend direction in this case.
🔶  DETAILS 
This indicator can be thought of as a segmented linear model ( a(n)t + b(n) ), where  n  is the specific interval index. Unlike a regular segmented linear regression model, this indicator is not subject to lookahead bias, coefficients of the model are obtained on previous intervals.
The quality of the fit of the model is dependent on the variability of its coefficients  a(n)  and  b(n) . Coefficients being less subject to change over time are more indicative of trend persistence.
🔶  SETTINGS 
 
 Timeframe: Determine the frequency at which new trends are estimated.
Luxalgo
Liquidity Voids (FVG) [LuxAlgo]The Liquidity Voids (FVG) indicator is designed to detect liquidity voids/imbalances derived from the fair value gaps and highlight the distribution of the liquidity voids at specific price levels. 
Fair value gaps and liquidity voids are both indicators of sell-side and buy-side imbalance in trading. The only difference is how they are represented in the trading chart. Liquidity voids occur when the price moves sharply in one direction forming long-range candles that have little trading activity, whilst a fair value is a gap in price.
 🔶 USAGE 
  
Liquidity can help you to determine where the price is likely to head next. In conjunction with higher timeframe market structure, and supply and demand, liquidity can give you insights into potential price movement. It's essential to practice using liquidity alongside trend analysis and supply and demand to read market conditions effectively.  
  
The peculiar thing about liquidity voids is that they almost always fill up. And by “filling”, we mean the price returns to the origin of the gap. The reason for this is that during the gap, an imbalance is created in the asset that has to be made up for. The erasure of this gap is what we call the filling of the void. And while some voids waste no time in filling, some others take multiple periods before they get filled. 
 🔶 SETTINGS 
The script takes into account user-defined parameters and detects the liquidity voids based on them, where detailed usage for each user-defined input parameter in indicator settings is provided with the related input's tooltip.
 🔹 Liquidity Detection 
 
 Liquidity Voids Threshold: Act as a filter while detecting the Liquidity Voids. When set to 0 basically means no filtering is applied, increasing the value causes the script to check the width of the void compared to a fixed-length ATR value 
 Bullish: Color customization option for Bullish Liquidity Voids
 Bearish: Color customization option for Bearish Liquidity Voids
 Labels: Toggles the visibility of the Liquidity Void label 
 Filled Liquidity Voids: Toggles the visibility of the Filled Liquidity Voids 
 
 🔹 Display Options 
 
 Mode: Controls the lookback length of detection and visualization 
 # Bars: Lookback length customization, in case Mode is set to Present
 
 🔶 RELATED SCRIPTS 
 Buyside-Sellside-Liquidity 
 Fair-Value-Gaps
ICT Silver Bullet [LuxAlgo]The ICT Silver Bullet indicator is inspired from the lectures of "The Inner Circle Trader" (ICT) and highlights the Silver Bullet (SB) window which is a specific 1-hour interval where a Fair Value Gap (FVG) pattern can be formed.
When a FVG is formed during the Silver Bullet window, Support & Resistance lines will be drawn at the end of the SB session.
  
  
There are 3 different Silver Bullet windows (New York local time):
 
 The London Open Silver Bullet (3 AM — 4 AM ~ 03:00 — 04:00)
 The AM Session Silver Bullet (10 AM — 11 AM ~ 10:00 — 11:00)
 The PM Session Silver Bullet (2 PM — 3 PM ~ 14:00 — 15:00) 
 
🔶  USAGE 
The ICT Silver Bullet indicator aims to provide users a comprehensive display as similar as possible to how anyone would manually draw the concept on their charts.
It's important to use anything below the 15-minute timeframe to ensure proper setups can display. In this section, we are purely using the 3-minute timeframe.
In the image below, we can see a bullish setup whereas a FVG was successfully retested during the Silver Bullet session. This was then followed by a move upwards to liquidity as our target.
  
Alternatively, you can also see below a bearish setup utilizing the ICT Silver Bullet indicator outlined.
  
At this moment, the indicator has removed all other FVGs within the Silver Bullet session & has confirmed this FVG as the retested one.
There is also a support level marked below to be used as a liquidity target as per the ICT Silver Bullet concept suggests.
  
In the below chart we can see 4 separate consecutive examples of bullish & bearish setups on the 3-minute chart.
  
🔶  CONCEPTS 
This technique can visualize potential support/resistance lines, which can be used as targets.
The script contains 2 main components:
• forming of a Fair Value Gap (FVG)
• drawing support/resistance (S/R) lines 
🔹 Forming of FVG
1 basic principle: when a FVG at the end of the SB session is not retraced, it will be made invisible.
  
  
Dependable on the settings, different FVG's will be shown.
• 'All FVG': all FVG's are shown, regardless the trend
  
• 'Only FVG's in the same direction of trend': Only FVG's are shown that are similar to the trend at that moment (trend can be visualized by enabling ' Show ' -> ' Trend ') 
     -> only bearish FVG when the trend is bearish vs. bullish FVG when trend is bullish
  
• 'strict': Besides being similar to the trend, only FVG's are shown when the closing price at the end of the SB session is:
     – below the top of the FVG box (bearish FVG)
     – above bottom of the FVG box (bullish FVG)
  
• 'super-strict': Besides being similar to the trend, only FVG's are shown when the FVG box is NOT broken 
     in the opposite direction AND the closing price at the end of the SB session is:
     – below bottom of the FVG box (bearish FVG)
     – above the top of the FVG box (bullish FVG)
  
 ' Super-Strict ' mode resembles ICT lectures the most. 
🔹 Drawing support/resistance lines
 When  the SB session has ended, the script draws potential support/resistance lines, again, dependable on the settings.
• Previous session (any): S/R lines are fetched between current and previous session.
     For example, when current session is ' AM SB Session (10 AM — 11 AM) ', then previous session is 
     ' London Open SB (3 AM — 4 AM) ', S/R lines between these 2 sessions alone will be included.
  
• Previous session (similar): S/R lines are fetched between current and previous - similar - session. 
     For example, when current session is ' London Open SB (3 AM — 4 AM)' , only S/R lines between 
     current session and previous ' London Open SB (3 AM — 4 AM) ' session are included.
  
When a new session starts, S/R lines will be removed, except when enabling ' Keep lines (only in  strict mode) '
This is not possible in ' All FVG ' or ' Only FVG's in the same direction of trend ' mode, since the chart would be cluttered.
Note that in ' All FVG ' or ' Only FVG's in the same direction of trend ' mode, both, Support/Resistance lines will be shown, 
while in Strict/Super-Strict mode:
     • only Support lines will be shown if a bearish FVG appears
     • only Resistance lines if a bullish FVG is shown
  
The lines will still be drawn the the end of the SB session, when a valid FVG appears, 
but the S/R lines will remain visible and keep being updated until price reaches that line.
  
  
This publication contains a "Minimum Trade Framework (mTFW)", which represents the best-case expected price delivery, this is not your actual trade entry - exit range.
 • 40 ticks for index futures or indices
 • 15 pips for Forex pairs. 
  
When on ' Strict/Super-Strict ' mode, only S/R lines will be shown which are:
   • higher than the lowest FVG bottom + mTFW, in a bullish scenario
   • lower than the highest FVG bottom - mTFW, in a bearish scenario
When on ' All FVG/Only FVG's in the same direction of trend ' mode, or on non-Forex/Futures/Indices symbols, S/R needs to be higher/lower than SB session high/low.
🔶  SETTINGS 
(Check CONCEPTS for deeper insights and explanation)
🔹 Swing settings (left): Sets the length, which will set the lookback period/sensitivity of the Zigzag patterns (which directs the trend)
🔹 Silver Bullet Session; Show SB session: show lines and labels of SB session
     Labels can be disabled separately in the ' Style ' section, color is set at the ' Inputs ' section.
🔹 FVG
     – Mode
      • All FVG
      • Only FVG's in the same direction of trend
      • Strict
      • Super-Strict
     – Colors
     – Extend: extend till last bar of SB session
🔹 Targets – support/resistance lines
     – Previous session (any): S/R lines fetched between current and previous SB session
     – Previous session (similar): S/R lines fetched between current and previous similar SB session
     – Colors
     – Keep lines (only in  strict mode)
🔹 Show
     – MSS ~ Session: Show  Market Structure Shift , only when this happens during a SB session
     – Trend: Show trend (Zigzag, colored ~ trend)
  
  
 
Predictive Ranges [LuxAlgo]The Predictive Ranges indicator aims to efficiently predict future trading ranges in real-time, providing multiple effective support & resistance levels as well as indications of the current trend direction.
Predictive Ranges was a premium feature originally released by LuxAlgo in 2020.
The feature was discontinued & made legacy, however, due to its popularity and reproduction attempts, we deemed it necessary to release it open source to the community.
🔶  USAGE 
  
The primary purpose of this indicator is to provide potential support & resistance levels on the chart by estimating future trading ranges.
  
When the price reaches one of the upper/lower levels of the Predictive Ranges we can expect the price to reverse.
  
If the price exits the predicted range, new levels are given in real-time & they do not repaint. Higher "Factor" values allow returning longer term and wider ranges less susceptible to be exited.
🔹 Estimating Trend Directions 
  
Users are able to easily estimate trend directions by looking at the central levels of the predictive ranges, which represent an estimate of the price central tendency.
If this central level increases it means the price is up-trending, if it is decreasing price is down-trending.
🔶  SETTINGS 
 
 Length: ATR Length used for the indicator calculation. Higher values will tend to return ranges of equal width.
 Factor: Control the ranges width. Higher values will return less frequent ranges, each having a higher width.
 Timeframe: Indicator timeframe output.
 Source: Input source of the indicator. It is recommended to use input sources on the same scale as the price.
Liquidity Sentiment Profile [LuxAlgo]The  Liquidity Sentiment Profile  is an advanced charting tool that measures by combining  PRICE  and  VOLUME  data over specified anchored periods and highlights within a sequence of profiles the distribution of the liquidity and the market sentiment at specific price levels.
The Liquidity Sentiment Profile allows traders to reveal significant price levels, dominant market sentiment, support and resistance levels, supply and demand zones, liquidity availability levels, liquidity gaps, consolidation zones, and more based on price and volume data.
Liquidity refers to the availability of orders at specific price levels in the market, allowing transactions to occur smoothly.
 🔶 USAGE 
  
A Liquidity Sentiment Profile is a combination of a liquidity and a sentiment profile, where the right part of the profile displays the distribution of the traded activity at different price levels and the left part displays the market sentiment at those price levels.
The Liquidity Sentiment Profiles are visualized with different colors, where each color has a different meaning.
  
The Liquidity Sentiment Profiles aim to present Value Areas based on the significance of price levels, thus allowing users to identify value areas that can be formed more than once within the range of a single profile.
  
Level of Significance Line - displays the changes in the price levels with the highest traded activity (developing POC)
  
 🔶 SETTINGS 
The script takes into account user-defined parameters and plots the profiles, where detailed usage for each user-defined input parameter in indicator settings is provided with the related input's tooltip.
 🔹 Liquidity Sentiment Profiles 
 
 Anchor Period: The indicator resolution is set by the input of the Anchor Period, the default option is AUTO. 
 
 🔹 Liquidity Profile Settings 
 
 Liquidity Profile: Toggles the visibility of the Liquidity Profiles 
 High Traded Nodes: Threshold and Color option for High Traded Nodes
 Average Traded Nodes: Color option for Average Traded Nodes
 Low Traded Nodes: Threshold and Color option for Low Traded Nodes
 
 🔹 Sentiment Profile Settings 
 
 Sentiment Profile: Toggles the visibility of the Sentiment Profiles
 Bullish Nodes: Color option for Bullish Nodes
 Bearish Nodes: Color option for Bearish Nodes
 
 🔹 Other Settings 
 
 Level of Significance: Toggles the visibility of the Level of Significance Line
 Profile Price Levels: Toggles the visibility of the Profile Price Levels
 Number of Rows: Specify how many rows each profile histogram will have. Caution, having it set to high values will quickly hit Pine Script™ drawing objects limit and fewer historical profiles will be displayed  
 Profile Width %: Alters the width of the rows in the histogram, relative to the profile length
 Profile Range Background Fill: Toggles the visibility of the Profiles Range
 
 🔶 LIMITATIONS 
The amount of drawing objects that can be used is limited, as such using a high number of rows can display fewer historical profiles and occasionally incomplete profiles.
 🔶 RELATED SCRIPTS 
🔹  Buyside-Sellside-Liquidity 
🔹  ICT-Concepts 
🔹  Swing-Volume-Profiles
Supply and Demand Daily [LuxAlgo]The Supply and Demand Daily indicator displays daily supply and demand areas on the user's chart. These areas are constructed using the market data within a previous daily interval.
This script makes use of the same logic as our previous  Supply and Demand Visible Range indicator .
🔶  USAGE 
  
The supply/demand areas & levels displayed by the indicator aim to provide potential support/resistance levels for users. Supply areas highlight where buyers are willing to exit the market and sell the asset, thus providing resistance and potentially causing prices to reverse or bounce back downwards, while demand areas highlights where buyers were willing to purchase the asset, thus providing support and potentially causing prices to reverse or bounce back upwards.
  
Historical areas allow the user to study the evolution of supply/demand from one day to another. Wider areas highlight prices avoiding reverting to this area, while thinner areas highlight prices returning more frequently to them.
  
Trends can be determined by looking at the price position relative to the previous day's supply/demand areas. Price breaking down from the demand zone is indicative of a downtrend, while price breaking above the supply zone is indicative of an uptrend.
  
Pullback/throwback scenarios can also be common using this indicator.
🔶  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.
 
🔶  RELATED SCRIPTS 
Market Structure CHoCH/BOS (Fractal) [LuxAlgo]The Market Structure CHoCH/BOS (Fractal) indicator is an experimental take on classical market structure, whereas fractal patterns are used for their construction instead of swing points.
Compared to utilizing swing points for highlighting market structure like our  Smart Money Concepts indicator , fractal-based market structure can appear as more adaptive, however, it can also be more restrictive when it comes to returning swing points which can cause the indicator to miss reversals in some cases.
If enabled from within the settings, users can see support and resistance levels returned from the detected market structure with breakouts highlighted on the chart. Alongside this feature, an additional dashboard showing the structure to fractal structure percentage is also provided.
🔶  SETTINGS 
 
 Length: Length of the fractal patterns to detect.
 
🔹 Style 
 
 Bullish Structures: Show bullish structures.
 Bearish Structures: Show bullish structures.
 Support: Show support levels.
 Resistance: Show resistance levels.
 
🔹 Dashboard 
 
 Show Dashboard: Show structure to fractal percentage dashboard on the chart.
 Location: Location of the dashboard on the chart.
 Size: Dashboard size.
 
🔶  USAGE 
  
Market structure is commonly used to determine trend direction by using price positions relative to prior swing points. Using fractal patterns to determine market structure can allow users to obtain shorter, more frequent structure labels.
Market structure is commonly classified as follows:
 
 Change of Character (CHoCH), also referred to as Market Structure Shift (MSS)
 Break of Structure (BOS), also referred to as Market Structure Break (MSB)
 
  
Change of Characters indicate a shift in the market trend, confirming trend reversals. Break of Structures on the other hand occur once a trend is already determined, confirming new higher highs/lower lows.
  
Using higher length values allow users to detect longer-term fractals, thus highlighting longer-term market structures. The image above detects fractal patterns made of 7 candles, even if the increment is only of 2 bars this significantly reduces the amount of detected market structure labels.
The result obtained by utilizing fractals and higher settings can be a more dynamic view of market structure, however, as seen in the image above this can introduce very significant delay compared to utilizing pure swing points.
🔹 Support/Resistance 
  
The indicator also returns support/resistance levels constructed from the market structure, these levels are obtained similarly to order blocks, finding the minimum on the interval of a bullish market structure and the maximum of a bearish market structure.
Price reaching a support/resistance level can be expected to bounce from it. Once a level is broken, the support/resistance level will no longer extend, and a circle will be displayed highlighting the break. 
While utilizing this script for fractal-based market structure, these levels can be useful to ensure all swing points are still considered by the user with the possibility of the indicator missing reversals due to its calculation not being based on swing points themselves.
🔹 Dashboard 
The dashboard reports the structure to fractal percentage, that is the amount of bullish/bearish market structures relative to the total amount of detected bullish/bearish fractal patterns.
This allows us to see how often a detected fractal pattern is used to display a market structure. 
🔶  DETAILS 
🔹 Fractals 
  
In the context of technical analysis, Fractals refer to specific patterns that exhibit self-similarity at different scales or timeframes.
The most commonly known fractal pattern consists of a consecutive sequence of candles (more commonly 5), with the central candle being the lowest (in case of a bullish fractal) or highest (in case of a bearish fractal). 
A bullish fractal has candles on the right side of the central candle with increasing lows, while candles on the left side have decreasing lows.
A bearish fractal has candles on the right side of the central candle with decreasing highs, while candles on the left side have increasing highs.
🔶  RELATED SCRIPTS 
🔹 Smart Money Concepts 
🔹 Market Structure Trailing Stop 
🔹 ICT Concepts
Reversal Signals [LuxAlgo]The Reversal Signals indicator is a technical analysis tool that aims to identify when a trend is fading and potentially starting to reverse. 
As a counter-trend tool, the Reversal Signals indicator aims to solve the problem of several technical analysis indicators that perform well during trending markets but struggle in ranging markets. By understanding the key concepts and applications of the tool, traders can enhance their market timing and improve their trading strategies.
Note: It's important to explore the settings of the indicator to customize to your own usage & display as there are various options available as covered below.
 🔶 USAGE 
  
The Reversal Signals indicator is comprised of two main phases:  Momentum Phase  and  Trend Exhaustion Phase . These phases help identify potential trend reversals in bullish, bearish, and ranging markets.
 🔹The Momentum Phase 
The momentum phase consists of a 9-candle count and in rare cases 8-candle count. In a bullish trend, a starting number ‘1’ is plotted if a candle closes higher than the close of a candle four periods ago. In a bearish trend, a starting number ‘1’ is plotted if a candle closes lower than the close of a candle four periods ago. 
The following numbers are plotted when each successive candle satisfies the four-period rule. The potential reversal point comes when the Reversal Signals plot a label on top of a candle in a bullish trend or at the bottom of a candle in a bearish trend. The momentum phase is immediately canceled if, at any point, a candle fails to satisfy the four-period rule.
Based on the extremes of the momentum phase, the Reversal Signals generate support & resistance levels as well as risk/stop levels.
  
 🔹 The Trend Exhaustion Phase 
The trend exhaustion phase starts after completing the momentum phase and consists of a 13-candle count. In a bullish trend exhaustion phase, each candle’s close is compared to the close of two candles earlier, and the close must be greater than the close two periods earlier. In a bearish trend exhaustion phase, each candle’s close is compared to the close of two candles earlier, and the close must be lower than the close two periods earlier. 
The trend exhaustion phase does not require a consecutive sequence of candles; if the order of candles is interrupted, the trend exhaustion phase is not canceled. The trend exhaustion phase generates stronger trading signals than the momentum phase, with the potential for longer-lasting price reversals.
  
 🔹 Trading Signals 
The Reversal Signals script presents an overall setup and some phase-specific trade setup options, where probable trades might be considered. All phase-specific trade setups, presented as options, are triggered once the selected phase is completed and followed by a price flip in the direction of the trade setup. 
 Please note that those setups are presented for educational purposes only and do not constitutes professional and/or financial advice 
- Momentum: Enter a trade at momentum phase completion, and search for buy (sell) when the bullish (bearish) momentum phase pattern is complete. Ideally, the momentum phase completion should close near its support/resistance line but shall not be above them, which indicates continuation of the trend
- Exhaustion: Enter a trade on trend exhaustion phase completion, and search for buy (sell) when the bullish (bearish) trend exhaustion phase is complete
- Qualified: Buy (sell) when a bullish (bearish) trend exhaustion phase combined with another bullish (bearish) momentum phase sequence is complete
Long trade setups are presented with "L" label and short trade setups with "S" label, where the content of the label displays details related to the probable trade opportunity
Once a phase-specific trade setup is triggered then the Reversal Signals script keeps checking the status of the price action relative to the phase-specific trade setups and in case something goes wrong presents a caution label. Pay attention to the content of the caution labels as well as where they appear. A trade signal, followed immediately by a warning indication can be assumed as a continuation of the underlying trend and can be traded in the opposite direction of the suggested signal
  
It is strongly advised to confirm trading setups in conjunction with other forms of technical and fundamental analysis, including technical indicators, chart/candlestick pattern analysis, etc.
 🔶 DETAILS 
The Reversal Signals script performs the detection of the phases by counting the candlestick meeting the specific conditions, which includes:
 - Detection of the 8th and 9th candle perfection during the momentum phase
 - In some cases, the 8th count will be assumed as momentum phase completion 
 - Trend exhaustion phase counting stops in case any type of momentum phase completion is detected during the counting process
 - Postponing the last count of the trend exhaustion phase, the 13th candle must be below/above the 8th candle and if not the candles will be indicated with '+' sign under them and the script continues to search for a 13th candle at the next ones until the conditions are met
 🔶 ALERTS 
When an alert is configured, the user will have the ability to be notified in case;
 
  Momentum / Trend Exhaustion phase completion
  Support & Resistance level cross detection
  Stop / Risk level cross detection
  Long / Short Trade Setups are triggered
 
Please note, alerts are available with 'any alert() function call' and the alerts will be received only for the features that are enabled during alert configuration
 🔶 SETTINGS 
 🔹 Momentum Phase 
 
 Display Phases: displays the momentum phases, where the Completed option allows the display of only completed momentum phases. The detailed option allows the display of the entire process of the momentum phase processes
 Support & Resistance Levels: Toggles the visibility of the Support & Resistance Levels and Line Styling options
 Momentum Phase Risk Levels: Toggles the visibility of the momentum phase Stop/Risk Levels and Line Styling options
 
For color options please refer to the options available under the style tab
 🔹 Trend Exhaustion Phase 
 
 Display Phases: displays the trend exhaustion phases, where the Completed option allows the display of only completed trend exhaustion phases. The detailed option allows the display of the entire process of the trend exhaustion phase processes
 Trend Exhaustion Phase Risk Levels: Toggles the visibility of the trend exhaustion phase Stop/Risk Levels
 Trend Exhaustion Phase Target Levels: Toggles the visibility of the trend exhaustion phase Target Levels
 
For color options please refer to the options available under the style tab
 🔹 Trade Setups 
 
 Overall Trend Direction & Trade Setup: displays the overall trend and probable trade setup levels, the users should search for a price flip and confirm with other means of technical and fundamental analysis for the trade setups once the label is plotted
  Phase-Specific Trade Setup Options
 Momentum: Searches for a trade setup after momentum phase completion 
 Exhaustion: Searches for a trade setup after trend exhaustion phase completion, stronger trend reversal possibility compared to momentum phase setup  
 Qualified: Searches for a trade setup after the trend exhaustion phase followed by a momentum phase completion
 None: No trade setups are presented 
 Price Flips against the Phase Specific Trade Setups: enables checking the price action relative to the phase-specific trade setups
 
 🔶 RELATED SCRIPTS 
Here are the scripts that may add additional insight during potential trading decisions.
 
   Buyside-Sellside-Liquidity 
   Support-Resistance-Classification 
Open Interest Chart [LuxAlgo]The  Open Interest Chart  displays  Commitments of Traders   %change  of  futures open interest , with a unique circular plotting technique, inspired from this publication  Periodic Ellipses .
🔶  USAGE 
  
Open interest represents the total number of contracts that have been entered by market participants but have not yet been offset or delivered. This can be a direct indicator of market activity/liquidity, with higher open interest indicating a more active market.
Increasing open interest is highlighted in green on the circular plot, indicating money coming into the market, while decreasing open interests highlighted in red indicates money coming out of the market.
You can set up to 6 different Futures Open interest tickers for a quick follow up:
🔶  DETAILS 
Circles are drawn, using  plot() , with the functions  createOuterCircle()  (for the largest circle) and  createInnerCircle()  (for inner circles).
Following snippet will reload the chart, so the circles will remain at the right side of the chart:
 
if ta.change(chart.left_visible_bar_time ) or
   ta.change(chart.right_visible_bar_time) 
    n := bar_index
 
Here is a snippet which will draw a 39-bars wide circle that will keep updating its position to the right.
 
//@version=5
indicator("")
n = bar_index
barsTillEnd = last_bar_index - n
if ta.change(chart.left_visible_bar_time ) or
   ta.change(chart.right_visible_bar_time) 
    n := bar_index
    
createOuterCircle(radius) => 
    var int end   = na
    var int start = na
    var basis     = 0.
    barsFromNearestEdgeCircle   = 0.
    barsTillEndFromCircleStart  = radius
    startCylce                  = barsTillEnd % barsTillEndFromCircleStart == 0            // start circle    
    bars                        = ta.barssince(startCylce)                                                              
    barsFromNearestEdgeCircle  := barsTillEndFromCircleStart -1 
    basis   := math.min(startCylce ? -1 : basis + 1 / barsFromNearestEdgeCircle * 2, 1)    // 0 -> 1                    
    shape    = math.sqrt(1 - basis * basis) 
    rad      =      radius     /  2
    isOK     = barsTillEnd <= barsTillEndFromCircleStart and  barsTillEnd >  0
    hi       = isOK ? (rad + shape * radius) - rad : na
    lo       = isOK ? (rad - shape * radius) - rad : na
    start   := barsTillEnd     == barsTillEndFromCircleStart ? n -1 : start
    end     := barsTillEnd     == 0  ? start + radius : end 
     
  = createOuterCircle(40)
plot(h), plot(l)
 
🔶  LIMITATIONS 
 
 Due to the inability to draw between bars, from time to time, drawings can be slightly off. 
 Bar-replay can be demanding, since it has to reload on every bar progression. We don't recommend using this script on bar-replay. If you do, please choose the lowest speed and from time to time pause bar-replay for a second. You'll see the script gets reloaded.
 
🔶  SETTINGS 
🔹  TICKERS 
 
 Toggle : 
    • Enabled  -> uses the first column with a pre-filled list of  Futures Open Interest  tickers/symbols
    • Disabled -> uses the empty field where you can enter your own ticker/symbol
 Pre-filled list : the first column is filled with a list, so you can choose your open interest easily, otherwise you would see  COT:088691_F_OI  aka  Gold Futures Open Interest  for example.
     If applicable, you will see 3 different COT data:
    • COT: Legacy Commitments of Traders report data
    • COT2: Disaggregated Commitments of Traders report data
    • COT3: Traders in Financial Futures report data
 Empty field : When needed, you can pick another ticker/symbol in the empty field at the right and disable the toggle.
 Timeframe : Commitments of Traders (COT) data is tallied by the Commodity Futures Trading Commission (CFTC) and is published weekly. Therefore data won't change every day.
     Default set TF is Daily
 
🔹  STYLE 
 
 From middle: 
    • Enabled (default): Drawings start from the middle circle -> towards outer circle is  + %change , towards middle of the circle is  - %change 
    • Disabled: Drawings start from the middle POINT of the circle, towards outer circle is  + OR - 
    -> in both options,  + %change  will be coloured  green ,  - %change  will be coloured  red .
    ->  0 %change  will be coloured  blue , and when  no data  is available, this will be coloured  gray .
 Size circle : options tiny, small, normal, large, huge.
 Angle : Only applicable if "From middle" is disabled!
    -> sets the angle of the spike:
  
 Show Ticker : Name of ticker, as seen in table, will be added to labels.
 Text - fill 
    • Sets colour for  +/- %change 
 Table 
    • Sets 2 text colours, size and position
 Circles 
    • Sets the colour of circles, style can be changed in the  Style  section.
       You can make it as crazy as you want:
  
Support Resistance Classification [LuxAlgo]The Support Resistance Classification indicator shows SR levels from a user-defined range using higher time-frame data (HTF). Levels are classified 1 through 10 based on their strength, with lower values indicating  stronger  support/resistance levels.
This indicator doesn't use visible range functionality, in contrast to our  Support Resistance Classification (VR)   indicator, it uses a set lookback period to find support/resistance levels.
Since both techniques cannot be used together in 1 script, we developed a separate, NON-VR version.
 🔶 USAGE 
  
Certain indicators on higher timeframes can provide longer-term support/resistance levels on lower timeframes. Users can use the provided levels and use them as references for future support/resistance levels.
  
The classification algorithm measures the strength of a support/resistance level using the set range and is in a range of 1 to 10, with higher values indicating a  weaker  support/resistance.
  
Supports/resistances highlighted by the indicator can be used for future applications by marking them on the chart (quickly done with alt + h).
 🔶 DETAILS 
All calculations are based on what is seen in the last   amount of bars, which is the period between the blue vertical line and the last candle:
  
  
  
Since only Swings which are not broken are included, every break would exclude that swing. Therefore, even when 'value' is chosen at Settings ('Value'), breaks are always calculated on the entire line.
🔶  SETTINGS 
Lookback: Amount of bars from  current bar  to  x bars back , this is the period where support/resistance levels are calculated.
Fade: After  x breaks  the line becomes invisible
Value:
 
 value: 
    • SMA, upper/lower: the breaks are triggered on the moving average itself
    • Fibonacci Pivot Point levels, Previous High, Previous Low: only last HTF values can be used for breaks
    • Swings (see SWING SETTINGS)
 line:
    • SMA, upper/lower: the breaks are triggered on the entire line, based on its latest value
    • Fibonacci Pivot Point Levels, Previous High, Previous Low: breaks are triggered on the entire line, based on its latest value 
    • Swings (see SWING SETTINGS)
 
🔹  Swing Settings  
Swings are always calculated at the current timeframe, setting an HTF is not applicable to Swings.
 
 Left/Right: for Swing calculation ( pivothigh ,  pivotlow )
 Show: enables you to see the pivot points
 
 🔹 Set 
 
 N°: The concerning number
 TYPE:
    • SMA (Simple Moving Average)
    • Previous High/Low 
    • Upper/Lower ( Bollinger Bands )
    •  Pivot Point levels : "Fibonacci" 
 LENGTH: sets the 'Number of bars', needed for calculations (applicable for SMA, upper/lower)
 MULT: sets the 'Standard deviation factor' (only applicable for upper/lower - BB)
 HTF: sets 'Higher Time Frame' (applicable for SMA, upper/lower, Previous High/Low, Fibonacci)
 
 🔹 Show Values 
You can make up to 5 values visible (if you want to check/verify), except for Swings (see SWING SETTINGS)
To do so, enable (A -> E), and choose the N° you want to see.
This also is a useful tool if you're not sure which value you want to set.
Swing Volume Profiles [LuxAlgo]The Swing Volume Profiles indicator aims to calculate and highlight trading activity at specific price levels between two swing points; allowing traders to reveal dominant and/or significant price levels based on volume.
By measuring traded volume at all price levels in the market over a specified time period, the script can also be used to detect some key analysis generally such as supply & demand, buy-side & sell-side liquidity levels, unfilled liquidity voids, and imbalances that can highlight on the chart.
 🔶 USAGE 
  
A volume profile is an advanced charting tool that displays the traded volume at different price levels over a specific period. It helps you visualize where the majority of trading activity has occurred.
Key Levels are the areas where the volume is concentrated or where there are significant volume spikes. These levels are known as key support and resistance levels. High-volume nodes indicate areas of high activity and are likely to act as support or resistance in the future.
Volume profile also helps identify value areas, which represent the price levels where the most trading activity has taken place. These levels can act as areas of support or resistance as traders perceive them as fair value.
  
The Point of Control describes the price level where the most volume was traded. A Naked Point of Control (also called a Virgin Point of Control) is a previous POC that has not been traded. Extending PoC options 'Until Bar Cross' or 'Until Bar Touch' helps in identifying Naked Point of Control Lines.
  
Previous PoC levels can serve as support and resistance for future price movements. Extending PoC Level 'Until Last Bar' option will help to identify such levels.
  
 🔶 DETAILS 
One of the unique features of the script is its ability to detect some other key levels such as levels of acceptance and rejection.
 
  Levels of rejection we may summarize as supply and demand levels, these are also referred to as buy-side and sell-side liquidity levels. They usually occur at extreme highs or lows, where prices may be too high for buyers (high supply, low demand) or too low for sellers (low supply, high demand)
  Levels of acceptance are the levels where Liquidity Voids occur, these are also referred to imbalances. Liquidity voids are sudden changes in price when the price jumps from one level to another. The peculiar thing about liquidity voids is that they almost always fill up, so we call them levels of acceptance.
 
  
 🔶 ALERTS 
When an alert is configured, the user will have the ability to be notified in case:
 
  Point Of Control Line is touched/crossed
  Value Area High Line is touched/crossed
  Value Area Low Line is touched/crossed
 
 🔶 SETTINGS 
 🔹 Display Options 
 
 Mode: Controls the lookback length of detection and visualization, where  Present  assumes last X bars specifid in '# Bars' option and  Historical  assumes all data available to the user as well as allowed limits of visiual objects (boxs, lines, labels etc)
 # Bars: Controls the lookback length.
 
 🔹 Swing Volume Profiles 
The script takes into account user-defined parameters and plots volume profiles. Due to Pine Script™ drwaing objects limit only total volume profiles are presented.
 
 Swing Detection Length: Lookback period 
 Swing Volume Profiles: Toggles the visibility of the Volume Profiles, with color options to differentiate the Value Area within a profile.
 Profile Range Background Fill: Toggles the visibility of the Volume Profiles Range
 
 🔹 Point of Control (PoC) 
Point of Control (POC) – The price level for the time period with the highest traded volume
 
 Point of Control (PoC): Toggles the visibility of the Point of Control
 Developing PoC: Toggles the visibility of the Developing PoC 
 Extend PoC: Option that allows detecting virgin PoC levels. Virgin Point of Control (VPoC) is defined as a Point of Control that has never been revisited or touched. The option also allows PoC levels to extend till the last bar aiming to present levels from history where the levels were traded significantly and those levels can be used as support and resistance levels. 
 
 🔹 Value Area (VA) 
Value Area (VA) – The range of price levels in which the specified percentage of all volume was traded during the time period.
 
 Value Area Volume %: Specifies percentage of the Value Area
 Value Area High (VAH): Toggles the visibility of the Value Area High, the highest price level within the Value Area
 Value Area Low (VAL): Toggles the visibility of the Value Area Low, the lowest price level within the Value Area
 Value Area (VA) Background Fill: Toggles the visibility of the Value Area Range
 
 🔹 Liquidity Levels / Voids 
 
 Unfilled Liquidity, Thresh: Enable display of the Unfilled Liquidity Levels and Liquidity Voids, where threshold value defines the significance of the level.
 
 🔹 Profile Stats 
 
 Position, Size: Specifies the position and the size of the label presenting Profile Stats, the tooltip of the label includes all related info for each profile.
 Price, Price Change, and Cumulative Volume: Enable display of the given options on the chart.
 
 🔹 Volume Profile Others 
 
 Number of Rows: Specify how many rows each histogram will have. Caution, having it set to high values will quickly hit Pine Script™ drawing objects limit and may cause fewer historical profiles to be displayed.  
 Placement: Place profile either left or right.
 Profile Width %: Alters the width of the rows in the histogram, relative to the calculated profile length.
 
 🔶 RELATED SCRIPTS 
 
  Alternative Liquidity Void Detection script,  Buyside-Sellside-Liquidity 
Support Resistance Classification (VR) [LuxAlgo]The Support Resistance Classification (VR) indicator shows SR levels on any chart's visible range using higher time-frame data (HTF). Levels are classified 1 through 10 based on their strength, with lower values indicating stronger support/resistance levels.
This indicator uses visible range functionality, whereas if you adjust your chart to show previous price data, the indicator may show new levels.
 🔶 USAGE 
  
Certain indicators on higher timeframes can provide longer term support/resistance levels on lower timeframes. Users can use the provided levels on a chart visible range and use them as reference for future support/resistance levels.
  
The classification algorithm measures the strength of a support/resistance level using the entire chart visible range and is in a range of 1 to 10, with higher values indicating a weaker support/resistance.
  
Supports/resistances highlighted by the indicator can be used for future applications by marking them on the chart (quickly done with alt + h).
 🔶 DETAILS 
  
All calculations are based on what you see on the Visible Chart, as such changing the chart will recalculate the indicator.
  
Since only Swings which are not broken are included, every break would exclude that swing. Therefore, even when 'value' is chosen at Settings ('Value'), breaks are always calculated on the entire line.
🔶  SETTINGS 
Fade: After x breaks the line becomes invisible
Value:
 
 value: 
    • SMA, upper/lower: the breaks are triggered on the moving average itself
    • Fibonacci Pivot Point levels, Previous High, Previous Low: only last HTF values can be used for breaks
    • Swings (see SWING SETTINGS)
 line:
    • SMA, upper/lower: the breaks are triggered on the entire line, based on its latest value
    • Fibonacci Pivot Point Levels, Previous High, Previous Low: breaks are triggered on the entire line, based on its latest value 
    • Swings (see SWING SETTINGS)
 
🔹  Swing Settings  
Swings are always calculated at current timeframe, setting a HTF is not applicable on Swings.
 
 Left/Right: for Swing calculation ( pivothigh ,  pivotlow )
 Show: enables you to see the pivot points
 
 🔹 Set 
 
 N°: The concerning number
 TYPE:
    • SMA (Simple Moving Average)
    • Previous High/Low 
    • Upper/Lower ( Bollinger Bands )
    •  Pivot Point levels : "Fibonacci" 
 LENGTH: sets the 'Number of bars', needed for calculations (applicable for SMA, upper/lower)
 MULT: sets the 'Standard deviation factor' (only applicable for upper/lower - BB)
 HTF: sets 'Higher Time Frame' (applicable for SMA, upper/lower, Previous High/Low, Fibonacci)
 
 🔹 Show Values 
You can make up to 5 values visible (if you want to check/verify), except for Swings (see SWING SETTINGS)
To do so, enable (A -> E), and choose the N° you want to see.
This also is a useful tool if you're not sure which value you want to set.
Buyside & Sellside Liquidity [LuxAlgo]The Buyside & Sellside Liquidity indicator aims to detect & highlight the first and arguably most important concept within the ICT trading methodology,  Liquidity  levels.
 🔶 SETTINGS 
 🔹 Liquidity Levels 
 
 Detection Length: Lookback period 
 Margin: Sets margin/sensitivity for a liquidity level detection
 
 🔹 Liquidity Zones 
 
 Buyside Liquidity Zones: Enables display of the buyside liquidity zones.
 Margin: Sets margin/sensitivity for the liquidity zone boundaries.
 Color: Color option for buyside liquidity levels & zones.
 Sellside Liquidity Zones:  Enables display of the sellside liquidity zones.
 Margin: Sets margin/sensitivity for the liquidity zone boundaries.
 Color: Color option for sellside liquidity levels & zones.
 
 🔹 Liquidity Voids 
 
 Liquidity Voids: Enables display of both bullish and bearish liquidity voids.
 Label: Enables display of a label indicating liquidity voids.
 
 🔹 Display Options 
 
 Mode: Controls the lookback length of detection and visualization, where  Present  assumes last 500 bars and  Historical  assumes all data available to the user
 # Visible Levels: Controls the amount of the liquidity levels/zones to be visualized. 
 
 🔶 USAGE 
  
Definitions of Liquidity refer to the availability of orders at specific price levels in the market, allowing transactions to occur smoothly. 
In the context of Inner Circle Trader's teachings, liquidity mainly relates to stop losses or pending orders and liquidity level/pool, highlighting a concentration of buy or sell orders at specific price levels. Smart money traders, such as banks and other large institutions, often target these liquidity levels/pools to accumulate or distribute their positions.  
There are two types of liquidity;  Buyside liquidity  and  Sellside liquidity .
Buyside liquidity represents a level on the chart where short sellers will have their stops positioned, and Sellside liquidity represents a level on the chart where long-biased traders will place their stops.
These areas often act as support or resistance levels and can provide trading opportunities.
  
When the liquidity levels are breached at which many stop/limit orders are placed have been traded through, the script will create a zone aiming to provide additional insight to figure out the odds of the next price action.
Reversal: It’s common that the price may reverse course and head in the opposite direction, seeking liquidity at the opposite extreme.
  
Continuation: When the zone is also broken it is a sign for continuation price action.
  
It's worth noting that ICT concepts are specific to the methodology developed by Michael J. Huddleston and may not align with other trading approaches or strategies.
 🔶 DETAILS 
 Liquidity voids  are sudden changes in price when the price jumps from one level to another. Liquidity voids will appear as a single or a group of candles that are all positioned in the same direction. These candles typically have large real bodies and very short wicks, suggesting very little disagreement between buyers and sellers. The peculiar thing about liquidity voids is that they almost always fill up.
  
 🔶 ALERTS 
When an alert is configured, the user will have the ability to be notified in case;
 
  Liquidity level is detected/updated.
  Liquidity level is breached.
 
 🔶 RELATED SCRIPTS 
 
   ICT-Concepts 
   ICT-Macros 
   Imbalance-Detector 
SMT Divergences [LuxAlgo]The SMT Divergences indicator highlights SMT divergences between the chart symbol and two user-selected tickers (ES and YM by default).
A dashboard returning the SMT divergences statistics is also provided within the settings.
🔶  SETTINGS 
 
 Swing Lookback: Calculation window used to detect swing points.
 Comparison Ticker: If enabled, will detect SMT divergences between the chart prices and the prices of the selected ticker.
 
🔹  Dashboard 
 
 Show Dashboard: Displays statistics dashboard on the chart.
 Location: Location of the dashboard on the chart.
 Size: Size of the displayed dashboard.
 
🔶  USAGE 
  
SMT Divergences are characterized by diverging swing points between two securities.
  
The detection of SMT Divergences is performed by detecting swing points using the user chart prices as well as the prices of the selected external tickers. If a swing point on the chart ticker is detected at the same time on external tickers, comparison is performed.
Due to the detection requiring swing point confirmation (3 candles by default), this indicator can better be used to study price behaviors on the occurrence of an SMT divergence.
  
The dashboard highlights the number of SMT divergences that occurred on a swing high and swing low between the chart ticker and the selected external tickers.
The returned percentage indicates the proportion of swing highs or swing lows that led to an SMT divergence.
Volume Profile Regression Channel [LuxAlgo]The Volume Profile Regression Channel calculates a volume profile from an anchored linear regression channel. Users can choose the starting and ending points for the indicator calculation interval.
Like a regular volume profile, a "line" of control (LOC), value area, and a developing LOC are displayed.
 🔶 SETTINGS 
 
 Sections: The number of sections the linear regression channel is divided into for the calculation of the volume profile.
 Width %: Determines the length of the profile within the channel relative to the channel length.
 Value Area %: Highlights the sections starting from the POC whose accumulated volume is equal to the user-defined percentage of the total profile sections volume.
 🔶 USAGES 
  
Regular volume profiles are often constructed from a horizontal price area, this can allow highlighting price areas where most trading activity takes place.
However, when price is strongly trending a classical volume profile can sometimes be more uniform. This is where using an angled volume profile can be useful.
  
The line of control allows highlighting the section of the channel with the most accumulated volume, this line can be used as a potential future support/resistance. This is where an angled volume profile might be the most useful.
The developing LOC highlights the LOC location at a specific time within the profile (from left to right) and can sometimes provide an estimate of the underlying trend in the price.
 🔶 DETAILS 
To be computed the script requires a left and right chart time coordinates. When adding the script to their charts users can determine the left and right time coordinates by clicking on the chart.
The linear regression channel width is determined so that the channel precisely encompasses the whole price.
 🔶 LIMITATIONS 
Using a very large calculation interval can return timeouts. Users can reduce the calculation interval to fix that issue from occurring.
The amount of drawing objects that can be used is limited, as such using a high calculation interval can display an incomplete profile.
 🔶 ACKNOWLEDGEMENTS 
If you are interested in these types of scripts, @HeWhoMustNotBeNamed published a similar script where users can use a custom line angle. See his 'Angled Volume Profile' script from March 2023.
ICT Macros [LuxAlgo]The ICT Macros indicator aims to highlight & classify ICT Macros, which are time intervals where algorithmic trading takes place to interact with existing liquidity or to create new liquidity.
 🔶 SETTINGS 
 🔹 Macros 
 
 Macro Time options  (such as '09:50 AM 10:10'): Enable specific macro display. 
 Top Line ,  Mid Line ,  Bottom Line  and  Extending Lines  options: Controls the lines for the specific macro.
 
 🔹 Macro Classification 
 
 Length :  A length to detect Market Structure Brakes and classify macro type based on detection. 
 Swing Area : Swing or Liquidity Area selection, highest/lowest of the wick or the candle bodies.
 Accumulation ,  Manipulation  and  Expansion  color options for the classified macros.
 
 🔹 Others 
 
 Macro Texts : Controls both the size and the visibility of the macro text.
 Alert Macro Times in Advance (Minutes) : This option will plot a vertical line presenting the start of the next macro time. The line will not appear all the time, but it will be there based on remaining minutes specified in the option.
 Daylight Saving Time (DST) : Adjust time appropriate to Daylight Saving Time of the specific region.
 
 🔶 USAGE 
  
A macro is a way to automate a task or procedure which you perform on a regular basis.
In the context of ICT's teachings, a macro is a small program or set of instructions that unfolds within an algorithm, which influences price movements in the market. These macros operate at specific times and can be related to price runs from one level to another or certain market behaviors during specific time intervals. They help traders anticipate market movements and potential setups during specific time intervals.
To trade these effectively, it is important to understand the time of day when certain macros come into play, and it is strongly advised to introduce the concept of liquidity in your analysis.
Macros can be classified into three categories where the Macro classification is calculated based on the Market Structure prior to macro and the Market Structure during the macro duration:
Manipulation Macro
  
Manipulation macros are characterized by liquidity being swept both on the buyside and sellside.
Expansion Macro
  
Expansion macros are characterized by liquidity being swept only on the buyside or sellside. Prices within these macros are highly correlated with the overall trend. 
Accumulation Macro
  
Accumulation macros are characterized by an accumulation of liquidity. Prices within these macros tend to range. 
The script returns the maximum/minimum price values reached during the macro interval alongside the average between the maximum/minimum and extends them until a new macro starts. These levels can act as supports and resistances.
  
 🔶 DETAILS 
All required data for the macro detection and classification is retrieved using 1 minute data sets, this includes candles as well as pivot/swing highs and lows. This approach guarantees the visually presented objects are same (same highs/lows) on higher timeframes as well as the macro classification remain same as it is in 1 min charts.
  
8 Macros can be displayed by the script (4 are enabled by default):
 
  02:33 AM 03:00 London Macro
  04:03 AM 04:30 London Macro
  08:50 AM 09:10 New York Macro
  09:50 AM 10:10 New York Macro
  10:50 AM 11:10 New York Macro
  11:50 AM 12:10 New York Launch Macro
  13:10 PM 13:40 New York Macro
  15:15 PM 15:45 New York Macro
 
 🔶 ALERTS 
When an alert is configured, the user will have the ability to be notified in advance of the next Macro time, where the value specified in 'Alert Macro Times in Advance (Minutes)' option indicates how early to be notified.
 🔶 LIMITATIONS 
The script is supported on 1 min, 3 mins and 5 mins charts.
 🔶 RELATED SCRIPTS 
EquiVolume [LuxAlgo]EquiVolume is a charting method that aims to incorporate volume information to a candlestick chart. Volume is highlighted through the candle body width, with wider candles suggesting more significant volume.
Our script shows an EquiVolume chart for the visible chart range. Additionally regular volume can be plotted as a column plot with the column's width controlled by volume.
 🔶 SETTINGS 
 🔹 Options 
 
 Chart: Shows  candles  with volume adjusted width.
 Volume: Shows  volume  with volume adjusted width.
 
 🔹 Intrabar Analysis 
 
 Enable/disable: When LTF is enabled, the script will calculate the % volume/candles in the same direction than current timeframe.
 You can choose a LTF between 1 and 240 minutes.
 Type %: 
     - Volume: sum of volume of all LTF candles, which are in the same direction.
     - #bars: sum of all LTF candles, which are in the same direction.
 
 🔹 Width Boxes (bars) 
 
 Minimum width: sets the minimum width of a box (candle/volume)
 Maximum width: sets the maximum width of a box (candle/volume)
 
 🔶 USAGE 
This charting method makes it easier to spot large volume candles, against comparing candles to volume.
  
Another example:
  
Additionally, users can make the script perform an intrabar analysis on the chart candles, allowing to highlight bullish/bearish activity within a candle. The script can estimate bullish/bearish trading activity within a candle or simply use intrabar candle signs.
 Example 
- 15-minute candle is green
- 10 1-minute candles (LTF) IN that 15-minute candle are green -> 10/15 = 66,667%
-> The current 15-minute candle will be 66,667% filled with green color.
  
Note that the script will draw everything from last visible bar at the right to left, as such you can scroll backwards, and the script will show you the data of the visible chart.
  
Scrolling back will return the following result:
  
 🔶 REMARKS 
When the LTF is too far apart from current timeframe, you should get an error. To prevent this, the LTF will automatically rise, giving no error.
  
When this happens, the adjusted LTF will be displayed. Do note, due to a maximum available LTF data, sometimes boxes won't always be visible (since there is no LTF data anymore)
To solve this, just elevate your LTF:
  
When the set LTF is higher than current TF, you would normally get an error as well.
This script will automatically adjust the LTF to current TF, together with a visible warning (no error though).
  
Due to the inability to draw a line in the space between bars, sometimes a wick won't be placed exactly in the middle.
 
FVG Sessions [LuxAlgo]The FVG Sessions indicator highlights the first fair value gap of the trading session as well as the session range. Detected fair value gaps extend to the end of the trading session.
Alerts are included on the formation of a session fair value gap, price being within a session fair value gap, mitigations, and price crossing session fair value gaps average.
 🔶 USAGE 
  
Trader ICT states that the first fair value gap of the trading session can attract the most significant reaction. Having only one FVG per session allows users to further focus on that precise imbalance as well as external elements.
  
The mitigation of a fair value gap is clearly indicated on the chart with a more transparent color allowing users to see inverse FVGs.
  
Extending the fair value gaps allows the imbalance area to provide potential support and resistance.
Do note that this script should be used on intraday charts.
 🔶 ALERTS 
The script includes the following alerts:
 🔹 Bullish/Bearish FVG 
Alerts on the formation of the first bullish or bearish FVG of the session.
 🔹 Bullish/Bearish FVG Mitigation 
Alerts when the first bullish or bearish FVG of the session is mitigated.
 🔹 Price Within FVG 
Alerts when price is within the first bullish or bearish FVG area of the session.
 🔹 Price Cross FVG Average 
Alerts when price cross the average level of the first bullish or bearish FVG of the session.
Volume Profile Matrix [LuxAlgo]The Volume Profile Matrix indicator extends from regular volume profiles by also considering calculation intervals within the calculation window rather than only dividing the calculation window in rows.
Note that this indicator is subject to repainting & back-painting, however, treating the indicator as a tool for identifying frequent points of interest can still be very useful.
 🔶 SETTINGS 
 
 Lookback: Number of most recent bars used to calculate the indicator.
 Columns: Number of columns (intervals) used to calculate the volume profile matrix.
 Rows: Number of rows (intervals) used to calculate the volume profile matrix.
 
 🔶 USAGE 
  
The Volume Profile Matrix indicator can be used to obtain more information regarding liquidity on specific time intervals. Instead of simply dividing the calculation window into equidistant rows, the calculation is done through a grid.
  
Grid cells with trading activity occurring inside them are colored. More activity is highlighted through a gradient and by default, cells with a color that are closer to red indicate that more trading activity took place within that cell. The cell with the highest amount of trading activity is always highlighted in yellow.
  
Each interval (column) includes a point of control which highlights an estimate of the price level with the highest traded volume on that interval. The level with the highest traded volume of the overall grid is extended to the most recent bar.
Breaker Blocks with Signals [LuxAlgo]The Breaker Blocks with Signals indicator aims to highlight a complete methodology based on breaker blocks. Breakout signals between the price and breaker blocks are highlighted and premium/discount swing levels are included to provide potential take profit/stop loss levels.
This script also includes alerts for each signal highlighted.
🔶  SETTINGS  
🔹  Breaker Blocks  
 
 Length: Sensitivity of the detected swings used to construct breaker blocks. Higher values will return longer term breaker blocks.
 Use only candle body: Only use the candle body when determining the maximum/minimum extremities of the order blocks.
 Use 2 candles instead of 1: Use two candles to confirm the occurrence of a breaker block.
 Stop at first break of center line: Do not highlight breakout signals after invalidation until reset.
 
🔹  PD Array  
 
 Only when E is in premium/discount zone: Only set breaker block if point E of wave ABCDE is within the corresponding zone.
 Show premium discount zone: Show premium/discount zone.
 Highlight Swing Break: Highlight occurrences of price breaking a previous swing level.
 Show Swings/PD Arrays: Show swing levels/labels and pd areas.
 
🔶  USAGE  
The Breaker Blocks with Signals indicator aims to provide users with a minimalistic display alongside optimal signals to be aware of for finding trade setups as shown below.
  
Here we can see a MSS occurred allowing the indicator to detect a Breaker Block (-BB) & display a red arrow to confirm this signal.
The signal(s) that can be used for potential entries are only during retests of the breaker blocks.
A potential strategy traders could use with this indicator is to target the corresponding Discount PD Arrays detected (for a short position) and Premium PD Arrays (for a long position).
  
In the image above we can see price generated the potential entry signals in orange & fell to the Discount PD Arrays as a logical setup to look for with this indicator.
  
As we can see in the image above, signals can be considered invalid when price closes above the 50% level in which it would be suggested to wait for another setup.
Users still looking for more potential setups based on the same breaker block can disable the "Stop at first break of center line" setting within the settings menu.
  
In the image above we can see a bullish example whereas price confirmed a bullish breaker block (+BB), had a quick pullback into it that was confirmed by the green arrow, and then reached the Premium PD Arrays.
  
While retests of breaker blocks can still function well if they occur later in the price action, it's most preferable for users to look for entry signals that are near confirmed breaker blocks (5-10 bars) opposed to waiting 20+ bars.
  
Additional take profits based on the occurence of the breaker blocks are given in order to provide targets after the occurence of a breaker block breakout.
🔶  DETAILS  
  
Breaker blocks are formed after a mitigated order block, these can provide change of polarity opportunities, thus playing a role as a potential support/resistance. It is the re-test/retrace of price to a breaker block that will set the conditions to provide signals.
  
The above chart describes the creation of a breaker block.
  
The signal generation logic makes use of various rules described below:
Bullish Breaker Blocks:
 
 opening price is within the breaker block, while the closing price is above the upper extremity of the breaker block.
 Price did not cross the breaker block average in the interval since the previous breakout.
 
Bearish Breaker Blocks:
 
 opening price is within the breaker block, while the closing price is below the lower extremity of the breaker block.
 Price did not cross the breaker block average in the interval since the previous breakout.
 
  
When a new pattern is formed, all previous drawings are removed.
🔶  RELATED SCRIPTS  
  
  
 
Range Sentiment Profile [LuxAlgo]The Range Sentiment Profile indicator is inspired from the volume profile and aims to indicate the degree of bullish/bearish variations within equidistant price areas inside the most recent price range.
The most bullish/bearish price areas are highlighted through lines extending over the entire range.
 🔶 SETTINGS 
 
 Length: Most recent bars used for the calculation of the indicator.
 Rows: Number of price areas the price range is divided into.
 Use Intrabar: Use intrabar data to compute the range sentiment profile.
 Timeframe: Intrabar data timeframe.
 
 🔶 USAGE 
  
This tool can be used to easily determine if a certain price area contain more significant bullish or bearish price variations. This is done by obtaining an estimate of the accumulation of all the close to open variations occurring within a specific profile area.
A blue range background indicates a majority of bullish variations within each area while an orange background indicates a majority of bearish variations within each area.
  
Users can easily identify the areas with the most bullish/bearish price variations by looking at the bullish/bearish maximums.
  
It can be of interest to see where profile bins might have no length, these can indicate price areas with price variations with alternating signs (bullish variations are followed by a bearish sign) and similar body. They can also indicate a majority of either bullish or bearish variations alongside a minority of more significant opposite variations.
These areas can also provide support/resistance, as such price entering these areas could reverse.
  
Users can obtain more precise results by allowing the profile to use intrabar data. This will change the calculation of the profile, see the  details  section for more information.
 🔶 DETAILS 
The Range Sentiment Profile's design is similar to the way a volume profile is constructed.
First the maximum/minimum values over the most recent  Length  bars are obtained, these define the calculation range of the profile.
The range is divided into  Rows  equidistant areas. We then see if price lied within a specific area, if it's the case we accumulate the difference between the closing and opening price for that specific area.
Let  d = close - open . The length of the bin associated to a specific area is determined as follows:
 length = Width / 100 * Area / Max 
Where  Area  is the accumulated  d  within the area, and  Max  the maximum value between the absolute value of each accumulated  d  of all areas.
The percentage visible on each bin is determined as 100 multiplied by the accumulated  d  within the area divided by the total absolute value of  d  over the entire range.
 🔹 Intrabar Calculation 
When using intrabar data the range sentiment profile is calculated differently. 
For a specific area and candle within the interval, the accumulated close to open difference is accumulated only if the intrabar candle of the user selected timeframe lies within the area.
This can return more precise results compared to the standard method, at the cost of a higher computation time.
Volume Forecasting [LuxAlgo]The Volume Forecasting indicator provides a forecast of volume by capturing and extrapolating periodic fluctuations. Historical forecasts are also provided to compare the method against volume at time  t .
This script will not work on tickers that do not have volume data.
 🔶 SETTINGS 
 
 Median Memory: Number of days used to compute the median and first/third quartiles.
 Forecast Window: Number of bars forecasted in the future.
 Auto Forecast Window: Set the forecast window so that the forecast length completes an interval.
 
 🔶 USAGE 
  
The periodic nature of volume on certain securities allows users to more easily forecast using historical volume. The forecast can highlight intervals where volume tends to be more important, that is where most trading activity takes place.
  
More pronounced periodicity will tend to return more accurate forecasts.
  
The historical forecast can also highlight intervals where high/low volume is not expected.
The interquartile range is also highlighted, giving an area where we can expect the volume to lie.
 🔶 DETAILS 
This forecasting method is similar to the time series decomposition method used to obtain the seasonal component.
  
We first segment the chart over equidistant intervals. Each interval is delimited by a change in the daily timeframe.
  
To forecast volume at time  t+1  we see where the current bar lies in the interval, if the bar is the 78th in interval then the forecast on the next bar is made by taking the median of the 79th bar over  N  intervals, where  N  is the median memory.
This method ensures capturing the periodic fluctuation of volume.
Market Structure Trailing Stop [LuxAlgo]This script returns trailing stops on the occurrence of market structure (CHoCH/BOS labeling). Trailing stops are adjusted based on trailing maximums/minimums with the option for users to be able to control how quickly a trailing stop can converge toward the price.
 🔶 SETTINGS 
 
 Pivot Lookback: Pivot length used for the detection of swing points.
 Increment Factor %: Controls how fast trailing stops converge toward the price, with lower values returning slower converging trailing stops.
 Reset Stop On: Determines if trailing stops are reset on CHoCH structure or all (CHoCH + BOS).
 Show Structure: Determines if market structure is displayed.
 
 🔶 USAGE 
  
Trailing stops allow traders to protect them against downside risk while also guaranteeing a potential profit in case the market goes in the expected direction of the trade.
  
Users making use of market structure as a primary entry condition can benefit from having trailing stops based on these to either provide an additional exit condition or to provide points of support/resistance with the price.
  
Trailing stops can avoid being hit more frequently by using a lower  Increment Factor %  setting.
  
Finally, users can reset the trailing stop when any market structure is detected (or only on CHoCHs). Allowing trailing stops to reset on the detection of any market structure allows the indicator to return trailing stops closer to the price. CHoCH labels are highlighted as dashed lines while BOS labels are highlighted as dotted lines.
 🔶 DETAILS 
  
When a new structure (or only CHoCH if specified by the user) is detected, trailing stops will initially be set based on the maximum/minimum made on the previous trend. This will also set the trailing maximum/minimum to the current price value.
If an uptrend is detected (most recent market structure is bullish) then the trailing stop will increase if the trailing maximum increase, the increment is calculated as:
 trailing stop = trailing stop + Increment Factor % of (trailing maximum - previous trailing maximum) 
If a downtrend is detected (most recent market structure is bearish) then the trailing stop will decrease if the trailing minimum decrease, the decrement is calculated as:
 trailing stop = trailing stop + Increment Factor % of (trailing minimum - previous trailing minimum)






















