ZigZag Smart Trend [TradingFinder] Major & Minor Structured Wave🔵 Introduction  
🟣 Zigzag 
Zigzag is a lagging indicator; this indicator identifies points on a price chart that have more significant changes than its previous wave and then by connecting these lines to each other, it assists traders in trend detection. 
This indicator reduces random price fluctuations and attempts to make the primary price trend clearer.
🟣 Pivot  
Pivots are points where the price chart changes direction. Pivots, also called reversal points, form when supply and demand forces dominate one another. 
Different types of technical analysis pivots can be introduced into two categories, minor pivots, and major pivots, each of which has a specific meaning in analysis. 
 Major Pivot : These pivots actually indicate major changes in the direction of the chart and occur at the end of trends. Analysts seeking to reach the primary analysis focus more on major pivot points. In fact, most technical analysis tools are examined and determined based on major pivots. 
 Minor Pivot : This type of pivot focuses more on small and subsidiary points and directions. Therefore, it occurs at the end of corrections. Analysts focusing on minor pivots represent small trends, and it should be noted that minor pivots are not suitable for use in primary technical tools.
 How to identify minor and major pivots :
Minor pivots are pivots formed between two major pivots and fail to break the opposite major pivot. 
Major pivots are pivots that have either successfully broken the opposite pivot or have moved more than the previous pivot of the same type.
🔵 How to use 
Based on identifying pivots and drawing zigzag lines, you can have various uses for this indicator.
 Identifying support and resistance levels :
  
 Identifying Elliott Waves :
  
 Identifying classic patterns  :
  
 Identifying pivots with higher validity :
  
 Identifying internal and external breakouts :
  
 Identifying trends and range areas :
  
 Identifying pivot types along with major and minor recognition : 
  
 MHH : Major Higher High
 MLH : Major Lower High 
 MLL : Major Lower Low 
 MHL : Major Higher Low 
 mHH : Minor Higher High 
 mLH : Minor Lower High 
 mLL : Minor Lower Low 
 mHL : Minor Higher Low
🔵 Settings 
 Pivot Period Zigzag Line : Using this input, you can determine the pivot period for identifying zigzag swings.
 Show Zigzag Line : To show or not to show the zigzag line. 
 Zigzag Line Color : Change the color of the zigzag line.
 Zigzag Line Style : Change the Style of the zigzag line. 
 Zigzag Line Width : Change the Width of the zigzag line.
 Show Label : To show or not to show Pivot Type.
 Color Label : Change the color of the Pivot Type Label.
 
Gelombang Elliott
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 ) 
ZigZag LibraryThis is yet another ZigZag library.
🔵 Key Features
1.  Lightning-Fast Performance : Optimized code ensures minimal lag and swift chart updates.
2.  Real-Time Swing Detection : No more waiting for swings to finalize! This library continuously identifies the latest swing formation.
3.  Amplitude-Aware : Discover significant swings earlier, even if they haven't reached the standard bar length.
4.  Customizable Visualization : Draw ZigZag on-demand using polylines for a tailored analysis experience.
Stay tuned for more features as this library is being continuously enhanced. For the latest updates, please refer to the release information.
🔵 API
 
// Import this library. Remember to check the latest version of this library and replace the version number below.
import algotraderdev/zigzag/1 as zz
// Initialize the ZigZag instance.
var zz.ZigZag zig = zz.ZigZag.new().init(
  zz.Settings.new(
    swingLen = 5,
    lineColor = color.blue,
    lineStyle = line.style_solid,
    lineWidth = 1))
// Analyze the ZigZag using the latest bar's data.
zig.tick()
// Draw the ZigZag.
if barstate.islast
  zig.draw()
ZigZag Multi [TradingFinder] Trend & Wave Lines - Structures🔵 Introduction 
"Zigzag" is an indicator that forms based on price changes. Essentially, the function of this indicator is to connect consecutive and alternating High and Low pivots. This pattern assists in analyzing price changes and can also be used to identify classic patterns. "Zigzag" is an analytical tool that, by filtering partial price movements based on the specified period, can identify price waves across different time frames (short or long term).
🔵 Reason for Creation 
The combination of "short term zigzag" and "long term zigzag" enhances accuracy and reduces analysis time. In a time frame, "long term zigzag" represents the main trend, while "short term zigzag" depicts short-term waves.
🔵 How to Use 
After selecting the desired time frame and adding "zigzag" to the chart, begin utilization. Keep in mind to identify the main market trend from "long term zigzag" and the minor waves from "short term zigzag".
  
🟣 Important:  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.
  
🔵 Settings 
 Short term zigzag : In this section, you can adjust settings such as time frame range, display mode, color, and line width of the zigzag lines.
 Short term label : This section allows you to activate or deactivate the display of zigzag labels according to your needs. You can also customize their color and size.
 Long term zigzag : Here, you can adjust settings for time frame range, display mode, color, and line width of zigzag lines.
 Long term label : Similar to short term label settings.
The recommended time frame for "long term zigzag" is between 9 to 15, and for "short term zigzag" is between 3 to 5.
  
🟣 Important Notes :
Considering the different behaviors of financial markets and various time frames, it is recommended to experiment with different time frame settings when using "zigzag" to find the best settings for each symbol and time frame, thereby preventing potential errors.
🟣 Terminology Explanations :
"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).
Zigzag Fibonacci Golden Zone [UAlgo]🔶 Description: 
The "Zigzag Fibonacci Golden Zone" aims to identify potential trend pullback points by utilizing a combination of zigzag patterns and Fibonacci "Golden Zone (0.618 - 0.786)" retracement levels. It plots zigzag lines on the price chart, highlighting significant swing highs and swing lows, and overlays Fibonacci retracement levels to indicate potential support and resistance zones. Additionally, it provides options to display buy and sell signals based on specific criteria.
 🔶 Key Features: 
 Zigzag Lines:  The indicator plots zigzag lines on the price chart, marking significant swing highs and swing lows. These lines help traders visualize the direction and magnitude of price swings.
 Fibonacci Retracement Levels:  The indicator overlays Fibonacci retracement levels on the chart, indicating potential support and resistance levels. These levels are derived from the Fibonacci sequence and are commonly used by traders to identify reversal points.
  
 Fibonacci occurs again when a new zigzag low or high is created : 
Before new zigzag low pivot appears,
  
After new Zigzag low pivot appears,
  
As you see new fibonacci created after new pivot found also price bounced from retracement zone.
 Customization Options:  Traders can customize various parameters of the indicator, such as the length of the zigzag pattern, color preferences for different elements, and visibility of price labels and buy/sell signals.
 Buy/Sell Signals:  The indicator generates buy and sell signals based on predefined criteria, such as price movements relative to Fibonacci levels and other market conditions. These signals can help traders identify potential entry and exit points in the market.
 Example : 
  
 Disclaimer :
Please note that trading involves significant risk, and past performance is not indicative of future results. The "Zigzag Fibonacci Golden Zone" indicator is provided for informational purposes only and should not be considered financial advice. Traders should conduct their own research and analysis before making any investment decisions. Additionally, the indicator's performance may vary depending on market conditions and other factors. Users are encouraged to use the indicator as part of a comprehensive trading strategy and to exercise caution when trading in the financial markets.
Trended CVD [Mxwll]Hey!
This indicator "Trended CVD" categorizes price movement by trend (using zig zag) and calculates cumulative volume delta for the entirety of the price move.
 Features 
 
 CVD calculated for the trend
 CVD divergences are distinguished (uptrend and falling CVD / downtrend and rising CVD)
 CVD output normalized to scale with chart, and is plotted alongside the trend
 Can be used for trend confirmation (CVD trend correlating with price trend)
 All regular zig-zag features available 
 What constitutes a trend is customizable. Can locate small, medium, large price trends with detailed user-input settings.
 
 How-To Use Trended CVD 
  
The image above shows one of two primary uses for the indicator.
In the left-half of the image, price is downtrending simultaneously with CVD; thereby, CVD is confirming the downtrend.
The right-half of the image shows price uptrending simultaneously with CVD; CVD is confirming the uptrend.
This information can be used to classify the "strength" of the price move, and decide to trade with it or against it.
  
The image above shows the second primary use for the indicator.
A slight price decrease transpires while CVD increases - CVD diverging upwards from the price trend.
This information can be used to classify the strength of the downtrend, and decide to trade against it, or abstain from trading with it.
  
The image above shows, subsequent to divergence, price failed to sustain "meaningful" downwards movement.
  
Labels oriented at the final pivot of a trend show the cumulative volume delta for the entirety of the price move (distinguishable by the superimposed zig zag line).
That's really it! A more complex concept integrated with a simple output. 
Thank you!
ZigzagLiteLibrary   "ZigzagLite" 
Lighter version of the Zigzag Library. Without indicators and sub-component divisions
 method getPrices(pivots) 
  Gets the array of prices from array of Pivots
  Namespace types: Pivot 
  Parameters:
     pivots (Pivot ) : array array of Pivot objects
  Returns: array array of pivot prices
 method getBars(pivots) 
  Gets the array of bars from array of Pivots
  Namespace types: Pivot 
  Parameters:
     pivots (Pivot ) : array array of Pivot objects
  Returns: array array of pivot bar indices
 method getPoints(pivots) 
  Gets the array of chart.point from array of Pivots
  Namespace types: Pivot 
  Parameters:
     pivots (Pivot ) : array array of Pivot objects
  Returns: array array of pivot points
 method getPoints(this) 
  Namespace types: Zigzag
  Parameters:
     this (Zigzag) 
 method calculate(this, ohlc, ltfHighTime, ltfLowTime) 
  Calculate zigzag based on input values and indicator values
  Namespace types: Zigzag
  Parameters:
     this (Zigzag) : Zigzag object
     ohlc (float ) : Array containing OHLC values. Can also have custom values for which zigzag to be calculated
     ltfHighTime (int) : Used for multi timeframe zigzags when called within request.security. Default value is current timeframe open time.
     ltfLowTime (int) : Used for multi timeframe zigzags when called within request.security. Default value is current timeframe open time.
  Returns: current Zigzag object
 method calculate(this) 
  Calculate zigzag based on properties embedded within Zigzag object
  Namespace types: Zigzag
  Parameters:
     this (Zigzag) : Zigzag object
  Returns: current Zigzag object
 method nextlevel(this) 
  Namespace types: Zigzag
  Parameters:
     this (Zigzag) 
 method clear(this) 
  Clears zigzag drawings array
  Namespace types: ZigzagDrawing 
  Parameters:
     this (ZigzagDrawing ) : array
  Returns: void
 method clear(this) 
  Clears zigzag drawings array
  Namespace types: ZigzagDrawingPL 
  Parameters:
     this (ZigzagDrawingPL ) : array
  Returns: void
 method drawplain(this) 
  draws fresh zigzag based on properties embedded in ZigzagDrawing object without trying to calculate
  Namespace types: ZigzagDrawing
  Parameters:
     this (ZigzagDrawing) : ZigzagDrawing object
  Returns: ZigzagDrawing object
 method drawplain(this) 
  draws fresh zigzag based on properties embedded in ZigzagDrawingPL object without trying to calculate
  Namespace types: ZigzagDrawingPL
  Parameters:
     this (ZigzagDrawingPL) : ZigzagDrawingPL object
  Returns: ZigzagDrawingPL object
 method drawfresh(this, ohlc) 
  draws fresh zigzag based on properties embedded in ZigzagDrawing object
  Namespace types: ZigzagDrawing
  Parameters:
     this (ZigzagDrawing) : ZigzagDrawing object
     ohlc (float ) : values on which the zigzag needs to be calculated and drawn. If not set will use regular OHLC
  Returns: ZigzagDrawing object
 method drawcontinuous(this, ohlc) 
  draws zigzag based on the zigzagmatrix input
  Namespace types: ZigzagDrawing
  Parameters:
     this (ZigzagDrawing) : ZigzagDrawing object
     ohlc (float ) : values on which the zigzag needs to be calculated and drawn. If not set will use regular OHLC
  Returns:  
 PivotCandle 
  PivotCandle represents data of the candle which forms either pivot High or pivot low or both
  Fields:
     _high (series float) : High price of candle forming the pivot
     _low (series float) : Low price of candle forming the pivot
     length (series int) : Pivot length
     pHighBar (series int) : represents number of bar back the pivot High occurred.
     pLowBar (series int) : represents number of bar back the pivot Low occurred.
     pHigh (series float) : Pivot High Price
     pLow (series float) : Pivot Low Price
 Pivot 
  Pivot refers to zigzag pivot. Each pivot can contain various data
  Fields:
     point (chart.point) : pivot point coordinates
     dir (series int) : direction of the pivot. Valid values are 1, -1, 2, -2
     level (series int) : is used for multi level zigzags. For single level, it will always be 0
     ratio (series float) : Price Ratio based on previous two pivots
     sizeRatio (series float) 
 ZigzagFlags 
  Flags required for drawing zigzag. Only used internally in zigzag calculation. Should not set the values explicitly
  Fields:
     newPivot (series bool) : true if the calculation resulted in new pivot
     doublePivot (series bool) : true if the calculation resulted in two pivots on same bar
     updateLastPivot (series bool) : true if new pivot calculated replaces the old one.
 Zigzag 
  Zigzag object which contains whole zigzag calculation parameters and pivots
  Fields:
     length (series int) : Zigzag length. Default value is 5
     numberOfPivots (series int) : max number of pivots to hold in the calculation. Default value is 20
     offset (series int) : Bar offset to be considered for calculation of zigzag. Default is 0 - which means calculation is done based on the latest bar.
     level (series int) : Zigzag calculation level - used in multi level recursive zigzags
     zigzagPivots (Pivot ) : array which holds the last n pivots calculated.
     flags (ZigzagFlags) : ZigzagFlags object which is required for continuous drawing of zigzag lines.
 ZigzagObject 
  Zigzag Drawing Object
  Fields:
     zigzagLine (series line) : Line joining two pivots
     zigzagLabel (series label) : Label which can be used for drawing the values, ratios, directions etc.
 ZigzagProperties 
  Object which holds properties of zigzag drawing. To be used along with ZigzagDrawing
  Fields:
     lineColor (series color) : Zigzag line color. Default is color.blue
     lineWidth (series int) : Zigzag line width. Default is 1
     lineStyle (series string) : Zigzag line style. Default is line.style_solid.
     showLabel (series bool) : If set, the drawing will show labels on each pivot. Default is false
     textColor (series color) : Text color of the labels. Only applicable if showLabel is set to true.
     maxObjects (series int) : Max number of zigzag lines to display. Default is 300
     xloc (series string) : Time/Bar reference to be used for zigzag drawing. Default is Time - xloc.bar_time.
     curved (series bool) : Boolean field to print curved zigzag - used only with polyline implementation
 ZigzagDrawing 
  Object which holds complete zigzag drawing objects and properties.
  Fields:
     zigzag (Zigzag) : Zigzag object which holds the calculations.
     properties (ZigzagProperties) : ZigzagProperties object which is used for setting the display styles of zigzag
     drawings (ZigzagObject ) : array which contains lines and labels of zigzag drawing.
 ZigzagDrawingPL 
  Object which holds complete zigzag drawing objects and properties - polyline version
  Fields:
     zigzag (Zigzag) : Zigzag object which holds the calculations.
     properties (ZigzagProperties) : ZigzagProperties object which is used for setting the display styles of zigzag
     zigzagLabels (label ) 
     zigzagLine (series polyline) : polyline object of zigzag lines
ZigzagLibrary   "Zigzag" 
Zigzag related user defined types. Depends on DrawingTypes library for basic types
 method tostring(this, sortKeys, sortOrder, includeKeys) 
  Converts ZigzagTypes/Pivot object to string representation
  Namespace types: Pivot
  Parameters:
     this (Pivot) : ZigzagTypes/Pivot
     sortKeys (bool) : If set to true, string output is sorted by keys.
     sortOrder (int) : Applicable only if sortKeys is set to true. Positive number will sort them in ascending order whreas negative numer will sort them in descending order. Passing 0 will not sort the keys
     includeKeys (string ) : Array of string containing selective keys. Optional parmaeter. If not provided, all the keys are considered
  Returns: string representation of ZigzagTypes/Pivot
 method tostring(this, sortKeys, sortOrder, includeKeys) 
  Converts Array of Pivot objects to string representation
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) : Pivot object array
     sortKeys (bool) : If set to true, string output is sorted by keys.
     sortOrder (int) : Applicable only if sortKeys is set to true. Positive number will sort them in ascending order whreas negative numer will sort them in descending order. Passing 0 will not sort the keys
     includeKeys (string ) : Array of string containing selective keys. Optional parmaeter. If not provided, all the keys are considered
  Returns: string representation of Pivot object array
 method tostring(this) 
  Converts ZigzagFlags object to string representation
  Namespace types: ZigzagFlags
  Parameters:
     this (ZigzagFlags) : ZigzagFlags object
  Returns: string representation of ZigzagFlags
 method tostring(this, sortKeys, sortOrder, includeKeys) 
  Converts ZigzagTypes/Zigzag object to string representation
  Namespace types: Zigzag
  Parameters:
     this (Zigzag) : ZigzagTypes/Zigzagobject
     sortKeys (bool) : If set to true, string output is sorted by keys.
     sortOrder (int) : Applicable only if sortKeys is set to true. Positive number will sort them in ascending order whreas negative numer will sort them in descending order. Passing 0 will not sort the keys
     includeKeys (string ) : Array of string containing selective keys. Optional parmaeter. If not provided, all the keys are considered
  Returns: string representation of ZigzagTypes/Zigzag
 method calculate(this, ohlc, indicators, indicatorNames) 
  Calculate zigzag based on input values and indicator values
  Namespace types: Zigzag
  Parameters:
     this (Zigzag) : Zigzag object
     ohlc (float ) : Array containing OHLC values. Can also have custom values for which zigzag to be calculated
     indicators (matrix) : Array of indicator values
     indicatorNames (string ) : Array of indicator names for which values are present. Size of indicators array should be equal to that of indicatorNames
  Returns: current Zigzag object
 method calculate(this) 
  Calculate zigzag based on properties embedded within Zigzag object
  Namespace types: Zigzag
  Parameters:
     this (Zigzag) : Zigzag object
  Returns: current Zigzag object
 method nextlevel(this) 
  Calculate Next Level Zigzag based on the current calculated zigzag object
  Namespace types: Zigzag
  Parameters:
     this (Zigzag) : Zigzag object
  Returns: Next Level Zigzag object
 method clear(this) 
  Clears zigzag drawings array
  Namespace types: ZigzagDrawing 
  Parameters:
     this (ZigzagDrawing ) : array
  Returns: void
 method drawplain(this) 
  draws fresh zigzag based on properties embedded in ZigzagDrawing object without trying to calculate
  Namespace types: ZigzagDrawing
  Parameters:
     this (ZigzagDrawing) : ZigzagDrawing object
  Returns: ZigzagDrawing object
 method drawfresh(this, ohlc, indicators, indicatorNames) 
  draws fresh zigzag based on properties embedded in ZigzagDrawing object
  Namespace types: ZigzagDrawing
  Parameters:
     this (ZigzagDrawing) : ZigzagDrawing object
     ohlc (float ) : values on which the zigzag needs to be calculated and drawn. If not set will use regular OHLC
     indicators (matrix) : Array of indicator values
     indicatorNames (string ) : Array of indicator names for which values are present. Size of indicators array should be equal to that of indicatorNames
  Returns: ZigzagDrawing object
 method drawcontinuous(this, ohlc, indicators, indicatorNames) 
  draws zigzag based on the zigzagmatrix input
  Namespace types: ZigzagDrawing
  Parameters:
     this (ZigzagDrawing) : ZigzagDrawing object
     ohlc (float ) : values on which the zigzag needs to be calculated and drawn. If not set will use regular OHLC
     indicators (matrix) : Array of indicator values
     indicatorNames (string ) : Array of indicator names for which values are present. Size of indicators array should be equal to that of indicatorNames
  Returns:  
 method getPrices(pivots) 
  Namespace types: Pivot 
  Parameters:
     pivots (Pivot ) 
 method getBars(pivots) 
  Namespace types: Pivot 
  Parameters:
     pivots (Pivot ) 
 Indicator 
  Indicator is collection of indicator values applied on high, low and close
  Fields:
     indicatorHigh (series float) : Indicator Value applied on High
     indicatorLow (series float) : Indicator Value applied on Low
 PivotCandle 
  PivotCandle represents data of the candle which forms either pivot High or pivot low or both
  Fields:
     _high (series float) : High price of candle forming the pivot
     _low (series float) : Low price of candle forming the pivot
     length (series int) : Pivot length
     pHighBar (series int) : represents number of bar back the pivot High occurred.
     pLowBar (series int) : represents number of bar back the pivot Low occurred.
     pHigh (series float) : Pivot High Price
     pLow (series float) : Pivot Low Price
     indicators (Indicator ) : Array of Indicators - allows to add multiple
 Pivot 
  Pivot refers to zigzag pivot. Each pivot can contain various data
  Fields:
     point (chart.point) : pivot point coordinates
     dir (series int) : direction of the pivot. Valid values are 1, -1, 2, -2
     level (series int) : is used for multi level zigzags. For single level, it will always be 0
     componentIndex (series int) : is the lower level zigzag array index for given pivot. Used only in multi level Zigzag Pivots
     subComponents (series int) : is the number of sub waves per each zigzag wave. Only applicable for multi level zigzags
     microComponents (series int) : is the number of base zigzag components in a zigzag wave
     ratio (series float) : Price Ratio based on previous two pivots
     sizeRatio (series float) 
     subPivots (Pivot ) 
     indicatorNames (string ) : Names of the indicators applied on zigzag
     indicatorValues (float ) : Values of the indicators applied on zigzag
     indicatorRatios (float ) : Ratios of the indicators applied on zigzag based on previous 2 pivots
 ZigzagFlags 
  Flags required for drawing zigzag. Only used internally in zigzag calculation. Should not set the values explicitly
  Fields:
     newPivot (series bool) : true if the calculation resulted in new pivot
     doublePivot (series bool) : true if the calculation resulted in two pivots on same bar
     updateLastPivot (series bool) : true if new pivot calculated replaces the old one.
 Zigzag 
  Zigzag object which contains whole zigzag calculation parameters and pivots
  Fields:
     length (series int) : Zigzag length. Default value is 5
     numberOfPivots (series int) : max number of pivots to hold in the calculation. Default value is 20
     offset (series int) : Bar offset to be considered for calculation of zigzag. Default is 0 - which means calculation is done based on the latest bar.
     level (series int) : Zigzag calculation level - used in multi level recursive zigzags
     zigzagPivots (Pivot ) : array which holds the last n pivots calculated.
     flags (ZigzagFlags) : ZigzagFlags object which is required for continuous drawing of zigzag lines.
 ZigzagObject 
  Zigzag Drawing Object
  Fields:
     zigzagLine (series line) : Line joining two pivots
     zigzagLabel (series label) : Label which can be used for drawing the values, ratios, directions etc.
 ZigzagProperties 
  Object which holds properties of zigzag drawing. To be used along with ZigzagDrawing
  Fields:
     lineColor (series color) : Zigzag line color. Default is color.blue
     lineWidth (series int) : Zigzag line width. Default is 1
     lineStyle (series string) : Zigzag line style. Default is line.style_solid.
     showLabel (series bool) : If set, the drawing will show labels on each pivot. Default is false
     textColor (series color) : Text color of the labels. Only applicable if showLabel is set to true.
     maxObjects (series int) : Max number of zigzag lines to display. Default is 300
     xloc (series string) : Time/Bar reference to be used for zigzag drawing. Default is Time - xloc.bar_time.
 ZigzagDrawing 
  Object which holds complete zigzag drawing objects and properties.
  Fields:
     zigzag (Zigzag) : Zigzag object which holds the calculations.
     properties (ZigzagProperties) : ZigzagProperties object which is used for setting the display styles of zigzag
     drawings (ZigzagObject ) : array which contains lines and labels of zigzag drawing.
Volatility ZigZagIt calculates and plots zigzag lines based on volatility and price movements. It has various inputs for customization, allowing you to adjust parameters like source data, length, deviation, line styling, and labeling options.
The indicator identifies pivot points in the price movement, drawing lines between these pivots based on the deviation from certain price levels or volatility measures.
The script labels various data points at the ZigZag pivot points on the chart. These labels provide information about different aspects of the price movement and volume around these pivot points. Here's a breakdown of what gets labeled:
Price Change: Indicates the absolute and average percentage change between the two pivot points. It displays the absolute or relative change in price as a percentage. Additionally, the average absolute price increase or the average rate of increase can also be labeled.
Volume: Shows the total volume and average volume between the two pivot points.
Number of Bars: Indicates the number of bars between the current and the last pivot point.
Reversal Price: Displays the price of the reversal point (the previous pivot).
Zig-Zag Open Interest Footprint [Kioseff Trading]Hello!
This script "Zig Zag Open Interest Footprint" calculates open interest x price values for zig zag trends!
 Features 
 
 Open interest footprints anchored to zig zag trends
 Summed OI x price level footprints
 Total OI (for each category) for the entire trend shown
 Standard POC lines, in addition to separated POC lines for each category of open interest x price possibility
 Up to 9999 profile rows per zigzag trend
 Stylistic options for profiles
 Configurable zig zag - footprints generated for small to large trends
 
The zigzag indicator is configurable as normal; minor and major trend volume footprints are calculable. This indicator can be thought of as "Open Interest Footprint for Trends''.
Up to 9999 open interest levels (price levels) can be calculated for each profile, thanks to the new polyline feature, allowing for less aggregation / more precision of open interest at price.
 Zig Zag OI Footprints 
  
The image above shows primary functionality!
Green = Higher OI + Higher Price
Yellow = Lower OI + Higher Price
Purple = Higher OI + Lower Price
Red     = Lower OI + Lower Price
Profiles are generated for each trend identified by the zigzag indicator.
  
The image above shows the indicator calculating open interest x price for specific price blocks on the footprint. Aggregate open interest for the identified trend is displayed over the profile!
Neon highlighted values correspond to the highest open interest change for the category. This is a configurable option :D
  
The image above shows POC lines for each category of open interest x price!
Additionally, you can select to show a single POV for footprint - the single level the greatest amount of OI change occurred. 
  
The indicator is robust enough to calculate on "long zig zags" and "short zig zags"; curved profiles can also be used!
  
The image above shows key levels, each OI footprint, and summed OI values for the current trend!
That's about it :D
This indicator is part of a series titled "Bull vs. Bear" - a suite of profile-like indicators I will be releasing over the coming days. Thanks for checking this out!
If you have any suggestions please feel free to share!
ZigZag++ FibonacciAuto Fibonacci tools  are powerful ways designed to simplify your technical analysis by automatically drawing Fibonacci retracement and extension levels on your chart. This indicator is built to enhance your trading experience with clearer market moves and informative insights.
You can easily spot your waves and patterns when the percentages are moving with you.
 Key Features: 
 Automated Fibonacci Levels:  Plots Fibonacci retracement and extension levels based on recent price movements.
 Multi-Timeframe Support:  This indicator is your versatile companion, offering multi-timeframe functionality. You can seamlessly track Fibonacci levels across different resolutions, providing a comprehensive view of the market.
Two Types of Fibs:  Retracement  and  Timeframe  extension Fibonacci levels. Use retracements to identify potential reversal points and extensions to anticipate price targets, giving you a well-rounded perspective on market movements.
 Benefits: 
 
 Save Time: No more manual Fibonacci drawing; It does this for you in real-time.
 Enhanced Analysis: Gain a deeper understanding of potential support, resistance, and price targets.
 User-Friendly: Suitable for traders of all levels, this indicator simplifies complex technical analysis.
 
 For the math lovers 
I started creating the ZigZag++ based on the MT4 calculation as I found it better performing than the tradingview inbuilt one. I have revised the calculation couple of times and now the final calculation is simple yet more accurate for my analysis.
First, I observe the market direction for the last  Depth  setting by comparing the rate at which high values reduce and low values increase. When the number of ticks set by  Deviation  is crossed and the last cross is more than the  Backstep  candles, then we have our ZigZag points.
These are the points we use in our Fibonacci calculation.
 Checkout ZigLib below to use the same logic in your scripts. 
 Sample usage 
This is a 4 Hour configuration with the default settings.
When the trend reversed, some key points I watch are 0.618 and 0.5. The market retraced back and formed the new point for the next ZigZag line on that level. This market behaviour happens quite often on these Fibonacci points. I would be looking for reversal or a break in this zone to know the next step.
Resources
 ZigZag++ Lib  by me; for retrieving the line points.
 Fibonacci Toolkit  by Lux Algo; For drawing the Timeframe Fibs. Very Amazing script.
Zigzag Chart Points█  OVERVIEW
This indicator displays zigzag based on high and low using latest  pine script version 5 ,   chart.point  which using time, index and price as parameters.
Pretty much a strip down using latest pine script function, without any use of  library .
This allow pine script user to have an idea of simplified and cleaner code for zigzag.
█  CREDITS
 LonesomeTheBlue 
█  FEATURES
1. Label can be show / hide including text can be resized.
2. Hover to label, can see tooltip will show price and time.
3. Tooltip will show date and time for hourly timeframe and below while show date only for day timeframe and above.
█  NOTES
1. I admit that chart.point just made the code much more cleaner and save more time. I previously using  user-defined type(UDT)  which quite hassle.
2. I have no plan to extend this indicator or include alert just I thinking to explore  log.error()  and  runtime.error() , which I may probably release in other publications.
█  HOW TO USE'
Pretty much similar inside mentioned references, which previously I created.
█  REFERENCES
1.  Zigzag Array Experimental 
2.  Simple Zigzag UDT 
3.  Zig Zag Ratio Simplified 
4.  Cyclic RSI High Low With Noise Filter 
5.  Auto AB=CD 1 to 1 Ratio Experimental
ZigLibLibrary   "ZigLib" 
Calculate the points for ZigZag++. 
You can use custom data and resolution for your ZigZag++.
Sample Usage
 
import DevLucem/ZigLib/1 as ZigZag
  = ZigZag.zigzag(low, high)
bgcolor(direction<0? color.rgb(255, 82, 82, 80): color.rgb(0, 230, 119, 80))
line zz = line.new(z1.time, z1.price, z2.time, z2.price, xloc.bar_time, width=3)
if direction==direction 
    line.delete(zz )
 
 zigzag(_low, _high, depth, deviation, backstep) 
        Get current zigzag points and direction
  Parameters:
     _low (float)  
     _high (float) 
     depth (int) 
     deviation (int) 
     backstep (int) 
        Returns  direction, chart point 1 and chart point 2 
The Next Pivot [Kioseff Trading]Hello!
This script "The Next Pivot" uses various similarity measures to compare historical price sequences to the current price sequence!
 Features 
 
 Find the most similar price sequence up to 100 bars from the current bar
 Forecast price path up to 250 bars
 Forecast ZigZag up to 250 bars 
 Spearmen 
 Pearson    
 Absolute Difference
 Cosine Similarity
 Mean Squared Error
 Kendall
  Forecasted linear regression channel
 
  
The image above shows/explains some of the indicator's capabilities!
  
The image above highlights the projected zig zag (pivots) pattern!
Colors are customizable (:
  
Additionally, you can plot a forecasted LinReg channel.
Should load times permit it, the script  can  search all bar history for a correlating sequence. This won't always be possible, contingent on the forecast length, correlation length, and the number of bars on the chart.
 Reasonable Assessment  
The script uses various similarity measures to find the "most similar" price sequence to what's currently happening. Once found, the subsequent price move (to the most similar sequence) is recorded and projected forward. 
So, 
1: Script finds most similar price sequence
2: Script takes what happened after and projects forward 
While this may be useful, the projection is simply the reaction to a possible one-off "similarity" to what's currently happening. Random fluctuations are likely and, if occurring, similarities between the current price sequence and the "most similar" sequence are plausibly coincidental. 
That said, if you have any ideas on cool features to add please let me know! 
Thank you (:
Zigzag Trend-based Color [SteinG]Zigzag Indicator with Trend-based Color Coding and Info Table 
This indicator is forked from Trendoscope's  Recursive Zigzag 
The Zigzag Indicator with Trend-based Color Coding and Info Table is a powerful tool for technical analysis, designed to help you identify significant price swings, visualize trends, and analyze pivot points with ease. This advanced indicator offers enhanced functionalities and improved visual representation.
The primary purpose of the Zigzag Indicator is to identify and highlight important price reversals, commonly referred to as pivot points, in a given chart. These pivot points are essential in recognizing trend changes and potential market turning points. With the Zigzag Indicator, you can quickly identify these pivotal moments and gain valuable insights into market dynamics.
One of the standout features of this indicator is the color coding applied to the Zigzag line, which intuitively reflects the trend associated with each pivot point. The color scheme is as follows:
-  Green : Indicates an upward trend, representing a bullish movement in the price.
-  Lime : Represents a retracement during an upward trend, indicating a temporary pullback before the uptrend resumes.
-  Red : Signifies a downward trend, indicating a bearish movement in the price.
-  Orange : Represents a retracement during a downward trend, indicating a temporary bounce before the downtrend resumes.
This color coding allows you to easily visualize the prevailing market sentiment and make more informed trading decisions accordingly.
In addition to the visual representation, the Zigzag Indicator also includes an informative table that provides essential details about each pivot point. The table presents the following information for each pivot point:
1.  Pivot Value : The price level at which the pivot point occurs.
2.  Direction : Indicates whether the pivot point represents an upward or downward trend.
3.  Fibo Ratios : Displays the Fibonacci retracement levels between two consecutive pivot points, offering insights into potential support and resistance levels.
The inclusion of this comprehensive info table enables you to analyze pivot points more effectively, understand the underlying price dynamics, and identify key trading opportunities.
PivotLibrary   "Pivot" 
This library helps you store and manage pivots.
 bias(isHigh, isHigher, prevWasHigher) 
  Helper function to calculate bias.
  Parameters:
     isHigh (bool) : (bool)		Wether the pivot is a pivot high or not.
     isHigher (bool) : (bool)		Wether the pivot is a higher pivot or not.
@return  		(bool) 		The bias (true = bullish, false = bearish, na = neutral).
     prevWasHigher (bool) 
 biasToString(bias) 
  Parameters:
     bias (bool) 
 biasToColor(bias, theme) 
  Parameters:
     bias (bool) 
     theme (Theme) 
 nameString(isHigh, isHigher) 
  Parameters:
     isHigh (bool) 
     isHigher (bool) 
 abbrString(isHigh, isHigher) 
  Parameters:
     isHigh (bool) 
     isHigher (bool) 
 tooltipString(y, isHigh, isHigher, bias, theme) 
  Parameters:
     y (float) 
     isHigh (bool) 
     isHigher (bool) 
     bias (bool) 
     theme (Theme) 
 createLabel(x, y, isHigh, isHigher, prevWasHigher, settings) 
  Parameters:
     x (int) 
     y (float) 
     isHigh (bool) 
     isHigher (bool) 
     prevWasHigher (bool) 
     settings (Settings) 
 new(x, y, isHigh, isHigher, settings) 
  Parameters:
     x (int) 
     y (float) 
     isHigh (bool) 
     isHigher (bool) 
     settings (Settings) 
 newArray(size, initialValue) 
  Parameters:
     size (int) 
     initialValue (Pivot) 
 method getFirst(this) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
 method getLast(this, isHigh) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     isHigh (bool) 
 method getLastHigh(this) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
 method getLastLow(this) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
 method getPrev(this, numBack, isHigh) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     numBack (int) 
     isHigh (bool) 
 method getPrevHigh(this, numBack) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     numBack (int) 
 method getPrevLow(this, numBack) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     numBack (int) 
 method getText(this) 
  Namespace types: Pivot
  Parameters:
     this (Pivot) 
 method setX(this, value) 
  Namespace types: Pivot
  Parameters:
     this (Pivot) 
     value (int) 
 method setY(this, value) 
  Namespace types: Pivot
  Parameters:
     this (Pivot) 
     value (float) 
 method setXY(this, x, y) 
  Namespace types: Pivot
  Parameters:
     this (Pivot) 
     x (int) 
     y (float) 
 method setBias(this, value) 
  Namespace types: Pivot
  Parameters:
     this (Pivot) 
     value (int) 
 method setColor(this, value) 
  Namespace types: Pivot
  Parameters:
     this (Pivot) 
     value (color) 
 method setText(this, value) 
  Namespace types: Pivot
  Parameters:
     this (Pivot) 
     value (string) 
 method add(this, pivot) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     pivot (Pivot) 
 method updateLast(this, y, settings) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     y (float) 
     settings (Settings) 
 method update(this, y, isHigh, settings) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     y (float) 
     isHigh (bool) 
     settings (Settings) 
 Pivot 
  Stores Pivot data.
  Fields:
     x (series int) 
     y (series float) 
     isHigh (series bool) 
     isHigher (series bool) 
     bias (series bool) 
     lb (series label) 
 Theme 
  Attributes for customizable look and feel.
  Fields:
     size (series string) 
     colorDefault (series color) 
     colorNeutral (series color) 
     colorBullish (series color) 
     colorBearish (series color) 
     colored (series bool) 
     showTooltips (series bool) 
     showTooltipName (series bool) 
     showTooltipValue (series bool) 
     showTooltipBias (series bool) 
 Settings 
  All settings for the pivot.
  Fields:
     theme (Theme)
Absolute ZigZag LibLibrary   "Absolute_ZigZag_Lib" 
This ZigZag Library is a Bit different. Instead of using percentages or looking more than 1 bar left or right, this Zigzag library calculates pivots by just looking at the current bar highs and lows and the ones of one bar earlier. 
This is the most accurate way of calculating pivots and it also eliminates lag. 
The library also features a solution for bars that have both a higher high and a higher low like seen below.
  
You can also use your own colors for the labels and the lines.
  
You can also quickly select a one-colored theme without changing all colors at once
  
 method isHigherHigh(this) 
  Checks if current pivot is a higher high
  Namespace types: Pivot
  Parameters:
     this (Pivot) : (Pivot)         The object to work with.
@return          (bool)          True if the pivot is a higher high, false if not.
 method isLowerHigh(this) 
  Checks if current pivot is a lower high
  Namespace types: Pivot
  Parameters:
     this (Pivot) : (Pivot)         The object to work with.
@return          (bool)          True if the pivot is a lower high, false if not.
 method isHigherLow(this) 
  Checks if current pivot is a higher low
  Namespace types: Pivot
  Parameters:
     this (Pivot) : (Pivot)         The object to work with.
@return          (bool)          True if the pivot is a higher low, false if not.
 method isLowerLow(this) 
  Checks if current pivot is a lower low
  Namespace types: Pivot
  Parameters:
     this (Pivot) : (Pivot)         The object to work with.
@return          (bool)          True if the pivot is a lower low, false if not.
 method getLastPivotHigh(this) 
  Gets the last Pivot High
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) : (array)  The object to work with.
@return          (Pivot)         The latest Pivot High
 method getLastPivotLow(this) 
  Gets the last Pivot Low
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) : (array)  The object to work with.
@return          (Pivot)         The latest Pivot Low
 method prev(this, index) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     index (int) 
 method last(this, throwError) 
  Namespace types: Pivot 
  Parameters:
     this (Pivot ) 
     throwError (bool) 
 new(highFirst, theme) 
  Parameters:
     highFirst (bool) 
     theme (Theme) 
 getLowerTimeframePeriod() 
 Theme 
  Used to create a (color) theme to draw Zigzag
  Fields:
     colorDefault (series color) 
     colorNeutral (series color) 
     colorBullish (series color) 
     colorBearish (series color) 
     coloredLines (series bool) 
 Point 
  Used to determine a coordination on the chart
  Fields:
     x (series int) 
     y (series float) 
 Pivot 
  Used to determine pivots on the chart
  Fields:
     point (Point) 
     isHigh (series bool) 
     isHigher (series bool) 
     ln (series line) 
     lb (series label)
SuperBollingerTrend (Expo)█  Overview 
The  SuperBollingerTrend  indicator is a combination of two popular technical analysis tools, Bollinger Bands, and SuperTrend. By fusing these two indicators, SuperBollingerTrend aims to provide traders with a more comprehensive view of the market, accounting for both volatility and trend direction. By combining trend identification with volatility analysis, the SuperBollingerTrend indicator provides traders with valuable insights into potential trend changes. It recognizes that high volatility levels often accompany stronger price momentum, which can result in the formation of new trends or the continuation of existing ones.
█  How Volatility Impacts Trends 
Volatility can impact trends by expanding or contracting them, triggering trend reversals, leading to breakouts, and influencing risk management decisions. Traders need to analyze and monitor volatility levels in conjunction with trend analysis to gain a comprehensive understanding of market dynamics. 
█  How to use 
 Trend Reversals:  High volatility can result in more dramatic price fluctuations, which may lead to sharp trend reversals. For example, a sudden increase in volatility can cause a bullish trend to transition into a bearish one, or vice versa, as traders react to significant price swings.
  
 Volatility Breakouts:  Volatility can trigger breakouts in trends. Breakouts occur when the price breaks through a significant support or resistance level, indicating a potential shift in the trend. Higher volatility levels can increase the likelihood of breakouts, as they indicate stronger market momentum and increased buying or selling pressure. This indicator triggers when the volatility increases, and if the price is near a key level when the indicator alerts, it might trigger a great trend.
  
█  Features 
 Peak Signal Move 
The indicator calculates the peak price move for each ZigZag and displays it under each signal. This highlights how much the market moved between the signals. 
 Average ZigZag Move 
All price moves between two signals are stored, and the average or the median is calculated and displayed in a table. This gives traders a great idea of how much the market moves on average between two signals.
 Take Profit 
The Take Profit line is placed at the average or the median price move and gives traders a great idea of what they can expect in average profit from the latest signals. 
-----------------
Disclaimer
The information contained in my Scripts/Indicators/Ideas/Algos/Systems does not constitute financial advice or a solicitation to buy or sell any securities of any type. I will not accept liability for any loss or damage, including without limitation any loss of profit, which may arise directly or indirectly from the use of or reliance on such information.
All investments involve risk, and the past performance of a security, industry, sector, market, financial product, trading strategy, backtest, or individual's trading does not guarantee future results or returns. Investors are fully responsible for any investment decisions they make. Such decisions should be based solely on an evaluation of their financial circumstances, investment objectives, risk tolerance, and liquidity needs.
My Scripts/Indicators/Ideas/Algos/Systems are only for educational purposes!
[JL] Supertrend Zone Pivot Point with zigzag fibThis is an open-source Pine script that generates a Supertrend Zone Pivot Point with Zigzag Fib indicator for TradingView. The indicator displays the Supertrend Zone, pivot points, and Fibonacci levels on the chart.
One of the unique features of this indicator is that it uses a Zigzag that does not repaint, ensuring accurate high and low points for the pivot points. 
Another feature is that when the Supertrend is in an uptrend, only the highest points are taken as pivot points, and when it's in a downtrend, only the lowest points are taken as pivot points.
The Fibonacci levels are calculated based on the previous high and low pivot points, with labels displaying the corresponding levels on the chart. 
  
The indicator also includes options to show/hide the Zigzag and Fibonacci levels.
Overall, this indicator is useful for identifying key pivot points and Fibonacci levels in the Supertrend Zone, providing valuable information for traders to make informed decisions.
Elliott Wave [LuxAlgo]The Elliott Wave indicator allows users to detect Elliott Wave (EW) impulses as well as corrective segments automatically on the chart. These are detected and displayed serially, allowing users to keep track of the evolution of an impulse or corrective wave.
Fibonacci retracements constructed from detected impulse waves are also included.
This script additionally allows users to get alerted on a wide variety of trigger conditions (see the ALERTS section below).
🔶  SETTINGS 
  
🔹 Source 
  • "high" -> options high, close, maximum of open/close
  • "low"   -> options low, close, minimum of open/close
🔹 ZigZag 
  • The source and length are used to check whether a new Pivot Point is found.
   Example:
   • source = high/low, length = 10:
   • There is a new pivot  high when:
     - previous high is higher than current high 
     - the highs of 10 bars prior to previous high are all lower
   • These pivot  points  are used to form the ZigZag lines, which in their turn are used for pattern recognition
🔶  USAGE 
The basic principles we use to identify Elliott Wave impulses are: 
    • A movement in the direction of the trend ( Motive/Impulse wave ) is divided in 5 waves (Wave 1 -> 5)
    • The  Corrective Wave  (against the trend) is divided in 3 waves (Wave A -> C)
    • The waves can be subdivided in smaller waves
    •  Wave 2  can’t retrace more than the beginning of  Wave 1 
    •  Wave 4  does not overlap with the price territory of  Wave 1 
  
Here we see an example:
  
Let's look at the development:
  • 1 bar after point (5) a confirmed  5 Motive Wave pattern  is found (1 -> 5; The 5 Waves can also be seen as one large  Wave 1 ).
  •  Next, the script draws a set of Fibonacci lines, which are area's where the Corrective Wave potentially will bounce.
  
Here we see the fifth wave is getting larger, the previous highest point is updated, and the  Wave 5  is larger than  Wave 3 :
  
  
(At this point, the pattern is invalidated, and it display as dotted)
Further progression in time:
  
  
At this point, a confirmed " 3 Corrective Wave pattern " is found (a -> c)
  
When a new high has developed, a circle is drawn (in the same color of the lines)
  
However, when the bottom of the drawn box has breached, a red cross will be visualized.
  
Further progression:
  
Later on, a bearish  confirmed " 5 Motive Wave pattern " is found (1 -> 5):
  
When a Corrective Wave becomes invalidated, the ABC pattern will display as dashed (not dotted):
  
🔶  TECHNIQUES 
Pine Script™ introduces methods!
   • More information can be found here:
   •  Pine Script™ v5 User Manual  👉  Methods 
   •  Pine Script™ language reference manual  👉  method 
🔶  ALERTS 
 Dynamic alerts are included in the script, you only need to set 1 alert to receive following messages:
 
   • When a new EW Motive Pattern is found (Bullish/Bearish )
   • When a new EW Corrective Pattern is found (Bullish/Bearish )
   • When an EW Motive Pattern is invalidated (Bullish/Bearish )
   • When an EW Corrective Pattern is invalidated (Bullish/Bearish )
   • When possible, a start of a new EW Motive Wave is found (Bullish/Bearish )
   •  Here is information how you can set these alerts()
Recursive Zigzag [Trendoscope]Here is an another outcome of Object Oriented Zigzag and Pattern Ecosystem of Libraries. 
We already have another implementation of  recursive zigzag  which makes use of earlier library  rzigzag . Here in this example, we make use of similar logic but leverage the new type and method based Zigzag system libraries to derive the indicator.
 🎲 Design Overview  
Similar to Recursive Auto Pitchfork, here too the indicator code is around 50 lines. Whereas most of the heavy lifting is done by the libraries.
  
 🎲 Base Libraries 
Base libraries are those which does not have any dependency. They form basic structures which are later used in other libraries. These libraries need to be crafted carefully so that minimal updates are done later on. Any updates on these libraries will impact all the dependent libraries and scripts.
 🎯 Drawing 
 
   DrawingTypes  - Defines basic drawing types Point, Line, Label, Box, Linefill and related property types.
   DrawingMethods  - All the methods or functionality surrounding Basic types are defined here.
 
 🎲 Layer 1 Libraries 
These are the libraries which has direct dependency on base libraries.
 🎯 Zigzag 
 
   ZigzagTypes  - Types required for defining Zigzag and Divergence
   ZigzagMethods  - Methods associated with Zigzag Type definitions.
 
 🎲Indicator 
Indicator draws zigzags based on given length. And then recursively derives next level zigzags based on previous levels. As per the utility, indicator is useful in several ways
 
  Visualising price structure based on zigzag pivots - which in turn can help visualise patterns.
  Ability to add any oscillator makes it easy to spot divergences with choice of indicators.
  Programmers can use the derived values to build complex algorithms such as automatic pattern recognition.
 
 🎯 Settings 
Settings are explained via tooltips. These are very much straight forward and directly related to zigzag, oscillators and divergence.
  
PitchforkMethodsLibrary   "PitchforkMethods" 
Methods associated with Pitchfork and Pitchfork Drawing. Depends on the library PitchforkTypes for Pitchfork/PitchforkDrawing objects which in turn use DrawingTypes for basic objects Point/Line/LineProperties. Also depends on DrawingMethods for related methods
 tostring(this) 
  Converts PitchforkTypes/Fork object to string representation
  Parameters:
     this : PitchforkTypes/Fork object
  Returns: string representation of PitchforkTypes/Fork
 tostring(this) 
  Converts Array of PitchforkTypes/Fork object to string representation
  Parameters:
     this : Array of PitchforkTypes/Fork object
  Returns: string representation of PitchforkTypes/Fork array
 tostring(this, sortKeys, sortOrder) 
  Converts PitchforkTypes/PitchforkProperties object to string representation
  Parameters:
     this : PitchforkTypes/PitchforkProperties object
     sortKeys : If set to true, string output is sorted by keys.
     sortOrder : Applicable only if sortKeys is set to true. Positive number will sort them in ascending order whreas negative numer will sort them in descending order. Passing 0 will not sort the keys
  Returns: string representation of PitchforkTypes/PitchforkProperties
 tostring(this, sortKeys, sortOrder) 
  Converts PitchforkTypes/PitchforkDrawingProperties object to string representation
  Parameters:
     this : PitchforkTypes/PitchforkDrawingProperties object
     sortKeys : If set to true, string output is sorted by keys.
     sortOrder : Applicable only if sortKeys is set to true. Positive number will sort them in ascending order whreas negative numer will sort them in descending order. Passing 0 will not sort the keys
  Returns: string representation of PitchforkTypes/PitchforkDrawingProperties
 tostring(this, sortKeys, sortOrder) 
  Converts PitchforkTypes/Pitchfork object to string representation
  Parameters:
     this : PitchforkTypes/Pitchfork object
     sortKeys : If set to true, string output is sorted by keys.
     sortOrder : Applicable only if sortKeys is set to true. Positive number will sort them in ascending order whreas negative numer will sort them in descending order. Passing 0 will not sort the keys
  Returns: string representation of PitchforkTypes/Pitchfork
 createDrawing(this) 
  Creates PitchforkTypes/PitchforkDrawing from PitchforkTypes/Pitchfork object
  Parameters:
     this : PitchforkTypes/Pitchfork object
  Returns: PitchforkTypes/PitchforkDrawing object created
 createDrawing(this) 
  Creates PitchforkTypes/PitchforkDrawing array from PitchforkTypes/Pitchfork array of objects
  Parameters:
     this : array of PitchforkTypes/Pitchfork object
  Returns: array of PitchforkTypes/PitchforkDrawing object created
 draw(this) 
  draws from PitchforkTypes/PitchforkDrawing object
  Parameters:
     this : PitchforkTypes/PitchforkDrawing object
  Returns: PitchforkTypes/PitchforkDrawing object drawn
 delete(this) 
  deletes PitchforkTypes/PitchforkDrawing object
  Parameters:
     this : PitchforkTypes/PitchforkDrawing object
  Returns: PitchforkTypes/PitchforkDrawing object deleted
 delete(this) 
  deletes underlying drawing of PitchforkTypes/Pitchfork object
  Parameters:
     this : PitchforkTypes/Pitchfork object
  Returns: PitchforkTypes/Pitchfork object deleted
 delete(this) 
  deletes array of PitchforkTypes/PitchforkDrawing objects
  Parameters:
     this : Array of PitchforkTypes/PitchforkDrawing object
  Returns: Array of PitchforkTypes/PitchforkDrawing object deleted
 delete(this) 
  deletes underlying drawing in array of PitchforkTypes/Pitchfork objects
  Parameters:
     this : Array of PitchforkTypes/Pitchfork object
  Returns: Array of PitchforkTypes/Pitchfork object deleted
 clear(this) 
  deletes array of PitchforkTypes/PitchforkDrawing objects and clears the array
  Parameters:
     this : Array of PitchforkTypes/PitchforkDrawing object
  Returns: void
 clear(this) 
  deletes array of PitchforkTypes/Pitchfork objects and clears the array
  Parameters:
     this : Array of Pitchfork/Pitchfork object
  Returns: void
PitchforkTypesLibrary   "PitchforkTypes" 
User Defined Types to be used for Pitchfork and Drawing elements of Pitchfork. Depends on DrawingTypes for Point, Line, and LineProperties objects
 PitchforkDrawingProperties 
  Pitchfork Drawing Properties object
  Fields:
     extend : If set to true, forks are extended towards right. Default is true
     fill : Fill forklines with transparent color. Default is true
     fillTransparency : Transparency at which fills are made. Only considered when fill is set. Default is 80
     forceCommonColor : Force use of common color for forks and fills. Default is false
     commonColor : common fill color. Used only if ratio specific fill colors are not available or if forceCommonColor is set to true.
 PitchforkDrawing 
  Pitchfork drawing components
  Fields:
     medianLine : Median line of the pitchfork
     baseLine : Base line of the pitchfork
     forkLines : fork lines of the pitchfork
     linefills : Linefills between forks
 Fork 
  Fork object property
  Fields:
     ratio : Fork ratio
     forkColor : color of fork. Default is blue
     include : flag to include the fork in drawing. Default is true
 PitchforkProperties 
  Pitchfork Properties
  Fields:
     forks : Array of Fork objects
     type : Pitchfork type. Supported values are "regular", "schiff", "mschiff", Default is regular
     inside : Flag to identify if to draw inside fork. If set to true, inside fork will be drawn
 Pitchfork 
  Pitchfork object
  Fields:
     a : Pivot Point A of pitchfork
     b : Pivot Point B of pitchfork
     c : Pivot Point C of pitchfork
     properties : PitchforkProperties object which determines type and composition of pitchfork
     dProperties : Drawing properties for pitchfork
     lProperties : Common line properties for Pitchfork lines
     drawing : PitchforkDrawing object






















