Volume Surprise [LuxAlgo]The Volume Surprise tool displays the trading volume alongside the expected volume at that time, allowing users to spot unexpected trading activity on the chart easily.
The tool includes an extrapolation of the estimated volume for future periods, allowing forecasting future trading activity.
🔶  USAGE 
  
We define Volume Surprise as a situation where the actual trading volume deviates significantly from its expected value at a given time.
Being able to determine if trading activity is higher or lower than expected allows us to precisely gauge the interest of market participants in specific trends.
A histogram constructed from the difference between the volume and expected volume is provided to easily highlight the difference between the two and may be used as a standalone.
  
The tool can also help quantify the impact of specific market events, such as news about an instrument. For example, an important announcement leading to volume below expectations might be a sign of market participants underestimating the impact of the announcement.
  
Like in the example above, it is possible to observe cases where the volume significantly differs from the expected one, which might be interpreted as an anomaly leading to a correction.
🔹 Detecting Rare Trading Activity 
Expected volume is defined as the mean (or median if we want to limit the impact of outliers) of the volume grouped at a specific point in time. This value depends on grouping volume based on periods, which can be user-defined.
However, it is possible to adjust the indicator to overestimate/underestimate expected volume, allowing for highlighting excessively high or low volume at specific times.
In order to do this, select "Percentiles" as the summary method, and change the percentiles value to a value that is close to 100 (overestimate expected volume) or to 0 (underestimate expected volume).
  
In the example above, we are only interested in detecting volume that is excessively high, we use the 95th percentile to do so, effectively highlighting when volume is higher than 95% of the volumes recorded at that time.
🔶  DETAILS 
🔹 Choosing the Right Periods 
Our expected volume value depends on grouping volume based on periods, which can be user-defined.
For example, if only the hourly period is selected, volumes are grouped by their respective hours. As such, to get the expected volume for the hour 7 PM, we collect and group the historical volumes that occurred at 7 PM and average them to get our expected value at that time.
Users are not limited to selecting a single period, and can group volume using a combination of all the available periods. 
Do note that when on lower timeframes, only having higher periods will lead to less precise expected values. Enabling periods that are too low might prevent grouping. Finally, enabling a lot of periods will, on the other hand, lead to a lot of groups, preventing the ability to get effective expected values.
In order to avoid changing periods by navigating across multiple timeframes, an "Auto Selection" setting is provided.
🔹 Group Length 
  
The  length  setting allows controlling the maximum size of a volume group. Using higher lengths will provide an expected value on more historical data, further highlighting recurring patterns.
🔹 Recommended Assets 
Obtaining the expected volume for a specific period (time of the day, day of the week, quarter, etc) is most effective when on assets showing higher signs of periodicity in their trading activity.
This is visible on stocks, futures, and forex pairs, which tend to have a defined, recognizable interval with usually higher trading activity.
  
Assets such as cryptocurrencies will usually not have a clearly defined periodic trading activity, which lowers the validity of forecasts produced by the tool, as well as any conclusions originating from the volume to expected volume comparisons.
🔶  SETTINGS 
 
 Length: Maximum number of records in a volume group for a specific period. Older values are discarded.
 Smooth: Period of a SMA used to smooth volume. The smoothing affects the expected value.
 
🔹 Periods 
 
 Auto Selection: Automatically choose a practical combination of periods based on the chart timeframe.
  Custom periods can be used if disabling "Auto Selection". Available periods include:
- Minutes
- Hours
- Days (can be: Day of Week, Day of Month, Day of Year)
- Months
- Quarters
 
🔹 Summary 
 
 Method: Method used to obtain the expected value. Options include Mean (default) or Percentile.
 Percentile: Percentile number used if "Method" is set to "Percentile". A value of 50 will effectively use a median for the expected value. 
 
🔹 Forecast 
 
 Forecast Window: Number of bars ahead for which the expected volume is predicted.
 Style: Style settings of the forecast.
Luxalgo
ICT Anchored Market Structures with Validation [LuxAlgo]The  ICT Anchored Market Structures with Validation  indicator is an advanced iteration of the original  Pure-Price-Action-Structures  tool, designed for price action traders. 
It systematically tracks and validates key price action structures, distinguishing between true structural shifts/breaks and short-term sweeps to enhance trend and reversal analysis. The indicator automatically highlights structural points, confirms breakouts, identifies sweeps, and provides clear visual cues for short-term, intermediate-term, and long-term market structures.
A distinctive feature of this indicator is its exclusive reliance on price patterns. It does not depend on any user-defined input, ensuring that its analysis remains robust, objective, and uninfluenced by user bias, making it an effective tool for understanding market dynamics.
🔶  USAGE 
  
Market structure is a cornerstone of price action analysis. This script automatically detects real-time market structures across short-term, intermediate-term, and long-term levels, simplifying trend analysis for traders. It assists in identifying both trend reversals and continuations with greater clarity.
  
Market structure shifts and breaks help traders identify changes in trend direction. A shift signals a potential reversal, often occurring when a swing high or low is breached, suggesting a transition in trend. A break, on the other hand, confirms the continuation of an established trend, reinforcing the current direction. Recognizing these shifts and breaks allows traders to anticipate price movement with greater accuracy.
  
It’s important to note that while a CHoCH may signal a potential trend reversal and a BoS suggests a continuation of the prevailing trend, neither guarantees a complete reversal or continuation. In some cases, CHoCH and BoS levels may act as liquidity zones or areas of consolidation rather than indicating a clear shift or continuation in market direction. The indicator’s validation component helps confirm whether the detected CHoCH and BoS are true breakouts or merely liquidity sweeps.
  
🔶  DETAILS 
🔹  Market Structures 
Market structures are derived from price action analysis, focusing on identifying key levels and patterns in the market. Swing point detection, a fundamental concept in ICT trading methodologies and teachings, plays a central role in this approach.
  
Swing points are automatically identified based exclusively on market movements, without requiring any user-defined input.
🔹  Utilizing Swing Points 
Swing points are not identified in real-time as they form. Short-term swing points may appear with a delay of up to one bar, while the identification of intermediate and long-term swing points is entirely dependent on subsequent market movements. Importantly, this detection process is not influenced by any user-defined input, relying solely on pure price action. As a result, swing points are generally not intended for real-time trading scenarios.
Instead, traders often analyze historical swing points to understand market trends and identify potential entry and exit opportunities. By examining swing highs and lows, traders can:
 
 Recognize Trends:  Swing highs and lows provide insight into trend direction. Higher swing highs and higher swing lows signify an uptrend, while lower swing highs and lower swing lows indicate a downtrend.
 Identify Support and Resistance Levels:  Swing highs often act as resistance levels, referred to as Buyside Liquidity Levels in ICT terminology, while swing lows function as support levels, also known as Sellside Liquidity Levels. Traders can leverage these levels to plan their trade entries and exits.
 Spot Reversal Patterns:  Swing points can form key reversal patterns, such as double tops or bottoms, head and shoulders, and triangles. Recognizing these patterns can indicate potential trend reversals, enabling traders to adjust their strategies effectively.
 Set Stop Loss and Take Profit Levels:  In ICT teachings, swing levels represent price points with expected clusters of buy or sell orders. Traders can target these liquidity levels/pools for position accumulation or distribution, using swing points to define stop loss and take profit levels in their trades.
 
Overall, swing points provide valuable information about market dynamics and can assist traders in making more informed trading decisions.
🔹  Logic of Validation 
The validation process in this script determines whether a detected market structure shift or break represents a confirmed breakout or a sweep.
The breakout is confirmed when the close price is significantly outside the deviation range of the last detected structural price. This deviation range is defined by the 17-period Average True Range (ATR), which creates a buffer around the detected market structure shift or break.
A sweep occurs when the price breaches the structural level within the deviation range but does not confirm a breakout. In this case, the label is updated to 'SWEEP.'
A visual box is created to represent the price range where the breakout or sweep occurs. If the validation process continues, the box is updated. This box visually highlights the price range involved in a sweep, helping traders identify liquidity events on the chart.
  
 🔶 SETTINGS 
The settings for Short-Term, Intermediate-Term, and Long-Term Structures are organized into groups, allowing users to customize swing points, market structures, and visual styles for each.
🔹  Structures 
 
 Swings and Size:  Enables or disables the display of swing highs and lows, assigns icons to represent the structures, and adjusts the size of the icons.
 Market Structures:  Toggles the visibility of market structure lines.
 Market Structure Validation:  Enable or disable validation to distinguish true breakouts from liquidity sweeps.
 Market Structure Labels:  Displays or hides labels indicating the type of market structure.
 Line Style and Width:  Allows customization of the style and width of the lines representing market structures.
 Swing and Line Colors:  Provides options to adjust the colors of swing icons, market structure lines, and labels for better visualization.
 
🔶  RELATED SCRIPTS 
 
 Pure-Price-Action-Structures. 
 Market-Structures-(Intrabar). 
Session Gap Fill [LuxAlgo]The  Session Gap Fill  tool detects and highlights filled and unfilled price gaps between regular sessions. It features a dashboard with key statistics about the detected gaps.
The tool is highly customizable, allowing users to filter by different types of gaps and customize how they are displayed on the chart.
🔶  USAGE 
  
By default, the tool detects all price gaps between sessions. A price gap is defined as a difference between the opening price of one session and the closing price of the previous session. In this case, the tool uses the opening price of the first bar of the session against the closing price of the previous bar.
A bullish gap is detected when the session open price is higher than the last close, and a bearish gap is detected when the session open price is lower than the last close.
  
Gaps represent a change in market sentiment, a difference in what market participants think between the close of one trading session and the open of the next.
What is useful to traders is not the gap itself, but how the market reacts to it.
 
 Unfilled gaps occur when prices do not return to the previous session's closing price.
 Filled gaps occur when prices come back to the previous session's close price.
 
By analyzing how markets react to gaps, traders can understand market sentiment, whether different prices are accepted or rejected, and take advantage of this information to position themselves in favor of bullish or bearish market sentiment.
Next, we will cover the Gap Type Filter and Statistics Dashboard.
🔹  Gap Type Filter 
  
Traders can choose from three options: display all gaps, display only overlapping gaps, or display only non-overlapping gaps. All gaps are displayed by default.
An overlapping gap is defined when the first bar of the session has any price in common with the previous bar. No overlapping gap is defined when the two bars do not share any price levels.
As we will see in the next section, there are clear differences in market behavior around these types of gaps.
🔹  Statistics Dashboard 
  
The Statistics Dashboard displays key metrics that help traders understand market behavior around each type of gap.
 
 Gaps: The percentage of bullish and bearish gaps.
 Filled: The percentage of filled bullish and bearish gaps.
 Reversed: The percentage of filled gaps that move in favor of the gap
 Bars Avg.: The average number of bars for a gap to be filled.
 
Now, let's analyze the chart on the left of the image to understand those stats. These are the stats for all gaps, both overlapping and non-overlapping.
Of the total, bullish gaps represent 55%, and bearish ones represent 44%. The gap bias is pretty balanced in this market.
The second statistic, Filled, shows that 63% of gaps are filled, both bullish and bearish. Therefore, there is a higher probability that a gap will be filled than not.
The third statistic is reversed. This is the percentage of filled gaps where prices move in favor of the gap. This applies to filled bullish gaps when the close of the session is above the open, and to filled bearish gaps when the close of the session is below the open. In other words, first there is a gap, then it fills, and finally it reverses. As we can see in the chart, this only happens 35% of the time for bullish gaps and 29% of the time for bearish gaps.
The last statistic is Bars Avg., which is the average number of bars for a gap to be filled. On average, it takes between one and two bars for both bullish and bearish gaps. On average, gaps fill quickly.
As we can see on the chart, selecting different types of gaps yields different statistics and market behavior. For example, overlapping gaps have a greater than 90% chance of being filled, whereas non-overlapping gaps have a less than 40% chance.
🔶  SETTINGS 
 
 Gap Type: Select the type of gap to display.
 
🔹  Dashboard 
 
  Dashboard: Enable or disable the dashboard.
  Position: Select the location of the dashboard.
  Size: Select the dashboard size.
 
🔹  Style 
 
 Filled Bullish Gap: Enable or disable this gap and choose the color.
 Filled Bearish Gap: Enable or disable this gap and choose the color.
 Unfilled Gap: Enable or disable this gap and choose the color.
 Max Deviation Level: Enable or disable this level and choose the color.
 Open Price Level: Enable or disable this level and choose the color.
Power Hour Breakout Signals [LuxAlgo]The  Power Hour Breakout  tool helps traders identify key price levels from the Power Hour and spot breakouts from those levels easily. This tool features Power Hour extensions, Fibonacci levels, and session break marks for the trader's convenience.
🔶  USAGE 
  
The Power Hour is defined as the last hour of the trading session and is set by default from 3:00 p.m. to 4:00 p.m. New York time. During this period, volume and volatility enter the market. Traders using higher timeframes may use this period to enter or exit positions by placing MOC (Market on Close) orders.
This tool highlights the Power Hour and the top and bottom price levels. Each time prices break out from these levels, a signal is displayed on the chart.
We can use the Power Hour to gauge market sentiment:
 
 Bullish sentiment: Price trades above the Power Hour.
 Mixed sentiment: Price trades within the Power Hour.
 Bearish sentiment: Price trades below the Power Hour.
 
🔹  Displaying Power Hours and Breakouts 
  
By default, all detected Power Hours are displayed. Traders can manually adjust this number by disabling the "Display All" parameter in the Settings panel.
Breakouts are displayed by default, too, but this feature can be disabled as well.
The chart above shows different configurations of these parameters.
🔹  Power Hour Extensions 
  
Traders can use Power Hour extensions as potential targets for breakout signals.
In the settings panel, traders can select the percentage of the Power Hour price range to use for each extension. For example, 100% uses the full range, 200% uses the range twice, and so on.
As seen on the chart, traders can configure different percentages for the top and bottom extensions.
🔹  Fibonacci Levels 
  
Traders can display default or custom Fibonacci levels on the Power Hour range to identify retracement opportunities and evaluate market movement strength. Each level can be enabled or disabled, as well as customized by level, color, and line style.
For example, as we can see on the chart, prices attempt to break out at the Power Hour top level, then retrace to the 0.618 Fibonacci level, and then rise to the 200% Power Hour top extension.
🔶  SETTINGS 
 
 Display Last X Power Hours: Select how many Power Hours to display or enable the Display All feature.
 Power Hour (NY Time): Choose a custom Power Hour in New York time.
 
🔹  Breakouts 
 
 Breakouts: Enable or disable breakouts.
 Bullish Breakout: Select color for bullish breakouts.
 Bearish Breakout: Select color for bearish breakouts.
 
🔹  Extensions 
 
 Top Extension: Enable or disable the top extension and choose the percentage of Power Hour to use.
 Bottom extension: Enable or disable the bottom extension and choose the percentage of Power Hour to use.
 
🔹  Fibonacci Levels 
 
 Display Fibonacci: Enable or disable Fibonacci levels.
 Reverse: Reverse Fibonacci levels.
 Levels, Colors & Style
 Display Labels: Enable or disable labels and choose text size.
 
🔹  Style 
 
 Power Hour Colors
 Extension Transparency: Choose the extension's transparency. 0 is solid, and 100 is fully transparent.
 Session Breaks: Enable or disable session breaks.
Initial Balance Breakout Signals [LuxAlgo]The  Initial Balance Breakout Signals  help traders identify breakouts of the Initial Balance (IB) range. 
The indicator includes automatic detection of IB or can use custom sessions, highlights top and bottom IB extensions, custom Fibonacci levels, and goes further with an IB forecast with two different modes.
🔶  USAGE 
  
The initial balance is the price range made within the first hour of the trading session. It is an intraday concept based on the idea that high volume and volatility enter the market through institutional trading at the start of the session, setting the tone for the rest of the day.
The initial balance is useful for gauging market sentiment, or, in other words, the relationship between buyers and sellers.
 
 Bullish sentiment: Price trades above the IB range.
 Mixed sentiment: Price trades within the IB range.
 Bearish sentiment: Price trades below the IB range.
 
The initial balance high and low are important levels that many traders use to gauge sentiment. There are two main ideas behind trading around the IB range.
 
 IB Extreme Breakout: When the price breaks and holds the IB high or low, there is a high probability that the price will continue in that direction.
 IB Extreme Rejection: When the price tries to break those levels but fails, there is a high probability that it will reach the opposite IB extreme.
 
This indicator is a complete Initial Balance toolset with custom sessions, breakout signals, IB extensions, Fibonacci retracements, and an IB forecast. All of these features will be explained in the following sections.
🔹  Custom Sessions and Signals 
  
By default, sessions for Initial Balance and breakout signals are in Auto mode. This means that Initial Balance takes the first hour of the trading session and shows breakout signals for the rest of the session.
With this option, traders can use the tool for open range trading, making it highly versatile. The concept behind open range (OR) is the same as that of initial balance (IB), but in OR, the range is determined by the first minute, three or five minutes, or up to the first 30 minutes of the trading session.
As shown in the image above, the top chart uses the Auto feature for the IB and Breakouts sessions. The bottom chart has the Auto feature disabled to use custom sessions for both parameters. In this case, the first three minutes of the trading session are used, turning the tool into an Open Range trading indicator.
  
This chart shows another example of using custom sessions to display overnight NASDAQ futures sessions.
The left chart shows a custom session from the Tokyo open to the London open, and the right chart shows a custom session from the London open to the New York open.
The chart shows both the Asian and European sessions, their top and bottom extremes, and the breakout signals from those extremes.
🔹  Initial Balance Extensions 
  
Traders can easily extend both extremes of the Initial Balance to display their preferred targets for breakouts. Enable or disable any of them and set the IB percentage to use for the extension.
As the chart shows, the percentage selected on the settings panel directly affects the displayed levels.
Setting 25 means the tool will use a quarter of the detected initial balance range for extensions beyond the IB extremes. Setting 100 means the full IB range will be used.
Traders can use these extensions as targets for breakout signals.
🔹  Fibonacci Levels 
  
Traders can display default or custom Fibonacci levels on the IB range to trade retracements and assess the strength of market movements. Each level can be enabled or disabled and customized by level, color, and line style.
As we can see on the chart, after the IB was completed, prices were unable to fall below the 0.236 Fibonacci level. This indicates significant bullish pressure, so it is expected that prices will rise.
Traders can use these levels as guidelines to assess the strength of the side trying to penetrate the IB. In this case, the sellers were unable to move the market beyond the first level.
🔹  Initial Balance Forecast 
  
The tool features two different forecasting methods for the current IB. By default, it takes the average of the last ten values and applies a multiplier of one.
 
 IB Against Previous Open: averages the difference between IB extremes and the open of the previous session.
 Filter by current day of the week: averages the difference between IB extremes and the open of the current session for the same day of the week.
 
This feature allows traders to see the difference between the current IB and the average of the last IBs. It makes it very easy to interpret: if the current IB is higher than the average, buyers are in control; if it is lower than the average, sellers are in control.
For example, on the left side of the chart, we can see that the last day was very bullish because the IB was completely above the forecasted value. This is the IB mean of the last ten trading days.
On the right, we can see that on Monday, September 15, the IB traded slightly higher but within the forecasted value of the IB mean of the last ten Mondays. In this case, it is within expectations.
🔶  SETTINGS 
 
 Display Last X IBs: Select how many IBs to display.
 Initial Balance: Choose a custom session or enable the Auto feature.
 Breakouts: Enable or disable breakouts. Choose custom session or enable the Auto feature.
 
🔹  Extensions 
 
 Top Extension: Enable or disable the top extension and choose the percentage of IB to use.
 Bottom extension: Enable or disable the bottom extension and choose the percentage of IB to use.
 
🔹  Fibonacci Levels 
 
 Display Fibonacci: Enable or disable Fibonacci levels.
 Reverse: Reverse Fibonacci levels.
 Levels, Colors & Style
 Display Labels: Enable or disable labels and choose text size.
 
🔹  Forecast 
 
 Display Forecast: Select the forecast method.
- IB Against Previous Open: Calculates the average difference between the IB high and low and the previous day's IB open price.
- Filter by Current Day of Week: Calculates the average difference between the IB high and low and the IB open price for the same day of the week.
 Forecast Memory: The number of data points used to calculate the average.
 Forecast Multiplier: This multiplier will be applied to the average. Bigger numbers will result in wider predicted ranges.
 Forecast Colors: Choose from a variety of colors.
 Forecast Style: Choose a line style.
 
🔹  Style 
 
 Initial Balance Colors
 Extension Transparency: Choose the extension's transparency. 0 is solid, and 100 is fully transparent.
Volume Bubbles & Liquidity Heatmap [LuxAlgo]The  Volume Bubbles & Liquidity Heatmap  indicator highlights volume and liquidity clearly and precisely with its volume bubbles and liquidity heat map, allowing to identify key price areas.
Customize the bubbles with different time frames and different display modes: total volume, buy and sell volume, or delta volume.
🔶  USAGE 
  
The primary objective of this tool is to offer traders a straightforward method for analyzing volume on any selected timeframe.
By default, the tool displays buy and sell volume bubbles for the daily timeframe over the last 2,000 bars. Traders should be aware of the difference between the timeframe of the chart and that of the bubbles.
The tool also displays a liquidity heat map to help traders identify price areas where liquidity accumulates or is lacking.
🔹  Volume Bubbles 
The bubbles have three possible display modes:
 
 Total Volume: Displays the total volume of trades per bubble.
 Buy & Sell Volume: Each bubble is divided into buy and sell volume.
 Delta Volume: Displays the difference between buy and sell volume.
 
Each bubble represents the trading volume for a given period. By default, the timeframe for each bubble is set to daily, meaning each bubble represents the trading volume for each day.
The size of each bubble is proportional to the volume traded; a larger bubble indicates greater volume, while a smaller bubble indicates lower volume.
The color of each bubble indicates the dominant volume: green for buy volume and red for sell volume.
  
One of the tool's main goals is to facilitate simple, clear, multi-timeframe volume analysis.
The previous chart shows Delta Volume bubbles with various chart and bubble timeframe configurations.
  
To correctly visualize the bubbles, traders must ensure there is a sufficient number of bars per bubble. This is achieved by using a lower chart timeframe and a higher bubble timeframe.
As can be seen in the image above, the greater the difference between the chart and bubble timeframes, the better the visualization.
🔹  Liquidity Heatmap 
  
The other main element of the tool is the liquidity heatmap. By default, it divides the chart into 25 different price areas and displays the accumulated trading volume on each.
The image above shows a 4-hour BTC chart displaying only the liquidity heatmap. Traders should be aware of these key price areas and observe how the price behaves in them, looking for possible opportunities to engage with the market.
  
The main parameters for controlling the heatmap on the settings panel are Rows and Cell Minimum Size. Rows modifies the number of horizontal price areas displayed, while Cell Minimum Size modifies the minimum size of each liquidity cell in each row.
As can be seen in the above BTC hourly chart, the cell size is 24 at the top and 168 at the bottom. The cells are smaller on top and bigger on the bottom.
The color of each cell reflects the liquidity size with a gradient; this reflects the total volume traded within each cell. The default colors are:
 
 Red: larger liquidity
 Yellow: medium liquidity
 Blue: lower liquidity
 
🔹  Using Both Tools Together 
This indicator provides the means to identify directional bias and market timing.
The main idea is that if buyers are strong, prices are likely to increase, and if sellers are strong, prices are likely to decrease. This gives us a directional bias for opening long or short positions. Then, we combine our directional bias with price rejection or acceptance of key liquidity levels to determine the timing of opening or closing our positions.
Now, let's review some charts.
  
This first chart is BTC 1H with Delta Weekly Bubbles. Delta Bubbles measure the difference between buy and sell volume, so we can easily see which group is dominant (buyers or sellers) and how strong they are in any given week. This, along with the key price areas displayed by the Liquidity Heatmap, can help us navigate the markets.
We divided market behavior into seven groups, and each group has several bubbles, numbered from 1 to 17.
 
 Bubbles 1, 2, and 3: After strong buyers market consolidates with positive delta, prices move up next week.
 Bubbles 3, 4, and 5: Strength changes from buyers to sellers. Next week, prices go down.
 Bubbles 6 and 7: The market trades at higher prices, but with negative delta. Next week, prices go down.
 Bubbles 7, 8, and 9: Strength changes from sellers to buyers. Next weeks (9 and 10), prices go up.
 Bubbles 10, 11, and 12: After strong buyers prices trade higher with a negative delta. Next weeks (12 and 13) prices go down.
 Bubbles 12, 14, and 15: Strength changes from sellers to buyers; next week, prices increase.
 Bubbles 15 and 16: The market trades higher with a very small positive delta; next week, prices go down.
 
Current bubble/week 17 is not yet finished. Right now, it is trading lower, but with a smaller negative delta than last week. This may signal that sellers are losing strength and that a potential reversal will follow, with prices trading higher.
  
This is the same BTC 1H chart, but with price rejections from key liquidity areas acting as strong price barriers.
When prices reach a key area with strong liquidity and are rejected, it signals a good time to take action.
By observing price behavior at certain key price levels, we can improve our timing for entering or exiting the markets.
🔶  DETAILS 
🔹  Bubbles Display 
  
From the settings panel, traders can configure the bubbles with four main parameters: Mode, Timeframe, Size%, and Shape.
The image above shows five-minute BTC charts with execution over the last 3,500 bars, different display modes, a daily timeframe, 100% size, and shape one.
  
The Size % parameter controls the overall size of the bubbles, while the Shape parameter controls their vertical growth.
Since the chart has two scales, one for time and one for price, traders can use the Shape parameter to make the bubbles round.
The chart above shows the same bubbles with different size and shape parameters.
You can also customize data labels and timeframe separators from the settings panel.
🔶  SETTINGS 
 
 Execute on last X bars: Number of bars for indicator execution
 
🔹  Bubbles 
 
 Display Bubbles: Enable/Disable volume bubbles.
 Bubble Mode: Select from the following options: total volume, buy and sell volume, or the delta between buy and sell volume.
 Bubble Timeframe: Select the timeframe for which the bubbles will be displayed.
 Bubble Size %: Select the size of the bubbles as a percentage.
 Bubble Shape: Select the shape of the bubbles. The larger the number, the more vertical the bubbles will be stretched.
 
🔹  Labels 
 
 Display Labels: Enable/Disable data labels, select size and location.
 
🔹  Separators 
 
 Display Separators: Enable/Disable timeframe separators and select color.
 
🔹  Liquidity Heatmap 
 
 Display Heatmap: Enable/Disable liquidity heatmap.
 Heatmap Rows: select number of rows to be displayed.
 Cell Minimum Size: Select the minimum size for each cell in each row.
 Colors.
 
🔹  Style 
 
 Buy & Sell Volume Colors.
Rally Base Drop Signals [LuxAlgo]The Rally Base Drop indicator is built around the Supply and Demand (SND) concept known as "Rally, Base & Drop" Candles. These candle types are commonly used in this trading approach to identify price structure.
This indicator highlights bars by labeling them as "Rally," "Drop," or "Base" candles. It also identifies specific sequence patterns formed by these candles.
🔶  USAGE 
  
The Rally, Base, Drop candlestick approach is a straightforward method for identifying price action structure.
Candles are categorized into three types, which are then analyzed to understand market structure and Supply/Demand levels.
 
 Rally: Two or more consecutive bullish candles.
 Drop: Two or more consecutive bearish candles.
 Base: A single bullish or bearish candle that breaks the previous trend.
 
🔹  Rally & Drop Candles 
These candles show clear directional momentum and signal whether demand or supply is dominating. They are helpful when identifying trends, as they highlight strong price movement.
🔹  Base Candles 
In most SND strategies, "Base" can have several interpretations.
Typically, base candles represent short periods of consolidation that test the trend before continuation. They can also be found at turning points (tops or bottoms).
For this indicator, a base candle is simply one that does not follow the direction of nearby candles or is where a Drop and Rally meet. Multiple base candles often reflect indecision in the market, suggesting a temporary balance between buyers and sellers.
🔹  Reversal Sequences 
  
 
 Rally-Base-Drop (RBD)
 Drop-Base-Rally (DBR)
 
In Supply and Demand analysis, these sequences are considered reversals. They mark zones where buyer and seller activity has shifted, which can lead to future price reactions. These areas are known as "Supply or Demand Zones" and are often revisited by price, making them useful for trade setups.
🔹  Continuation Sequences 
  
 
 Rally-Base-Rally (RBR)  
 Drop-Base-Drop (DBD)
 
Continuation sequences show a brief pause in the trend, followed by further movement in the same direction. In SND terms, they represent zones where orders accumulate before a continuation move. These are typically used to join ongoing trends, as they indicate sustained interest from buyers or sellers.
🔶  DETAILS 
🔹  Color Modes 
The script includes three color modes. "No Color" is self-explanatory, while the other two options relate to how candles are detected.
 A Rally or Drop requires at least two candles to be successfully identified. As a result, detection occurs on the second candle. However, the full Rally or Drop includes both candles.
 
Two coloring methods are available:
 
 Full Color: Once a Rally or Drop is detected (on the second bar), both candles are colored, starting from the first. This reflects the full pattern.
 Color on Detection: Only the second candle (where detection occurs) is colored. This avoids changing past bars and may be useful for live analysis.
 
  
🔶  SETTINGS 
 
 Sequences: Select which sequences to display on the chart.
 Bar Color Logic: Choose the preferred bar coloring method.
Volume by Time [LuxAlgo]The Volume by Time indicator collects volume data for every point in time over the day and displays the average volume of the specific dataset collected at each respective bar.
The indicator overlays the current volume and the historical average to allow for better comparisons.
 🔶  USAGE 
  
Throughout the day, the volume of every bar is stored in groups organized by the time when each bar occurred.
Over time, the datasets accumulate, and from that, we can simply determine the average value at each specific time of the day.
  
The display is a histogram style, which consists of hollow bars and solid filled columns.
 -Hollow bars represent the average volume at that time of the day.
-Solid columns display the current volume from the current bar. 
  
By default, the entire history of data is used, but if desired, the number of days under analysis can be specified to provide a more relevant point of view.
A readout of the number of days being analyzed can be seen in the status bar at any time.
 Note: Due to partial sessions, it is typical to see this value change throughout the day; this is simply due to the fact that not every trading session has the exact same schedule 100% of the time. 
  
The analysis type can also be specified; these can be either Average (Default) or Median.
  
Additionally, a Bi-directional can be toggled for a distinct difference between upwards volume and downwards volume.
🔶  SETTINGS 
 
 Analysis Type: Choose between Average or Median analysis modes.
 Length (Days): Set the number of days to use for analysis. Set to 0 for full data (Default 0).
 Bi-Directional Toggle: Toggle between one-sided or two-sided display.
Standardized Cumulative Deltas [LuxAlgo]The  Standardized Cumulative Deltas  tool allows traders to compare the cumulative standardized open-close difference for up to 10 different tickers, allowing them to visualize the general sentiment for all selected tickers.
These results allow the construction of two areas showing the average or extreme bullish and bearish cumulative change for all enabled tickers, providing a summarized view of the overall ticker group sentiment.
🔶  USAGE 
  
This tool is meant to give a full picture of the individuals and/or overall selected tickers, and unlike classical indicators, the displayed series of values is not meant to be directly interpreted over time. 
Given the selected lookback period, a majority of observations being above 0 indicate an overall bullish market for the asset.
  
By default, the auto lookback period feature is enabled, allowing the tool to use all the visible bars for its calculations. Traders can also set the lookback period manually. The above chart uses a fixed lookback period of 500.
  
Up to 10 tickers can be used. While major cryptocurrencies are set by default, the users can set a specific basket of assets, such as US equities, forex pairs, commodities, etc.
🔹  Densities 
  
The provided areas, here called densities, can be used to get an overall sentiment of the selected tickers. The upper density (bullish) processes positive deltas, while the lower one (bearish) processes negative ones.
Interpretation is subject to the selected "Density Mode".
 
 Average: Densities track the average bullish/bearish cumulative deltas for the selected tickers. For example, a more prominent bullish density would indicate that, on average, cumulative deltas were positive across the tickers.
 Envelope: Densities track the extreme values made by bullish/bearish cumulative deltas for the selected tickers. Here, a more prominent density would indicate more volatile bullish/bearish movements, depending on the density. 
 
  
🔹  Dashboard 
  
The tool features a dashboard with active tickers and their respective colors for traders' convenience.
🔶  DETAILS 
🔹  Densities 
  
Densities are obtained by applying a forward-backward exponential moving average on the average, or the highest/lowest cumulative series, depending on the selected Density Mode. 
The resulting densities are smoothed by the "Smoothing" parameter located in the Settings panel, with higher values returning smoother envelopes with less variability.
Do note that the smoothing method used here is subject to repainting.
🔶  SETTINGS 
 
 Lookback: Select the lookback period and enable/disable the Auto Lookback feature
 Tickers: Enable/disable and select up to 10 tickers and their colors
 Density Mode: Determine how densities are calculated
 
🔹  Dashboard 
 
 Show Dashboard: Enable/disable the dashboard
 Position: Select the dashboard position
 Size: Select the dashboard size
 
🔹  Style 
 
 Density: Enable/disable the density areas
 Bullish Density: Select the color of the top density area
 Bearish Density: Select the color of the bottom density area
 Smoothing: Select the smoothing constant for the EMA calculation
Trendlines Oscillator [LuxAlgo]The  Trendlines Oscillator  helps traders identify trends and momentum based on the normalized distances between the current price and the most recently detected bullish and bearish trend lines. 
The indicator features bullish and bearish momentum, a signal line with crossings, and multiple smoothing options.
🔶  USAGE 
  
The indicator displays three lines: two for momentum and one for the signal. When one of the momentum lines (bullish or bearish) crosses the signal line, the tool displays a dot to indicate which momentum is gaining strength.
As a general rule, when the green bullish momentum line is above the red bearish momentum line, it indicates buyer strength. This means that the actual prices are farther from the support trend lines than the resistance trend lines. The opposite is true for seller strength.
To calculate bullish momentum, the tool first identifies bullish trend lines acting as support below the price. Then, it measures the delta between the price and those trend lines and normalizes the reading into the displayed momentum values.
The same process is used for bearish momentum, but with bearish trendlines acting as resistance above the price.
🔹  Length & Memory 
  
Modifying the Length and Memory values will cause the tool to display different momentum values.
Traders can adjust the length to detect larger trendlines and adjust the memory to indicate how many trendlines the tool should consider.
As the chart above shows, smaller values make the tool more responsive, while larger values are useful for detecting larger trends.
🔹  Smoothing 
  
By default, the data is not smoothed, and the signal uses a triangular moving average with a length of 10. Traders can smooth both the data and the signal line.
Traders can choose from up to ten different methods, or none. Some examples are shown on the chart above.
🔶  DETAILS 
The steps for the calculations are as follows:
1. Gather the pivots, highs, and lows.
 ph      = fixnan(ta.pivothigh(lengthInput, lengthInput))
pl      = fixnan(ta.pivotlow(lengthInput, lengthInput)) 
2. Calculate the slope and y-intercept for each trendline between contiguous lower highs (resistance) or higher lows (support).
 if ph < ph 
    slope = (ph - ph )/(n-lengthInput - phx1)
    res.unshift(l.new(ph  - slope * phx1, slope))
if pl > pl 
    slope = (pl - pl )/(n-lengthInput - plx1)
    sup.unshift(l.new(pl  - slope * plx1, slope)) 
3. Calculate the value of each trendline on the current bar, then calculate the difference with the current price (delta). To calculate the relative sum of deltas, only consider trendlines below the price for support or above the price for resistance.
 method get_point(l id, x)=>
    id.slope * x + id.intercept
	
	for element in sup
    point = element.get_point(n)
    if sourceInput > point
        sup_sum += sourceInput - point
    
    sup_den += math.abs(sourceInput - point)
for element in res
    point = element.get_point(n)
    if sourceInput < point
        res_sum += point - sourceInput
    res_den += math.abs(point - sourceInput) 
4. Normalize the value from 0 to 100 by taking the sum of the relative values of the deltas divided by the sum of the absolute values of the deltas.	
 float supportLine       = sup_sum / sup_den * 100
float resistanceLine    = res_sum / res_den * 100 
5. Smooth both values, then calculate the signal line as the difference between them.
 float smoothSupport     = smooth(supportLine,dataSmoothingInput,dataSmoothingLengthInput)
float smoothResistance  = smooth(resistanceLine,dataSmoothingInput,dataSmoothingLengthInput)
float signal            = math.abs(smoothSupport - smoothResistance)
float signalLine        = smooth(signal,smoothingInput,smoothingLengthInput) 
6. Calculate the crossing signals against the signal line, using only the first signal from each series of bullish or bearish crossings.
 bullSignal      = smoothSupport > signalLine and smoothSupport  < signalLine 
bearSignal      = smoothResistance > signalLine and smoothResistance  < signalLine 
lastSignal      := bullSignal and lastSignal == BEAR ? BULL : bearSignal and lastSignal == BULL ? BEAR : lastSignal
firstBull       = ta.change(lastSignal) > 0
firstBear       = ta.change(lastSignal) < 0 
🔶  SETTINGS 
 
 Length: The size of the market structure used for trendline detection.
 Memory: The number of trendlines used in calculations.
 Source: The source for the calculations is closing prices by default.
 
🔹  Smoothing 
 
 Data Smoothing: Choose the smoothing method and length
 Signal Smoothing: Choose the smoothing method and length
 
Bitcoin Expectile Model [LuxAlgo]The Bitcoin Expectile Model is a novel approach to forecasting Bitcoin, inspired by the popular Bitcoin Quantile Model by PlanC. By fitting multiple Expectile regressions to the price, we highlight zones of corrections or accumulations throughout the Bitcoin price evolution.
While we strongly recommend using this model with the Bitcoin All Time History Index  INDEX:BTCUSD  on the 3 days or weekly timeframe using a logarithmic scale, this model can be applied to any asset using the daily timeframe or superior.
 Please note that here on TradingView, this model was solely designed to be used on the Bitcoin 1W chart, however, it can be experimented on other assets or timeframes if of interest. 
🔶  USAGE 
  
The Bitcoin Expectile Model can be applied similarly to models used for Bitcoin, highlighting lower areas of possible accumulation (support) and higher areas that allow for the anticipation of potential corrections (resistance).
By default, this model fits 7 individual Expectiles Log-Log Regressions to the price, each with their respective expectile ( tau ) values (here multiplied by 100 for the user's convenience). Higher tau values will return a fit closer to the higher highs made by the price of the asset, while lower ones will return fits closer to the lower prices observed over time.
  
Each zone is color-coded and has a specific interpretation. The green zone is a buy zone for long-term investing, purple is an anomaly zone for market bottoms that over-extend, while red is considered the distribution zone.
  
The fits can be extrapolated, helping to chart a course for the possible evolution of Bitcoin prices. Users can select the end of the forecast as a date using the "Forecast End" setting.
  
While the model is made for Bitcoin using a log scale, other assets showing a tendency to have a trend evolving in a single direction can be used. See the chart above on QQQ weekly using a linear scale as an example.
  
The Start Date can also allow fitting the model more locally, rather than over a large range of prices. This can be useful to identify potential shorter-term support/resistance areas.
🔶  DETAILS 
🔹 On Quantile and Expectile Regressions 
Quantile and Expectile regressions are similar; both return extremities that can be used to locate and predict prices where tops/bottoms could be more likely to occur.
The main difference lies in what we are trying to minimize, which, for Quantile regression, is commonly known as Quantile loss (or pinball loss), and for Expectile regression, simply Expectile loss.
You may refer to external material to go more in-depth about these loss functions; however, while they are similar and involve weighting specific prices more than others relative to our parameter tau, Quantile regression involves minimizing a weighted mean absolute error, while Expectile regression minimizes a weighted squared error.
The squared error here allows us to compute Expectile regression more easily compared to Quantile regression, using Iteratively reweighted least squares. For Quantile regression, a more elaborate method is needed.
In terms of comparison, Quantile regression is more robust, and easier to interpret, with quantiles being related to specific probabilities involving the underlying cumulative distribution function of the dataset; on the other expectiles are harder to interpret.
🔹 Trimming & Alterations 
It is common to observe certain models ignoring very early Bitcoin price ranges. By default, we start our fit at the date 2010-07-16 to align with existing models.
By default, the model uses the number of time units (days, weeks...etc) elapsed since the beginning of history + 1 (to avoid NaN with log) as independent variable, however the Bitcoin All Time History Index  INDEX:BTCUSD  do not include the genesis block, as such users can correct for this by enabling the "Correct for Genesis block" setting, which will add the amount of missed bars from the Genesis block to the start oh the chart history.
🔶  SETTINGS 
 
 Start Date: Starting interval of the dataset used for the fit.
 Correct for genesis block: When enabled, offset the X axis by the number of bars between the Bitcoin genesis block time and the chart starting time.
 
🔹 Expectiles 
 
 Toggle: Enable fit for the specified expectile. Disabling one fit will make the script faster to compute.
 Expectile: Expectile (tau) value multiplied by 100 used for the fit. Higher values will produce fits that are located near price tops.
 
🔹 Forecast 
 
 Forecast End: Time at which the forecast stops.
 
🔹 Model Fit 
 
 Iterations Number: Number of iterations performed during the reweighted least squares process, with lower values leading to less accurate fits, while higher values will take more time to compute.
On-Chain Signals [LuxAlgo]The  On-Chain Signals  indicator uses fundamental blockchain metrics to provide traders with an objective technical view of their favorite cryptocurrencies. 
It uses IntoTheBlock datasets integrated within TradingView to generate four key signals: Net Network Growth, In the Money, Concentration, and Large Transactions.
Together, these four signals provide traders with an overall directional bias of the market. All of the data can be visualized as a gauge, table, historical plot, or average.
🔶  USAGE 
  
The main goal of this tool is to provide an overall directional bias based on four blockchain signals, each with three possible biases: bearish, neutral, or bullish. The thresholds for each signal bias can be adjusted on the settings panel.
These signals are based on IntoTheBlock's On-Chain Signals.
 
 Net network growth: Change in the total number of addresses over the last seven periods; i.e., how many new addresses are being created.
 In the Money: Change in the seven-period moving average of the total supply in the money. This shows how many addresses are profitable.
 Concentration: Change in the aggregate addresses of whales and investors from the previous period. These are addresses holding at least 0.1% of the supply. This shows how many addresses are in the hands of a few.
 Large Transactions: Changes in the number of transactions over $100,000. This metric tracks convergence or divergence from the 21- and 30-day EMAs and indicates the momentum of large transactions.
 
All of these signals together form the blockchain's overall directional bias.
 
 Bearish: The number of bearish individual signals is greater than the number of bullish individual signals.
 Neutral: The number of bearish individual signals is equal to the number of bullish individual signals.
 Bullish: The number of bullish individual signals is greater than the number of bearish individual signals.
 
If the overall directional bias is bullish, we can expect the price of the observed cryptocurrency to increase. If the bias is bearish, we can expect the price to decrease. If the signal is neutral, the price may be more likely to stay the same.
Traders should be aware of two things. First, the signals provide optimal results when the chart is set to the daily timeframe. Second, the tool uses IntoTheBlock data, which is available on TradingView. Therefore, some cryptocurrencies may not be available.
🔹  Display Mode 
  
Traders have three different display modes at their disposal. These modes can be easily selected from the settings panel. The gauge is set by default.
🔹  Gauge 
  
The gauge will appear in the center of the visible space. Traders can adjust its size using the Scale parameter in the Settings panel. They can also give it a curved effect.
The number of bars displayed directly affects the gauge's resolution: More bars result in better resolution.
The chart above shows the effect that different scale configurations have on the gauge.
🔹  Historical Data 
  
The chart above shows the historical data for each of the four signals.
Traders can use this mode to adjust the thresholds for each signal on the settings panel to fit the behavior of each cryptocurrency. They can also analyze how each metric impacts price behavior over time.
🔹  Average 
  
This display mode provides an easy way to see the overall bias of past prices in order to analyze price behavior in relation to the underlying blockchain's directional bias.
The average is calculated by taking the values of the overall bias as -1 for bearish, 0 for neutral, and +1 for bullish, and then applying a triangular moving average over 20 periods by default. Simple and exponential moving averages are available, and traders can select the period length from the settings panel.
🔶  DETAILS 
The four signals are based on IntoTheBlock's On-Chain Signals. We gather the data, manipulate it, and build the signals depending on each threshold.
 
 Net network growth
 float netNetworkGrowthData      = customData('_TOTALADDRESSES')
float netNetworkGrowth          = 100*(netNetworkGrowthData /netNetworkGrowthData  - 1) 
 In the Money
 float inTheMoneyData            = customData('_INOUTMONEYIN')
float averageBalance            = customData('_AVGBALANCE')
float inTheMoneyBalance         = inTheMoneyData*averageBalance
float sma                       = ta.sma(inTheMoneyBalance,7)
float inTheMoney                = ta.roc(sma,1) 
 Concentration
 float whalesData                = customData('_WHALESPERCENTAGE')
float inverstorsData            = customData('_INVESTORSPERCENTAGE')
float bigHands                  = whalesData+inverstorsData
float concentration             = ta.change(bigHands )*100 
 Large Transactions
 float largeTransacionsData      = customData('_LARGETXCOUNT')
float largeTX21                 = ta.ema(largeTransacionsData,21) 
float largeTX30                 = ta.ema(largeTransacionsData,30) 
float largeTransacions          = ((largeTX21 - largeTX30)/largeTX30)*100 
 
🔶  SETTINGS 
 
 Display mode: Select between gauge, historical data and average.
 Average: Select a smoothing method and length period.
 
🔹  Thresholds 
 
 Net Network Growth : Bullish and bearish thresholds for this signal.
 In The Money : Bullish and bearish thresholds for this signal.
 Concentration : Bullish and bearish thresholds for this signal.
 Transactions : Bullish and bearish thresholds for this signal.
 
🔹  Dashboard 
 
 Dashboard : Enable/disable dashboard display
 Position : Select dashboard location
 Size : Select dashboard size
 
🔹  Gauge 
 
 Scale : Select the size of the gauge
 Curved : Enable/disable curved mode
 Select Gauge colors for bearish, neutral and bullish bias
 
🔹  Style 
 
 Net Network Growth : Enable/disable historical plot and choose color
 In The Money : Enable/disable historical plot and choose color
 Concentration : Enable/disable historical plot and choose color
 Large Transacions : Enable/disable historical plot and choose color
Internal Pivot Pattern [LuxAlgo]The  Internal Pivot Pattern  indicator is a novel method allowing traders to detect pivots without excessive delay on the chart timeframe, by using the lower timeframe data from a candle. 
It features custom colors for candles and zigzag lines to help identify trends. A dashboard showing the accuracy of the pattern is also included.
🔶  USAGE 
  
We define a pivot as the occurrence where the middle candle over a specific interval (for example, the most recent 21 bars) is the highest (pivot high) or the lowest (pivot low). This method commonly allows for identifying swing highs/lows on a trader's chart; however, this pattern can only be identified after a specific number of bars has been formed, rendering this pattern useless for real-time detection of swing highs/lows.
  
This indicator uses a different approach, removing the need to wait for candles to form on the user chart; instead, we check the lower timeframe data of the current candle and evaluate for the presence of a pivot given the internal data, effectively providing pivot confirmation at the candle close.
An internal pivot low pattern is indicative of a potential uptrend, while an internal pivot high is indicative of a potential downtrend.
Candles are colored based on the last internal pivot detected, with blue candle colors indicating that the most recent internal pivot is a pivot low, indicating an uptrend, while an orange candle color indicates that the most recent internal pivot is a pivot high, indicating a downtrend.
🔹  Timeframes 
  
The timeframe setting allows controlling the amount of lower timeframe data to consider for the internal pivot detection. This setting must be lower than the user's chart timeframe.
Using a timeframe significantly lower than the user chart timeframe will evaluate a larger amount of data for the pivot detection, making it less frequent, while using a timeframe closer to the chart timeframe can make the internal pivot detection more frequent, and more prone to false positives.
🔹  Accuracy Dashboard 
  
The Accuracy Dashboard allows evaluating how accurate the detected patterns are as a percentage, with a pattern being judged accurate if subsequent patterns are detected higher or lower than a previous one.
For example, an internal pivot low is judged accurate if the following internal pivot is higher than it, indicating that higher highs have been made.
This dashboard can be useful to determine the timeframe setting to maximize the respective internal pivot accuracy.
🔶  SETTINGS 
 
 Timeframe: Timeframe for detecting internal swings
 Accuracy Dashboard: Enable or disable the Accuracy Dashboard.
 
🔹  Style 
 
 Internal Pivot High: Color of the dot displayed upon the detection of an internal pivot high
 Internal Pivot Low: Color of the dot displayed upon the detection of an internal pivot low
 Zig-Zag: Color of the zig-zag segments connecting each internal pivot
 Candles: Enable candle coloring, with control over the color of the candles highlighting the detected trend
Multi Ranges Volume Distribution [LuxAlgo]The  Multi Ranges Volume Distribution  tool allows traders to see the volume distribution by price for three different timeframes simultaneously. Each distribution can report the total amount of accumulated volume or the accumulated buy/sell volume separately.
Levels are displayed at the top and bottom of each timeframe's range, as well as the POC or level with the most volume.
🔶  USAGE 
  
By default, the tool displays daily, weekly, and monthly volume distributions, highlighting the accumulated volume within each row.
Each distribution shows the volume at each price, as well as three lines: the top and bottom prices, and the price at which the most volume was traded.
The reported accumulated volume can be useful for highlighting which price areas are of the most interest to traders, with the specific timeframe specifying whether this interest is long-term or short-term.
🔹  Timeframes & Rows 
  
Traders can adjust the timeframe and the number of rows for each volume distribution.
This is useful for multi-timeframe analysis of volume at the same price levels, or for obtaining detailed data within the same timeframe.
The chart above shows three volume distributions with the same monthly timeframe but a different number of rows; each is more detailed than the previous one.
🔹  Total vs Buy & Sell Volume 
  
Traders can choose to display either the total volume or the buy and sell volumes.
As we can see on the above chart, the background of each row uses a gradient that is a function of the delta between the buy and sell volumes.
This is useful to determine which areas attract buyers and sellers.
🔶  SETTINGS 
 
 Volume Display: Select between total volume and buy and sell volume.
 Distance between each box: Adjust the spacing of the volume distributions.
 Period A: Select a timeframe and the number of rows.
 Period B: Select a timeframe and the number of rows.
 Period C: Select a timeframe and the number of rows.
Internal Candle Strength [LuxAlgo]The  Internal Candle Strength  tool allows traders to divide each chart bar into multiple rows of custom size and inspect the strength of the lower timeframes trends located within each row. 
This tool effectively helps traders in identifying the power dynamic between bulls and bears within multiple areas within each bar, providing the ability to conduct LTF analysis.
🔶  USAGE 
  
The strength displayed within each row ranges from 0% to 100%, with 0% being the most bearish and 100% being the most bullish.
Traders should be aware of the extreme probabilities located at the higher/lower end of the bars, as this can signal a change in strength and price direction.
  
Traders can select the lower timeframe to pull the data from or the row size in the scale of the chart. Selecting a lower timeframe will provide more data to evaluate an area's strength.
Do note that only a timeframe lower than the chart timeframe should be selected.
🔹  Row Size 
  
Selecting a smaller row size will increase the number of rows per bar, allowing for a more detailed analysis. A lower value will also generally mean that less data will be considered when calculating the strength of a specific area.
As we can see on the chart above (all BTCUSD 30m), by selecting a different row size, traders can control how many rows are displayed per bar.
🔶  SETTINGS 
 
 Timeframe: Lower timeframe used to calculate the candle strength.
 Row Size: Size of each row on the chart scale, expressed as a fraction of the candle range.
Expanded Cloud [LuxAlgo]The  Expanded Cloud  tool allows traders to identify and follow trends accurately. It is based on the well-known Donchian Channels, but with enhanced features. 
It features a trailing cloud that expands with the price and a trading stats dashboard.
🔶  USAGE 
  
The tool is super easy to use. Traders can identify bigger or smaller trends just by adjusting the length from the settings panel.
Trend identification is based on Donchian Channels. An uptrend is indicated when the cloud is located below the price, while a downtrend is indicated when the cloud is above it.
Dots signal the start of a new trend, and the width of the clouds identifies the strength of the price expansion. The wider the cloud, the bigger the move.
The expanded cloud, due to its visual, can also act as a trailing stop.
🔹  Trend Identification 
  
As we can see in the chart above, different length values identify different trends on the same BTC daily chart. Larger values identify larger trends.
🔹  Cloud Expansion 
  
From the settings panel, traders can adjust how the clouds expand based on the Expansion % parameter. It accepts values from 0 to 100, which controls how much of the expansion is taken into account. Higher values will make the cloud expand and get closer to the price faster.
When the cloud moves opposite to the direction of the indicated trend (e.g: the cloud decreases while being below the price), it is often indicative of the end of a retracement, and we can expect the price to move with the indicated trend.
The chart above shows the effect of different Expansion % values.
🔹  Dashboard 
  
The trading statistics dashboard informs traders of key metrics derived from the tool. The following are notable:
 
 PNL: Theoretical profit or loss from all trends identified by the tool in the right scale units.
 EXPECT.: Expected value of each trade. It is derived from win rate and risk-to-reward metrics.
 AVG: 1st TOUCH: The average number of bars from the beginning of a new trend until the price touches the cloud for the first time.
 
🔶  SETTINGS 
 
 Length: Length for trend detection
 Expansion %: Percentage of price expansion for cloud formation
 Source: Source of the data
 
🔹  Dashboard 
 
 Show Dashboard: Enable/disable the statistics dashboard
 Location: Dashboard location
 Size: Dashboard size
Bitcoin Power Law Clock [LuxAlgo]The Bitcoin Power Law Clock is a unique representation of Bitcoin prices proposed by famous Bitcoin analyst and modeler Giovanni Santostasi. 
It displays a clock-like figure with the Bitcoin price and average lines as spirals, as well as the 12, 3, 6, and 9 hour marks as key points in the cycle.
🔶  USAGE 
  
Giovanni Santostasi, Ph.D., is the creator and discoverer of the Bitcoin Power Law Theory. He is passionate about Bitcoin and has 12 years of experience analyzing it and creating price models.
As we can see in the above chart, the tool is super intuitive. It displays a clock-like figure with the current Bitcoin price at 10:20 on a 12-hour scale.
This tool only works on the 1D INDEX:BTCUSD chart. The ticker and timeframe must be exact to ensure proper functionality.
According to the Bitcoin Power Law Theory, the key cycle points are marked at the extremes of the clock: 12, 3, 6, and 9 hours. According to the theory, the current Bitcoin prices are in a frenzied bull market on their way to the top of the cycle.
🔹  Enable/Disable Elements 
  
All of the elements on the clock can be disabled. If you disable them all, only an empty space will remain.
The different charts above show various combinations. Traders can customize the tool to their needs.
🔹  Auto scale 
  
The clock has an auto-scale feature that is enabled by default. Traders can adjust the size of the clock by disabling this feature and setting the size in the settings panel.
The image above shows different configurations of this feature.
🔶  SETTINGS 
🔹  Price 
 
 Price: Enable/disable price spiral, select color, and enable/disable curved mode
 Average: Enable/disable average spiral, select color, and enable/disable curved mode
 
🔹  Style 
 
 Auto scale: Enable/disable automatic scaling or set manual fixed scaling for the spirals
 Lines width: Width of each spiral line
 Text Size: Select text size for date tags and price scales
 Prices: Enable/disable price scales on the x-axis
 Handle: Enable/disable clock handle
 Halvings: Enable/disable Halvings
 Hours: Enable/disable hours and key cycle points
 
🔹  Time & Price Dashboard 
 
 Show Time & Price: Enable/disable time & price dashboard
 Location: Dashboard location
 Size: Dashboard size
Bitcoin Power Law [LuxAlgo]The Bitcoin Power Law tool is a representation of Bitcoin prices first proposed by Giovanni Santostasi, Ph.D. It plots BTCUSD daily closes on a log10-log10 scale, and fits a linear regression channel to the data. 
This channel helps traders visualise when the price is historically in a zone prone to tops or located within a discounted zone subject to future growth.
🔶  USAGE 
  
Giovanni Santostasi, Ph.D. originated the Bitcoin Power-Law Theory; this implementation places it directly on a TradingView chart. The white line shows the daily closing price, while the cyan line is the best-fit regression. 
A channel is constructed from the linear fit root mean squared error (RMSE), we can observe how price has repeatedly oscillated between each channel areas through every bull-bear cycle.
  
Excursions into the upper channel area can be followed by price surges and finishing on a top, whereas price touching the lower channel area coincides with a cycle low.
  
Users can change the channel areas multipliers, helping capture moves more precisely depending on the intended usage.
 This tool only works on the daily  BTCUSD  chart. Ticker and timeframe must match exactly for the calculations to remain valid. 
🔹  Linear Scale 
Users can toggle on a linear scale for the time axis, in order to obtain a higher resolution of the price, (this will affect the linear regression channel fit, making it look poorer).
🔶  DETAILS 
One of the advantages of the Power Law Theory proposed by Giovanni Santostasi is its ability to explain multiple behaviors of Bitcoin. We describe some key points below.
🔹  Power-Law Overview 
A power law has the form  y = A·xⁿ , and Bitcoin’s key variables follow this pattern across many orders of magnitude. Empirically, price rises roughly with t⁶, hash-rate with t¹² and the number of active addresses with t³. 
When we plot these on log-log axes they appear as straight lines, revealing a scale-invariant system whose behaviour repeats proportionally as it grows.
🔹  Feedback-Loop Dynamics 
Growth begins with new users, whose presence pushes the price higher via a Metcalfe-style square-law. A richer price pool funds more mining hardware; the Difficulty Adjustment immediately raises the hash-rate requirement, keeping profit margins razor-thin. 
A higher hash rate secures the network, which in turn attracts the next wave of users. Because risk and Difficulty act as braking forces, user adoption advances as a power of three in time rather than an unchecked S-curve. This circular causality repeats without end, producing the familiar boom-and-bust cadence around the long-term power-law channel.
🔹  Scale Invariance & Predictions   
Scale invariance means that enlarging the timeline in log-log space leaves the trajectory unchanged. 
The same geometric proportions that described the first dollar of value can therefore extend to a projected million-dollar bitcoin, provided no catastrophic break occurs. Institutional ETF inflows supply fresh capital but do not bend the underlying slope; only a persistent deviation from the line would falsify the current model.
🔹  Implications   
The theory assigns scarcity no direct role; iterative feedback and the Difficulty Adjustment are sufficient to govern Bitcoin’s expansion. Long-term valuation should focus on position within the power-law channel, while bubbles—sharp departures above trend that later revert—are expected punctuations of an otherwise steady climb. 
Beyond about 2040, disruptive technological shifts could alter the parameters, but for the next order of magnitude the present slope remains the simplest, most robust guide.
 Bitcoin behaves less like a traditional asset and more like a self-organising digital organism whose value, security, and adoption co-evolve according to immutable power-law rules. 
🔶  SETTINGS 
🔹  General 
 
 Start Calculation: Determine the start date used by the calculation, with any prior prices being ignored. (default - 15 Jul 2010)  
 Use Linear Scale for X-Axis: Convert the horizontal axis from log(time) to linear calendar time  
 
🔹  Linear Regression 
 
 Show Regression Line: Enable/disable the central power-law trend line  
 Regression Line Color: Choose the colour of the regression line  
 Mult 1: Toggle line & fill, set multiplier (default +1), pick line colour and area fill colour  
 Mult 2: Toggle line & fill, set multiplier (default +0.5), pick line colour and area fill colour  
 Mult 3: Toggle line & fill, set multiplier (default -0.5), pick line colour and area fill colour  
 Mult 4: Toggle line & fill, set multiplier (default -1), pick line colour and area fill colour  
 
🔹  Style 
 
 Price Line Color: Select the colour of the BTC price plot  
 Auto Color: Automatically choose the best contrast colour for the price line  
 Price Line Width: Set the thickness of the price line (1 – 5 px)  
 Show Halvings: Enable/disable dotted vertical lines at each Bitcoin halving  
 Halvings Color: Choose the colour of the halving lines  
FVG Trailing Stop [LuxAlgo]The FVG Trailing Stop indicator tracks unmitigated Fair Value Gaps (FVG) data to produce a Trailing Stop indicator able to determine if the market is uptrending or downtrending easily.
🔶  USAGE 
  
The FVG Trailing Stop is intended to identify trend directions through its position relative to the closing price:
 
 Bullish:  Price is located above the Trailing Stop, indicating that all  Bearish  FVGs have been mitigated and the trend is anticipated to continue upwards.
 Bearish State:  Price is located below the Trailing Stop, indicating that all  Bullish  FVGs have been mitigated and the trend is anticipated to continue downwards.
 
The Trailing Stop originates from two extremities obtained from the average of respective unmitigated FVGs. The specific directional average is also displayed as a more transparent secondary line, however, the trailing stop is derived from this value and a new trend will not be detected until the opposite directional average is crossed.
Price reaching the Trailing Stop is caused by retracements and can lead to the following scenarios:
 
 Outcome 1:  The directional average is crossed next, indicating a new trend direction.
 Outcome 2:  The directional average is held as support or resistance, leading to a new impulse and a continuation of the trend.
  
🔹  Reset on Cross 
  
While price crossing the Trailing Stop should be considered as a sign of an upcoming trend change; it is possible for the price to still evolve outside it.
As a solution, we have included the "Reset on Cross" feature, which (as the name suggests) hides and resets the Trailing Stop each time it is crossed, leading to a "Neutral" state. 
This opens the opportunity for the Trailing Stop to be displayed again once the price moves again in the direction of the pre-established trend. A trader might use this to accumulate positions within a specific trend.
🔶  DETAILS 
The script uses a typical identification method for FVGs. Once identified, the script collects the point of the FVG farthest from the current price when formed.
 
 For Upwards FVGs this is the bottom of the FVG.
 For Downwards FVGs this is the top of the FVG.
 
The data is managed only to use the last input lookback of FVGs. If an FVG is mitigated, it frees up a spot in the memory for a new FVG, however, if the lookback is full, the oldest will be deleted.
From there, it uses a "trailing" logic only to move the Trailing Stop in one direction until the trailing stop resets or the direction flips.
The extremities used to calculate the Trailing Stop are created from 2 calculation steps, the first step involves taking the raw average of the FVG mitigation levels, and the second step applies a simple moving average (SMA) smoothing of the precedent-obtained averages.
🔶  SETTINGS 
 
 Unmitigated FVG Lookback: Sets the maximum number of Unmitigated FVGs that the script will use.
 Smoothing Length: Sets the smoothing length for the Trailing Stop to reduce erratic results. 
 Reset on Cross: When enabled, hide and reset the Trailing Stop until the price starts moving in the pre-established trend direction again.
Candle Breakout Oscillator [LuxAlgo]The  Candle Breakout Oscillator  tool allows traders to identify the strength and weakness of the three main market states: bullish, bearish, and choppy.
Know who controls the market at any given moment with an oscillator display with values ranging from 0 to 100 for the three main plots and upper and lower thresholds of 80 and 20 by default.
🔶  USAGE 
  
The Candle Breakout Oscillator represents the three main market states, with values ranging from 0 to 100. By default, the upper and lower thresholds are set at 80 and 20, and when a value exceeds these thresholds, a colored area is displayed for the trader's convenience.
This tool is based on pure price action breakouts. In this context, we understand a breakout as a close above the last candle's high or low, which is representative of market strength. All other close positions in relation to the last candle's limits are considered weakness.
So, when the bullish plot (in green) is at the top of the oscillator (values above 80), it means that the bullish breakouts (close below the last candle low) are at their maximum value over the calculation window, indicating an uptrend. The same interpretation can be made for the bearish plot (in red), indicating a downtrend when high.
On the other hand, weakness is indicated when values are below the lower threshold (20), indicating that breakouts are at their minimum over the last 100 candles. Below are some examples of the possible main interpretations:
  
There are three main things to look for in this oscillator: 
 
 Value reaches extreme
 Value leaves extreme
 Bullish/Bearish crossovers
 
As we can see on the chart, before the first crossover happens the bears come out of strength (top) and the bulls come out of weakness (bottom), then after the crossover the bulls reach strength (top) and the bears weakness (bottom), this process is repeated in reverse for the second crossover.
  
The other main feature of the oscillator is its ability to identify periods of sideways trends when the sideways values have upper readings above 80, and trending behavior when the sideways values have lower readings below 20. As we just saw in the case of bullish vs. bearish, sideways values signal a change in behavior when reaching or leaving the extremes of the oscillator.
🔶  DETAILS 
🔹  Data Smoothing 
  
The tool offers up to 10 different smoothing methods. In the chart above, we can see the raw data (smoothing: None) and the RMA, TEMA, or Hull moving averages.
🔹  Data Weighting 
  
Users can add different weighting methods to the data. As we can see in the image above, users can choose between None, Volume, or Price (as in Price Delta for each breakout).
🔶  SETTINGS 
 
 Window: Execution window, 100 candles by default
 
🔹  Data 
 
 Smoothing Method: Choose between none or ten moving averages
 Smoothing Length: Length for the moving average
 Weighting Method: Choose between None, Volume, or Price
 
🔹  Thresholds 
 
 Top: 80 by default
 Bottom: 20 by default
Long Wick Detector [LuxAlgo]The  Long Wick Detector  tool allows traders to identify candle wicks longer than a user-defined volatility threshold. This makes it useful for spotting zones with high supply or demand. 
The tool displays mitigated and unmitigated levels and changes the color of the candles based on wick size and level breakouts.
🔶  USAGE 
  
By default, the tool displays long mitigated and unmitigated candle wicks, with a maximum duration for an unmitigated long wick of 1,000 bars. What does all this mean?
🔹  Wick Threshold 
  
Traders can adjust the volatility threshold to identify long wicks, with a higher threshold detecting more significant wicks.
As we can see in the image above, the tool detects more wicks with a smaller threshold compared to a higher one.
🔹  Level % 
  
Traders can choose the percentage of the wick at which the level is located. By default, the level is displayed at the extremes of the wick. This parameter accepts values between 0 and 100.
 
 100: extreme of the wick
 50: middle of the wick
 0: start of the wick
 
🔹  Max Duration 
  
This parameter allows traders to specify the number of bars for the levels. The tool will only display mitigated or unmitigated levels up to the specified number of bars.
As shown in the above image, a longer duration allows more room for mitigation, displaying more levels.
🔹  Colored Candles 
  
The tool allows for color customization using two parameters from the settings panel. The chart shows the different outputs.
The setting "Wick-Based Transparency" makes candles with smaller wicks less visible and candles with longer wicks more visible.
On the other hand, "Breakout-Based Color" changes the base color of the candles based on the mitigation of long wicks. When the price breaks above a detected top wick, the bullish color is used. When the price breaks below a detected bottom wick, the bearish color is used.
🔶  SETTINGS 
 
 Wick Threshold: The volatility threshold for wick detection. Use a smaller value to detect smaller wicks.
 Level %: Placement of the plotted level relative to the wick.
 Max Duration: The maximum duration in bars of mitigated wicks.
 Mitigated Wicks: Enable or disable mitigated wicks.
 
🔹  Style 
 
 Wick Based Transparency: Make candles with smaller wicks more transparent and candles with longer wicks more solid.
 Breakout Based Color: Change the base color based on wick mitigation.
 Bullish & Bearish Colors
Market Breadth Toolkit [LuxAlgo]The  Market Breadth Toolkit  allows traders to use up to 6 different market breadth measures on two different exchanges, for a total of 12 different views of the market. 
This toolkit includes divergence detection and allows setting custom fixed levels for traders who want to experiment with them.
🔶  USAGE 
  
The main idea behind Breadth is to measure the number of advancing and declining issues and/or volume by exchange to have an idea of the underlying strength of the whole exchange.
On the other hand, thrusts represent big impulses in the breadth, as it is described by technicians to be the start of a new bullish trend.
By default, the Toolkit is set to "Breadth Thrust Zweig", with divergences enabled.
We will now explain all the different breadth measures available in the toolkit.
🔹  Deemer Breakaway Momentum 
  
The "Breakaway Momentum" is a concept related to market breadth introduced by legendary technical analyst Walter Deemer.
As stated on his website: 
 We coined the term "breakaway momentum" in the 1970's to describe this REALLY powerful upward momentum 
and: 
 We now know that the stock market generates breakaway momentum when the 10-day total advances on the NYSE are greater than 1.97 times the 10-day total NYSE declines OR the 20-day total advances on the NYSE are greater than 1.72 times the 20-day total NYSE declines. 
As we can see in the chart above, which shows both methods, momentum is identified when the ratio of advancing issues to declining issues is greater than 1.97 for the 10-day average or 1.72 for the 20-day average.
🔹  Zweig Breadth Tools 
  
Legendary trader and author Marting Zweig, best known as the author of "Winning on Wall Street" and the creator of the Put/Call Ratio.
In this toolkit, we feature two of his other tools:
 
 Breadth Thrust: Number of Advancing / (Number of Advancing + Number of Declining Stocks)
 Market Thrust: (Number of Advancing × Advancing Volume) — (Number of Declining Stocks × Declining Volume)
 
As we can see on the above chart, the Breadth Thrust printed a new signal on April 24, 2025, which is a bullish signal on the daily chart that can last several months, considering the previous signals.
On the right side, we have the Market Thrust as the delta between advancing minus declining volume weighted.
🔹  Whaley Measures 
  
Wayne Whaley received the 2010 Charles Dow Award from the CMT Association, as stated on their website: "In 1994, the CMT Association established the Charles H. Dow Award to recognize outstanding research in technical analysis."
We include two of the tools from this paper:
 
 Advance Decline Thrust: Number of Advancing / (Number of Advancing + Number of Declining Stocks)
 Up/Down Volume Thrust Advancing Volume / (Advancing Volume + Declining Volume)
 
The chart above shows Thrust signals at extreme readings as described in the paper.
🔹  Divergences 
  
The divergence detector is enabled by default, traders can disable it and fine-tune the detection length in the settings panel.
🔹  Fixed Levels 
  
Traders can adjust the Thrust detection thresholds in the settings panel.
In the image above, we can see the Deemer Breakaway Momentum 10 with the original threshold (below) and with the 3.0 threshold (above).
🔶  SETTINGS 
 
 Breadth: Choose between 6 different breadth thrust measurement methods.
 Data: Choose between NYSE or NASDAQ exchanges.
 Divergences: Enable/Disable divergences and select the length detection.
 
🔹  Levels 
 
 Use Fixed Levels: Enable/Disable Fixed Levels.
 Top Level: Select the top-level threshold.
 Bottom Level: Select bottom level threshold.
 Levels Style: Choose between dashed, dotted, or solid style.
 
🔹  Style 
 
 Breadth: Select breadth colors
 Divergence: Select divergence colors
Adaptive Momentum Oscillator [LuxAlgo]The  Adaptive Momentum Oscillator  tool allows traders to measure the current relative momentum over a given period using the maximum delta in price.
It features a histogram with gradient color, divergences, and an adaptive moving average that allows traders to clearly see the smoothed trend direction.
🔶  USAGE 
  
This unbounded oscillator has positive momentum when values are above 0 and negative momentum when values are below 0. The adaptive moving average is used as a minimum lag smoothing tool over the momentum histogram.
🔹  Signal Line 
  
There are two main uses for the signal line drawn on the chart above.
 
 Momentum crosses above or below the signal line: acceleration in momentum.
 Signal line crosses the 0 value: positive or negative momentum.
 
🔹  Data Length 
  
On the chart above, we can compare different length sizes and how the tool values change, allowing traders to get a shorter or longer-term view of current market strength.
🔹  Smoothing Length 
  
In the previous figure, we can compare how different Smoothing Length values affect the oscillator output.
🔹  Divergences 
  
The divergence detector is disabled by default. Traders can enable it and adjust the divergence length from the settings panel.
  
As we can see in the chart above, by changing the length of the divergences, traders can fine-tune their detection, a small number will detect smaller divergences, and use a larger number for larger divergences.
🔶  SETTINGS 
 
 Data: Select data source, close price by default
 Data Length: Select the length for data gathering
 Smoothing Length: Select the length for data smoothing
 Divergences: Enable/Disable divergences detection and length






















