Papercuts Recency CandlesPapercuts Recency Candles 
V0.8 by Joel Eckert @PapercutsTrading 
 ***This is currently an experimental visual exploratory concept.***
*** Experimental tools should only be explored by fellow coders and experienced traders.*** 
  
 DESCRIPTION: 
  As coders, how can we seamlessly transition between actual and smoothed price data sets as data ages?   
This is a visual experiment to see if and how data can be smoothly transitioned from one value to another over a set number of candles. If we visualize a chart in 3 zones, a head, a body, and a tail we can start to understand how this could work.  The head zone would represent the first data set of actual asset prices.  The body zone would represent the transition period from the first to the to the second data set.  Last, the tail zone would represent the second data set made of a Hull Moving Average of the asset.  
  
 CONCEPT: 
 
 It is conceived that data and position precision constantly shift as they decay or age, therefore making older price levels act more like price regions or zones vs exact price points.  This is what I am calling Recency.
 This indicator utilizes the concept of "Recency" to explore the possibility of a new style of candle.  It aims to maintain accurately on recent prices action but loosen up accuracy on older price action.  The very nature of this requires ALTERING HISTORICAL DATA within the body zone or transition candles to achieve the effect.   It is similar to trying to merge a line chart type with a candle chart type.
 This experiment of using recency for candles was to create candles that stay more accurate near current price but fade away into a simple line as they age out, resulting in a simplified view of the big picture which consists of older price action. 
 This experimental design theoretically will help you stay focused only on what is currently unfolding and to minimize distractions from older price nuances. 
 
 USAGE: 
 WHO: 
 
 This is not recommended for new traders or novices that are unfamiliar with standard tools.  Standardized tools should always be used to get grounded and build a foundation.  
 Active traders who are familiar with trading comfortably should experiment with this to see if they find it interesting or usable.  
 Pine coders may find this concept interesting enough, and may adapt the idea to other elements of their own scripts if they find it interesting… I just ask they give credit where credit is due.
 
 HOW: 
The best way to visualize how this works is to do the following:
 
 Load it on a chart.
 Turn off Standard candles in Chart Setting of the current window.  I actually just turn off the bodies and borders, and dim the old wicks as I like the way the old wicks look when left alone with these new candles.
 Enable chart replay at a faster speed, like 3x, and play back the chart to watch the behavior of the candles.   
 You’ll be able to see how the head of the candle type preserves OHLC, and indicates direction but as the candle starts to age it progressively flowers into the HMA
 While it plays back try adjusting settings to see how they affect behavior.   
 You can see the data average in real-time which often reveals how unstable actual price noise really is.
 The head candle diagonals indicate the candle body direction.
 
 SETTINGS: 
 
 Coloring:  You can choose your own bullish or bearish colors to match your scheme.
Price Line: The price line is colored according to the trend and 
 Head Length:  These candles are true to the source high and low.  They remain slightly brighter than transition candles.  We have a max of 50 to keep things responsive.
 Time Decay Length:  This is the amount of candles it takes to transition to the tail. Max is 300 to keep things responsive.
 Decay Continuity:   This forces transition candles to complete the HMA curve instead of creating gaps when conforming to it.  The best way to visualize this feature is to run a 3x replay of an asset, and toggle the result on and off.  On is preferred.
  
 Tail HMA Length:  This is the smoothing amount for the resulting HMA stepline that calculates every close, but has a delayed draw until after the transition candles.  You can optionally turn off the delayed visibility to help with comprehension.
 Tail HMA Weight:  This is simply an option to make the tail thicker or thinner. This also adjusts the border on the head candles to help them stand out.
 Show Side Bias Dots:  Default true: Draws a dot when bias to one side changes to help keep you on the right side of trade. Side bias is simply the alignment of 3 moving averages in one direction.
 
 IMPORTANT NOTES: 
 
 You'll have to turn off or dim the standard candles in your view "Chart Settings" to see this properly. 
 Be aware that since the candles are based on boxes and utilize the “recency concept”, which means their data decays and changes as it ages. This results in a cleaner chart overall, but exact highs and lows will be averaged out as the data decays, forming a Hull Moving Average stepline of your defined length once decay has finished.
 
 SUMMARY OF HOW IT WORKS: 
 
 First it takes candle information and creates unique boxes that represent each candle based on the high and low.   It utilizes boxes because standard candles once written, cannot be later altered or removed… which is a key element for this effect to work.
 Next it creates a second box and line from open to close for the body of the Head candles.  This indicates direction at a glance.
 As candles age beyond the defined distance of the “Head” they enter the "Body" aka "Time Decay" zone.  Here the accuracy of the high and low will be averaged down using an incremental factor of the HMA, defined by "Time Decay Length" amount of candles. 
 The resulting tail is an HMA of Tail HMA Length.  This tail is always calculate at close, but is not drawn instantly.  The draw is delayed so that there is not overlapping data, and this makes the effect look more elegant.
 There are also two EMAs within the script that do nothing but help candle coloring and help provide a trade side bias.  When both EMA's and the HMA align, a side  bias is defined.  Only when the side bias changes will a new dot is formed.
 
Head candles have been simplified from previous versions to be easier to read at a a glance.
  
Search in scripts for "one一季度财报"
Useful_lib_publicLibrary   "Useful_lib_public" 
Useful functions
 CountBarsOfDay() 
  count bars for one for the diffrent time frames
  Returns: number of bars for one day
 LastBarsOfDay() 
  Index number for the las bar for one day
  Returns: TRUE is that the last bar from day
 isTuesday() 
  TRUE is tuesday
  Returns: TRUE is tuesday else FALSE
 Rsi(src, len) 
  RSI calulation
  Parameters:
     src (float) : RSI Source
     len (simple int) : RSI Length
  Returns: RSI Value
 CalcIndex(netPos, weeks) 
  Index calulation
  Parameters:
     netPos (float) : Source
     weeks (simple int) : Length
  Returns: "COT Index"
 RsiStock(src, len, smoothK) 
  TRUE is tuesday
  Parameters:
     src (float) 
     len (simple int) 
     smoothK (int) 
  Returns: RSI Stochastik
 Offset() 
  Use Offset for Day time frame
  Returns: Offset
 PercentChange(Data, LastData) 
  Calc different in Percent
  Parameters:
     Data (float) 
     LastData (float) 
  Returns: Change in percent
Smart Money Concept [TradingFinder] Major OB + FVG + Liquidity🔵 Introduction 
"Smart Money" refers to funds under the control of institutional investors, central banks, funds, market makers, and other financial entities. Ordinary people recognize investments made by those who have a deep understanding of market performance and possess information typically inaccessible to regular investors as "Smart Money". 
Consequently, when market movements often diverge from expectations, traders identify the footprints of smart money. For example, when a classic pattern forms in the market, traders take short positions. However, the market might move upward instead. They attribute this contradiction to smart money and seek to capitalize on such inconsistencies in their trades.
The "Smart Money Concept" (SMC) is one of the primary styles of technical analysis that falls under the subset of "Price Action". Price action encompasses various subcategories, with one of the most significant being "Supply and Demand", in which SMC is categorized. 
The SMC method aims to identify trading opportunities by emphasizing the impact of large traders (Smart Money) on the market, offering specific patterns, techniques, and trading strategies.
🟣 Key Terms of Smart Money Concept (SMC) 
• Market Structure (Trend)
• Change of Character (ChoCh)
• Break of Structure (BoS)
• Order Blocks (Supply and Demand)
• Imbalance (IMB)
• Inefficiency (IFC)
• Fair Value Gap (FVG)
• Liquidity
• Premium and Discount
🔵 How Does the "Smart Money Concept Indicator" Work? 
🟣 Market Structure 
    a. Accumulation
    b. Market-Up
    c. Distribution
    d. Market-Down
a)  Accumulation Phase : During the accumulation period, typically following a downtrend, smart money enters the market without significantly affecting the pricing trend.
b)  Market-Up Phase : In this phase, the price of an asset moves upward from the accumulation range and begins to rise. Usually, the buying by retail investors is the main driver of this trend, and due to positive market sentiment, it continues.
c)  Distribution Phase : The distribution phase, unlike the accumulation stage, occurs after an uptrend. In this phase, smart money attempts to exit the market without causing significant price fluctuations.
d)  Market-Down Phase : In this stage, the price of an asset moves downward from the distribution phase, initiating a prolonged downtrend. Smart money liquidates all its positions by creating selling pressure, trapping latecomer investors.
The result of these four phases in the market becomes the market trend.
  
 Types of Trends in Financial Markets :
    a. Up-Trend
    b. Down Trend
    c. Range (No Trend)
a)  Up-Trend : The market breaks consecutive highs.
b)  Down Trend : The market breaks consecutive lows.
c)  No Trend or Range : The market oscillates within a range without breaking either highs or lows.
  
  
🟣 Change of Character (ChoCh) 
The "ChoCh" or "Change of Character" pattern indicates an initial change in order flow in financial markets. This structural change occurs when a major pivot in the opposite direction of the market trend fails. It signals a potential change in the market trend and can serve as a signal for short-term or long-term trend changes in a trading symbol.
🟣 Break of Structure (BoS) 
The "BoS" or "Break of Structure" pattern indicates the continuation of the trend in financial markets. This structure forms when, in an uptrend, the price breaks its ceiling or, in a downtrend, the price breaks its floor.
  
  
🟣 Order Blocks (Supply and Demand) 
Order blocks consist of supply and demand areas where the likelihood of price reversal is higher. There are six order blocks in this indicator, categorized based on their origin and formation reasons.
a. Demand Main Zone, "ChoCh" Origin.
b. Demand Sub Zone, "ChoCh" Origin.
c. Demand All Zone, "BoS" Origin.
d. Supply Main Zone, "ChoCh" Origin.
e. Supply Sub Zone, "ChoCh" Origin.
f. Supply All Zone, "BoS" Origin.
  
  
🟣 FVG | Inefficiency | Imbalance 
These three terms are almost synonymous. They describe the presence of gaps between consecutive candle shadows. This inefficiency occurs when the market moves rapidly. Primarily, imbalances and these rapid movements stem from the entry of smart money and the imbalance between buyer and seller power. Therefore, identifying these movements is crucial for traders.
These areas are significant because prices often return to fill these gaps or even before they occur to fill price gaps.
  
🟣 Liquidity 
Liquidity zones are areas where there is a likelihood of congestion of stop-loss orders. Liquidity is considered the driving force of the entire market, and market makers may manipulate the market using these zones. However, in many cases, this does not happen because there is insufficient liquidity in some areas. 
 Types of Liquidity in Financial Markets :
    a. Trend Lines
    b. Double Tops | Double Bottoms
    c. Triple Tops | Triple Bottoms
    d. Support Lines | Resistance Lines
All four types of liquidity in this indicator are automatically identified.
  
  
🟣 Premium and Discount 
Premium and discount zones can assist traders in making better decisions. For instance, they may sell positions in expensive ranges and buy in cheaper ranges. The closer the price is to the major resistance, the more expensive it is, and the closer it is to the major support, the cheaper it is.
🔵 How to Use 
🟣 Change of Character (ChoCh) and Break of Structure (BoS) 
This indicator detects "ChoCh" and "BoS" in both Minor and Major states. You can turn on the display of these lines by referring to the last part of the settings.
  
🟣 Order Blocks (Supply and Demand) 
Order blocks are Zones where the probability of price reversal is higher. In demand Zones you can buy opportunities and in supply Zones you can check sell opportunities.
The "Refinement" feature allows you to adjust the width of the order block according to your strategy. There are two modes, "Aggressive" and "Defensive," in the "Order Block Refine". The difference between "Aggressive" and "Defensive" lies in the width of the order block. 
For risk-averse traders, the "Defensive" mode is suitable as it provides a lower loss limit and a greater reward-to-risk ratio. For risk-taking traders, the "Aggressive" mode is more appropriate. These traders prefer to enter trades at higher prices, and this mode, which has a wider order block width, is more suitable for this group of individuals.
  
  
🟣 Fair Value Gap (FVG) | Imbalance (IMB) | Inefficiency (IFC) 
In order to identify the "fair value gap" on the chart, it must be analyzed candle by candle. In this process, it is important to pay attention to candles with a large size, and a candle and a candle should be examined before that. 
Candles before and after this central candle should have long shadows and their bodies should not overlap with the central candle body. The distance between the shadows of the first and third candles is known as the FVG range.
 These areas work in two ways :
•  Supply and demand area : In this case, the price reacts to these areas and the trend is reversed.
•  Liquidity zone : In this scenario, the price "fills" the zone and then reaches the order block.
 Important note : In most cases, the FVG zone of very small width acts as a supply and demand zone, while the zone of significant width acts as a liquidity zone and absorbs price.
When the FVG filter is activated, the FVG regions are filtered based on the specified algorithm.
 FVG filter types include the following :
1. Very Aggressive Mode : In addition to the initial condition, an additional condition is considered. For bullish FVG, the maximum price of the last candle must be greater than the maximum price of the middle candle. 
Similarly, for a bearish FVG, the minimum price of the last candle must be lower than the minimum price of the middle candle. This mode removes the minimum number of FVGs.
2. Aggressive : In addition to the very aggressive condition, the size of the middle candle is also considered. The size of the center candle should not be small and therefore more FVGs are removed in this case.
3. Defensive : In addition to the conditions of the very aggressive mode, this mode also considers the size of the middle pile, which should be relatively large and make up the majority of the body. 
Also, to identify bullish FVGs, the second and third candles must be positive, while for bearish FVGs, the second and third candles must be negative. This mode filters out a significant number of FVGs and keeps only those of good quality.
4. Very Defensive : In addition to the conditions of the defensive mode, in this mode the first and third candles should not be very small-bodied doji candles. This mode filters out most FVGs and only the best quality ones remain.
  
🟣 Liquidity 
These levels are where traders intend to exit their trades. "Market makers" or smart money usually accumulate or distribute their trading positions near these levels, where many retail traders have placed their "stop loss" orders. When liquidity is collected from these losses, the price often reverses.
A "Stop hunt" is a move designed to offset liquidity generated by established stop losses. Banks often use major news events to trigger stop hunts and capture liquidity released into the market. For example, if they intend to execute heavy buy orders, they encourage others to sell through stop-hots.
Consequently, if there is liquidity in the market before reaching the order block area, the validity of that order block is higher. Conversely, if the liquidity is close to the order block, that is, the price reaches the order block before reaching the liquidity limit, the validity of that order block is lower.
  
  
  
🟣 Alert 
With the new alert functionality in this indicator, you won't miss any important trading signals. Alerts are activated when the price hits the last order block.
1. It is possible to set alerts for each "symbol" and "time frame". The system will automatically detect both and include them in the warning message.
2. Each alert provides the exact date and time it was triggered. This helps you measure the timeliness of the signal and evaluate its relevance.
3. Alerts include target order block price ranges. The "Proximal" level represents the initial price level strike, while the "Distal" level represents the maximum price gap in the block. These details are included in the warning message.
4. You can customize the alert name through the "Alert Name" entry.
5. Create custom messages for "long" and "short" alerts to be sent with notifications.
  
🔵 Setting 
a.  Pivot Period of Order Blocks Detector : 
Using this parameter, you can set the zigzag period that is formed based on the pivots.
b.  Order Blocks Validity Period (Bar) : 
You can set the validity period of each Order Block based on the number of candles that have passed since the origin of the Order Block.
c.  Demand Main Zone, "ChoCh" Origin : 
You can control the display or not display as well as the color of Demand Main Zone, "ChoCh" Origin.
d.  Demand Sub Zone, "ChoCh" Origin : 
You can control the display or not display as well as the color of Demand Sub Zone, "ChoCh" Origin.
e.  Demand All Zone, "BoS" Origin : 
You can control the display or not display as well as the color of Demand All Zone, "BoS" Origin.
f.  Supply Main Zone, "ChoCh" Origin : 
You can control the display or not display as well as the color of Supply Main Zone, "ChoCh" Origin.
g.  Supply Sub Zone, "ChoCh" Origin : 
You can control the display or not display as well as the color of Supply Sub Zone, "ChoCh" Origin.
h.  Supply All Zone, "BoS" Origin : 
You can control the display or not display as well as the color of Supply All Zone, "BoS" Origin.
i.  Refine Demand Main : You can choose to be refined or not and also the type of refining.
j.  Refine Demand Sub : You can choose to be refined or not and also the type of refining. 
k.  Refine Demand BoS : You can choose to be refined or not and also the type of refining.
l.  Refine Supply Main : You can choose to be refined or not and also the type of refining.
m.  Refine Supply Sub : You can choose to be refined or not and also the type of refining.
n.  Refine Supply BoS : You can choose to be refined or not and also the type of refining.
o.  Show Demand FVG : You can choose to show or not show Demand FVG.
p.  Show Supply FVG : You can choose to show or not show Supply FVG
q.  FVG Filter : You can choose whether FVG is filtered or not. Also specify the type of filter you want to use.
r.  Show Statics High Liquidity Line : Show or not show Statics High Liquidity Line.
s.  Show Statics Low Liquidity Line : Show or not show Statics Low Liquidity Line.
t.  Show Dynamics High Liquidity Line : Show or not show Dynamics High Liquidity Line. 
u.  Show Dynamics Low Liquidity Line : Show or not show Dynamics Low Liquidity Line.
v.  Statics Period Pivot : 
Using this parameter, you can set the Swing period that is formed based on Static  Liquidity Lines.
w.  Dynamics Period Pivot :  
Using this parameter, you can set the Swing period that is formed based Dynamics Liquidity Lines.
x.  Statics Liquidity Line Sensitivity : 
is a number between 0 and 0.4. Increasing this number decreases the sensitivity of the "Statics Liquidity Line Detection" function and increases the number of lines identified. The default value is 0.3.
y.  Dynamics Liquidity Line Sensitivity :
is a number between 0.4 and 1.95. Increasing this number increases the sensitivity of the "Dynamics Liquidity Line Detection" function and decreases the number of lines identified. The default value is 1.
z.  Alerts Name : You can customize the alert name using this input and set it to your desired name.
aa.  Alert Demand Main Mitigation : 
If you want to receive the alert about Demand Main 's mitigation after setting the alerts, leave this tick on. Otherwise, turn it off.
bb.  Alert Demand Sub Mitigation : 
If you want to receive the alert about Demand Sub's mitigation after setting the alerts, leave this tick on. Otherwise, turn it off.
cc.  Alert Demand BoS Mitigation : 
If you want to receive the alert about Demand BoS's mitigation after setting the alerts, leave this tick on. Otherwise, turn it off.
dd.  Alert Supply Main Mitigation :
If you want to receive the alert about Supply Main's mitigation after setting the alerts, leave this tick on. Otherwise, turn it off.
ee.  Alert Supply Sub Mitigation : 
If you want to receive the alert about Supply Sub's mitigation after setting the alerts, leave this tick on. Otherwise, turn it off.
ff.  Alert Supply BoS Mitigation : 
If you want to receive the alert about Supply BoS's mitigation after setting the alerts, leave this tick on. Otherwise, turn it off.
gg.  Message Frequency : 
This parameter, represented as a string, determines the frequency of announcements. Options include: 'All' (triggers the alert every time the function is called), 'Once Per Bar' (triggers the alert only on the first call within the bar), and 'Once Per Bar Close' (activates the alert only during the final script execution of the real-time bar upon closure). The default setting is 'Once per Bar'.
hh.  Show Alert time by Time Zone : 
The date, hour, and minute displayed in alert messages can be configured to reflect any chosen time zone. For instance, if you prefer London time, you should input 'UTC+1'. By default, this input is configured to the 'UTC' time zone.
ii. Display More Info : The 'Display More Info' option provides details regarding the price range of the order blocks (Zone Price), along with the date, hour, and minute. If you prefer not to include this information in the alert message, you should set it to 'Off'.
 You also have access to display or not to display, choose the Style and Color of all the lines below :
a. Major Bullish "BoS" Lines
b. Major Bearish "BoS" Lines
c. Minor Bullish "BoS" Lines
d. Minor Bearish "BoS" Lines
e. Major Bullish "ChoCh" Lines
f. Major Bearish "ChoCh" Lines
g. Minor Bullish "ChoCh" Lines
h. Minor Bearish "ChoCh" Lines
i. Last Major Support Line
j. Last Major Resistance Line
k. Last Minor Support Line
l. Last Minor Resistance Line
Timeframe Continuity Oscillator [TFO]This indicator is used to visualize timeframe continuity - a core concept of "The Strat" - along with some added logic for potential range limiters.
When discussing timeframe continuity, typically we are evaluating several timeframes to see if price is trading above or below the current open of each respective timeframe. If we are concerned with the 15m, 4h, and 1D for example, and price is trading above the current open of each of those timeframes, we can say that we have full timeframe continuity (FTFC) up. Conversely, if price is trading below the current open of each of those timeframes, we can say that we have FTFC down.
We can visualize this with an oscillator of sorts, where the zero line is anchored to the open price of the highest timeframe that we're concerned with. Using the prior example, this would be the 1D timeframe. As long as price is above the current 1D open, it is impossible to have FTFC down; and as long as price is below the current 1D open, it is impossible to have FTFC up. This is why we base the oscillator's values off of the highest timeframe's open (the values are simply how far price has traded from this open) - any value greater than zero tells us that there is potential to have FTFC up, and any value less than zero tells us that there is potential to have FTFC down.
There are a few ways we chose to visualize this data. First, we can choose the "Binary" option which simply uses one solid bullish color above the zero line, and one solid bearish color below the zero line.
  
Second, we can choose the "Gradient" option to help describe whether we have FTFC up or down. Values above the zero line will be a mix of the bullish color and mid color, where the mid color indicates no timeframe continuity up and the bullish color indicates FTFC up - sort of like a color spectrum of timeframe continuity to describe how many timeframes are in agreement. Similarly, values below the zero line will be a mix of the bearish color and the mid color, where the mid color again indicates no timeframe continuity down and the bearish color indicates FTFC down.
  
Lastly, we can choose the "FTFC Only" option which will only color the histogram bars as bullish if there is FTFC up, or bearish if there is FTFC down.
  
One more feature that we added is these upper and lower bands that aim to help describe the potential upper and lower limits that price may travel, relative to the highest timeframe's open. This is done by taking the standard deviation of some defined lookback period, for example, 2 standard deviations of the previous 10 weeks, assuming 1W is the highest timeframe enabled. 
  
The concept is similar to that of an ADR (average daily range) as it can be used to estimate maximum range extensions for the largest timeframe. The arrows you see are plotted once the value exceeds either band - alerts can be enabled for these events as well through any alert() function call.
 sVPSA - standardized Volume Price Spread AnalysisDear Analysts and Traders,
I want to introduce my new indicator - sVPSA - standardized Volume Price Spread Analysis. For me, this script is helpfully in Technical Analysis mainly with Wyckoff and VSA methodologies. Maybe You are in circle of people who used my previous script - normalized Volume Price Spread Analysis. I work with him a lot of time, but I come to a conclusion that I can do better...
Theory concept...
What is a big volume? How big was this spread? It was extreme high or just high? How to do an answer for this and a lot other questions related to this subject? My thoughts was directed to statistics. In my first script I used to x/max normalized data. It was good, but susceptible for high deviation events. So, I choose standardization method with smaller sensitivity on violent events - z-Score standardization Description of z-Score formula:
Z = (x-mean)/standard deviation 
Probability of event are descriptive by probability density function - The Normal Distribution.  
 en.wikipedia.org 
en.Wikipedia.org
This is base of script methodology, let’s go deeper in indicator. 
X axis is time, date. Y axis is standard deviation. Narrow bar represent price spread, wide one is volume. Colors are corresponding to deviation, blue < sigma, green > sigma, red > 2*sigma and fuchsia > 3*sigma. Appearance is full editable. 
Data collection starts from left to right. There is two possibilities to use, constans number of bars or visible data range, also indicator permit to overscore linear regression from data. There is a possibility to set an alert. 
Short introduction how put an interpretation on visualized data. 
  
For this example I used constans value of data collection, 52 bars. So, from left I see great, fuchsia volume bar with low spread. This record respond Celsius withdrawals pause. This is bar with the biggest volume on presented chart, more than four sigmas. Spread value is near one sigma. I should consider this via one of Wyckoffs laws - effort vs result. I see a three bars in turn, they tenor tells me that bear market is possible near end. Accumulation structure near new year,  spring test and bullish momentum bar near march are approval of this idea. Next high spread bars have volume near mean value. Effort is low but result is great. Interesting is last bar, with -2,8 deviation of volume. I see the lowest volume value on chart, so he’s deviation is strong to negative side. This script require a little of practise and can be a potent tool in Technical Analysis. 
If You have a concept how to improve my script or You experience bug, please, send me feedback. 
I hope that You consider my work as useful. 
I wish You great trades and faultless analysis. 
CatTheTrader
swinglibraryLibrary   "swinglibrary" 
This library is for calculating non-repainting swings for further calculation on them.
These swings can later be drawn, but drawing is not part of this library, only the calculation.
 What do I need to use the library? 
You better include the following constants into your script using this library:
 
int SWING_NO_ACTION         = 0
int SWING_FLIP              = 1
int SWING_FLIP_NEW_SWING    = 2
int SWING_FLIP_UPDATED      = 3
int RELATION_HIGHER         = 1
int RELATION_EQUAL          = 0
int RELATION_LOWER          = -1
 
 Choosing the function, that fits your needs 
This library contains 4 functions for calculating swings, the difference between them are the data you get for every swing point and additional average values for length and duration:
 
  swings()
  swingsR()
  swingsL()
  swingsLDR()
 
The  naming scheme  of these functions is the following:
The base version swings() is only for the swings containing the following swingPoint type:
 swingPoint 
  Fields:
     x (integer) : bar index
     y (float) : price
     hilo (integer)  1 -> high, -1 -> low
and the return type:
 swingReturn 
  Fields:
     swings (array) : array of the last x swing points
     newSwingHigh (integer) : flag to detect changes for swing highs see constants (SWING_NO_ACTION, SWING_FLIP_NEW_SWING, SWING_FLIP_UPDATED)
     newSwingLow (integer) : flag to detect changes for swing lows see constants (SWING_NO_ACTION, SWING_FLIP_NEW_SWING, SWING_FLIP_UPDATED)
The  R  in swingsR() stands for  relation  where the previously shown types do also contain the relation between the swings of the same swing type (highs and lows respectively).
The same goes for  L  in swingsL() for  length  containing the price difference between the current and previous swing point in ticks.
And in the following version swingsLDR() there is also the  duration  between the current and previous point included.
The parameters for the other functions and type definitions include only the ones, that are needed, the "full" version of the function is described here:
 swingsLDR(swingSize, dtbStrength, init, SWING_HISTORY_NUM) 
  Parameters:
     swingSize (int)  This parameter defines the size of the swings to look after, meaning higher values will lead to bigger swings
     dtbStrength (int)  Value between 0 and 100 is a factor (%) to the ATR that is used to calculate equal highs/lows (double tops / bottoms).
Higher values will result in a higher tolerance of price difference between the swings.
     init (bool)  This value is usually set to false on default.
It has a special use case, where we need to reduce memory usage and calculation time on the script using this library by start calculating at x bars back instead of the beginning of the chart.
In this case, we set init = true on the first bar we start calculating the swings on to perform the correct initialization.
     SWING_HISTORY_NUM (int)  This is the max number of swings that are stored in the array, so only the last SWING_HISTORY_NUM swings are stored in the array to reduce the memory usage.
New ones remove the oldest ones like in a ring buffer.
This is also influencing the average duration and average swing length.
 swingPointLDR 
  Fields:
     x (integer) : bar index
     y (float) : price
     hilo (integer) : 1 -> high, -1 -> low
     length (float) : price difference to the previous swing point in ticks
     duration (integer) : duration difference to the previous swing point in number of bars
     relation (integer) : see constants RELATION_HIGHER, RELATION_EQUAL, RELATION_LOWER: reelation to the previous swing points of the same type (previous high or previous low respectively)
 swingReturnLDR 
  Fields:
     swings (array) : array of the last x swing points
     newSwingHigh (integer) : flag to detect changes for swing highs see constants (SWING_NO_ACTION, SWING_FLIP_NEW_SWING, SWING_FLIP_UPDATED)
     newSwingLow (integer) : flag to detect changes for swing lows see constants (SWING_NO_ACTION, SWING_FLIP_NEW_SWING, SWING_FLIP_UPDATED)
     avSwLength (float) : average swing length for the last x swings (depending on the max number of swings)
     avSwingDuration (float) : average swing duration for the last x swings (depending on the max number of swings)
Relative Average Extrapolation [ChartPrime]Relative Average Extrapolation (ChartPrime)  is a new take on session averages, like the famous  vwap . This indicator leverages patterns in the market by leveraging average-at-time to get a footprint of the average market conditions for the current time. This allows for a great estimate of market conditions throughout the day allowing for predictive forecasting. If we know what the market conditions are at a given time of day we can use this information to make assumptions about future market conditions. This is what allows us to estimate an entire session with fair accuracy. This indicator works on any intra-day time frame and will not work on time frames less than a minute, or time frames that are a day or greater in length. A unique aspect of this indicator is that it allows for analysis of pre and post market sessions independently from regular hours. This results in a cleaner and more usable vwap for each individual session. One drawback of this is that the indicator utilizes an average for the length of a session. Because of this, some after hour sessions will only have a partial estimation. The average and deviation bands will work past the point where it has been extrapolated to in this instance however. On low time frames due to the limited number of data points, the indicator can appear noisy. 
  
Generally crypto doesn't have a consistent footprint making this indicator less suitable in crypto markets. Because of this we have implemented other weighting schemes to allow for more flexibility in the number of use cases for this indicator. Besides volume weighting we have also included time, volatility, and linear (none) weighting. Using any one of these weighting schemes will transform the vwap into a wma, volatility adjusted ma, or a simple moving average. All of the style are still session period and will become  longer  as the session progresses. 
  
 Relative Average Extrapolation (ChartPrime)  works by storing data for each time step throughout the day by utilizing a custom indexing system. It takes the a  key , ie hour/minute, and transforms it into an array index to stor the current data point in its unique array. From there we can take the current time of day and advance it by one step to retrieve the data point for the next bar index. This allows us to utilize the footprint the extrapolate into the future. We use the relative rate of change for the average, the relative deviation, and relative price position to extrapolate from the current point to the end of the session. This process is fast and effective and possibly easier to use than the built in map feature. 
  
If you have used vwap before you should be familiar with the general settings for this indicator. We have made a point to make it as intuitive for anyone who is already used to using the standard vwap. You can pick the source for the average and adjust/enable the deviation bands multipliers in the settings group. The average period is what determines the number of days to use for the average-at-time. When it is set to 0 it will use all available data. Under "Extrapolation" you will find the settings for the estimation. "Direction Sensitivity" adjusts how sensitive the indicator is to the direction of the vwap. A higher number will allow it to change directions faster, where a lower number will make it more stable throughout the session. Under the "Style" section you will find all of the color and style adjustments to customize the appearance of this indicator. 
  
 Relative Average Extrapolation (ChartPrime)  is an advanced and customizable session average indicator with the ability to estimate the direction and volatility of intra-day sessions. We hope you will find this script fascinating and useful in your trading and decision making. With its unique take on session weighting and forecasting, we believe it will be a secret weapon for traders for years to come.
 Enjoy 
Volume Bars ColorThe Volume Bars Color indicator for the TradingView platform is a tool for visualizing trading volumes based on their values. It colors volume histograms on the chart according to their relative magnitude compared to the average volume and standard deviation.
Features:
- Volumes exceeding the average value by more than one standard deviation are considered large and highlighted in red.
- Volumes lower than the average by more than one standard deviation are considered low and displayed in orange.
- Volumes within one standard deviation of the average are considered average and marked in gray.
- Users can adjust the period for calculating the average volume.
How to Use:
- Add the indicator to your chart.
- Adjust the period for calculating the average volume using the corresponding parameter.
- Observe how trading volumes on the chart are colored based on their magnitude relative to the average volume and standard deviation.
Example Usage:
On the chart, red volume histograms indicate periods of high trading activity, orange histograms signify low trading volume, and gray histograms represent average trading volume.
Remember:
The Volume Bars Color indicator helps visualize trading volumes and identify periods with the most active or least active trading volume. However, it should be used in conjunction with other tools and analytical methods to make informed trading decisions.
1000X Dual T3 Set to Any Time Frame1000X Dual T3 Set to Any Time Frame
The "1000X Dual T3 Set to Any Time Frame" is an enhancement of the well-known T3 indicator, building upon the  T3 Average script by HPotter , which was itself based on Tim Wilson's work on smoothing techniques. This version provides two T3 lines, which is useful when adapting one each to the long and short trends on the same chart, with the added flexibility of setting the indicator to a higher time frame than the one you are currently trading. We also make the "b" value adjustable, creating a more sensitivity, adaptable indicator. This indicator is recommended as a trend filter  or confirmation indicator in trading strategies. 
 Key Features 
Dual Trend Analysis: The dual T3 offers a view of long and short trends to aid in better optimized market analysis. This avoids the problem with using a single T3 line to filter tradable price action for both long and short sides, which forces one to compromise performance in order to achieve profitability in both directions. 
Timeframe Customization: This indicator can be set to a desired timeframe while trading another. For example, the T3 can be set as a trend filter on the daily or weekly time frame to separate bull and bear markets, even as you work with other indicators on a chart set to a lower time frame. Set the time frame in the inputs, using minutes (15, 60, 240, etc.) or using D, W, and M. 
Preserved T3 Script: Like the powerful HPotter script on which it builds, this indicator leverages EMA-based T3 smoothing calculations for smooth and responsive trend lines. 
B Value adjustability: Given the role of the b value in smoothing and sensitivity, I have found it beneficial to make the b value an adjustable input as well. A higher b value will make the T3 line more responsive to recent price changes, making it closer to the actual price movements but potentially more susceptible to market noise. 
Visual Trend Indicators: In addition to filtering markets using the "above or below" approach, this script provides colour coding to delineate trend directions.
Acknowledgments
As stated, this work is a tribute to the foundational contributions of Tim Wilson and the subsequent development by HPotter whose script was the basis of this one. The enhancements in this version aim to provide added value to the trading community. 
Twin Range Filter VisualizedVisulaized version of @colinmck's Twin Range Filter version on TradingView.
On @colinmck's Twin Range Filter version, you can only see Long and Short signals on the chart.
But in this version of TRF, users can visually see the BUY and SELL signals on the chart with an added line of TRF.
TRF is an average of two smoothed Exponential Moving Averages, fast one has 27 bars of length and the slow one has 55 bars.
The purpose is to obtain two ranges that price fluctuates between (upper and lower range) and have LONG AND SHORT SIGNALS when close price crosses above the upper range and conversely crosses below lower range.
I personally combine the upper and lower ranges on one line to see the long and short signals with my own eyes so,
-BUY when price is higher or equal to the upper range level and the indicator line turns to draw the lower range to follow the price just under the bars as a trailing stop loss indicator like SuperTrend.
-SELL when price is lower or equal to the lower range levelline under the bars and then the indicator line turns to draw the upper range to follow the price just over the bars in that same trailing stop loss logic.
There are also two coefficients that adjusts the trailing line distance levels from the price multiplying the effect of the faster and slower moving averages.
The default values of the multipliers:
Fast range multiplier of Fast Moving Average(27): 1.6
Slow range multiplier of fSlow Moving Average(55): 2
Remember that if you enlarge these multipliers you will enlarge the ranges and have less but lagging signals. Conversely, decreasing the multipliers will have small ranges (line will get closer to the price and more signals will occur)
Divergence Detector [TradingFinder] RSI + MACD + AO Oscillator 🔵 Introduction 
🟣 Understanding Divergence 
As mentioned, divergence occurs in technical analysis when a stock's price behaves contrary to indicators on the price chart. Divergence can signify either a reversal of the stock's trend or a continuation of the previous trend correction. 
Divergences can act as reversal patterns or continuation patterns. Moreover, divergences can be utilized to identify potential support and resistance levels.
For instance, when an indicator is trending upwards and positive, but the price is declining and trending downwards, divergence occurs. Divergence in a stock indicates trader indecision in buying and selling and warns traders to reconsider their decisions regarding buying or holding the stock. 
Divergence aids analysts in identifying critical price points. In indicator divergences, it serves as a potent signal in the realm of technical analysis.
🟣 Types of Divergence 
1.Regular Divergence
    o	Positive Regular Divergence (RD+)
    o	Negative Regular Divergence (RD-)
2.Hidden Divergence
    o	Positive Hidden Divergence (HD+)
    o	Negative Hidden Divergence (HD-)
3.Time Divergence
 Key Note : This indicator is specifically designed to identify "Regular Divergence" only. Therefore, the following explanation pertains to this type of divergence.
🔵 Regular Divergence/Convergence 
Regular Divergence(Convergence) occurs due to conflicting behavior between the indicator and the price chart, typically at the end of a trend. Recognizing Regular Divergence suggests an anticipation of a trend reversal or a pattern resembling a reversal.
  
🟣 Positive Regular Divergence (RD+) 
In contrast to negative divergence, positive Regular Divergence occurs at the end of a downtrend and between two price lows. It manifests when the price forms a new low on the price chart, but the indicator fails to recognize it. 
Positive Regular Divergence indicates strong buying pressure and weak selling pressure. Following the identification of positive divergence on the chart, one can anticipate a price increase for the examined stock.
  
🟣 Negative Regular Divergence (RD-) 
This type of Regular Divergence emerges between two price highs during an uptrend. A new high is formed on the price chart, but the indicator fails to acknowledge it. This scenario indicates negative Regular Divergence. 
The likelihood of a subsequent market downturn is high. Negative divergence signifies strong selling pressure and weak buying pressure, suggesting an unfavorable future for the stock.
  
🔵 How to use 
By utilizing the "Fractal Period" input, you can specify your desired periods for identifying divergences.
Additionally, through the "Divergence Detect Method" feature, you can choose which oscillators (MACD, RSI, or AO) to base divergence identification on.
 Divergence in MACD Oscillator :
Divergence in the MACD indicator occurs when the price chart and the MACD line form a noticeable opposing pattern, meaning the price moves contrary to the MACD line. In this scenario, one expects a reversal in price direction.
  
 Divergence in RSI Oscillator :
If divergence occurs during a downtrend on the price chart (two consecutive lows, with the second low being lower) and on the corresponding RSI point (two consecutive lows, with the second low being higher), it signifies positive Regular Divergence and implies a buying signal.
 
Conversely, if divergence occurs during an uptrend on the price chart (two consecutive highs, with the second high being higher) and on the corresponding RSI point (two consecutive highs, with the second high being lower), it indicates negative Regular Divergence, signaling a selling opportunity.
  
 Divergence in AO Oscillator :
The AO indicator calculates histograms similar to the AO base. It calculates the difference between the simple moving averages of 5 and 34 periods based on the median of each bar. Then, it plots the bars based on the difference. 
It then compares the histograms to detect peaks and troughs in the AO histograms and compares the identified peaks and troughs to the price. Whenever divergence is detected, it plots lines and arrows.
  
🔵 Table 
The table contains information on the functional features of this oscillator that you can utilize. Four categories of information are presented in the table: "Exist," "Consecutive," "Divergence Quality," and "Change Phase Indicator."
 Exist : 
If divergence exists, you'll see "+" in this row.
 Consecutive : 
Divergences may occur consecutively. If same-type divergences form within short intervals, you can observe the count in this row.
  
 Divergence Quality : Based on the number of consecutive divergences, their quality can be evaluated. If one divergence exists, its quality is considered "Normal." If two divergences exist, the quality is "Good," and if three or more divergences exist, the quality is considered "Strong."
 Change Phase Indicator : If a phase change occurs between two oscillation peaks formed based on divergence, this change is identified and displayed in this row.
  
Momentum Ghost Machine [ChartPrime]Momentum Ghost Machine (ChartPrime)  is designed to be the next generation in momentum/rate of change analysis. This indicator utilizes the properties of one of our favorite filters to create a more accurate and stable momentum oscillator by using a high quality filtered delayed signal to do the momentum comparison. 
Traditional momentum/roc uses the raw price data to compare current price to previous price to generate a directional oscillator. This leaves the oscillator prone to false readings and noisy outputs that leave traders unsure of the real likelihood of a future movement. One way to mitigate this issue would be to use some sort of moving average. Unfortunately, this can only go so far because simple moving average algorithms result in a poor reconstruction of the actual shape of the underlying signal. 
The  windowed sinc  low pass filter is a linear phase filter, meaning that it doesn't change the shape or size of the original signal when applied. This results in a faithful reconstruction of the original signal, but without the "high frequency noise". Just like any filter, the process of applying it requires that we have "future" samples resulting in a time delay for real time applications. Fortunately this is a great thing in the context of a momentum oscillator because we need some representation of past price data to compare the current price data to. By using an ideal low pass filter to generate this delayed signal we can super charge the momentum oscillator and fix the majority of issues its predecessors had. 
This indicator has a few extra features that other momentum/roc indicators dont have. One major yet simple improvement is the inclusion of a moving average to help gauge the rate of change of this indicator. Since we included a moving average, we thought it would only be appropriate to add a histogram to help visualize the relationship between the signal and its average. To go further with this we have also included linear extrapolation to further help you predict the momentum and direction of this oscillator. Included with this extrapolation we have also added the histogram in the extrapolation to further enhance its visual interpretation. Finally, the inclusion of a candle coloring feature really drives how the utility of the  Momentum Machine . 
There are three distinct options when using the candle coloring feature: Direct, MA, and Both. With  direct  the candles will be colored based on the indicators direction and polarity. When it is above zero and moving up, it displays a green color. When it is above zero and moving down it will display a light green color. Conversely, when the indicator is below zero and moving down it displays a red color, and when it it moving up and below zero it will display a light red color. MA coloring will color the candles just like a MACD. If the signal is above its MA and moving up it will display a green color, and when it is above its MA and moving down it will display a light green color. 
When the signal is below its MA and moving down it will display a red color, and when its below its ma and moving up it will display a light red color. Both combines the two into a single color scheme providing you with the best of both worlds. If the indicator is above zero it will display the MA colors with a slight twist. When the indicator is moving down and is below its MA it will display a lighter color than before, and when it is below zero and is above its MA it will display a darker color color.
 Length of 50 with a smoothing of 100 
 Length of 50 with a smoothing of 25 
By default, the indicator is set to a  momentum length  of 50, with a  post smoothing  of 2. We have chosen the longer period for the momentum length to highlight the performance of this indicator compared to its ancestors. A major point to consider with this indicator is that you can only achieve so much smoothing for a chosen delay. This is because more data is required to produce a smoother signal at a specified length. Once you have selected your desired momentum length you can then select your desired  momentum smoothing . This is made possible by the use of the windowed sinc low pass algorithm because it includes a frequency cutoff argument. This means that you can have as little or as much smoothing as you please without impacting the period of the indicator. In the provided examples above this paragraph is a visual representation of what is going on under the hood of this indicator. The blue line is the filtered signal being compared to the current closing price. As you can see, the filtered signal is very smooth and accurately represents the underlying price action without noise.
We hope that users can find the same utility as we did in this indicator and that it levels up your analysis utilizing the momentum oscillator or rate of change. 
 Enjoy 
ZigZag Library [TradingFinder]🔵 Introduction  
The "Zig Zag" indicator is an analytical tool that emerges from pricing changes. Essentially, it connects consecutive high and low points in an oscillatory manner. This method helps decipher price changes and can also be useful in identifying traditional patterns. 
By sifting through partial price changes, "Zig Zag" can effectively pinpoint price fluctuations within defined time intervals.
🔵 Key Features 
1. Drawing the Zig Zag based on Pivot points :
The algorithm is based on pivots that operate consecutively and alternately (switch between high and low swing). In this way, zigzag lines are connected from a swing high to a swing low and from a swing low to a swing high.
Also, with a very low probability, it is possible to have both low pivots and high pivots in one candle. In these cases, the algorithm tries to make the best decision to make the most suitable choice.
You can control what period these decisions are based on through the "PiPe" parameter.
  
2.Naming and labeling each pivot based on its position as "Higher High" (HH), "Lower Low" (LL), "Higher Low" (HL), and "Lower High" (LH).
Additionally, classic patterns such as HH, LH, LL, and HL can be recognized. All traders analyzing financial markets using classic patterns and Elliot Waves can benefit from the "zigzag" indicator to facilitate their analysis.
" HH ": When the price is higher than the previous peak (Higher High). 
" HL ": When the price is higher than the previous low (Higher Low). 
" LH ": When the price is lower than the previous peak (Lower High). 
" LL ": When the price is lower than the previous low (Lower Low). 
  
🔵 How to Use  
First, you can add the library to your code as shown in the example below.
 import TFlab/ZigZagLibrary_TradingFinder/1 as ZZ 
 Function "ZigZag" Parameters :
🟣 Logical Parameters 
1. HIGH : You should place the "high" value here. High is a float variable.
2. LOW : You should place the "low" value here. Low is a float variable.
3. BAR_INDEX : You should place the "bar_index" value here. Bar_index is an integer variable.
4. PiPe : The desired pivot period for plotting Zig Zag is placed in this parameter. For example, if you intend to draw a Zig Zag with a Swing Period of 5, you should input 5. 
PiPe is an integer variable.
 Important : 
Apart from the "PiPe" indicator, which is part of the customization capabilities of this indicator, you can create a multi-time frame mode for the indicator using 3 parameters "High", "Low" and "BAR_INDEX". In this way, instead of the data of the current time frame, use the data of other time frames.
Note that it is better to use the current time frame data, because using the multi-time frame mode is associated with challenges that may cause bugs in your code.
  
🟣 Setting Parameters 
5. SHOW_LINE : It's a boolean variable. When true, the Zig Zag line is displayed, and when false, the Zig Zag line display is disabled.
6. STYLE_LINE : In this variable, you can determine the style of the Zig Zag line. You can input one of the 3 options: line.style_solid, line.style_dotted, line.style_dashed. STYLE_LINE is a constant string variable.
7. COLOR_LINE : This variable takes the input of the line color.
8. WIDTH_LINE : The input for this variable is a number from 1 to 3, which is used to adjust the thickness of the line that draws the Zig Zag. WIDTH_LINE is an integer variable.
9. SHOW_LABEL : It's a boolean variable. When true, labels are displayed, and when false, label display is disabled.
10. COLOR_LABEL : The color of the labels is set in this variable.
11. SIZE_LABEL : The size of the labels is set in this variable. You should input one of the following options: size.auto, size.tiny, size.small, size.normal, size.large, size.huge.
12. Show_Support : It's a boolean variable that, when true, plots the last support line, and when false, disables its plotting.
13. Show_Resistance : It's a boolean variable that, when true, plots the last resistance line, and when false, disables its plotting.
 Suggestion : 
You can use the following code snippet to import Zig Zag into your code for time efficiency.
 //import Library
import TFlab/ZigZagLibrary_TradingFinder/1 as ZZ
// Input and Setting
// Zig Zag Line
ShZ = input.bool(true , 'Show Zig Zag Line', group = 'Zig Zag') //Show Zig Zag
PPZ = input.int(5 ,'Pivot Period Zig Zag Line' , group = 'Zig Zag') //Pivot Period Zig Zag
ZLS = input.string(line.style_dashed , 'Zig Zag Line Style' , options =  , group = 'Zig Zag' )
//Zig Zag Line Style
ZLC = input.color(color.rgb(0, 0, 0) , 'Zig Zag Line Color' , group = 'Zig Zag')  //Zig Zag Line Color
ZLW = input.int(1 , 'Zig Zag Line Width' , group = 'Zig Zag')//Zig Zag Line Width 
// Label
ShL = input.bool(true , 'Label', group = 'Label') //Show Label 
LC =  input.color(color.rgb(0, 0, 0) , 'Label Color' , group = 'Label')//Label Color
LS =  input.string(size.tiny , 'Label size' , options =  , group = 'Label' )//Label size
Show_Support= input.bool(false, 'Show Last Support',
 tooltip = 'Last Support' , group = 'Support and Resistance')
Show_Resistance = input.bool(false, 'Show Last Resistance',
 tooltip = 'Last Resistance' , group = 'Support and Resistance')
//Call Function
ZZ.ZigZag(high ,low ,bar_index ,PPZ , ShZ ,ZLS , ZLC, ZLW ,ShL , LC , LS , Show_Support , Show_Resistance ) 
Earnings Line+Growth stock investors are concerned with Earnings per share that is growing, Sales (Revenue) that is growing and Increasing gross margins. This indicator helps view each of these parameters.
On the chart is Tesla (TSLA) gross margin (blue line) on a 12 trailing months basis (TTM). As you can see, TSLA's margins appear to be eroding.
The user selects one of the following parameters to display from the input drop down menu:
"EARNINGS_PER_SHARE_BASIC", "TOTAL_REVENUE", or "GROSS_MARGIN".
The value axis for your selection will appear on the left side of the chart.
The user also selects one of the following periods: "FY", "FQ" or "TTM" (Fiscal year, fiscal quarter or 12-trailing months). You have an option to display the inputs by checking the box. This is useful as a reminder but can be removed if the label is in the way.
The chart will render on any chart time scale, however longer time scales will probably be of more value. Weekly charts work well.
It is not possible to display more than one line simultaneously because of axis incompatibilities. However, it is possible to load this indicator multiple times and select different items in each. In this case additional left-side scales will be shown as well as additional lines. Common pairings are Revenue (Sales) and Earnings, or, Revenue and Gross Margin.
@ jmikes
Bitcoin Momentum StrategyThis is a very simple long-only strategy I've used since December 2022 to manage my Bitcoin position. 
I'm sharing it as an open-source script for other traders to learn from the code and adapt it to their liking if they find the system concept interesting.
 General Overview 
Always do your own research and backtesting - this script is not intended to be traded blindly (no script should be) and I've done limited testing on other markets beyond Ethereum and BTC, it's just a template to tweak and play with and make into one's own.
The results shown in the strategy tester are from Bitcoin's inception so as to get a large sample size of trades, and potential returns have diminished significantly as BTC has grown to become a mega cap asset, but the script includes a date filter for backtesting and it has still performed solidly in recent years (speaking from personal experience using it myself - DYOR with the date filter).
The main advantage of this system in my opinion is in limiting the max drawdown significantly versus buy & hodl. Theoretically much better returns can be made by just holding, but that's also a good way to lose 70%+ of your capital in the inevitable bear markets (also speaking from experience).
In saying all of that, the future is fundamentally unknowable and past results in no way guarantee future performance.
 System Concept: 
Capture as much Bitcoin upside volatility as possible while side-stepping downside volatility as quickly as possible.
The system uses a simple but clever momentum-style trailing stop technique I learned from one of my trading mentors who uses this approach on momentum/trend-following stock market systems.
Basically, the system "ratchets" up the stop-loss to be much tighter during high bearish volatility to protect open profits from downside moves, but loosens the stop loss during sustained bullish momentum to let the position ride.
It is invested most of the time, unless BTC is trading below its 20-week EMA in which case it stays in cash/USDT to avoid holding through bear markets. It only trades one position (no pyramiding) and does not trade short, but can easily be tweaked to do whatever you like if you know what you're doing in Pine. 
 Default parameters: 
HTF: Weekly Chart
EMA: 20-Period
ATR: 5-period
Bar Lookback: 7
 Entry Rule #1: 
Bitcoin's current price must be trading above its higher-timeframe EMA (Weekly 20 EMA).
 Entry Rule #2: 
Bitcoin must not be in 'caution' condition (no large bearish volatility swings recently). 
Enter at next bar's open if conditions are met and we are not already involved in a trade.
 "Caution" Condition: 
Defined as true if BTC's recent 7-bar swing high minus current bar's low is > 1.5x ATR, or Daily close < Daily 20-EMA.
 Trailing Stop: 
Stop is trailed 1 ATR from recent swing high, or 20% of ATR if in caution condition (ie. 0.2 ATR).
Exit on next bar open upon a close below stop loss. 
I typically use a limit order to open & exit trades as close to the open price as possible to reduce slippage, but the strategy script uses market orders. 
I've never had any issues getting filled on limit orders close to the market price with BTC on the Daily timeframe, but if the exchange has relatively low slippage I've found market orders work fine too without much impact on the results particularly since BTC has consistently remained above $20k and highly liquid.
 Cost of Trading: 
The script uses no leverage and a default total round-trip commission of 0.3% which is what I pay on my exchange based on their tier structure, but this can vary widely from exchange to exchange and higher commission fees will have a significantly negative impact on realized gains so make sure to always input the correct theoretical commission cost when backtesting any script. 
Static slippage is difficult to estimate in the strategy tester given the wide range of prices & liquidity BTC has experienced over the years and it largely depends on position size, I set it to 150 points per buy or sell as BTC is currently very liquid on the exchange I trade and I use limit orders where possible to enter/exit positions as close as possible to the market's open price as it significantly limits my slippage. 
But again, this can vary a lot from exchange to exchange (for better or worse) and if BTC volatility is high at the time of execution this can have a negative impact on slippage and therefore real performance, so make sure to adjust it according to your exchange's tendencies. 
Tax considerations should also be made based on short-term trade frequency if crypto profits are treated as a CGT event in your region.
 Summary: 
A simple, but effective and fairly robust system that achieves the goals I set for it. 
From my preliminary testing it appears it may also work on altcoins but it might need a bit of tweaking/loosening with the trailing stop distance as the default parameters are designed to work with Bitcoin which obviously behaves very differently to smaller cap assets.
Good luck out there!
Composite Trend Oscillator [ChartPrime]CODE DUELLO: 
Have you ever stopped to wonder what the underlying filters contained within complex algorithms are actually providing for you? Wouldn't it be nice to actually visually inspect for that? Those would require some kind of wild west styled quick draw duel or some comparison method as a proper 'code duello'. Then it can be determined which filter can 'draw' the quickest from it's computational holster with the least amount of lag and smoothness.
In Pine we can do so, discovering how beneficial that would be. This can be accomplished by quickly switching from one filter to another by input() back and forth, requiring visual memory. A better way could be done by placing two indicators added to the chart and then eventually placed into one indicator pane on top of each other.
By adding a filter() helper function that calls other moving average functions chosen for comparison, it can put to the test which moving average is the best drawing filter suited to our expected needs. PhiSmoother was formerly debuted and now it is utilized in a more complex environment in a multitude of ways along side other commonly utilized filters. Now, you the reader, get to judge for yourself...
 FILTER VERSATILITY: 
Having the capability to adjust between various smoothing methods such as PhiSmoother, TEMA, DEMA, WMA, EMA, and SMA  on historical market data within the code provides an advantage. Each of these filter methods offers distinct advantages and hinderances. PhiSmoother stands out often by having superb noise rejection, while also being able to manipulate the fine-tuning of the phase or lag of the indicator, enhancing responsiveness to price movements.
The following are more well-known classic filters. TEMA (Triple Exponential Moving Average) and DEMA (Double Exponential Moving Average) offer reduced transient response times to price changes fluctuations. WMA (Weighted Moving Average) assigns more weight to recent data points, making it particularly useful for reduced lag. EMA (Exponential Moving Average) strikes a balance between responsiveness and computational efficiency, making it a popular choice. SMA (Simple Moving Average) provides a straightforward calculation based on the arithmetic mean of the data. VWMA and RMA have both been excluded for varying reasons, both being unworthy of having explanation here.
By allowing for adjustment refinements between these filter methods, traders may garner the flexibility to adapt their analysis to different market dynamics, optimizing their algorithms for improved decision-making and performance on demand.
 INDICATOR INTRODUCTION: 
ChartPrime's Composite Trend Oscillator operates as an oscillator based on the concept of a moving average ribbon. It utilizes up to 32 filters with progressively longer periods to assess trend direction and strength. Embedded within this indicator is an alternative view that utilizes the separation of the ribbon filaments to assess volatility. Both versions are excellent candidates for trend and momentum, both offering visualization of polarity, directional coloring, and filter crossings. Anyone who has former experience using RSI or stochastics may have ease of understanding applying this to their chart. 
  
 COMPOSITE CLUSTER MODES EXPLAINED: 
In Trend Strength mode, the oscillator behavior signifies market direction and movement strength. When the oscillator is rising and above zero, the market is within a bullish phase, and visa versa. If the signal filter crosses the composite trend, this indicates a potential dynamic shift signaling a possible reversal. When the oscillator is teetering on its extremities, the market is more inclined to reverse later.
  
With Volatility mode, the oscillator undergoes a transformation, displaying an unbounded oscillator driven by market volatility. While it still employs the same scoring mechanism, it is now scaled according to the strength of the market move. This can aid with identification of ranging scenarios. However, one side effect is that the oscillator no longer has minimum or maximum boundaries. This can still be advantageous when considering divergences.
  
 NOTEWORTHY SETTINGS FEATURES: 
The following input settings described offer comprehensive control over the indicator's behavior and visualization.
Common Controls:
 
 Price Source Selection -  The indicator offers flexibility in choosing the price source for analysis. Traders can select from multiple options.
 Composite Cluster Mode -  Choose between "Trend Strength" and "Volatility" modes, providing insights into trend directionality or volatility weighting.
 Cluster Filter and Length -  Selects a filter for the cluster composition. This includes a length parameter adjustment.
 
Cluster Options:
 
 Cluster Dispersion -  Users can adjust the separation between moving averages in the cluster, influencing the sensitivity of the analysis.
 Cluster Trimming -  By modifying upper and lower trim parameters, traders can adjust the sensitivity of the moving averages within the cluster, enhancing its adaptability.
 PostSmooth Filter and Length -  Choose a filter to refine the composite cluster's post-smoothing with a length parameter adjustment.
 Signal Filter and Length -  Users can select a filter for the lagging signal plot, also having a length parameter adjustment.
 Transition Easing -  Sensitivity adjustment to influence the transition between bullish and bearish colors.
 Enjoy 
Signal Filter / Connectable [Azullian]The  connectable signal filter  is an intricate part of an  indicator system  designed to help test, visualize and build strategy configurations without coding. Like all  connectable indicators , it interacts through the TradingView input source, which serves as a  signal connector  to link indicators to each other. All connectable indicators send  signal weight  to the next node in the system until it reaches either a  connectable signal monitor, signal filter and/or strategy. 
The connectable signal filter's function has several roles in the connectable system: 
 •  Input hub:  Connect indicators or daisy-chained indicators directly to the filter, manage connections in one place
 •  Modification:  Modify incoming signals by applying smoothing, scaling, or modifiers
 •  Filtering:  Set the trade direction and conditions a signal must adhere to to be passed through
 •  Visualization:  When connected, the  signal filter  visualizes all incoming signal weights 
Let's review the separate parts of this indicator.
█  INPUTS 
We've provided 3 inputs for connecting indicators or chains (1→, 2→, 3→) which are all set to 'Close' by default. 
  
An input has several controls: 
 •  Enable disable:  Toggle the entire input on or off
 •  Input:  Connect indicators here, choose indicators with a compatible : Signal connector.
 •  G - Gain:  Increase or reduce the strength of the incoming signal by a factor.
█  FILTER SIGNALS  
   
The core of the  signal filter , determine a signal direction with the signal mode and determine a threshold (TH).
 •  ¤ - Trade direction: 
    ○ EL: Send Enter Long signals to the strategy
    ○ XL: Send Exit Long signals to the strategy
    ○ ES: Send Enter Short signals to the strategy
    ○ XS: Send Exit Short signals to the strategy
 •  TH - Threshold:  Define how much weight is needed for a signal to be accepted and passed through to the  connectable strategy .
■  VISUALS 
  
 •  ☼: Brightness % :  Set the opacity for the signal curves
 •  🡓: ES Color :  Set the color for the ES: Entry Short signal
 •  ⭳: XS Color :  Set the color for the XS: Exit Short signal
 •  ⌥: Plot mode :  Set the plotting mode
    ○ Signals IN: Show all signals
    ○ Signals OUT: Show only scoring signals
 •  🡑: EL Color :  Set the color for the EL: Enter Long signal
 •  ⭱: XL Color :  Set the color for the XL: Exit Long signal
█  USAGE OF CONNECTABLE INDICATORS 
 ■  Connectable chaining mechanism 
Connectable indicators can be connected directly to the  signal monitor, signal filter or strategy , or they can be daisy chained to each other while the last indicator in the chain connects to the signal monitor, signal filter or strategy. When using a  signal filter  you can chain the filter to the strategy input to make your chain complete.
  
   •  Direct chaining:  Connect an indicator directly to the  signal monitor, signal filter or strategy  through the provided inputs (→).
   •  Daisy chaining:  Connect indicators using the indicator input (→). The first in a daisy chain should have a flow (⌥) set to 'Indicator only'. Subsequent indicators use 'Both' to pass the previous weight. The final indicator connects to the  signal monitor, signal filter, or strategy. 
 ■  Set up the signal filter with a connectable indicator and strategy 
  Let's connect the MACD to a connectable  signal filter  and a  strategy : 
  1.  Load all relevant indicators  
   • Load MACD / Connectable
   • Load Signal filter / Connectable
   • Load Strategy / Connectable
  2.  Signal Filter: Connect the MACD to the Signal Filter  
   • Open the  signal filter  settings
   • Choose one of the three input dropdowns (1→, 2→, 3→) and choose : MACD / Connectable: Signal Connector
   • Toggle the enable box before the connected input to enable the incoming signal
  3.  Signal Filter: Update the filter settings if needed  
   • The default filter mode for the trading direction is SWING, and is compatible with the default settings in the strategy and indicators. 
  4.  Signal Filter: Update the weight threshold settings if needed  
   • All connectable indicators load by default with a score of 6 for each direction (EL, XL, ES, XS)
   • By default, weight threshold (TH)  in the  signal filter  is set at 5. This allows each occurrence to score, as the default score in each  / Connectable  indicator is 6 and thus is 1 point above the threshold. Adjust to your liking.
  5.  Strategy: Connect the strategy to the signal filter in the strategy settings  
   • Select a strategy input → and select the  Signal filter: Signal connector 
  6.  Strategy: Enable filter compatible directions  
   • As the default setting of the  signal filter  has enabled EL (Enter Long), XL (Exit Long), ES (Enter Short) and XS (Exit short), the   connectable strategy  will receive all compatible directions.
   
 
  Now that everything is connected, you'll notice green spikes in the  signal filter  representing long signals, and red spikes indicating short signals. Trades will also appear on the chart, complemented by a performance overview. Your journey is just beginning: delve into different scoring mechanisms, merge diverse connectable indicators, and craft unique chains. Instantly test your results and discover the potential of your configurations. Dive deep and enjoy the process!
 
█  BENEFITS 
•  Adaptable Modular Design:  Arrange indicators in diverse structures via direct or daisy chaining, allowing tailored configurations to align with your analysis approach.
•  Streamlined Backtesting:  Simplify the iterative process of testing and adjusting combinations, facilitating a smoother exploration of potential setups.
•  Intuitive Interface:  Navigate TradingView with added ease. Integrate desired indicators, adjust settings, and establish alerts without delving into complex code.
•  Signal Weight Precision:  Leverage granular weight allocation among signals, offering a deeper layer of customization in strategy formulation.
•  Advanced Signal Filtering:  Define entry and exit conditions with more clarity, granting an added layer of strategy precision.
•  Clear Visual Feedback:  Distinct visual signals and cues enhance the readability of charts, promoting informed decision-making.
•  Standardized Defaults:  Indicators are equipped with universally recognized preset settings, ensuring consistency in initial setups across different types like momentum or volatility.
•  Reliability:   Our indicators are meticulously developed to prevent repainting. We strictly adhere to TradingView's coding conventions, ensuring our code is both performant and clean.
█  COMPATIBLE INDICATORS 
  Each indicator that incorporates our open-source 'azLibConnector' library and adheres to our conventions can be effortlessly integrated and used as detailed above. 
  For clarity and recognition within the TradingView platform, we append the suffix ' / Connectable' to every compatible indicator. 
█  COMMON MISTAKES, CLARIFICATIONS AND TIPS 
 •  Removing an indicator from a chain:  Deleting a linked indicator and confirming the "remove study tree" alert will also remove all underlying indicators in the object tree. Before removing one, disconnect the adjacent indicators and move it to the object stack's bottom.
 •  Point systems:  The azLibConnector provides 500 points for each direction (EL: Enter long, XL: Exit long, ES: Enter short, XS: Exit short) Remember this cap when devising a point structure.
 •  Flow misconfiguration:  In daisy chains the first indicator should always have a flow (⌥) setting of 'indicator only' while other indicator should have a flow (⌥) setting of 'both'.
 •  Hide attributes:  As connectable indicators send through quite some information you'll notice all the arguments are taking up some screenwidth and cause some visual clutter. You can disable arguments in Chart Settings / Status line.
 •  Layout and abbreviations:  To maintain a consistent structure, we use abbreviations for each input. While this may initially seem complex, you'll quickly become familiar with them. Each abbreviation is also explained in the inline tooltips.
 •  Inputs:  Connecting a connectable indicator directly to the strategy delivers the raw signal without a weight threshold, meaning every signal will trigger a trade.
█  A NOTE OF GRATITUDE 
  Through years of exploring TradingView and Pine Script, we've drawn immense inspiration from the community's knowledge and innovation. Thank you for being a constant source of motivation and insight.
█  RISK DISCLAIMER 
  Azullian's content, tools, scripts, articles, and educational offerings are presented purely for educational and informational uses. Please be aware that past performance should not be considered a predictor of future results.
PhiSmoother Moving Average Ribbon [ChartPrime]DSP FILTRATION PRIMER: 
DSP (Digital Signal Processing) filtration plays a critical role with financial indication analysis, involving the application of digital filters to extract actionable insights from data. Its primary trading purpose is to distinguish and isolate relevant signals separate from market noise, allowing traders to enhance focus on underlying trends and patterns. By smoothing out price data, DSP filters aid with trend detection, facilitating the formulation of more effective trading techniques.
Additionally, DSP filtration can play an impactful role with detecting support and resistance levels within financial movements. By filtering out noise and emphasizing significant price movements, identifying key levels for entry and exit points become more apparent. Furthermore, DSP methods are instrumental in measuring market volatility, enabling traders to assess volatility levels with improved accuracy.
In summary, DSP filtration techniques are versatile tools for traders and analysts, enhancing decision-making processes in financial markets. By mitigating noise and highlighting relevant signals, DSP filtration improves the overall quality of trading analysis, ultimately leading to better conclusions for market participants.
 APPLYING FIR FILTERS: 
FIR (Finite Impulse Response) filters are indispensable tools in the realm of financial analysis, particularly for trend identification and characterization within market data. These filters effectively smooth out price fluctuations and noise, enabling traders to discern underlying trends with greater fidelity. By applying FIR filters to price data, robust trading strategies can be developed with grounded trend-following principles, enhancing their ability to capitalize on market movements.
Moreover, FIR filter applications extend into wide-ranging utility within various fields, one being vital for informed decision-making in analysis. These filters help identify critical price levels where assets may tend to stall or reverse direction, providing traders with valuable insights to aid with identification of optimal entry and exit points within their indicator arsenal. FIRs are undoubtedly a cornerstone to modern trading innovation.
Additionally, FIR filters aid in volatility measurement and analysis, allowing traders to gauge market volatility accurately and adjust their risk management approaches accordingly. By incorporating FIR filters into their analytical arsenal, traders can improve the quality of their decision-making processes and achieve better trading outcomes when contending with highly dynamic market conditions.
 INTRODUCTORY DEBUT: 
ChartPrime's " PhiSmoother Moving Average Ribbon " indicator aims to mark a significant advancement in technical analysis methodology by removing unwanted fluctuations and disturbances while minimizing phase disturbance and lag. This indicator introduces PhiSmoother, a powerful FIR filter in it's own right comparable to Ehlers' SuperSmoother.
PhiSmoother leverages a custom tailored FIR filter to smooth out price fluctuations by mitigating aliasing noise problematic to identification of underlying trends with accuracy. With adjustable parameters such as phase control, traders can fine-tune the indicator to suit their specific analytical needs, providing a flexible and customizable solution.
Mathemagically, PhiSmoother incorporates various color coding preferences, enabling traders to visualize trends more effectively on a volatile landscape. Whether utilizing progression, chameleon, or binary color schemes, you can more fluidly interpret market dynamics and make informed visual decisions regarding entry and exit points based on color-coded plotting.
The indicator's alert system further enhances its utility by providing notifications of specifically chosen filter crossings. Traders can customize alert modes and messages while ensuring they stay informed about potential opportunities aligned with their trading style.
Overall, the "PhiSmoother Moving Average Ribbon" visually stands out as a revolutionary mechanism for technical analysis, offering traders a comprehensive solution for trend identification, visualization, and alerting within financial markets to achieve advantageous outcomes.
 NOTEWORTHY SETTINGS FEATURES: 
 Price Source Selection -  The indicator offers flexibility in choosing the price source for analysis. Traders can select from multiple options.
 Phase Control Parameter  - One of the notable standout features of this indicator is the phase control parameter. Traders can fine-tune the phase or lag of the indicator to adapt it to different market conditions or timeframes. This feature enables optimization of the indicator's responsiveness to price movements and align it with their specific trading tactics.
 Coloring Preferences -   Another magical setting is the coloring features, one being "Chameleon Color Magic". Traders can customize the color scheme of the indicator based on their visual preferences or to improve interpretation. The indicator offers options such as progression, chameleon, or binary color schemes, all having versatility to dynamically visualize market trends and patterns. Two colors may be specifically chosen to reduce overlay indicator interference while also contrasting for your visual acuity.
 Alert Controls -  The indicator provides diverse alert controls to manage alerts for specific market events, depending on their trading preferences.
 
 Alertable Crossings:  Receive an alert based on selectable predefined crossovers between moving average neighbors
 Customizable Alert Messages:  Traders can personalize alert messages with preferred information details
 Alert Frequency Control:  The frequency of alerts is adjustable for maximum control of timely notifications
RSI over screener (any tickers)█ OVERVIEW 
This screener allow you to watch up to 240 any tickers you need to check RSI overbought and oversold using multiple periods, including the percentage of RSIs of different periods being overbought/oversold, as well as the average between these multiple RSIs.
 █ THANKS 
LuxAlgo for his RSI over multi length   
I made function for this RSI and screener based on it.
allanster for his amazing idea how to split multiple symbols at once using a CSV list of ticker IDs   
 █ HOW TO USE 
- hide chart:
  
- add 6 copies of screener
- change list number at settings from 1 to 6 
- add you tickers
Screener shows signals when RSI was overbought or oversold and become to 0, this signal you may use to enter position(check other market condition before enter).
  
At settings you cam change Prefics, Appendix and put you tickers.
limitations are:
- max 40 tickers for one list
- max 4096 characters for one list
- tickers list should be separated by comma and may contains one space after the comma
By default it shows almost all BINANCE USD-M USDT tickers
Also you can adjust table for your screen by changing width of columns at settings.
If you have any questions or suggestions write comment or message.
VWAP 8EMA Crossover Scalping IndicatorWhy? 
Everybody, especially in Indian context, from 9:15 AM to 3:30 PM, wants to trade in BankNifty. 
And even  15m  is  Too Big  timeframe for The Great Indian Options buyers. Everyone knows how potentially BankNifty (& FinNifty on Tuesday and Sensex on Friday) can show dance within 15m. 
So there always been an overarching longing among traders to have something in shorter timeframes. And this 5m timeframe, looks like a  universally (sic) accepted Standard Timeframe  for Indian Options traders.  
So here is this.
 What? 
The time we are publishing this public indicator Indian market (Nifty) is in ATH at ~22200. 
In any such super trending market it's always good to wait for a dip and then in suitable time, enter the trade in the direction of the larger trend. The reversal trading systems, in such a situation, proves to be ineffective. 
Of course there are time when market is sideways and keeps on oscillating between +/2 standard deviation of the 20 SMA. In such a situation the reversal play works perfectly. But not so in such a trending market.
So the question comes up - after a dip what's the right point to enter. 
Hence comes the importance of such a crossover based trading system.
In this indicator, it's a well-known technique (nothing originally from ours, it's taken from social media, exact one we forgot) to find out the 8EMA and VWAP crossover. 
So we learned from social media, practice in our daily trading a bit, actuate it and now publishing it.
 A few salient points 
 
   It does not make sense to jump into the trade just on the crossover (or crossunder).
  So we added some more sugar to it, e.g. we check the color the candle. Also the next candle if crosses and closes above (or below) the breakout candle's high/low. 
  The polarity (color) of both the alert (breakout/breakdown) and confirmation candle to be same (green for crossover, red from crossunder).
  Of course, it does provider BUY and SELL alerts separately. 
 
These all we have found out doing backtesting and forward testing with 1/2 lots and saw this sort of approaches works. 
Hence all of these are added to this script.
 Nomenclature
 Here green line is the 8EMA and the red line is the VWAP.
Also there is a black dotted line. That's 50 EMA. It's to show you the trend.
The recent trade is shown in the top right of the chart as green (for buy) or red (for sell) with SL and 1:1 target.
 How to trade using this system?
 
This is roughly we have found the best possible use of this indicator.
Lets explain with a bullish BUY positive crossover (means 8EMA is crossing over the daily VWAP)
 
  Keep timeframe as 5m
  Check the direction/slope of the black dotted line (50 EMA). If it's upwards, only take bullish positions.
  Open the chart which has the VWAP. (e.g. FinNifty spot or MidcapNifty spot does not have vwap). So in those cases Future is the way to go.
  Wait for a breakout crossover and let the indicator gives a green, triangular UP arrow.
  Draw a horizontal line to the close of that candle for next few (say 6 candles i.e. 30m) candles.
  Wait for the price first to retest the 8EMA or even better the VWAP (or near to the 8EMA, VWAP)
  Let the price moves and closes above the horizontal line drawn in the 4th step.
  Take a bullish trade, keeping VWAP as the SL and 1:1 as the target.
  Additionally, Options buyer can consult ADX also to see if the ADX is more than 25 and moving up for the bullish trade. (This has to be added seperately in the chart, it's not a part of the indicator).
 
 Mention 
The concept we have taken from some social media. Forget exactly where we heard this first time. We just coded it with some additional steps.
 Statutory Disclaimer
 
 
  There is no silver bullet / holy grail in trading. Nothing works 100% time. One has to be careful about the loss (s)he can bear in case of the trade goes against.
  We, as the author of this script, is not responsible for any trading or position decision one is taken based on the outcome of this.
  It is our sole discretion to change, add, delete the portion or withdraw the whole script without any prior notice or intimation.
  In Indian Context: We are not SEBI registered.
VSA Volume Spread AnalysisVolume Spread Analysis with Trend Direction is an indicator designed to Identify trend based volume spread.
 
 Volume 
 Spread
 Trend
 
This is a very simple yet powerful to identify Trend and corresponding volume Breakout. Unlike other Volume Indicators this indicator detects Breakout along with trend direction. One can detect the Early breakout in volume using this indicator. The Buy or Sell Signal is based on zero crossing of the Histogram.
Trend direction is confirmed using the MA of the Histogram which is similar to the Volume MA on volume indicator. One can enter a trade using the indicator when Trend direction and histogram are in same direction. Entry is done when ever histogram crosses the Trend MA line. 
Fake entries can be eliminated by changing the indicator to higher Timeframe.
Spread is determined using the difference in open and close of the candle
Volume change is determined using the ratio of change of volume to previous volume
EMA 10 is used to determine the Spread and multiplied by volume change so the 
PRICE(ema10), Volume, Spread(close-open) are merged to one indicator.
Direction changes when ever difference of VSA is positive or negative.
Multi-Time AVWAP_BEARConcept 
 Collaboration Highlight:  
This was a collaboration with @Chart_School and @KioseffTrading Thank you to both, along with Ricardo Santos for his awesome library we used.
 Overview 
See how you view different time frame charts with one indicator and little to no adjustment.
 Innovation:  
The concept of using Anchored VWAP (AVWAP) with time events is a powerful technique in trading and technical analysis. Anchored VWAP differs from the traditional Volume Weighted Average Price (VWAP) by allowing traders to select a specific starting point or "anchor," from which the VWAP calculation begins. This approach is particularly useful for assessing price movements in relation to significant market events or specific periods of interest.
 Utility and Flexibility:  
Explaining the flexibility in turning on and off different time slices without much adjustment showcases a user-friendly design.
 Key Uses and Benefits 
 Comparative Performance:  
Anchoring the VWAP at the start of different time frames (e.g., weekly, monthly, quarterly) enables traders to compare the current price performance against previous periods. This comparison can highlight trends or shifts in trading momentum relative to past activity.
 Support and Resistance Levels:  
AVWAP lines can act as dynamic support and resistance levels. When anchored to significant time events, these levels gain additional relevance as they reflect the market's valuation of an asset since a notable point in time. Traders often watch for price interactions with these levels to make informed trading decisions.
 Risk Management:  
Anchored VWAP can serve as a benchmark for setting stop-loss orders or profit targets. By considering the price's relation to the AVWAP of a specific period or after a key event, traders can define exit points that are aligned with market-generated information.
 Trend Confirmation:  The direction and stability of the price relative to an anchored VWAP can indicate the strength of a trend. If the price consistently remains above an AVWAP anchored at a bullish event (or below for a bearish event), it may confirm the trend's continuation.
 Further Reading 
 Educational Resource:  
Becuase we are using Volume with a relation to price AVWAP is very powerful to show data that cannot be eye balled on its own. Brian Shannon's book "Maximum Trading Gains With Anchored VWAP - The Perfect Combination of Price, Time & Volume", is an excellent guide to best practices on how to use AVWAP to your advatage while trading. His book goes into depth about the best way to use this indicator to its fullest potencial.
 Tips for Using This Indicator 
 Weekly / Monthly / Quarterly Settings:  
All the settings for the lower timeframe charts are similar. Here is an example of seeing a Weekly AVWAP for 6 weeks, showing:
  1. The start of the 6-week AVWAP is using a High Low Close source for the first candle of the 6 weeks.
  
  2. The lines are colored "Red" for the AVWAPs.
  
  3. The line thickness is "1".
 Yearly Settings 
Simlair to the other settings with the Yearly we give you a couple more options along with 3 years to toggle on and off. The idea was to allow the user to see which AVWAP most effected by price and quickly toggle them on and off to unclutter their chart.
Watch for how and if the labels over lap and choose the one you feel is most in play. In Shannon's Book he talks about "Hand off's" and "Pinches". These concepts are easy to spot with being able to see all the Major Time Events, then simply toggle off the one you dont need.
A great benefit to how we coded this script you can buzz through a watch list without having to re-adjust the Anchor points. This will save you time if following a basket of symbols and show coorlations in the overall market.
 Secret Feature 
When looking at these becuase the user doesn't need to hand plot the anchor points and we are fouced on major time slices, I encourge you to use the Trading View "Bar Replay" Feature. You think that you are missing a high or low AVWAP but what is happening is the indicator is re-plotting a level that is super hard to see, then you will see the hand-offs like Shannon discusses in his book. This blew me away while we were discussing it post development.
 Conclusion 
There are so many uses of how to use VWAP and therories on its best practice. We are only using "TIME EVENTS". For more ways to use AVWAP, I would encourge you to also handplot them with Trading View's new "Anchored VWAP", as seen in the standard toolbar.
Using your ideas along with this indicator i think its a powerful combination.
 Also Check Out:   allanster's -  Anchored VWAP Pinch & Handoff, Intervals, and Signals 
He has a great AVWAP script that incorporates many AVWAP ideas.
Volatility System by W. WilderVolatility System (Volatility Stops) Similarity 
Most traders adjust their stops over time in the direction of the trend in order to lock in profits. Apart from moving averages, one of the most popular techniques is trailing stops using a multiple of Average True Range. There are several variations:
 
 The original Volatility System(Volatility Stops), introduced by Welles Wilder in his 1978 book: New Concepts in Technical Trading Systems
 Chandelier exits introduced by Alexander Elder in Come Into My Trading Room (2002) trail the stops from Highs or Lows rather than Closing Price
 Average True Range Trailing Stops are similar to the above, but include a ratchet mechanism to prevent stops moving down during an up-trend or rising during a down-trend, as ATR increases
 WillTrend intoduced by Larry Williams in 1988
 
 Comparison of systems 
All the systems under consideration have one common ingredient - ATR. ATR was developed by Welles Wilder and described in his book in 1978, also in this book the Volatility System was described, which in the future became known as Volatility Stops.
In fact, Wilder is the father of such systems due to the presence of ATR in the calculation of this type of indicator.
 The main difference of Volatility System 
Followers such as Larry Williams and Alexander Elder made minor changes to the value based on the ATR, mainly focusing on changing the base to which this value is added or subtracted.
Larry Williams uses the square root of 5 as a multiplier and calculates the ATR with a period of 66, and Alexander Elder uses a multiplier of 2.5-3.5 applying it to the ATR with a period of 22. Both authors changed the original value for ATR and multiplier calculations. Alexander Elder is closest to the original Welles Wilder calculation, which used a multiplier of 2.8.-3.1 applying it to an ATR with a period of 7.
As a reference, Elder took the Highest High(22) from which he subtracts ATR*Multiplier in an uptrend or the Lowest Low(22) to which he adds  ATR*Multiplier to obtain the turning point (SAR).
Larry Williams uses the average price of extremes (Highest High(10) + Lowest Low(10)) / 2 as a reference base to which he adds or subtracts the ATR*Multilpyer values.
Both systems differ from the original, because Wilder used Significan Close(SIC) in his calculations. SIC is the maximum closing price during an uptrend and the minimum closing price during a downtrend, which
does not go beyond the current trade, as in other systems. To calculate the base when a trend changes, bars that are outside the current trend will be used when calculating WillTrend and Chandelier Exit, in contrast to the Volatility System, which takes SIC values only within the current trade. This is the main difference from subsequent developments of similar systems.
 Improvements made 
The original Volatility System is present as an indicator on TradingView, but it is an improved version with the addition of a ratchet and works differently from the original Weilder system.
List of improvements:
 
 Added the ability to remove the ratchet. You need to turn off the "Trail one way" checkbox in the setting menu. When this function is turned off, the system will operate in the author-inventor mode. On some instruments, the original system works much better than the improved ratchet system, which cannot be turned off.
 Added the ability to use Highest High and Lowest Low as a base instead of the closing price.
 
 Volatility Stops Formula Description 
Welles Wilder's system uses Closing Price and incorporates a stop-and-reverse feature (as with his Parabolic SAR).
Determine the initial trend direction
Calculate the Significant Close ("SIC"): the highest close reached in an up-trend or the lowest close in a down-trend
Calculate Average True Range ("ATR") for the selected period (7 days in this example)
Multiply ATR by the Multiple (3.0 in this example, best values author describes as 2.8-3.1)
The first stop is calculated in day 7 and plotted for day 8
If an up-trend, the first stop is SIC - 3 * ATR, otherwise SIC + 3 * ATR for a down-trend
Repeat each day until price closes below the stop (or above in a down-trend)
Set SIC equal to the latest Close, reverse the trend and continue.
 Chandelier Exit Description 
Chandelier Exits subtract a multiple of Average True Range ("ATR") from the highest high for the selected period. Using the default settings as an example:
Highest High in last 22 days - 3 * ATR for 22 days
In a down-trend the formula is reversed:
Lowest Low in last 22 days + 3 * ATR for 22 days
The time period must be long enough to capture the highest point of the recent up-trend: too short and the stops move downward; too long and the high may be taken from a previous down-trend.
It is not essential to use the same period for up and down trends; down-trends are notoriously faster than up-trends and may benefit from a shorter time period.
The multiple of 3 may be varied, but most traders settle between 2.5 and 3.5.
 WillTrend Description 
Larry Williams is prefer to used the Square Root from 5 as a multiplayer for ATR. SQRT(5) = 2.236
WillTrend subtract a multiple of Average True Range ("ATR") from the Middle Price (Highest High for the selected period + Lowest Low for the selected period / 2).
(Highest High in last 10 days + Lowest Low in last 10 days) / 2 - 2.236 * ATR for 66 days
In a down-trend the formula is reversed:
(Highest High in last 10 days + Lowest Low in last 10 days) / 2 + 2.236 * ATR for 66 days






















