[blackcat] L2 Ehlers Autocorrelation Indicator V2OVERVIEW 
The Ehlers Autocorrelation Indicator is a technical analysis tool developed by John F. Ehlers that measures the correlation between price data and its lagged versions to identify potential market cycles and reversals.
 BACKGROUND 
Originally introduced in Ehlers' "Cycle Analytics for Traders" (2013), this indicator leverages autocorrelation principles to detect patterns in market data that deviate from random noise or perfect sine waves.
 FEATURES 
• Calculates Pearson correlation coefficients for lags from 0 to 60 bars
• Visualizes correlations using colored bars ranging from red (negative correlation) to yellow (positive correlation)
• Provides minimum averaging option through AvgLength input parameter
• Displays sharp reversal signals at price turning points
• Shows variations in bar thickness and count over time
 HOW TO USE 
Add the indicator to your chart
Adjust the AvgLength input as needed:
• Set to 0 for no averaging
• Increase value for smoother results
Interpret the colored bars:
• Red: Negative correlation
• Yellow: Positive correlation
• Sharp transitions indicate potential reversal points
 LIMITATIONS 
• Requires sufficient historical data for accurate calculations
• Performance may vary across different market conditions
• Results depend on proper parameter settings
 NOTES 
• The indicator uses highpass filtering and super smoother filtering techniques
• Color intensity varies based on correlation strength
• Multiple lag periods are displayed simultaneously for comprehensive analysis
 THANKS 
This implementation is based on Ehlers' original work and has been adapted for TradingView's Pine Script platform.
Wyszukaj w skryptach "wave"
Squeeze Momentum Indicator Strategy [LazyBear + PineIndicators]The Squeeze Momentum Indicator Strategy (SQZMOM_LB Strategy) is an automated trading strategy based on the Squeeze Momentum Indicator developed by LazyBear, which itself is a modification of John Carter's "TTM Squeeze" concept from his book Mastering the Trade (Chapter 11). This strategy is designed to identify low-volatility phases in the market, which often precede explosive price movements, and to enter trades in the direction of the prevailing momentum.
 Concept & Indicator Breakdown 
The strategy employs a combination of Bollinger Bands (BB) and Keltner Channels (KC) to detect market squeezes:
 Squeeze Condition: 
 
 When Bollinger Bands are inside the Keltner Channels (Black Crosses), volatility is low, signaling a potential upcoming price breakout.
 When Bollinger Bands move outside Keltner Channels (Gray Crosses), the squeeze is released, indicating an expansion in volatility.
 
 Momentum Calculation: 
 
 A linear regression-based momentum value is used instead of traditional momentum indicators.
 The momentum histogram is color-coded to show strength and direction:
 Lime/Green: Increasing bullish momentum
 Red/Maroon: Increasing bearish momentum
 
 Signal Colors: 
 
 Black: Market is in a squeeze (low volatility).
 Gray: Squeeze is released, and volatility is expanding.
 Blue: No squeeze condition is present.
 
 Strategy Logic 
The script uses historical volatility conditions and momentum trends to generate buy/sell signals and manage positions.
 1. Entry Conditions 
Long Position (Buy)
 
 The squeeze just released (Gray Cross after Black Cross).
 The momentum value is increasing and positive.
 The momentum is at a local low compared to the past 100 bars.
 The price is above the 100-period EMA.
 The closing price is higher than the previous close.
 
Short Position (Sell)
 
 The squeeze just released (Gray Cross after Black Cross).
 The momentum value is decreasing and negative.
 The momentum is at a local high compared to the past 100 bars.
 The price is below the 100-period EMA.
 The closing price is lower than the previous close.
 
 2. Exit Conditions 
Long Exit:
 
 The momentum value starts decreasing (momentum lower than previous bar).
 
Short Exit:
 
 The momentum value starts increasing (momentum higher than previous bar).
 
 Position Sizing 
Position size is dynamically adjusted based on 8% of strategy equity, divided by the current closing price, ensuring risk-adjusted trade sizes.
 How to Use This Strategy 
 Apply on Suitable Markets: 
Best for stocks, indices, and forex pairs with momentum-driven price action.
Works on multiple timeframes but is most effective on higher timeframes (1H, 4H, Daily).
 Confirm Entries with Additional Indicators: 
The author recommends ADX or WaveTrend to refine entries and avoid false signals.
 Risk Management: 
Since the strategy dynamically sizes positions, it's advised to use stop-losses or risk-based exits to avoid excessive drawdowns.
 Final Thoughts 
The Squeeze Momentum Indicator Strategy provides a systematic approach to trading volatility expansions, leveraging the classic TTM Squeeze principles with a unique linear regression-based momentum calculation. Originally inspired by John Carter’s method, LazyBear's version and this strategy offer a refined, adaptable tool for traders looking to capitalize on market momentum shifts.
Sigma 2.0 - Advanced Buy and Sell Signal IndicatorOverview:
Sigma 2.0 is a sophisticated trading indicator designed to help traders identify potential buy and sell opportunities across various financial markets. By leveraging advanced mathematical calculations and incorporating multiple analytical tools, Sigma 2.0 aims to enhance trading strategies by providing precise entry and exit signals.
Key Features:
Advanced Sigma Calculations:
Utilizes a combination of Exponential Moving Averages (EMAs) and price deviations to calculate the Sigma lines (sigma1 and sigma2).
Detects potential trend reversals through the crossover of these Sigma lines.
Customizable Signal Filtering:
Offers the ability to filter buy and sell signals based on user-defined thresholds.
Helps reduce false signals in volatile markets by setting overbought and oversold levels.
Overbought and Oversold Detection:
Identifies extreme market conditions where price reversals are more likely.
Changes the background color of the chart to visually indicate overbought or oversold states.
Integration of Exponential Moving Averages (EMAs):
Includes EMAs of different lengths (10, 21, 55, 200) to assist in identifying market trends.
EMAs act as dynamic support and resistance levels.
Higher Timeframe Signal Incorporation:
Allows users to include signals from a higher timeframe to align trades with the broader market trend.
Enhances the reliability of signals by considering multiple timeframes.
Custom Alerts:
Provides alert conditions for both buy and sell signals.
Enables traders to receive notifications, ensuring timely decision-making.
How It Works:
Sigma Calculation Methodology:
The indicator calculates an average price (ap) and applies EMAs to derive the Sigma lines.
sigma1 represents the smoothed price deviation, while sigma2 is a moving average of sigma1.
A crossover of sigma1 above sigma2 generates a buy signal, indicating potential upward momentum.
Conversely, a crossover of sigma1 below sigma2 generates a sell signal.
Signal Filtering and Thresholds:
Users can enable filtering to only consider signals when sigma1 is below or above certain thresholds.
This helps in focusing on more significant market movements and reducing noise.
Overbought/Oversold Levels:
The indicator monitors sigma1 to detect when the market is in extreme conditions.
Background color changes provide a quick visual cue for these conditions.
EMA Analysis:
The plotted EMAs help in confirming the trend direction.
They can be used alongside Sigma signals to validate trade entries and exits.
Higher Timeframe Signals:
Incorporates signals from a user-selected higher timeframe.
Helps in aligning trades with the overall market trend, increasing the potential success rate.
How to Use:
Adding the Indicator to Your Chart:
Search for "Sigma 2.0" in the TradingView Indicators menu and add it to your chart.
Configuring the Settings:
Adjust the Sigma configurations (Channel Length, Average Length, Signal Line Length) to suit your trading style.
Set the overbought and oversold levels according to your risk tolerance.
Choose whether to filter signals by thresholds.
Select the higher timeframe for additional signal confirmation.
Interpreting the Signals:
Buy Signals:
Indicated by a green triangle below the price bar.
Occur when sigma1 crosses above sigma2 and other conditions are met.
Sell Signals:
Indicated by a red triangle above the price bar.
Occur when sigma1 crosses below sigma2 and other conditions are met.
Higher Timeframe Signals:
Plotted with lime (buy) and maroon (sell) triangles.
Help confirm signals in the current timeframe.
Utilizing EMAs:
Observe the EMAs to gauge the overall trend.
Consider aligning buy signals when the price is above key EMAs and sell signals when below.
Setting Up Alerts:
Use the built-in alert conditions to receive notifications for buy and sell signals.
Customize alert messages as needed.
Credits:
Original Concept Inspiration:
This indicator is inspired by the WaveTrend oscillator and other momentum-based indicators.
Special thanks to the original authors whose work laid the foundation for this enhanced version.
Disclaimer:
Trading involves significant risk, and past performance is not indicative of future results.
This indicator is a tool to assist in analysis and should not be the sole basis for any trading decision.
Always perform thorough analysis and consider multiple factors before entering a trade.
Note:
Ensure your chart is clean and only includes this indicator when publishing.
The script is open-source and can be modified to fit individual trading strategies.
For any questions or support, feel free to reach out or comment.
E9 Shark-32 PatternUnderstanding the Shark-32 Pattern and its Trading Applications 
The Shark-32 Pattern is a bearish technical trading formation used to predict market reversals or trend continuations. It highlights a downward move followed by a corrective rally, signaling a potential resumption of the downtrend. Here’s a breakdown of how it works:
 What is the Shark-32 Pattern? 
The Shark-32 pattern is a five-wave structure typically observed in bearish markets:
 
 Wave 0 to X: A significant price decline starts the pattern.
 Wave X to A: A correction pushes the price slightly upward.
 Wave A to B: The price drops again but doesn’t reach the initial low.
 Wave B to C: A final sharp decline concludes the pattern.
 Once Wave C is formed, it suggests that the market will continue to move downward, presenting a potential selling or shorting opportunity.
 
 Using the Pattern in Trading 
This pattern is valuable for traders seeking high-probability bearish setups. The goal is to capitalize on the continuation of a downtrend following the corrective rally (X to A). Identifying the Shark-32 pattern helps anticipate the next wave of selling pressure.
 Trading Setup 
Identify a Shark-32 pattern.
If the price closes above the pattern's high, buy at the open the next day.
If the price closes below the pattern's low, short at the open the next day.
Sell/cover when the price moves 7% in the direction of the breakout.
Close the trade for a loss if the price moves 7% in the opposite direction.
For example, in a bull market after an upward breakout from a Shark-32, the net gain was $69.55. The method won 56% of the time with 5,218 winning trades and an average gain of $714.07. Conversely, 44% of trades were losers, with an average loss of $747.33. The average holding period was 26 calendar days.
The gains and losses were closely aligned with the 7% threshold set for this test.
 Key Target Levels 
To enhance the strategy, use dotted projection lines as target levels:
Upper Target: Drawn above the high of the corrective rally (Wave A). If the price breaks above this line, it may signal further upward movement, indicating a potentially weaker downtrend.
Lower Target: Positioned below the low of Wave C, providing a target for bearish trades.
These lines help determine future price targets and assist in setting take-profit or stop-loss levels.
 Trading the Breakout 
Look for breakouts once the Shark-32 pattern is identified:
Upward Breakout: If the price closes above the green line (high from two bars ago), it indicates a potential reversal to the upside.
Downward Breakout: If the price breaks below the red line (low from two bars ago), it confirms the bearish continuation.
Breakouts allow traders to adjust their positions based on market shifts.
 Trading Tips 
Continuation: The Shark-32 pattern acts as a continuation 60% of the time, confirming the ongoing trend.
Breakout Confirmation: Wait for the price to close above or below the pattern’s key levels before entering a trade.
Trade with the Trend: Since the Shark-32 is a continuation pattern, expect the breakout to align with the inbound price trend.
Symmetry: Patterns with symmetry often perform better. For more insights, refer to detailed trading literature.
Half-Staff: The Shark-32 can form midway in a trend, similar to flags and pennants.
 Shark-32: Trading Performance 
Based on an analysis of 23,369 trades, the following performance metrics were observed:
Bull Market with Upward Breakout: The average net profit was $69.55. This method won 56% of the time, with winning trades averaging $714.07. Losing trades, which constituted 44% of the total, had an average loss of $747.33. The average holding period was 26 calendar days.
Bull Market with Downward Breakout: The average net loss was $(76.36). This method won 43% of the time, with winning trades averaging $753.56. Losing trades, which constituted 57% of the total, had an average loss of $706.32. The average holding period was 23 calendar days.
Bear Market with Upward Breakout: The average net loss was $(89.13). This method won 46% of the time, with winning trades averaging $710.77. Losing trades, which constituted 54% of the total, had an average loss of $756.97. The average holding period was 16 calendar days.
Bear Market with Downward Breakout: The average net profit was $65.17. This method won 52% of the time, with winning trades averaging $781.62. Losing trades, which constituted 48% of the total, had an average loss of $722.41. The average holding period was 13 calendar days.
ABCD Projection [Trendoscope®]Over the years, we have extensively explored and published numerous scripts centered around various chart patterns, including Harmonic Patterns, Reversal Patterns, Elliott Waves, and more. Our expertise in these areas has led to frequent requests for an indicator based on the ABCD pattern. Although we didn't include it as part of our Harmonic Patterns collection, the development of a dedicated ABCD Projection Indicator has always been a priority for us.
 🎲 Overview of the ABCD Projection Indicator 
The ABCD Projection Indicator is designed to identify and project ABCD patterns using a Zigzag-based approach. This pattern, characterized by alternating pivot highs and lows labeled as A, B, C, and D, is particularly significant in trending markets where it signifies trend continuation following deep pullbacks.
The indicator works by confirming the ABC pivots and projecting the D pivot based on the established price swings. Since ABCD patterns are most effective in trending environments, the indicator focuses on filtering patterns where the retracement from the C pivot has not compromised the trade's potential. Specifically, it ensures that the starting point (S)—where the pattern is detected—has not retraced beyond a defined threshold, preserving the opportunity to execute a trade with the goal of reaching the projected D pivot.
Additionally, the ABCD Projection Indicator considers the retracement ratio from the C pivot, which plays a crucial role in risk management. A higher retracement ratio reduces the stop distance (from pivot A to the entry point S) while increasing the distance to the target (pivot D), thereby enhancing the reward/risk ratio for trades.
 🎲 Components of the ABCD Projection Indicator 
The ABCD Projection Indicator comprises several key components:
 
 A, B, C Pivots and Zigzag Wave : These elements form the foundational structure of the ABCD pattern.
 S Point : This is the location where the pattern is identified, positioned a few bars away from the confirmed C pivot.
 Estimated D Pivot : The D pivot is projected based on the A, B, and C price levels. The time or distance to the D pivot is influenced by the starting point S.
 Mini Stats Table : Located in the top right corner, this table displays win/loss ratios and risk/reward data for both bullish and bearish scenarios.
 Fibonacci Levels : Calculated from the C to D pivots, these levels are provided as a reference for additional analysis.
 
 🎲 Indicator Settings 
The settings for the ABCD Projection Indicator are minimal and intuitive, with tooltips provided to guide users through the configuration process.
Harmonic Patterns Library [TradingFinder]🔵 Introduction 
Harmonic patterns blend geometric shapes with Fibonacci numbers, making these numbers fundamental to understanding the patterns.
One person who has done a lot of research on harmonic patterns is Scott Carney.Scott Carney's research on harmonic patterns in technical analysis focuses on precise price structures based on Fibonacci ratios to identify market reversals. 
Key patterns include the Gartley, Bat, Butterfly, and Crab, each with specific alignment criteria. These patterns help traders anticipate potential market turning points and make informed trading decisions, enhancing the predictability of technical analysis.
🟣 Understanding 5-Point Harmonic Patterns 
In the current library version, you can easily draw and customize most XABCD patterns. These patterns often form M or W shapes, or a combination of both. By calculating the Fibonacci ratios between key points, you can estimate potential price movements. 
All five-point patterns share a similar structure, differing only in line lengths and Fibonacci ratios. Learning one pattern simplifies understanding others.
  
🟣 Exploring the Gartley Pattern 
The Gartley pattern appears in both bullish (M shape) and bearish (W shape) forms. In the bullish Gartley, point X is below point D, and point A surpasses point C. Point D marks the start of a strong upward trend, making it an optimal point to place a buy order. 
The bearish Gartley mirrors the bullish pattern with inverted Fibonacci ratios. In this scenario, point D indicates the start of a significant price drop. Traders can place sell orders at this point and buy at lower prices for profit in two-way markets.
🟣 Analyzing the Butterfly Pattern 
The Butterfly pattern also manifests in bullish (M shape) and bearish (W shape) forms. It resembles the Gartley pattern but with point D lower than point X in the bullish version. 
The Butterfly pattern involves deeper price corrections than the Gartley, leading to more significant price fluctuations. Point D in the bullish Butterfly indicates the beginning of a sharp price rise, making it an entry point for buy orders. 
The bearish Butterfly has inverted Fibonacci ratios, with point D marking the start of a sharp price decline, ideal for sell orders followed by buying at lower prices in two-way markets.
🟣 Insights into the Bat Pattern 
The Bat pattern, appearing in bullish (M shape) and bearish (W shape) forms, is one of the most precise harmonic patterns. It closely resembles the Butterfly and Gartley patterns, differing mainly in Fibonacci levels. 
The bearish Bat pattern shares the Fibonacci ratios with the bullish Bat, with an inverted structure. Point D in the bearish Bat marks the start of a significant price drop, suitable for sell orders followed by buying at lower prices for profit.
🟣 The Crab Pattern Explained 
The Crab pattern, found in both bullish (M shape) and bearish (W shape) forms, is highly favored by analysts. Discovered in 2000, the Crab pattern features a larger final wave correction compared to other harmonic patterns. 
The bearish Crab shares Fibonacci ratios with the bullish version but in an inverted form. Point D in the bearish Crab signifies the start of a sharp price decline, making it an ideal point for sell orders followed by buying at lower prices for profitable trades.
🟣 Understanding the Shark Pattern 
The Shark pattern appears in bullish (M shape) and bearish (W shape) forms. It differs from previous patterns as point C in the bullish Shark surpasses point A, with unique level measurements. 
The bearish Shark pattern mirrors the Fibonacci ratios of the bullish Shark but is inverted. Point D in the bearish Shark indicates the start of a sharp price drop, ideal for placing sell orders and buying at lower prices to capitalize on the pattern.
🟣 The Cypher Pattern Overview 
The Cypher pattern is another that appears in both bullish (M shape) and bearish (W shape) forms. It resembles the Shark pattern, with point C in the bullish Cypher extending beyond point A, and point D forming within the XA line. 
The bearish Cypher shares the Fibonacci ratios with the bullish Cypher but in an inverted structure. Point D in the bearish Cypher marks the start of a significant price drop, perfect for sell orders followed by buying at lower prices.
🟣 Introducing the Nen-Star Pattern 
The Nen-Star pattern appears in both bullish (M shape) and bearish (W shape) forms. In the bullish Nen-Star, point C extends beyond point A, and point D, the final point, forms outside the XA line, making CD the longest wave. 
The bearish Nen-Star has inverted Fibonacci ratios, with point D indicating the start of a significant price drop. Traders can place sell orders at point D and buy at lower prices to profit from this pattern in two-way markets.
The 5-point harmonic patterns, commonly referred to as XABCD patterns, are specific geometric price structures identified in financial markets. These patterns are used by traders to predict potential price movements based on historical price data and Fibonacci retracement levels. 
 Here are the main 5-point harmonic patterns :
 
 Gartley Pattern
 Anti-Gartley Pattern
 Bat Pattern
 Anti-Bat Pattern
 Alternate Bat Pattern
 Butterfly Pattern
 Anti-Butterfly Pattern
 Crab Pattern	
 Anti-Crab Pattern
 Deep Crab Pattern
 Shark Pattern
 Anti- Shark Pattern
 Anti Alternate Shark Pattern
 Cypher Pattern
 Anti-Cypher Pattern
 
 
🔵 How to Use 
To add "Order Block Refiner Library", you must first add the following code to your script.
 import TFlab/Harmonic_Chart_Pattern_Library_TradingFinder/1 as HP 
🟣 Parameters 
 XABCD(Name, Type, Show, Color, LineWidth, LabelSize, ShVF, FLPC, FLPCPeriod, Pivot, ABXAmin, ABXAmax, BCABmin, BCABmax, CDBCmin, CDBCmax, CDXAmin, CDXAmax) =>
Parameters: 
Name (string) 
Type (string) 
Show (bool) 
Color (color) 
LineWidth (int) 
LabelSize (string) 
ShVF (bool) 
FLPC (bool) 
FLPCPeriod (int) 
Pivot (int) 
ABXAmin (float) 
ABXAmax (float) 
BCABmin (float) 
BCABmax (float) 
CDBCmin (float) 
CDBCmax (float) 
CDXAmin (float) 
CDXAmax (float)
 
🟣 Genaral Parameters 
 Name : The name of the pattern.
 Type:  Enter "Bullish" to draw a Bullish pattern and "Bearish" to draw an Bearish pattern.
 Show : Enter "true" to display the template and "false" to not display the template.
 Color : Enter the desired color to draw the pattern in this parameter.
 LineWidth : You can enter the number 1 or numbers higher than one to adjust the thickness of the drawing lines. This number must be an integer and increases with increasing thickness.
 LabelSize : You can adjust the size of the labels by using the "size.auto", "size.tiny", "size.smal", "size.normal", "size.large" or "size.huge" entries.
🟣 Logical Parameters 
 ShVF : If this parameter is on "true" mode, only patterns will be displayed that they have exact format and no noise can be seen in them. If "false" is, the patterns displayed that maybe are noisy and do not exactly correspond to the original pattern.
  
 FLPC : if Turned on, you can see this ability of patterns when their last pivot is formed. If this feature is off, it will see the patterns as soon as they are formed. The advantage of this option being clear is less formation of fielded patterns, and it is accompanied by the lateest pattern seeing and a sharp reduction in reward to risk.
 FLPCPeriod : Using this parameter you can determine that the last pivot is based on Pivot period.
  
 Pivot : You need to determine the period of the zigzag indicator. This factor is the most important parameter in pattern recognition.
 ABXAmin : Minimum retracement of "AB" line compared to "XA" line.
 ABXAmax : Maximum retracement of "AB" line compared to "XA" line.
 BCABmin : Minimum retracement of "BC" line compared to "AB" line.
 BCABmax : Maximum retracement of "BC" line compared to "AB" line.
 CDBCmin : Minimum retracement of "CD" line compared to "BC" line.
 CDBCmax : Maximum retracement of "CD" line compared to "BC" line.
 CDXAmin : Minimum retracement of "CD" line compared to "XA" line.
 CDXAmax : Maximum retracement of "CD" line compared to "XA" line.
  
  
🟣 Function Outputs 
This library has two outputs. The first output is related to the alert of the formation of a new pattern. And the second output is related to the formation of the candlestick pattern and you can draw it using the "plotshape" tool.
 Candle Confirmation Logic :
  
 Example :
 import TFlab/Harmonic_Chart_Pattern_Library_TradingFinder/1 as HP
PP = input.int(3, 'ZigZag Pivot Period')
ShowBull = input.bool(true, 'Show Bullish Pattern')
ShowBear = input.bool(true, 'Show Bearish Pattern')
ColorBull = input.color(#0609bb, 'Color Bullish Pattern')
ColorBear = input.color(#0609bb, 'Color Bearish Pattern')
LineWidth = input.int(1 , 'Width Line')
LabelSize = input.string(size.small , 'Label size' , options =  )
ShVF = input.bool(false , 'Show Valid Format')
FLPC = input.bool(false , 'Show Formation Last Pivot Confirm')
FLPCPeriod =input.int(2, 'Period of Formation Last Pivot')
//Call function
  = HP.XABCD('Bullish Bat', 'Bullish', ShowBull, ColorBull , LineWidth, LabelSize ,ShVF,  FLPC, FLPCPeriod, PP, 0.382, 0.50, 0.382, 0.886, 1.618, 2.618, 0.85, 0.9)
  = HP.XABCD('Bearish Bat', 'Bearish', ShowBear, ColorBear , LineWidth, LabelSize ,ShVF,  FLPC, FLPCPeriod, PP, 0.382, 0.50, 0.382, 0.886, 1.618, 2.618, 0.85, 0.9)
//Alert
if BearAlert
    alert('Bearish Harmonic')
if BullAlert
    alert('Bulish Harmonic')
//CandleStick Confirm
plotshape(BearCandleConfirm, style = shape.arrowdown, color = color.red)
plotshape(BullCandleConfirm, style = shape.arrowup, color = color.green, location = location.belowbar )
 
VolumeSpreadAnalysisLibrary   "VolumeSpreadAnalysis" 
A library for Volume Spread Analysis (VSA).
 spread(_barIndex) 
  Calculates the spread of a bar.
  Parameters:
     _barIndex (int) : (int) The index of the bar.
  Returns: (float) The spread of the bar.
 volume(_barIndex) 
  Retrieves the volume of a bar.
  Parameters:
     _barIndex (int) : (int) The index of the bar.
  Returns: (float) The volume of the bar.
 body(_barIndex) 
  Calculates the body of a bar.
  Parameters:
     _barIndex (simple int) : (int) The index of the bar.
  Returns: (float) The body size of the bar.
 wickUpper(_barIndex) 
  Calculates the upper wick of a bar (upper shadow).
  Parameters:
     _barIndex (simple int) : (int) The index of the bar.
  Returns: (float) The upper wick size of the bar.
 wickLower(_barIndex) 
  Calculates the lower wick of a bar (lower shadow).
  Parameters:
     _barIndex (simple int) : (int) The index of the bar.
  Returns: (float) The lower wick size of the bar.
 calcForecastedSMA(_source, _length, _forecastedLevel) 
  Calculates the forecasted Simple Moving Average (SMA).
  Parameters:
     _source (float) : (series float) Source data for calculation.
     _length (simple int) : (int) The length of the SMA.
     _forecastedLevel (float) : (float) The forecasted level to include in the calculation.
  Returns: (float) The forecasted SMA value.
 calcForecastedEMA(_source, _length, _forecastedLevel) 
  Calculates the forecasted Exponential Moving Average (EMA).
  Parameters:
     _source (float) : (series float) Source data for calculation.
     _length (simple int) : (int) The length of the EMA.
     _forecastedLevel (float) : (float) The forecasted level to include in the calculation.
  Returns: (float) The forecasted EMA value.
 calcForecastedRMA(_source, _length, _forecastedLevel) 
  Calculates the forecasted Relative Moving Average (RMA).
  Parameters:
     _source (float) : (series float) Source data for calculation.
     _length (simple int) : (int) The length of the RMA.
     _forecastedLevel (float) : (float) The forecasted level to include in the calculation.
  Returns: (float) The forecasted RMA value.
 calcForecastedWMA(_source, _length, _forecastedLevel) 
  Calculates the forecasted Weighted Moving Average (WMA).
  Parameters:
     _source (float) : (series float) Source data for calculation.
     _length (simple int) : (int) The length of the WMA.
     _forecastedLevel (float) : (float) The forecasted level to include in the calculation.
  Returns: (float) The forecasted WMA value.
 calcElapsedTimePercent() 
  Calculates the elapsed time percent of the current bar.
  Returns: (float) The elapsed time percent.
 calcForecastedSpread(multiplierAtMidpoints, multiplierAtPeaks) 
  Calculates the forecasted spread using elapsed time and dynamic multipliers, handling spread's non-linear nature.
  Parameters:
     multiplierAtMidpoints (float) : (float) The multiplier value at midpoints.
     multiplierAtPeaks (float) : (float) The multiplier value at peaks.
  Returns: (float) The forecasted spread value.
 calcForecastedVolume() 
  Calculates the forecasted volume using elapsed time, satisfying volume's linear nature.
  Returns: (float) The forecasted volume value.
 calcForecastedMA(_source, _length, _forecastedSource, _type) 
  Calculates the forecasted Moving Average (MA) based on the specified type.
  Parameters:
     _source (float) : (series float) Source data for calculation.
     _length (simple int) : (int) The length of the MA.
     _forecastedSource (float) : (float) The forecasted level to include in the calculation.
     _type (simple string) : (string) The type of the MA ("SMA", "EMA", "SMMA (RMA)", "WMA").
  Returns: (float) The forecasted MA value.
 calcMA(_source, _length, _type) 
  Calculates the Moving Average (MA) based on the specified type.
  Parameters:
     _source (float) : (series float) Source data for calculation.
     _length (simple int) : (int) The length of the MA.
     _type (simple string) : (string) The type of the MA ("SMA", "EMA", "SMMA (RMA)", "WMA").
  Returns: (float) The MA value.
 bullBar(_barIndex) 
  Determines if the bar is bullish.
  Parameters:
     _barIndex (simple int) : (int) The index of the bar.
  Returns: (bool) True if the bar is bullish, otherwise false.
 bearBar(_barIndex) 
  Determines if the bar is bearish.
  Parameters:
     _barIndex (simple int) : (int) The index of the bar.
  Returns: (bool) True if the bar is bearish, otherwise false.
 breakout(_barIndex) 
  Determines if there is a breakout above the previous bar.
  Parameters:
     _barIndex (simple int) : (int) The index of the bar.
  Returns: (bool) True if there is a breakout, otherwise false.
 breakdown(_barIndex) 
  Determines if there is a breakdown below the previous bar.
  Parameters:
     _barIndex (simple int) : (int) The index of the bar.
  Returns: (bool) True if there is a breakdown, otherwise false.
 rejectionWickUpper(_rejectionWick) 
  Determines if the upper wick is a rejection wick.
  Parameters:
     _rejectionWick (simple float) : (float) The rejection wick percentage.
  Returns: (bool) True if the upper wick is a rejection wick, otherwise false.
 rejectionWickLower(_rejectionWick) 
  Determines if the lower wick is a rejection wick.
  Parameters:
     _rejectionWick (simple float) : (float) The rejection wick percentage.
  Returns: (bool) True if the lower wick is a rejection wick, otherwise false.
 setupDataVolume(_data, _mult_Low, _mult_High, _mult_Ultra, _maLengthVolume, _maTypeVolume) 
  Sets up data for volume levels.
  Parameters:
     _data (map) : (map) The map to store the levels.
     _mult_Low (simple float) : (float) The multiplier for low level.
     _mult_High (simple float) : (float) The multiplier for high level.
     _mult_Ultra (simple float) : (float) The multiplier for ultra level.
     _maLengthVolume (simple int) : (int) The length for MA.
     _maTypeVolume (simple string) : (string) The type for MA.
  Returns: (void) Nothing.
 setupDataSpread(_data, _mult_Low, _mult_High, _mult_Ultra, _maLengthSpread, _maTypeSpread) 
  Sets up data for spread levels.
  Parameters:
     _data (map) : (map) The map to store the levels.
     _mult_Low (simple float) : (float) The multiplier for low level.
     _mult_High (simple float) : (float) The multiplier for high level.
     _mult_Ultra (simple float) : (float) The multiplier for ultra level.
     _maLengthSpread (simple int) : (int) The length for MA.
     _maTypeSpread (simple string) : (string) The type for MA.
  Returns: (void) Nothing.
 setupDataForecastVolume(_dataForecast, _mult_Low, _mult_High, _mult_Ultra, _maLengthVolume, _predictedLevelVolume, _maTypeVolume) 
  Sets up data for volume and spread levels for forecast.
  Parameters:
     _dataForecast (map) 
     _mult_Low (simple float) : (float) The multiplier for low level.
     _mult_High (simple float) : (float) The multiplier for high level.
     _mult_Ultra (simple float) : (float) The multiplier for ultra level.
     _maLengthVolume (simple int) : (int) The length for MA.
     _predictedLevelVolume (float) : (float) The predicted level for MA.
     _maTypeVolume (simple string) : (string) The type for MA.
  Returns: (void) Nothing.
 setupDataForecastSpread(_dataForecast, _mult_Low, _mult_High, _mult_Ultra, _maLengthSpread, _predictedLevelSpread, _maTypeSpread) 
  Sets up data for spread levels for forecast.
  Parameters:
     _dataForecast (map) 
     _mult_Low (simple float) : (float) The multiplier for low level.
     _mult_High (simple float) : (float) The multiplier for high level.
     _mult_Ultra (simple float) : (float) The multiplier for ultra level.
     _maLengthSpread (simple int) : (int) The length for MA.
     _predictedLevelSpread (float) : (float) The predicted level for MA.
     _maTypeSpread (simple string) : (string) The type for MA.
  Returns: (void) Nothing.
 isVolumeLow(_data, _barIndex) 
  Determines if the volume is low.
  Parameters:
     _data (map) : (map) The data map with volume levels.
     _barIndex (int) 
  Returns: (bool) True if the volume is low, otherwise false.
 isVolumeNormal(_data, _barIndex) 
  Determines if the volume is normal.
  Parameters:
     _data (map) : (map) The data map with volume levels.
     _barIndex (int) 
  Returns: (bool) True if the volume is normal, otherwise false.
 isVolumeHigh(_data, _barIndex) 
  Determines if the volume is high.
  Parameters:
     _data (map) : (map) The data map with volume levels.
     _barIndex (int) 
  Returns: (bool) True if the volume is high, otherwise false.
 isVolumeUltra(_data, _barIndex) 
  Determines if the volume is ultra.
  Parameters:
     _data (map) : (map) The data map with volume levels.
     _barIndex (int) 
  Returns: (bool) True if the volume is ultra, otherwise false.
 isSpreadLow(_data, _barIndex) 
  Determines if the spread is low.
  Parameters:
     _data (map) : (map) The data map with spread levels.
     _barIndex (int) 
  Returns: (bool) True if the spread is low, otherwise false.
 isSpreadNormal(_data, _barIndex) 
  Determines if the spread is normal.
  Parameters:
     _data (map) : (map) The data map with spread levels.
     _barIndex (int) 
  Returns: (bool) True if the spread is normal, otherwise false.
 isSpreadHigh(_data, _barIndex) 
  Determines if the spread is high.
  Parameters:
     _data (map) : (map) The data map with spread levels.
     _barIndex (int) 
  Returns: (bool) True if the spread is high, otherwise false.
 isSpreadUltra(_data, _barIndex) 
  Determines if the spread is ultra.
  Parameters:
     _data (map) : (map) The data map with spread levels.
     _barIndex (int) 
  Returns: (bool) True if the spread is ultra, otherwise false.
 isVolumeText(_data) 
  Determines text string representing the volume area level.
  Parameters:
     _data (map) : (map) The data map with volume levels.
  Returns: (string) Text string of Low, Normal, High, or Ultra.
 isSpreadText(_data) 
  Determines text string representing the spread area level.
  Parameters:
     _data (map) : (map) The data map with spread levels.
  Returns: (string) Text string of Low, Normal, High, or Ultra.
 calcBarColor(_value, _level) 
  Calculates the color based level.
  Parameters:
     _value (float) : (float) The value to check.
     _level (float) : (float) The value level for comparison.
  Returns: (color) The color for the bar.
 bullPinBar(_maxBodyPercent, _minWickPercent) 
  Determines if the bar is a bull pin bar.
  Parameters:
     _maxBodyPercent (simple float) : (float) The maximum body percentage.
     _minWickPercent (simple float) : (float) The minimum wick percentage.
  Returns: (bool) True if the bar is a bull pin bar, otherwise false.
 bearPinBar(_maxBodyPercent, _minWickPercent) 
  Determines if the bar is a bear pin bar.
  Parameters:
     _maxBodyPercent (simple float) : (float) The maximum body percentage.
     _minWickPercent (simple float) : (float) The minimum wick percentage.
  Returns: (bool) True if the bar is a bear pin bar, otherwise false.
 dojiBar(_maxBodyPercent) 
  Determines if the bar is a doji.
  Parameters:
     _maxBodyPercent (simple float) : (float) The maximum body percentage.
  Returns: (bool) True if the bar is a doji, otherwise false.
 spinningTopBar(_minWicksPercent, _emaLength) 
  Determines if the bar is a spinning top.
  Parameters:
     _minWicksPercent (simple float) : (float) The minimum wicks percentage.
     _emaLength (simple int) : (int) The length for EMA calculation.
  Returns: (bool) True if the bar is a spinning top, otherwise false.
 highWaveBar(_minBodyPercent, _minWickPercent, _bars) 
  Determines if the bar is a high wave bar.
  Parameters:
     _minBodyPercent (simple float) : (float) The minimum body percentage.
     _minWickPercent (simple float) : (float) The minimum wick percentage.
     _bars (simple int) : (int) The number of bars for comparison.
  Returns: (bool) True if the bar is a high wave bar, otherwise false.
 consolidationBar(_data, _spread, _bars) 
  Determines if the bars are in consolidation.
  Parameters:
     _data (map) : (map) The data map with spread levels.
     _spread (simple float) : (float) The spread percentage for comparison.
     _bars (simple int) : (int) The number of bars for comparison.
  Returns: (bool) True if the bars are in consolidation, otherwise false.
 S_DownThrust(_data, _bullPinBarMaxBody, _bullPinBarMinWick) 
  Determines if there is a sign of strength (DownThrust).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _bullPinBarMaxBody (simple float) : (float) The maximum body percentage for bull pin bar.
     _bullPinBarMinWick (simple float) : (float) The minimum wick percentage for bull pin bar.
  Returns: (bool) True if there is a sign of strength (DownThrust), otherwise false.
 S_SellingClimax(_data, _rejectionWick) 
  Determines if there is a sign of strength (Selling Climax).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _rejectionWick (simple float) : (float) The rejection wick percentage.
  Returns: (bool) True if there is a sign of strength (Selling Climax), otherwise false.
 S_NoEffortBearishResult() 
  Determines if there is a sign of strength (No Effort Bearish Result).
  Returns: (bool) True if there is a sign of strength (No Effort Bearish Result), otherwise false.
 S_BearishEffortNoResult() 
  Determines if there is a sign of strength (Bearish Effort No Result).
  Returns: (bool) True if there is a sign of strength (Bearish Effort No Result), otherwise false.
 S_InverseDownThrust(_data, _bearPinBarMaxBody, _bearPinBarMinWick) 
  Determines if there is a sign of strength (Inverse DownThrust).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _bearPinBarMaxBody (simple float) : (float) The maximum body percentage for bear pin bar.
     _bearPinBarMinWick (simple float) : (float) The minimum wick percentage for bear pin bar.
  Returns: (bool) True if there is a sign of strength (Inverse DownThrust), otherwise false.
 S_FailedSellingClimax() 
  Determines if there is a sign of strength (Failed Selling Climax).
  Returns: (bool) True if there is a sign of strength (Failed Selling Climax), otherwise false.
 S_BullOutsideReversal(_data) 
  Determines if there is a sign of strength (Bull Outside Reversal).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
  Returns: (bool) True if there is a sign of strength (Bull Outside Reversal), otherwise false.
 S_EndOfFallingMarket(_data) 
  Determines if there is a sign of strength (End of Falling Market).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
  Returns: (bool) True if there is a sign of strength (End of Falling Market), otherwise false.
 S_PseudoDownThrust(_bullPinBarMaxBody, _bullPinBarMinWick) 
  Determines if there is a sign of strength (Pseudo DownThrust).
  Parameters:
     _bullPinBarMaxBody (simple float) : (float) The maximum body percentage for bull pin bar.
     _bullPinBarMinWick (simple float) : (float) The minimum wick percentage for bull pin bar.
  Returns: (bool) True if there is a sign of strength (Pseudo DownThrust), otherwise false.
 S_NoSupply(_bullPinBarMaxBody, _bullPinBarMinWick) 
  Determines if there is a sign of strength (No Supply).
  Parameters:
     _bullPinBarMaxBody (simple float) : (float) The maximum body percentage for bull pin bar.
     _bullPinBarMinWick (simple float) : (float) The minimum wick percentage for bull pin bar.
  Returns: (bool) True if there is a sign of strength (No Supply), otherwise false.
 W_UpThrust(_data, _bearPinBarMaxBody, _bearPinBarMinWick) 
  Determines if there is a sign of weakness (UpThrust).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _bearPinBarMaxBody (simple float) : (float) The maximum body percentage for bear pin bar.
     _bearPinBarMinWick (simple float) : (float) The minimum wick percentage for bear pin bar.
  Returns: (bool) True if there is a sign of weakness (UpThrust), otherwise false.
 W_BuyingClimax(_data, _rejectionWick) 
  Determines if there is a sign of weakness (Buying Climax).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _rejectionWick (simple float) : (float) The rejection wick percentage.
  Returns: (bool) True if there is a sign of weakness (Buying Climax), otherwise false.
 W_NoEffortBullishResult() 
  Determines if there is a sign of weakness (No Effort Bullish Result).
  Returns: (bool) True if there is a sign of weakness (No Effort Bullish Result), otherwise false.
 W_BullishEffortNoResult() 
  Determines if there is a sign of weakness (Bullish Effort No Result).
  Returns: (bool) True if there is a sign of weakness (Bullish Effort No Result), otherwise false.
 W_InverseUpThrust(_data, _bullPinBarMaxBody, _bullPinBarMinWick) 
  Determines if there is a sign of weakness (Inverse UpThrust).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _bullPinBarMaxBody (simple float) : (float) The maximum body percentage for bull pin bar.
     _bullPinBarMinWick (simple float) : (float) The minimum wick percentage for bull pin bar.
  Returns: (bool) True if there is a sign of weakness (Inverse UpThrust), otherwise false.
 W_FailedBuyingClimax() 
  Determines if there is a sign of weakness (Failed Buying Climax).
  Returns: (bool) True if there is a sign of weakness (Failed Buying Climax), otherwise false.
 W_BearOutsideReversal(_data) 
  Determines if there is a sign of weakness (Bear Outside Reversal).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
  Returns: (bool) True if there is a sign of weakness (Bear Outside Reversal), otherwise false.
 W_EndOfRisingMarket(_data) 
  Determines if there is a sign of weakness (End of Rising Market).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
  Returns: (bool) True if there is a sign of weakness (End of Rising Market), otherwise false.
 W_PseudoUpThrust(_bearPinBarMaxBody, _bearPinBarMinWick) 
  Determines if there is a sign of weakness (Pseudo UpThrust).
  Parameters:
     _bearPinBarMaxBody (simple float) : (float) The maximum body percentage for bear pin bar.
     _bearPinBarMinWick (simple float) : (float) The minimum wick percentage for bear pin bar.
  Returns: (bool) True if there is a sign of weakness (Pseudo UpThrust), otherwise false.
 W_NoDemand(_bearPinBarMaxBody, _bearPinBarMinWick) 
  Determines if there is a sign of weakness (No Demand).
  Parameters:
     _bearPinBarMaxBody (simple float) : (float) The maximum body percentage for bear pin bar.
     _bearPinBarMinWick (simple float) : (float) The minimum wick percentage for bear pin bar.
  Returns: (bool) True if there is a sign of weakness (No Demand), otherwise false.
 N_QuietDoji(_dojiBarMaxBody) 
  Determines if there is a neutral signal (Quiet Doji).
  Parameters:
     _dojiBarMaxBody (simple float) : (float) The maximum body percentage for doji bar.
  Returns: (bool) True if there is a neutral signal (Quiet Doji), otherwise false.
 N_BalancedDoji(_data, _dojiBarMaxBody) 
  Determines if there is a neutral signal (Balanced Doji).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _dojiBarMaxBody (simple float) : (float) The maximum body percentage for doji bar.
  Returns: (bool) True if there is a neutral signal (Balanced Doji), otherwise false.
 N_StrongDoji(_dojiBarMaxBody) 
  Determines if there is a neutral signal (Strong Doji).
  Parameters:
     _dojiBarMaxBody (simple float) : (float) The maximum body percentage for doji bar.
  Returns: (bool) True if there is a neutral signal (Strong Doji), otherwise false.
 N_QuietSpinningTop(_spinningTopBarMinWicks, _spinningTopBarEmaLength) 
  Determines if there is a neutral signal (Quiet Spinning Top).
  Parameters:
     _spinningTopBarMinWicks (simple float) : (float) The minimum wicks percentage for spinning top bar.
     _spinningTopBarEmaLength (simple int) : (int) The length for EMA calculation.
  Returns: (bool) True if there is a neutral signal (Quiet Spinning Top), otherwise false.
 N_BalancedSpinningTop(_data, _spinningTopBarMinWicks, _spinningTopBarEmaLength) 
  Determines if there is a neutral signal (Balanced Spinning Top).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _spinningTopBarMinWicks (simple float) : (float) The minimum wicks percentage for spinning top bar.
     _spinningTopBarEmaLength (simple int) : (int) The length for EMA calculation.
  Returns: (bool) True if there is a neutral signal (Balanced Spinning Top), otherwise false.
 N_StrongSpinningTop(_spinningTopBarMinWicks, _spinningTopBarEmaLength) 
  Determines if there is a neutral signal (Strong Spinning Top).
  Parameters:
     _spinningTopBarMinWicks (simple float) : (float) The minimum wicks percentage for spinning top bar.
     _spinningTopBarEmaLength (simple int) : (int) The length for EMA calculation.
  Returns: (bool) True if there is a neutral signal (Strong Spinning Top), otherwise false.
 N_QuietHighWave(_highWaveBarMinBody, _highWaveBarMinWick, _highWaveBarBars) 
  Determines if there is a neutral signal (Quiet High Wave).
  Parameters:
     _highWaveBarMinBody (simple float) : (float) The minimum body percentage for high wave bar.
     _highWaveBarMinWick (simple float) : (float) The minimum wick percentage for high wave bar.
     _highWaveBarBars (simple int) : (int) The number of bars for comparison.
  Returns: (bool) True if there is a neutral signal (Quiet High Wave), otherwise false.
 N_BalancedHighWave(_data, _highWaveBarMinBody, _highWaveBarMinWick, _highWaveBarBars) 
  Determines if there is a neutral signal (Balanced High Wave).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _highWaveBarMinBody (simple float) : (float) The minimum body percentage for high wave bar.
     _highWaveBarMinWick (simple float) : (float) The minimum wick percentage for high wave bar.
     _highWaveBarBars (simple int) : (int) The number of bars for comparison.
  Returns: (bool) True if there is a neutral signal (Balanced High Wave), otherwise false.
 N_StrongHighWave(_highWaveBarMinBody, _highWaveBarMinWick, _highWaveBarBars) 
  Determines if there is a neutral signal (Strong High Wave).
  Parameters:
     _highWaveBarMinBody (simple float) : (float) The minimum body percentage for high wave bar.
     _highWaveBarMinWick (simple float) : (float) The minimum wick percentage for high wave bar.
     _highWaveBarBars (simple int) : (int) The number of bars for comparison.
  Returns: (bool) True if there is a neutral signal (Strong High Wave), otherwise false.
 N_Consolidation(_data, _consolidationBarSpread, _consolidationBarBars) 
  Determines if there is a neutral signal (Consolidation).
  Parameters:
     _data (map) : (map) The data map with volume and spread levels.
     _consolidationBarSpread (simple float) : (float) The spread percentage for consolidation bar.
     _consolidationBarBars (simple int) : (int) The number of bars for comparison.
  Returns: (bool) True if there is a neutral signal (Consolidation), otherwise false.
Alligator + MA Trend Catcher [TradeDots]The "Alligator + MA Trend Catcher" is a trading strategy that integrates the William Alligator indicator with a Moving Average (MA) to establish robust entry and exit conditions, optimized for capturing trends.
 HOW IT WORKS 
This strategy combines the traditional William Alligator set up with an additional Moving Average indicator for enhanced trend confirmation, creating a user-friendly backtesting tool for traders who prefer the Alligator method.
The original Alligator strategy can frequently present fluctuations, even in well-established trends, leading to potentially premature exits. To mitigate this, we incorporate a Moving Average as a secondary confirmation measure to ensure the market trend has indeed shifted.
Here’s the operational flow for long orders:
 
   Entry Signal:  When the price rises above the Moving Average, it confirms a bullish market state. Enter if Alligator spread in an upward direction. The trade remains active even if the Alligator indicator suggests a trend reversal.
  Exit Signal:  The position is closed when the price falls below the Moving Average, and the Alligator spreads in the downward direction. This setup helps traders to maintain positions through the entirety of the trend for maximum gain.
 
 APPLICATION 
This strategy is tailored for assets with significant, well-defined trends, such as Bitcoin and Ethereum, which are known for their high volatility and substantial price movements. 
This strategy offers a low win-rate but high reward configuration, making asset selection critical for long-term profitability. If you choose assets that lack strong price momentum, there's a high chance that this strategy may not be effective.
For traders seeking to maximize gains from large trends without exiting prematurely, this strategy provides an aggressive yet controlled approach to riding out substantial market waves.
 DEFAULT SETUP 
Commission: 0.01%
Initial Capital: $10,000
Equity per Trade: 80%
 RISK DISCLAIMER 
Trading entails substantial risk, and most day traders incur losses. All content, tools, scripts, articles, and education provided by TradeDots serve purely informational and educational purposes. Past performances are not definitive predictors of future results.
AWR_WaveTrend Multitimeframe [adapted from LazyBear]I've adapted a script from Lazy Bear (WT trend oscillator)
WaveTrend Oscillator is a port of a famous TS/MT indicator.
When the oscillator (WT1 designed as a line) is above the overbought band (50 to 60) and crosses down the WT2 (dotted line), it is usually a good SELL signal. Similarly, when the oscillator crosses above the signal when below the Oversold band ( (-50 to -60)), it is a good BUY signal.
In this indicator, you can display at the same time, different time frames.
Choice possible are 1 mn, 15 mn, 30 mn, 60 mn, 120 mn, 240 mn, 1D, Week, Month.
Small time frames (1 to 30 mn) are represented by a blue lines (light to dark)
1H is in grey
2H & 4H are in purple (light to dark)
1D is in green
1W is in orange
1M is in black
You can choose which timeframes you want to display for the current period or for the last period closed.
In a few seconds, you perfectly see the selected timeframes trends.
There is also at the bottom right a table summing up all the different values of WT1, WT2 and difference between them.
Positive difference means an upside trend
Negative difference means a downside trend.
Another way of using this indicator is displaying only the difference between WT1 & WT2. It's giving the speed & the direction of all trends. Trends are our friends ... 
You can observe the significent times frames and look if they are all positives or negatives or  if the speed of lower timeframe cross a longer timeframe of if the speed is decreasing or increasing...
Difference values goes generaly from -20 to 20 (it can exceed a bit but really rare). 12 is already high level of speed.
Many uses possible.
In the exemple posted, I've selected WT1 and WT2 for timeframes 4H, Daily & Weekly.
Marker 1:
Orange lines (WT1) are far below - 50 (-67 here) and cross WT2 pointed lines : weekly buy signal
But this buy signal is balanced by 4H & Daily sell signal = it's marking start of hesitations of main trend !!!! 
Marker 2 : 
Next buy signal in 4H or daily would normaly confirm the start
Marker 3 : 
Sell signal in 4H and daily but weekly has an upside trend ! Start of a counter trend in the trend. To find the perfect timing of that you have to look to lower time frames, because 4H and daily are giving many hesitations signals crossing down & crossing up many times in an overbought zone.
Marker 4 :
End of the counter trend. Most of the time, the countertrend don't go in the "over" zone. That's why if you trading in an counter trend, you have to keep it in mind.
Then a few days later you can see the sell signal. And what a sell signal ! 4H & daily are smashed down really fastly ! Trends change warning ! 
Marker 5 
Long hesitation/change of the trend. Daily WT and 4H are below the weekly trends. Weekly start to go down.
Start of a counter trend inside the trend giving us the best selling signal at her end !
Marker 6 :
Long hesitation/change of the trend.
You have to look in lower time frames to identify the short trend. Difficult to find the best timing to get in. ....
I've add many alerts. When a time frame become positive or negative. When many time frames are positive or negative or above or below 47 level...
Please feel free to explore.
 
Hope it will help you.
Thanks to Lazybear ! Thousands thanks to Lazybear !
Exemple with difference 
Squeeze Momentum DeluxeThe Squeeze Momentum Deluxe is a comprehensive trading toolkit built with features of momentum, volatility, and price action. This script offers a suite for both mean reversion and trend-following analysis. Developed based on the original TTM Squeeze  implementation  by @LazyBear, this indicator introduces several innovative components to enhance your trading insights.
🔲  Components and Features 
 
   Momentum Oscillator -  as rooted in the TTM Squeeze, quantifies the relationship between price and its extremes over a defined period. By normalizing the calculation, the values become comparable throughout time and across securities, allowing for a nuanced assessment of Bullish and Bearish momentum. Furthermore, by presenting it as a ribbon with a signal line we gain additional information about the direction of price swings.
  
   Squeeze Bars -  The original squeeze concept is based on the relationship between the  Bollinger Bands  and  Keltner Channel , once the BB resides inside the KC a squeeze occurs. By understanding their fundamentals a new form of calculation can be inferred.
 
method bb(float src, simple int len, simple float mult) =>                     method kc(float src, simple int len, simple float mult) =>            
    float basis = ta.sma  (src, len)                                                float basis = ta.sma  (src, len)
    float dev   = ta.stdev(src, len)                                                float rng   = ta.atr  (     len)
    float upper = basis + dev * mult                                                float upper = basis + rng * mult
    float lower = basis - dev * mult                                                float lower = basis - rng * mult
                                                                        
 
Both BB and KC are constructed upon a moving average with the addition of  Standard Deviation  and  Average True Range  respectively. Therefore, the calculation can be transformed to when the Stdev is lower than the ATR a squeeze occurs.
 
method sqz(float src, simple int len) =>
    float dev = ta.stdev(src, len)
    float atr = ta.atr  (     len)
    dev < atr ? true : false
 
This indicator uses three different thresholds for the ATR to gain three levels of price "Squeeze" for further analysis.
  
   Directional Flux-  This component measures the overall direction of price volatility, offering insights into trend sentiment. Presented as waves in the background, it includes an OverFlux feature to signal extreme market bias in a particular direction which can signal either exhaustion or vital continuation. Additionally, the user can choose if to base the calculation on  Heikin-Ashi Candles  to bias the tool toward trend assessment.
  
   Confluence Gauges -  Placed at the top and bottom of the indicator, these gauges measure confluence in the relationship between the Momentum Oscillator and Directional Flux. They provide traders with an easily interpretable visual aid for detecting market sentiment. Reversal doritos displayed alongside them contribute to mean reversion analysis.
  
   Divergences (Real-Time) -  Equipped with a custom algorithm, the indicator detects real-time divergences between price and the oscillator. This dynamic feature enhances your ability to spot potential trend reversals as they occur.
  
 
🔲  Settings 
 
   Directional Flux Length -  Adjusts the period of which the background volatility waves operate on.
   Trend Bias -  Bases the calculation of the Flux to HA candles to bias its behavior toward the trend of price action. 
   Squeeze Momentum Length -  Calibrates the length of the main oscillator ribbon as well as the period for the squeeze algorithm.
   Signal -  Controls the width of the ribbon. Lower values result in faster responsiveness at the cost of premature positives.
   Divergence Sensitivity -  Adjusts a threshold to limit the amount of divergences detected based on strength. Higher values result in less detections, stronger structure.
 
🔲  Alerts  
 
   Sell Signal        
   Buy  Signal      
   Bullish Momentum  
   Bearish Momentum  
   Bullish Flux      
   Bearish Flux      
   Bullish Swing    
   Bearish Swing   
   Strong Bull Gauge 
   Strong Bear Gauge 
   Weak   Bull Gauge 
  Weak   Bear Gauge 
   High   Squeeze 
   Normal Squeeze  
  Low    Squeeze  
   Bullish Divergence 
   Bearish Divergence 
As well as the option to trigger 'any alert' call.
 
The Squeeze Momentum Deluxe is a comprehensive tool that goes beyond traditional momentum indicators, offering a rich set of features to elevate your trading strategy. I recommend using toolkit alongside other indicators to have a wide variety of confluence to therefore gain higher probabilistic and better informed decisions.
Trailing Stop-Loss Indicator (FinnoVent)The Dynamic 9 EMA Trailing Stop-Loss Indicator is a specialized tool designed for the TradingView community to enhance risk management in trading. This script dynamically adjusts a trailing stop-loss level based on the position of the price relative to a 9-period Exponential Moving Average (EMA), offering traders a systematic approach to protect potential profits and limit downside risk.
Functionality:
Adaptive Trailing Stop: The indicator calculates a trailing stop-loss that adjusts with the 9 EMA, providing a responsive method to secure gains or prevent extensive losses.
EMA Trend Indicator: The 9-period EMA serves as a momentum indicator, with the script adjusting the trailing stop-loss accordingly — above the EMA for short positions and below for long positions.
Entry Signal Visualization: Entry signals are visualized on the chart, indicating potential long and short positions based on price crossovers with the EMA.
Application:
This indicator is ideal for traders who utilize technical analysis to make informed decisions. By automatically adjusting the stop-loss level to the evolving market conditions, it is particularly useful for:
Day traders looking to capitalize on short-term price movements.
Swing traders aiming to secure positions during more extended market waves.
Any trading strategy that benefits from dynamic stop-loss management.
Usage:
To use the indicator, simply add it to your TradingView chart, and it will automatically plot the trailing stop levels. The green and red lines represent the trailing stops for long and short positions, respectively, providing clear visual cues for potential exit points.
Compliance with TradingView House Rules:
This script is provided for educational purposes and does not constitute investment advice. It is a unique creation that has been developed to contribute to the TradingView community by offering a tool that helps traders manage their trades more effectively.
Fibonacci TradingFibonacci Trading
This simple script draw Fibonacci Retracement to define pullback level and draw Fibonacci Extension to define target level of a upward wave or doward wave
1. Upward wave
1.1 Fibonacci Retracement
+ Fibonacci Retracement measuare from support to nearest resistance on the right.
+ Retracement Level 0 named as "Breake Even"
+ Retracement Level 100 named as "Long Invalidation"
+ Retracement Level 50 and 61.8 is ploted as blue line
+ The zone between Retracement Level 50 and 100 is filled by blue color and named as "Buy zone"
1.2 Fibonacci Extension
+ Fibonacci Extension measuare from Retracement Level 61.8 to Retracement Level 0
+ Fibonacci Extension Level 161.8 named as "Tp1 (Target point 1)"
+ Fibonacci Extension Level 261.8 named as "Tp2 (Target point 2)"
2. Doward wave
2.1 Fibonacci Retracement
+ Fibonacci Retracement measuare from resistance to nearest support on the right.
+ Retracement Level 0 named as "Breake Even"
+ Retracement Level 100 named as "Short Invalidation"
+ Retracement Level 50 and 61.8 is ploted as red line
+ The zone between Retracement Level 50 and 100 is filled by red color and named as "Sell zone"
2.2 Fibonacci Extension
+ Fibonacci Extension measuare from Retracement Level 61.8 to Retracement Level 0
+ Fibonacci Extension Level 161.8 named as "Tp1 (Target point 1)"
+ Fibonacci Extension Level 261.8 named as "Tp2 (Target point 2)"
3. Trading Setup
3.1 Long Only: Only display Fibonacci of Upward wave
3.2 Short Only: Only display Fibonacci of Doward wave
3.3 Both: Display both Fibonacci of Upward wave and Doward wave
MA Slope : New Method1 . Introduction 
 
Hello, traders. 
This indicator is designed to measure the slope of a moving average line.
I imagine many of you who use Pine Script have struggled with this; measuring the slope of a moving average line can be quite challenging.
Firstly, this is because while the x-axis is fixed to the 'number of candles', the price scale on the y-axis can be adjusted freely.
Secondly, while the concept of differentiation could simplify the measurement process, the resulting value will differ from the conventional derivative we are familiar with since 'delta x' is fixed to '1'.
Consequently, I've put a lot of thought into how to configure the x-axis and y-axis in order to measure a slope that aligns with our perception of 'slope'.
After some reflection, I, like many others, realized that many people measure the slope based on the pivot of the moving average line.
This indicator is the product of that reflection.
 2. Description 
 A. Setting 
First, select the moving average line for which you want to check the slope. While SMA is commonly used, T3 is set as the default because it best visualizes the slope.
If you check 'Show MA Slope Average Pivot Range?' in the input window, it displays the average of the recent 30 slope pivot highs and pivot lows.
In other words, it shows 'On average, this level of slope was produced in the recent 30 waves.'
 B. Usage 
  
A cross from 0 in the slope indicates a 'reversal in the slope of the curve', which is the most crucial value when observing the slope. 
Thus, fundamentally, it's important to look at the points where the slope becomes "0". Furthermore, when the slope starts to curve after rising, it signifies a change in acceleration, suggesting an imminent slope reversal.
(Note that acceleration was omitted from the indicator representation due to its tendency to overly complicate the data.)
While a shorter length of the moving average line may provide more useful slope data for actual trading, a less smooth moving average line may cross around 0 too often, making it less useful.
Therefore, it's crucial to adjust the 'Smoothing Length' in the input values to find a value that you believe is appropriate.
 3. Conclusion 
I always contemplate how to find a value in Pine Script that is similar to the perceived slope. 
I made this script thinking that it might be a novel approach, but there are still many areas that need improvement. 
If you have any innovative ideas about the slope, please feel free to provide feedback anytime.
Thank you.
--------
 1. 서론 
트레이더 여러분 안녕하세요. 이 지표는 이동평균선의 기울기를 측정하는 지표입니다.
아마 파인스크립트를 다루는 많은 분들이 같은 고민을 하셨을 것 같은데, 이동평균선의 기울기를 측정하는 것은 매우 어렵습니다.
그 이유로 첫번째는 x축은 '캔들 갯수'로 고정되어있는 반면, y축의 가격 스케일은 유동적으로 바꿀 수 있기 때문입니다.
두번째로는, 미분 개념을 이용하면 훨씬 수월하게 구할 수 있을테지만, 델타x가 '1'로 고정되어있기 때문에 우리가 알고있는 미분과 다른 값이 나옵니다.
따라서 x축과 y축을 어떻게 하면 실제 우리가 인식하는 '기울기'에 가깝도록 구성할 수 있을지에 대해 고민해보았습니다.
고민해본 결과 저 역시 그러하고, 많은 사람들이 이동평균선의 피벗을 기준으로 기울기를 측정한다는 사실을 알게되었습니다.
이 지표는 그 고민의 결과물입니다.
 2. 내용 설명 
 A. 셋팅 
먼저, 기울기를 확인하고싶은 이동평균선을 선택해주세요.
일반적으로 SMA를 많이 보시겠지만, T3가 기울기로 표현할 때 가장 아름다운 모습이 나오기 때문에 기본 설정을 T3로 설정했습니다.
Input창에 있는 'Show MA Slope Average Pivot Range?'를 체크하면, 최근 30개의 기울기 피벗 하이와 피벗 로우의 평균을 보여줍니다.
즉, '평균적으로, 최근 30개의 파동에서는 이 정도의 기울기가 만들어졌다'라는 것을 보여줍니다
 B. 사용법 
  
기울기가 0에서 크로스 된다는 것은, "곡선의 기울기가 반전"된다는 것이기에 기울기를 봄에 있어서 가장 중요한 값입니다. 따라서 가장 기본적으로는, 기울기가 "0"이 되는 곳을 보는 것이 중요하고
또 기울기가 올라갔다 꺾이기 시작할 때는, 가속도가 바뀌고 있다는 뜻이므로, 곧 기울기가 반전될 것을 의미합니다.
(다만 가속도를 지표로 표현하기엔, 너무나도 데이터가 지저분해져서 생략하였습니다)
이동평균선의 길이를 짧게 할수록 더 실제 트레이딩에 유용한 기울기 데이터를 얻을 수 있으나, 
부드럽지 못한 이동평균선은 기울기가 0 근처에서 크로스 되는 모습이 지나치게 많이 나올 것이기에 유용하지 않을 수 있습니다.
따라서, input값에 있는 'Smoothing Length'를 조절해가면서 자신이 생각하기에 맞는 값을 고르는 것이 중요합니다. 
 3. 맺음말 
파인스크립트에서 어떻게하면 실제 인식하는 기울기와 유사한 값을 찾을 수 있을까를 항상 고민합니다. 나름 새로운 접근방법이라 생각해서 이렇게 스크립트로 만들었으나, 여전히 아쉬운 부분이 많이 존재합니다.
기울기에 대한 좋은 아이디어가 있다면 언제든 피드백 해주세요.
감사합니다. 
Range of a source displayed in thirdsThis indicator will take the value of any external source input and display how it has changed over time (the lookback period in settings). For the purposes of display here I'm using the WT1 line from Wavetrend with Crosses by LazyBear to provide a source input.
The highest and lowest value of the source over the lookback period are used to determine the highest and lowest point - the green and red lines at the top and bottom of the bands. This region is then mathematically split into three, such that the source (and its optional moving average line) can be defined as being in the top third, the middle or the bottom third.
Applications for this could be in risk management where you may wish to take on a larger position size when a certain indicator is in the top third, or decide that you want to enter / leave positions when the source crosses in / out of the extreme points.
Variety MA Cluster Filter Crosses [Loxx]What is a Cluster Filter?  
One of the approaches to determining a useful signal (trend) in stream data. Small filtering (smoothing) tests applied to market quotes demonstrate the potential for creating non-lagging digital filters (indicators) that are not redrawn on the last bars.
 Standard Approach 
This approach is based on classical time series smoothing methods. There are lots of articles devoted to this subject both on this and other websites. The results are also classical:
1. The changes in trends are displayed with latency;
2. Better indicator (digital filter) response achieved at the expense of smoothing quality decrease;
3. Attempts to implement non-lagging indicators lead to redrawing on the last samples (bars).
And whereas traders have learned to cope with these things using persistence of economic processes and other tricks, this would be unacceptable in evaluating real-time experimental data, e.g. when testing aerostructures.
 The Main Problem 
It is a known fact that the majority of trading systems stop performing with the course of time, and that the indicators are only indicative over certain intervals. This can easily be explained: market quotes are not stationary. The definition of a stationary process is available in Wikipedia:
A stationary process is a stochastic process whose joint probability distribution does not change when shifted in time.
Judging by this definition, methods of analysis of stationary time series are not applicable in technical analysis. And this is understandable. A skillful market-maker entering the market will mess up all the calculations we may have made prior to that with regard to parameters of a known series of market quotes.
Even though this seems obvious, a lot of indicators are based on the theory of stationary time series analysis. Examples of such indicators are moving averages and their modifications. However, there are some attempts to create adaptive indicators. They are supposed to take into account non-stationarity of market quotes to some extent, yet they do not seem to work wonders. The attempts to "punish" the market-maker using the currently known methods of analysis of non-stationary series (wavelets, empirical modes and others) are not successful either. It looks like a certain key factor is constantly being ignored or unidentified.
The main reason for this is that the methods used are not designed for working with stream data. All (or almost all) of them were developed for analysis of the already known or, speaking in terms of technical analysis, historical data. These methods are convenient, e.g., in geophysics: you feel the earthquake, get a seismogram and then analyze it for few months. In other words, these methods are appropriate where uncertainties arising at the ends of a time series in the course of filtering affect the end result.
When analyzing experimental stream data or market quotes, we are focused on the most recent data received, rather than history. These are data that cannot be dealt with using classical algorithms.
 Cluster Filter 
Cluster filter is a set of digital filters approximating the initial sequence. Cluster filters should not be confused with cluster indicators.
Cluster filters are convenient when analyzing non-stationary time series in real time, in other words, stream data. It means that these filters are of principal interest not for smoothing the already known time series values, but for getting the most probable smoothed values of the new data received in real time.
Unlike various decomposition methods or simply filters of desired frequency, cluster filters create a composition or a fan of probable values of initial series which are further analyzed for approximation of the initial sequence. The input sequence acts more as a reference than the target of the analysis. The main analysis concerns values calculated by a set of filters after processing the data received.
  
In the general case, every filter included in the cluster has its own individual characteristics and is not related to others in any way. These filters are sometimes customized for the analysis of a stationary time series of their own which describes individual properties of the initial non-stationary time series. In the simplest case, if the initial non-stationary series changes its parameters, the filters "switch" over. Thus, a cluster filter tracks real time changes in characteristics.
 Cluster Filter Design Procedure 
Any cluster filter can be designed in three steps:
1. The first step is usually the most difficult one but this is where probabilistic models of stream data received are formed. The number of these models can be arbitrary large. They are not always related to physical processes that affect the approximable data. The more precisely models describe the approximable sequence, the higher the probability to get a non-lagging cluster filter.
2. At the second step, one or more digital filters are created for each model. The most general condition for joining filters together in a cluster is that they belong to the models describing the approximable sequence.
3. So, we can have one or more filters in a cluster. Consequently, with each new sample we have the sample value and one or more filter values. Thus, with each sample we have a vector or artificial noise made up of several (minimum two) values. All we need to do now is to select the most appropriate value.
 An Example of a Simple Cluster Filter 
For illustration, we will implement a simple cluster filter corresponding to the above diagram, using market quotes as input sequence. You can simply use closing prices of any time frame.
1. Model description. We will proceed on the assumption that:
The aproximate sequence is non-stationary, i.e. its characteristics tend to change with the course of time.
The closing price of a bar is not the actual bar price. In other words, the registered closing price of a bar is one of the noise movements, like other price movements on that bar.
The actual price or the actual value of the approximable sequence is between the closing price of the current bar and the closing price of the previous bar.
The approximable sequence tends to maintain its direction. That is, if it was growing on the previous bar, it will tend to keep on growing on the current bar.
2. Selecting digital filters. For the sake of simplicity, we take two filters:
The first filter will be a variety filter calculated based on the last closing prices using the slow period. I believe this fits well in the third assumption we specified for our model.
Since we have a non-stationary filter, we will try to also use an additional filter that will hopefully facilitate to identify changes in characteristics of the time series. I've chosen a variety filter using the fast period.
3. Selecting the appropriate value for the cluster filter.
So, with each new sample we will have the sample value (closing price), as well as the value of MA and fast filter. The closing price will be ignored according to the second assumption specified for our model. Further, we select the МА or ЕМА value based on the last assumption, i.e. maintaining trend direction:
 For an uptrend, i.e. CF(i-1)>CF(i-2), we select one of the following four variants: 
if CF(i-1)fastfilter(i), then CF(i)=slowfilter(i);
if CF(i-1)>slowfilter(i) and CF(i-1)slowfilter(i) and CF(i-1)>fastfilter(i), then CF(i)=MAX(slowfilter(i),fastfilter(i)).
 For a downtrend, i.e. CF(i-1)slowfilter(i) and CF(i-1)>fastfilter(i), then CF(i)=MAX(slowfilter(i),fastfilter(i));
if CF(i-1)>slowfilter(i) and CF(i-1)fastfilter(i), then CF(i)=fastfilter(i);
if CF(i-1)
Dominant Cycle Detection OscillatorThis is a Dominant Cycle Detection Oscillator that searches multiple ranges of wavelengths within a spectrum. Choose one of 4 different dominant cycle detection methods (MESA MAMA cycle, Pearson Autocorrelation, Discreet Fourier Transform, and Phase Accumulation) to determine the most dominant cycles and see the historical results. Straight lines can indicate a steady dominant cycle; while Wavy lines might indicate a varying dominant cycle length. The steadier the cycle, the easier it may be to predict future events in that cycle (keep the log scale in mind when considering steadiness). The presence of evenly divisible (or harmonic) cycle lengths may also indicate stronger cycles; for example, 19, 38, and 76 dominant lengths for the 2x, 4x, and 8x cycles. Practically, a trader can use these cycle outputs as the default settings for other Hurst/cycle indicators. For example, if you see dominant cycle oscillator outputs of 38 & 76 for the 4x and 8x cycle respectively, you might want to test/use defaults of 38 & 76 for the 4x & 8x lengths in the bandpass, diamond/semi-circle notation, moving average & envelope, and FLD instead of the defaults 40 & 80 for a more fine-tuned analysis. 
Muting the oscillator's historical lines and overlaying the indicator on the chart can visually cue a trader to the cycle lengths without taking up extra panes. The DFT Cycle lengths with muted historical lines have been overlayed on the chart in the photo.
The y-axis scale for this indicator's pane (just the oscillator pane, not the chart) most likely needs to be changed to logarithmic to look normal, but it depends on the search ranges in your settings. There are instructions in the settings. In the photo, the MESA MAMA scale is set to regular (not logarithmic) which demonstrates how difficult it can be to read if not changed.
In the Spectral Analysis chapter of Hurst's book Profit Magic, he recommended doing a Fourier analysis across a spectrum of frequencies. Hurst acknowledged there were many ways to do this analysis but recommended the method described by Lanczos. Currently in this indicator, the closest thing to the method described by Lanczos is the DFT Discreet Fourier Transform method.
Shoutout to @lastguru for the dominant cycle library referenced in this code. He mentioned that he may add more methods in the future. 
RSI Overbought/Oversold + Divergence IndicatorDESCRIPTION:
This script combines the Relative Strength Index ( RSI ), Moving Average and Divergence indicator to make a better decision when to enter or exit a trade.
- The Moving Average line (MA) has been made hidden by default but enhanced with an RSIMA cloud.
- When the RSI is above the selected MA it turns into green and when the RSI is below the select MA it turns into red.
- When the RSI is moving into the Overbought or Oversold area, some highlighted areas will appear.
- When some divergences or hidden divergences are detected an extra indication will be highlighted.
- When the divergence appear in the Overbought or Oversold area the more weight it give to make a decision.
- The same color pallet has been used as the default candlestick colors so it looks familiar.
HOW TO USE:
The prerequisite is that we have some knowledge about the Elliot Wave Theory, the Fibonacci Retracement and the Fibonacci Extension tools.
Wave 1
(1) When we receive some buy signals we wait until we receive some extra indications.
(2) On the RSI Overbought/Oversold + Divergence Indicator we can see a Bullish Divergence and our RSI is changing from red to green ( RSI is higher then the MA).
(3) If we are getting here into the trade then we need to use a stop loss. We put our stop loss 1 a 2 pips just below the lowest wick. We also invest maximum 50% of the total amount we want to invest.
Wave 2
(4) Now we wait until we see a clear reversal and here we starting to use the Fibonacci Retracement tool. We draw a line from the lowest point of wave(1) till the highest point of wave (1). When we are retraced till the 0.618 fib also called the golden ratio we check again the RSI Overbought/Oversold + Divergence Indicator. When we see a reversal we do our second buy. We set again a stop loss just below the lowest wick (this is the yellow line on the chart). We also move the stop loss we have set in step (3) to this level.
  
Wave 3
(5) To identify how far the uptrend can go we need to use the Fibonacci Extension tool. We draw a line from the lowest point of wave(1) till the highest point of wave (1) and draw it back to the lowest point of wave (2). Wave (3) is most of the time the longest wave and can go till it has reached the 1.618 or 2.618 fib. On the 1.618 we can take some profit. If we don't want to sell we move our stop loss to the 1 fib line (yellow line on the chart).
(6) We wait until we see a clear reversal on the Overbought/Oversold + Divergence Indicator and sell 33% to 50% of our investment.
  
Wave 4
(7) Now we wait again until we see a clear reversal and here we starting to use the Fibonacci Retracement tool. We draw a line from the lowest point of wave(2) till the highest point of wave (3). When we are retraced till the 0.618 fib also called the golden ratio we check again the RSI Overbought/Oversold + Divergence Indicator. When we see a reversal we buy again. We set again a stop loss just below the lowest wick (this is the yellow line on the chart).
(8) If we bought at the first reversal ours stop los was triggered (9) and we got out of the trade.
(9) If we did not bought at step (7) because our candle did not hit the 0.618 fib or we got stopped out of the trade we buy again at the reversal.
  
Wave 5
(10) To identify how far the uptrend can go we need to use the Fibonacci Extension tool. We draw a line from the lowest point of wave(2) till the highest point of wave (3) and draw it back to the lowest point of wave (4). Most of the time wave 5 goes up till it has reached the 1 fib. And that is the point where we got out of the trade with all of our investment. In this trade we got out of the trade a bit earlier. We received the sell signals and got a reversal on the Overbought/Oversold + Divergence Indicator.
  
We are hoping you learned something so you can make better decisions when to get into or out of a trade.
If you have any question just drop it into the comments below.
FEATURES:
• You can show/hide the RSI .
• You can show/hide the MA.
• You can show/hide the lRSIMA cloud.
• You can show/hide the Stoch RSI cloud.
• You can show/hide and adjust the Overbought and Oversold zones.
• You can show/hide and adjust the Overbought Extended and Oversold Extended zones.
• You can show/hide the Overbought and Oversold highlighted zones.
• Etc...
HOW TO GET ACCESS TO THE SCRIPT:
• Favorite the script and add it to your chart.
REMARKS:
• This advice is NOT financial advice.
• We do not provide personal investment advice and we are not a qualified licensed investment advisor.
• All information found here, including any ideas, opinions, views, predictions, forecasts, commentaries, suggestions, or stock picks, expressed or implied herein, are for informational, entertainment or educational purposes only and should not be construed as personal investment advice.
• We will not and cannot be held liable for any actions you take as a result of anything you read here.
• We only provide this information to help you make a better decision.
• While the information provided is believed to be accurate, it may include errors or inaccuracies.
Good Luck and have fun,
The CryptoSignalScanner Team
DOW Theory Price Action Multi-Time FrameThis indicator gives a visual representation of Dow Theory Price action based trend analysis and provides trader a table with 4 different timeframe to align with the trend. 
It will help traders identify if it is an ongoing Impulse Wave or a Corrective Wave.
3 rules for Bullish Price Action setup (Uptrend or continuation of existing UpTrend): Denoted by 'U' below the candlestic
HH - Higher High
HL - Higher Low
CAH - Close above prior High
3 rules for Bearish Price Action setup (Downtrend or continuation of existing DownTrend): Denoted by 'D' below the candlestic
LH - Lower High
HL - LowerLow
CAH - Close below prior Low
Exception - Outside Candle: Denoted by 'OC' above the candlestic
Outside reversal is a two-day price pattern that shows when a candle or bar on a candlestick or bar chart falls “outside” of the previous day's candle or bar.
The table posistion can be set be user from the input settings as per his screen setting / resolution. 
The trailing line can is also customizable from inputs, recomended value is 3-4.
Ideation Credits: Mr. Vineet Jain
SeongMo_MA_V3(Elliot_helper)Made to make it easier to count Elliott waves.
If you renew your new high price, you'll continue your new high price
When the new low is renewed, the new low is continued.
If you are within the range of the previous candle, use the ratio of the difference between the median value of the previous candle and the closing price of the current candle to determine whether to continue the high or low price.
If a can with a tail that updates a new high price and a new low price at the same time comes out, the phrase "Check_candle!" appears to mean that you should check it with a lower time zone candle.
Musashi_Katana=== Musashi-Katana ===
This tool was designed to fit my particular trading style and personal theories about the "Alchemy of the markets" and ''Harmonic Structure'.
Context
When following a Technical approach to to surf the markets, there are teachings that must be understood before reaching a confort-zone, this usually happen the possible worst way by constant experimentation, it hurts.
Here few technical hints:
- Align High timeframes with lower timeframes:
This simple concept relax a lot complexity of finding of a trend bias. Musashi-Katana allows you to use technical indicator corresponding to specific timeframes, like daily weekly or yearly. They wont change when you change the chart's timeframe, its very useful as you know where you're standing in the long term, Its quite relaxing.
- Use volume:
The constant usage of volume will allow you to sync with the market's breathing. This shows you the mass of money flowing into and out of the market, is key if you want to understand momentum. This tool can help here, as it have multi-period vwaps. You can use yearly, monthly for swing trading, and even weekly if you enjoy scalping.
Useful stuff:
- You have access to baselines, AMA and Kijun-sen with the possibility of adding ATR bands.
- AMAs come as two lines strategies for different approaches, fast medium or slow.
- You can experiment with normal and multi timeframe moving averages and other trend tools.
Final Note
If used correctly Musashi-Katana is a very powerful tool, which makes no sense as there is no correct usage. Don't add everything at the same time, experiment, combine stuff, every market is different.
Backtest every possible strategy before using it, see what works and doesn't. This gives you a lot of peace, specially while you're at the tip of the spear surfing the markets
--> I personally use this in combination with 'Musashi_Slasher (Mometum+Volatility)', as it gives me volatility and momentum in a very precise way.
Bearish Market Indicator V2Definition 
Have you ever wonder whether if the stock/index/market is  "bearish" ? A  Bearish Market Indicator (B.M.I)  is not a new concept, the definition is simply 20% lower from the recent (term: short-term, recent: usually within a year, a.k.a 1 year) highs (closing price with in the recent period or within in a year or simply a 52-Week High). It is called “bearish” by definition when the closing price is below 20% from the highest price within the year (52-Week high: Green Line). To visualize the “20%” below the recent highs, there is a plot (line: light yellow color in the middle) called a Bearish Market By Definition Value. For example, the SPX 500 has been in a bearish market which is why there is a purple color highlight over the 52-Week High (green line) since September 21, 2022 because the closing price is below the Bearish Market By Definition Value (light yellow color) or “20% below the recent highs”. Finally, there is a red line under in the graph and it is the lowest price within a year. So when you hear, “this ticker is at a 52-Week Low”, you know what it means.
Line Summary: 
Green Color Line = 52-Week High
Yellow Color Line = 20% away from the 52-Week High or  Bearish Market By Definition Value
Red Color Line = 52-Week Low
Color Summary:
Red Color = Bad
Saturated Red Color = Very Bad
Purple Color = Bearish (It may look pink:  red + purple)
White Color = Less Bad (That’s because there is no certainty only probability)
Green Color = Not too Bad (That’s because there is no certainty only probability)
  Now to more complicated Metrics 
>> If you do not like the technical indicators, go to the indicator settings, uncheck the tables. Otherwise, please continue reading. <<
  Pre-requisites  
+ Understand that the indicators are lagging indicators.
+ Using it under “D” or “Day” interval 
+ Already Understand: Moving Averages, Stochastic-RSI, RSI, Super Trend and MACD.
+ Please be aware that this might not be compatible with traders!
 Indicators 
This B.M.I is fused (comprised, combined) with multiple indicators:
- Moving Averages  
I would not rely just on the Moving Averages (MA) since it is a lagging indicator. The values are derived by finding the differences with respect to the MAs (between the closing price and with the respect MA).
- Stochastic-RSI 
Stochastic and RSI combo with RSI-Color coating. The first value is the rsi-stochastic-k followed by the rsi-stochastic-d both are compartmentalized with “|”.
Parameter: 
Numbers > 80 Not Good
Numbers < 20 Is it time? (You can manually verify the lines (k, d) or the values from them)
- Relative Strength Index (RSI)
The first value is the rsi followed by the rsi-ma both are compartmentalized with “|”. It is also coated with RSI-color. 
Parameter:
Numbers > 70 Overbought | Color Red
If the RSI > RSI’s MA = Green
If the RSI < RSI’s MA = Red
Numbers < 30 Oversold | Color Red
- Moving Averages Convergence Divergence (MACD)
The first value is the MACD-line followed by the signal-line both are compartmentalized with “|”.
Macd-line > signal line = green
Macd-line < signal line = red
- Supertrend (please look up from the documentation; i can not embed the link)
Think of this way, you’re riding a wave. If the wave is climbing, expect the price to follow.
Direction < 0 = Green 
Direction > 0 = Red
- Other Trend similar to supertrend  
This is similar to the Super Trend according the some. Imagine you’re drawing a trend line manually within 6 months.  
Within the period, the line gets smoothed over and over til the n=9.
> If the closing is less than the 9th value, it implies the trend is slowing down.
 Usage 
  Adjustments 
+ Since there are different holidays from different countries, you can change the BMI-Period from the indicator settings “BMI-4khansolo”. 
+ You can hide Technical Indicator Tables, it is also under the settings (see above).
> This will show red over the 52-Week high if it tests for positive  .
 Purpose 
Do you like eating the same food over and over? No! I love different food! I also love a variety of indicators. Especially, I love having MULTIPLE indicators presented in one canvas at the same time (personalized).
After spending a lot of time, I want to share my “FOOD” which is made of different ingredients (indicators) with someone who appreciates food! This Makes me a chef isn't it? Yes! Chef!
 Questions? 
If you have questions or spotted errors, please comment them below so that I can improve.
 Sources 
All the materials (i.e., functions like ta.rsi, etc...) used in here are available in the platform. 
All the references or sources materials are commented with the code since the I am not allowed to put them here.
Unified Composite Index [UCI] [KuraiBlu] [LazyBear]The purpose of this indicator is to combine the four basic types of indicators (Trend, Volatility, Momentum and Volume) to create a singular, composite index in order to provide a more holistic means of observing potential changes within the market, known as the Unified Composite Index  . The indicators used in this index are as follows:
Trend - Trend Composite Index    
Volatility -  Bollinger Bands %b  
Momentum - Relative Strength Index  
Volume - Money Flow Index  
The average price source can’t be altered as I’ve made it an average between ((open + close) / 2) and ((high + low) / 2).
The best way to use this is by observing several of the indicators at once in conjunction with the average, rather than simply using the average produced to determine the right moment to enter, or exit a trade by itself.  I've found when one indicator goes way out of bounds relative to the other three (and subsequently, the average array), then it presents a good buying, or selling opportunity. 
Some adjustments were made to several of the indicators in order to standardize them on a scale of 1-100 so that they could better accommodate the average array that was finally produced. Thanks to LazyBear for letting me strip down the WaveTrend Oscillator. 
Possible RSI [Loxx]Possible RSI   is a normalized, variety second-pass normalized, Variety RSI with Dynamic Zones and optionl High-Pass IIR digital filtering of source price input. This indicator includes 7 types of RSI.
 High-Pass Fitler (optional) 
The Ehlers Highpass Filter is a technical analysis tool developed by John F. Ehlers. Based on aerospace analog filters, this filter aims at reducing noise from price data. Ehlers Highpass Filter eliminates wave components with periods longer than a certain value. This reduces lag and makes the oscialltor zero mean. This turns the RSI output into something more similar to Stochasitc RSI where it repsonds to price very quickly. 
 First Normalization Pass 
RSI (Relative Strength Index) is already normalized. Hence, making a normalized RSI seems like a nonsense... if it was not for the "flattening" property of RSI. RSI tends to be flatter and flatter as we increase the calculating period--to the extent that it becomes unusable for levels trading if we increase calculating periods anywhere over the broadly recommended period 8 for RSI. In order to make that (calculating period) have less impact to significant levels usage of RSI trading style in this version a sort of a "raw stochastic" (min/max) normalization is applied. 
 Second-Pass Variety Normalization Pass 
There are three options to choose from:
1. Gaussian (Fisher Transform), this is the default: The Fisher Transform is a function created by John F. Ehlers that converts prices into a Gaussian normal distribution. The normaliztion helps highlights when prices have moved to an extreme, based on recent prices. This may help in spotting turning points in the price of an asset. It also helps show the trend and isolate the price waves within a trend.
  
2. Softmax: The softmax function, also known as softargmax: or normalized exponential function,  converts a vector of K real numbers into a probability distribution of K possible outcomes. It is a generalization of the logistic function to multiple dimensions, and used in multinomial logistic regression. The softmax function is often used as the last activation function of a neural network to normalize the output of a network to a probability distribution over predicted output classes, based on Luce's choice axiom.
  
3. Regular Normalization (devaitions about the mean): Converts a vector of K real numbers into a probability distribution of K possible outcomes without using log sigmoidal transformation as is done with Softmax. This is basically Softmax without the last step. 
  
 Dynamic Zones 
As explained in "Stocks & Commodities V15:7 (306-310): Dynamic Zones by Leo Zamansky, Ph .D., and David Stendahl"
Most indicators use a fixed zone for buy and sell signals. Here’ s a concept based on zones that are responsive to past levels of the indicator.
One approach to active investing employs the use of oscillators to exploit tradable market trends. This investing style follows a very simple form of logic: Enter the market only when an oscillator has moved far above or below traditional trading lev- els. However, these oscillator- driven systems lack the ability to evolve with the market because they use fixed buy and sell zones. Traders typically use one set of buy and sell zones for a bull market and substantially different zones for a bear market. And therein lies the problem.
Once traders begin introducing their market opinions into trading equations, by changing the zones, they negate the system’s mechanical nature. The objective is to have a system automatically define its own buy and sell zones and thereby profitably trade in any market — bull or bear. Dynamic zones offer a solution to the problem of fixed buy and sell zones for any oscillator-driven system.
An indicator’s extreme levels can be quantified using statistical methods. These extreme levels are calculated for a certain period and serve as the buy and sell zones for a trading system. The repetition of this statistical process for every value of the indicator creates values that become the dynamic zones. The zones are calculated in such a way that the probability of the indicator value rising above, or falling below, the dynamic zones is equal to a given probability input set by the trader.
To better understand dynamic zones, let's first describe them mathematically and then explain their use. The dynamic zones definition:
Find V such that:
For dynamic zone buy: P{X <= V}=P1
For dynamic zone sell: P{X >= V}=P2
where P1 and P2 are the probabilities set by the trader, X is the value of the indicator for the selected period and V represents the value of the dynamic zone.
The probability input P1 and P2 can be adjusted by the trader to encompass as much or as little data as the trader would like. The smaller the probability, the fewer data values above and below the dynamic zones. This translates into a wider range between the buy and sell zones. If a 10% probability is used for P1 and P2, only those data values that make up the top 10% and bottom 10% for an indicator are used in the construction of the zones. Of the values, 80% will fall between the two extreme levels. Because dynamic zone levels are penetrated so infrequently, when this happens, traders know that the market has truly moved into overbought or oversold territory.
Calculating the Dynamic Zones
The algorithm for the dynamic zones is a series of steps. First, decide the value of the lookback period t. Next, decide the value of the probability Pbuy for buy zone and value of the probability Psell for the sell zone.
For i=1, to the last lookback period, build the distribution f(x) of the price during the lookback period i. Then find the value Vi1 such that the probability of the price less than or equal to Vi1 during the lookback period i is equal to Pbuy. Find the value Vi2 such that the probability of the price greater or equal to Vi2 during the lookback period i is equal to Psell. The sequence of Vi1 for all periods gives the buy zone. The sequence of Vi2 for all periods gives the sell zone.
In the algorithm description, we have: Build the distribution f(x) of the price during the lookback period i. The distribution here is empirical namely, how many times a given value of x appeared during the lookback period. The problem is to find such x that the probability of a price being greater or equal to x will be equal to a probability selected by the user. Probability is the area under the distribution curve. The task is to find such value of x that the area under the distribution curve to the right of x will be equal to the probability selected by the user. That x is the dynamic zone.
 7 Types of RSI 
See here to understand which RSI types are included:
  
 Included: 
 
 Bar coloring
 4 signal types
 Alerts
 Loxx's Expanded Source Types
 Loxx's Variety RSI
 Loxx's Dynamic Zones






















