ZS Game Changer Pump & Dump DetectorZS GAME CHANGER PUMP AND DUMP DETECTOR - TOP 2 MOMENTUM TRACKER
Created by Zakaria Safri
An intelligent indicator specifically designed to identify and highlight the two most significant pump and dump candles within your selected lookback period. Perfect for traders who want to focus on the game-changing moves that truly matter in volatile markets like cryptocurrency, stocks, and forex.
CORE FEATURES
AUTOMATIC GAME CHANGER DETECTION
The indicator continuously scans your specified lookback period and automatically identifies the top 2 strongest pump candles and top 2 strongest dump candles. These game-changing candles are highlighted with distinctive gold labels and horizontal reference lines, making them instantly visible on your chart. Unlike other indicators that show every small move, this focuses exclusively on the market-moving moments that define trends and create opportunities.
INTELLIGENT PUMP AND DUMP CLASSIFICATION
Uses advanced percentage-based calculations to classify candles as pumps when price surges significantly upward and dumps when price plunges sharply downward. The detection system accounts for candle body size, wick proportions, and volume confirmation to ensure only legitimate momentum moves trigger signals. Customizable thresholds allow adaptation to any market volatility profile from calm stocks to wild altcoins.
ADVANCED WICK EXCLUSION FILTER
Eliminates false signals caused by candles with large wicks and small bodies. This filter focuses analysis exclusively on candles with substantial body sizes that indicate genuine directional conviction rather than temporary spikes followed by rejection. The body to candle ratio is fully adjustable to match your preferred signal quality standards.
VOLUME CONFIRMATION SYSTEM
Optional volume filter ensures detected pumps and dumps are backed by real market participation. The indicator compares current volume against a moving average and only triggers signals when volume exceeds your specified multiplier threshold. This eliminates low-volume noise and focuses on moves supported by institutional or crowd participation.
RALLY SEQUENCE DETECTION
Identifies and highlights consecutive sequences of pump or dump candles with colored background overlays. Green background indicates sustained buying pressure across multiple candles while red background shows sustained selling pressure. The rally detection system includes an optional one-miss allowance that prevents the sequence from breaking due to a single neutral candle.
HORIZONTAL REFERENCE LINES
Draws dashed lines from each game changer candle extending to the current bar, providing constant visual reference to the most significant support and resistance levels created by extreme momentum. The top game changer gets a thick dashed line while the second gets a dotted line for easy differentiation. Labels on the right side display the exact percentage move.
COMPREHENSIVE STATISTICS DASHBOARD
Real-time information panel showing current market status as pumping, dumping, or neutral along with the current candle percentage change. Displays the exact percentage values for top pump number 1, top pump number 2, top dump number 1, and top dump number 2. Shows running totals of all pumps and dumps detected since chart load. Tracks consecutive candle counts during active rally sequences.
TESTING AND VERIFICATION MODE
Built-in debug mode displays percentage change directly on each qualifying pump and dump candle, allowing instant verification that calculations are accurate. Shows which filters are currently active with a simple code in the dashboard. Helps traders understand exactly why certain candles qualified as game changers.
HOW THE GAME CHANGER DETECTION WORKS
SCANNING ALGORITHM
Every bar close, the indicator scans backward through your specified lookback period examining every candle's percentage change from its previous close. For bullish moves, it identifies the two candles with the largest positive percentage change that meet your threshold requirements. For bearish moves, it identifies the two candles with the largest negative percentage change meeting threshold requirements.
RANKING SYSTEM
Candles are ranked purely by their percentage move magnitude. The number 1 game changer is always the single strongest move in the lookback period. The number 2 game changer is the second strongest move. Rankings update dynamically as new candles form and old candles exit the lookback window.
VISUAL IDENTIFICATION
Game changer number 1 for both pumps and dumps receives a large gold label reading GAME CHANGER NUMBER 1 with zero transparency for maximum visibility. Game changer number 2 receives a slightly smaller gold label with partial transparency. The candle bars themselves are colored in gold instead of the standard green or red. Horizontal lines extend from the game changer price level to current bar.
FILTER APPLICATION
Only candles that pass your configured filters qualify for game changer consideration. If wick exclusion is enabled, candles with large wicks and small bodies are ignored. If volume confirmation is enabled, only candles with above-average volume qualify. This ensures game changers represent legitimate market moves rather than aberrations.
PRACTICAL APPLICATIONS
FOR CRYPTOCURRENCY TRADERS
Crypto markets experience extreme volatility with occasional massive pump and dump candles that define entire trends. This indicator instantly identifies which candles represent true market structure shifts versus normal noise. Use the game changer levels as key support and resistance for entries, exits, and stop placement. The top pump often marks the local high to watch for breakouts while the top dump marks the local low for reversal trades.
FOR DAY TRADERS
Intraday charts contain hundreds of candles but only a few truly matter for the session outcome. Game changer detection filters out 98 percent of candles to show you the 2 percent that drove the actual price movement. Enter trades on the side of the strongest recent game changer. Use game changer levels as magnet prices where algorithmic trading often returns.
FOR SWING TRADERS
On daily and four-hour timeframes, game changers represent major institutional activity or news-driven moves. The top dump often marks capitulation selling that creates reversal opportunities. The top pump often marks FOMO buying that creates resistance levels. Swing traders can build positions knowing these levels will be defended or tested multiple times.
FOR VOLATILITY ANALYSIS
Understanding which candles created the most volatility helps assess market risk. Multiple game changers clustered together indicate unstable choppy conditions. Game changers separated by many neutral candles indicate trending stable conditions. Use this context to adjust position sizing and stop distances appropriately.
FOR SUPPORT AND RESISTANCE TRADING
Game changer candles create the strongest support and resistance levels because they represent prices where massive volume transacted in short time periods. These levels have higher probability of holding on retest compared to arbitrary moving averages or pivot points. Trade bounces off game changer levels or breakouts through them.
RECOMMENDED SETTINGS BY MARKET
CRYPTOCURRENCY 15-MINUTE TO 1-HOUR CHARTS
Candle Size Threshold: 2.0 percent
Body to Candle Ratio: 0.5
Volume Multiplier: 1.5 times average
Game Changer Lookback: 100 bars
Extreme Threshold: 3.5 percent
Enable Wick Filter: Yes
Enable Volume Confirmation: Yes
Minimum Rally Candles: 3
STOCKS DAILY CHARTS
Candle Size Threshold: 1.0 percent
Body to Candle Ratio: 0.6
Volume Multiplier: 2.0 times average
Game Changer Lookback: 50 bars
Extreme Threshold: 2.5 percent
Enable Wick Filter: Yes
Enable Volume Confirmation: Yes
Minimum Rally Candles: 2
FOREX 1-HOUR TO 4-HOUR CHARTS
Candle Size Threshold: 0.5 percent
Body to Candle Ratio: 0.5
Volume Multiplier: Not applicable
Game Changer Lookback: 80 bars
Extreme Threshold: 1.0 percent
Enable Wick Filter: Yes
Enable Volume Confirmation: No
Minimum Rally Candles: 3
SCALPING 1-MINUTE TO 5-MINUTE CHARTS
Candle Size Threshold: 0.8 percent
Body to Candle Ratio: 0.4
Volume Multiplier: 1.2 times average
Game Changer Lookback: 50 bars
Extreme Threshold: 1.5 percent
Enable Wick Filter: No
Enable Volume Confirmation: Yes
Minimum Rally Candles: 2
WHAT IS INCLUDED
Automatic identification of top 2 pump candles
Automatic identification of top 2 dump candles
Gold colored game changer labels with size differentiation
Gold colored candle bars for game changers
Horizontal reference lines from game changers to current price
Regular pump and dump detection with green and red candles
Rally sequence detection with background highlighting
Extreme move detection and labeling system
Real-time statistics dashboard with all key metrics
Percentage change debug mode for verification
Volume confirmation filter with adjustable multiplier
Wick exclusion filter with adjustable body ratio
Customizable lookback period from 20 to 500 bars
Consecutive candle counter for rally tracking
Alert system for game changers, pumps, dumps, and rallies
Works on all timeframes from 1 minute to monthly
Compatible with stocks, forex, cryptocurrency, and futures
UNDERSTANDING GAME CHANGERS
WHAT MAKES A CANDLE A GAME CHANGER
A game changer is not just a large move but the largest move within context. In a volatile crypto market, a 5 percent pump might not rank in the top 2. In a stable stock, a 2 percent pump could be the number 1 game changer. The indicator adapts to your specific instrument and timeframe to find what truly matters in that context.
WHY FOCUS ON TOP 2 ONLY
Markets are driven by a small number of significant moves rather than the average of all moves. By focusing exclusively on the top 2 in each direction, traders can ignore noise and concentrate on the price levels that actually matter for support, resistance, and momentum. This creates clarity in decision making.
GAME CHANGERS AS MARKET STRUCTURE
The top pump often marks the recent high that bulls must break to continue uptrend. The top dump often marks the recent low that bears must break to continue downtrend. These become the key levels around which all other price action rotates. Understanding this structure is essential for profitable trading.
GAME CHANGERS AS SENTIMENT INDICATORS
Consecutive pump game changers signal strong bullish sentiment and FOMO conditions. Consecutive dump game changers signal fear and capitulation. Alternating pump and dump game changers signal indecision and range conditions. Read the pattern of game changers to gauge market psychology.
VERIFICATION AND TESTING
HOW TO VERIFY ACCURACY
Enable Show Debug Info on Chart in the Testing and Debug settings group. This displays the percentage change calculation directly on every qualifying pump and dump candle. Manually verify by calculating open minus close divided by close multiplied by 100. The debug percentage should match your manual calculation exactly.
HOW TO TEST FILTERS
Toggle wick exclusion filter on and off while watching how many candles qualify. With filter on, candles with long wicks and small bodies should disappear. Toggle volume confirmation on and off to see how low-volume candles get excluded. Adjust the thresholds and watch the real-time impact on signal count.
HOW TO VERIFY GAME CHANGERS
Look at your chart and visually identify which candle had the biggest green body in the lookback period. The game changer number 1 pump label should be on that exact candle. Repeat for the biggest red candle to verify game changer number 1 dump. The rankings should match your visual assessment.
LOOKBACK PERIOD EFFECTS
Decrease the lookback period to 20 bars and watch game changers update to only recent moves. Increase to 500 bars and watch game changers potentially change to older historic moves. The optimal lookback balances recency with significance. Too short misses important levels, too long includes irrelevant history.
DASHBOARD INFORMATION GUIDE
STATUS ROW
Shows PUMPING when current candle qualifies as a pump, DUMPING when current candle qualifies as a dump, or NEUTRAL when current candle does not meet threshold requirements. This updates in real-time on every bar close.
CURRENT CHANGE ROW
Displays the percentage change of the current candle from its previous close. Positive percentages indicate bullish candle, negative indicate bearish candle. This number may or may not meet your threshold to qualify as pump or dump.
TOP PUMP NUMBER 1
The highest positive percentage change found in your lookback period. This candle is marked with the large gold GAME CHANGER NUMBER 1 label below it. Shows N/A if no pumps exist in the lookback period.
TOP PUMP NUMBER 2
The second highest positive percentage change found in your lookback period. Marked with smaller gold GAME CHANGER NUMBER 2 label. Shows N/A if only one or zero pumps exist.
TOP DUMP NUMBER 1
The highest negative percentage change magnitude found in your lookback period. This candle is marked with the large gold GAME CHANGER NUMBER 1 label above it. Shows N/A if no dumps exist.
TOP DUMP NUMBER 2
The second highest negative percentage change magnitude found in your lookback period. Marked with smaller gold GAME CHANGER NUMBER 2 label. Shows N/A if only one or zero dumps exist.
TOTAL PUMPS
Running count of all pump candles detected since you loaded the indicator on this chart. This number continuously increases as new qualifying pumps form. Resets when you reload the chart.
TOTAL DUMPS
Running count of all dump candles detected since chart load. Increases as new qualifying dumps form and resets on chart reload.
CONSECUTIVE
Shows the current count of consecutive pump or dump candles during an active rally. Displays 3 UP during a 3-candle pump rally or 5 DN during a 5-candle dump rally. Shows 0 when no rally is active.
ALERT SYSTEM
GAME CHANGER DETECTED ALERT
Triggers whenever the current candle becomes one of the top 2 pumps or top 2 dumps. This is the highest priority alert indicating a market-moving event just occurred. Use this alert for immediate notification of significant opportunities.
PUMP DETECTED ALERT
Triggers on every candle that qualifies as a pump according to your threshold and filter settings. This includes regular pumps and extreme pumps but excludes game changers which have their separate alert. Use for general upward momentum monitoring.
DUMP DETECTED ALERT
Triggers on every candle that qualifies as a dump according to your settings. Includes regular and extreme dumps but excludes game changers. Use for general downward momentum monitoring.
PUMP RALLY STARTED ALERT
Triggers when consecutive pump candles reach your minimum rally threshold. Indicates the beginning of a sustained upward movement sequence. Use to catch trends early.
DUMP RALLY STARTED ALERT
Triggers when consecutive dump candles reach your minimum rally threshold. Indicates the beginning of a sustained downward movement sequence. Use for trend following or reversal timing.
ALERT MESSAGE FORMAT
All alerts include the ticker symbol and current price using TradingView placeholders. Messages are descriptive and specify which type of signal triggered. Alerts work with TradingView notification system including email, SMS, webhook, and app notifications.
TECHNICAL SPECIFICATIONS
CALCULATION METHODOLOGY
Percentage change calculated as current close minus previous close divided by previous close multiplied by 100. Body ratio calculated as absolute value of close minus open divided by high minus low. Volume elevation calculated as current volume divided by 20-period simple moving average of volume. Game changer ranking uses absolute value comparison across entire lookback array.
PERFORMANCE CHARACTERISTICS
Lightweight calculations optimized for speed on all timeframes. No repainting of signals ensuring all triggers are final on bar close. Variables properly scoped with var keyword for memory efficiency. Maximum bars back set to 500 to prevent excessive historical loading. Updates in real-time on every bar close without lag.
COMPATIBILITY
Works on all TradingView plans including free, pro, and premium. Compatible with stocks, forex, cryptocurrency, futures, indices, and commodities. Functions correctly on all timeframes from 1 second to monthly. No external data requests ensuring fast loading. Overlay true setting places directly on price chart.
RISK DISCLAIMER
This indicator is a technical analysis tool for identifying momentum and should not be used as the sole basis for trading decisions. Game changer levels can be broken during strong trends and are not guaranteed support or resistance. Pump and dump detection does not predict future price direction. Always use proper risk management with stop losses on every trade. Combine this indicator with other forms of analysis including fundamentals, market context, and risk assessment. Practice on demo accounts before live trading. Past performance of game changer signals does not guarantee future results. Trading carries substantial risk of loss and is not suitable for all investors. The creator is not responsible for trading losses incurred while using this tool.
SUPPORT AND UPDATES
Regular updates based on user feedback and market evolution. Built following PineCoders industry standards and best practices for code quality. Clean well-documented code structure for transparency and auditability. Optimized performance across all timeframes and instruments. Active development with continuous improvements and feature additions.
WHY CHOOSE ZS GAME CHANGER PUMP AND DUMP DETECTOR
Focuses on what matters by highlighting only the top 2 moves in each direction instead of cluttering your chart with every small fluctuation. Saves time by automatically identifying the most significant candles rather than requiring manual scanning. Provides clarity through visual gold labels and reference lines that make game changers unmistakable. Adapts to any market with customizable thresholds for volatility and volume. Eliminates noise with advanced wick and volume filters ensuring signal quality. Offers verification through debug mode proving calculations are accurate and trustworthy. Includes comprehensive statistics showing exact percentages and counts. Works everywhere across all markets, timeframes, and instruments without modification.
Transform your chart analysis by focusing exclusively on the game-changing moments that define trends and create opportunities.
Version 1.1 | Created by Zakaria Safri | Pine Script Version 5 | PineCoders Compliant
스크립트에서 "标准普尔500指数"에 대해 찾기
Squeeze Hour Frequency [CHE]Squeeze Hour Frequency (ATR-PR) — Standalone — Tracks daily squeeze occurrences by hour to reveal time-based volatility patterns 
  Summary 
This indicator identifies periods of unusually low volatility, defined as squeezes, and tallies their frequency across each hour of the day over historical trading sessions. By aggregating counts into a sortable table, it helps users spot hours prone to these conditions, enabling better scheduling of trading activity to avoid or target specific intraday regimes. Signals gain robustness through percentile-based detection that adapts to recent volatility history, differing from fixed-threshold methods by focusing on relative lowness rather than absolute levels, which reduces false positives in varying market environments.
  Motivation: Why this design? 
Traders often face uneven intraday volatility, with certain hours showing clustered low-activity phases that precede or follow breakouts, leading to mistimed entries or overlooked calm periods. The core idea of hourly squeeze frequency addresses this by binning low-volatility events into 24 hourly slots and counting distinct daily occurrences, providing a historical profile of when squeezes cluster. This reveals time-of-day biases without relying on real-time alerts, allowing proactive adjustments to session focus.
  What’s different vs. standard approaches? 
- Reference baseline: Classical volatility tools like simple moving average crossovers or fixed ATR thresholds, which flag squeezes uniformly across the day.
- Architecture differences:
  - Uses persistent arrays to track one squeeze per hour per day, preventing overcounting within sessions.
  - Employs custom sorting on ratio arrays for dynamic table display, prioritizing top or bottom performers.
  - Handles timezones explicitly to ensure consistent binning across global assets.
- Practical effect: Charts show a persistent table ranking hours by squeeze share, making intraday patterns immediately visible—such as a top hour capturing over 20 percent of total events—unlike static overlays that ignore temporal distribution, which matters for avoiding low-liquidity traps in crypto or forex.
  How it works (technical) 
The indicator first computes a rolling volatility measure over a specified lookback period. It then derives a relative ranking of the current value against recent history within a window of bars. A squeeze is flagged when this ranking falls below a user-defined cutoff, indicating the value is among the lowest in the recent sample.
On each bar, the local hour is extracted using the selected timezone. If a squeeze occurs and the bar has price data, the count for that hour increments only if no prior mark exists for the current day, using a persistent array to store the last marked day per hour. This ensures one tally per unique trading day per slot.
At the final bar, arrays compile counts and ratios for all 24 hours, where the ratio represents each hour's share of total squeezes observed. These are sorted ascending or descending based on display mode, and the top or bottom subset populates the table. Background shading highlights live squeezes in red for visual confirmation. Initialization uses zero-filled arrays for counts and negative seeds for day tracking, with state persisting across bars via variable declarations.
No higher timeframe data is pulled, so there is no repaint risk from external fetches; all logic runs on confirmed bars.
  Parameter Guide 
ATR Length — Controls the lookback for the volatility measure, influencing sensitivity to short-term fluctuations; shorter values increase responsiveness but add noise, longer ones smooth for stability — Default: 14 — Trade-offs/Tips: Use 10-20 for intraday charts to balance quick detection with fewer false squeezes; test on historical data to avoid over-smoothing in trending markets.
Percentile Window (bars) — Sets the history depth for ranking the current volatility value, affecting how "low" is defined relative to past; wider windows emphasize long-term norms — Default: 252 — Trade-offs/Tips: 100-300 bars suit daily cycles; narrower for fast assets like crypto to catch recent regimes, but risks instability in sparse data.
Squeeze threshold (PR < x) — Defines the cutoff for flagging low relative volatility, where values below this mark a squeeze; lower thresholds tighten detection for rarer events — Default: 10.0 — Trade-offs/Tips: 5-15 percent for conservative signals reducing false positives; raise to 20 for more frequent highlights in high-vol environments, monitoring for increased noise.
Timezone — Specifies the reference for hourly binning, ensuring alignment with market sessions — Default: Exchange — Trade-offs/Tips: Set to "America/New_York" for US assets; mismatches can skew counts, so verify against chart timezone.
Show Table — Toggles the results display, essential for reviewing frequencies — Default: true — Trade-offs/Tips: Disable on mobile for performance; pair with position tweaks for clean overlays.
Pos — Places the table on the chart pane — Default: Top Right — Trade-offs/Tips: Bottom Left avoids candle occlusion on volatile charts.
Font — Adjusts text readability in the table — Default: normal — Trade-offs/Tips: Tiny for dense views, large for emphasis on key hours.
Dark — Applies high-contrast colors for visibility — Default: true — Trade-offs/Tips: Toggle false in light themes to prevent washout.
Display — Filters table rows to focus on extremes or full list — Default: All — Trade-offs/Tips: Top 3 for quick scans of risky hours; Bottom 3 highlights safe low-squeeze periods.
  Reading & Interpretation 
Red background shading appears on bars meeting the squeeze condition, signaling current low relative volatility. The table lists hours as "H0" to "H23", with columns for daily squeeze counts, percentage share of total squeezes (summing to 100 percent across hours), and an arrow marker on the top hour. A summary row above details the peak count, its share, and the leading hour. A label at the last bar recaps total days observed, data-valid days, and top hour stats. Rising shares indicate clustering, suggesting regime persistence in that slot.
  Practical Workflows & Combinations 
- Trend following: Scan for hours with low squeeze shares to enter during stable regimes; confirm with higher highs or lower lows on the 15-minute chart, avoiding top-share hours post-news like tariff announcements.
- Exits/Stops: Tighten stops in high-share hours to guard against sudden vol spikes; use the table to shift to conservative sizing outside peak squeeze times.
- Multi-asset/Multi-TF: Defaults work across crypto pairs on 5-60 minute timeframes; for stocks, widen percentile window to 500 bars. Combine with volume oscillators—enter only if squeeze count is below average for the asset.
  Behavior, Constraints & Performance 
Logic executes on closed bars, with live bars updating counts provisionally but finalizing on confirmation; table refreshes only at the last bar, avoiding intrabar flicker. No security calls or higher timeframes, so no repaint from external data. Resources include a 5000-bar history limit, loops up to 24 iterations for sorting and totals, and arrays sized to 24 elements; labels and table are capped at 500 each for efficiency. Known limits: Skips hours without bars (e.g., weekends), assumes uniform data availability, and may undercount in sparse sessions; timezone shifts can alter profiles without warning.
  Sensible Defaults & Quick Tuning 
Start with ATR Length at 14, Percentile Window at 252, and threshold at 10.0 for broad crypto use. If too many squeezes flag (noisy table), raise threshold to 15.0 and narrow window to 100 for stricter relative lowness. For sluggish detection in calm markets, drop ATR Length to 10 and threshold to 5.0 to capture subtler dips. In high-vol assets, widen window to 500 and threshold to 20.0 for stability.
  What this indicator is—and isn’t 
This is a historical frequency tracker and visualization layer for intraday volatility patterns, best as a filter in multi-tool setups. It is not a standalone signal generator, predictive model, or risk manager—pair it with price action, news filters, and position sizing rules.
  Disclaimer 
The content provided, including all code and materials, is strictly for educational and informational purposes only. It is not intended as, and should not be interpreted as, financial advice, a recommendation to buy or sell any financial instrument, or an offer of any financial product or service. All strategies, tools, and examples discussed are provided for illustrative purposes to demonstrate coding techniques and the functionality of Pine Script within a trading context.
Any results from strategies or tools provided are hypothetical, and past performance is not indicative of future results. Trading and investing involve high risk, including the potential loss of principal, and may not be suitable for all individuals. Before making any trading decisions, please consult with a qualified financial professional to understand the risks involved.
By using this script, you acknowledge and agree that any trading decisions are made solely at your discretion and risk.
Do not use this indicator on Heikin-Ashi, Renko, Kagi, Point-and-Figure, or Range charts, as these chart types can produce unrealistic results for signal markers and alerts.
Best regards and happy trading
Chervolino
Thanks to Duyck
for the ma sorter
FVG Zones with Signals█ OVERVIEW
"FVG Zones with Signals" is a technical analysis tool that identifies Fair Value Gaps (FVG) on the chart and draws customizable zones in the form of boxes. It is ideal for traders using price action and market structure strategies, helping to identify potential imbalance zones and trading opportunities based on breakout and exit signals. With flexible size filter settings, box styles, and signal options, the indicator ensures clarity and precision on the chart.
█ CONCEPTS
The indicator is designed to identify potential entry points for trades based on FVG breakouts or retests. For chart clarity, a size filter for FVGs is included, based on a multiplier of the average candle size over a specified period.
Why are FVGs important? FVG zones represent areas of market imbalance, often attracting price back to "fill" the gap. Larger gaps (with a higher size multiplier) have a greater chance of being retested, as they indicate deeper imbalances—leaving more unexecuted orders in those zones, which attracts liquidity. Market makers and institutions often return to these levels to "refresh" liquidity before further moves. However, not every large FVG is retested quickly—in strong trends, smaller imbalances may be ignored, and the location (e.g., near swing highs/lows) is critical for retest probability.
█ FEATURES
- FVG Detection: Identifies bullish and bearish FVGs based on size filters (Candle Size Period and FVG Size Multiplier), with automatic initialization of historical gaps up to 500 candles back.
- Customizable Boxes: Draws FVG boxes with adjustable border colors, background gradients, border styles (solid, dashed, dotted), border widths, and transparency for both the background and the 50% FVG midline.
- Breakout and Exit Signals: Generates "Break" signals (green upward triangle for breakouts above bearish FVG, red downward triangle for breakouts below bullish FVG) and "Exit" signals (circles for exiting the zone), with options to select signal types (Break, Exit, or Both). A break signal causes the box to disappear, leaving a triangle as a trace of the breakout, which may serve as a signal to open a position. Exit signals (circles) may also indicate entry opportunities but require additional confirmation, such as alignment with the main trend.
- Midline: Automatically draws a dashed line at the 50% FVG level with adjustable transparency, aiding in assessing price reactions within the zone.
- Box Limitation: Automatically removes old or inactive FVGs after 500 candles to avoid chart clutter.
- Alerts: Built-in alerts for all signal types, including price and FVG type descriptions.
█ HOW TO USE
Add to Chart: Apply the indicator to your TradingView chart via the Pine Editor or Indicators menu.
Configure Settings:
- FVG Settings: Adjust Candle Size Period (default 20) and FVG Size Multiplier (default 1) to filter out small gaps—higher values generate fewer but more significant FVGs.
- Box Settings: Configure colors and styles for bullish (green) and bearish (red) boxes, including background transparency (default 80) and midline transparency.
- Signal Settings: Select signal types (Break, Exit, or Both) in Signal Type. Breakout signals appear after a candle closes outside the zone, while exit signals appear when exiting an FVG without a full breakout.
- Styling: Customize signal colors (green for buy/up, red for sell/down) and shape sizes.
Interpreting Signals:
- Break Up Signal: A green triangle below the bar indicates a breakout above a bearish FVG, suggesting potential continuation of an uptrend.
- Break Down Signal: A red triangle above the bar indicates a breakout below a bullish FVG, suggesting potential continuation of a downtrend.
- Exit Up/Down Signal: A green/red circle indicates an exit from an FVG without a full breakout, which may signal the end of a correction or preparation for a reversal.
- FVG Zones: If the price returns to an FVG and fills the gap, it may indicate equilibrium; an unfilled gap often leads to a retest.
- Use signals in conjunction with other technical analysis tools for confirmation, such as RSI (to identify overbought/oversold conditions) or MACD (to confirm momentum). Analyze FVGs from higher timeframes—these zones act as stronger imbalance levels and carry greater structural significance.
Exit signals (retests without breakouts) tend to be most effective when traded in line with the current trend.
█ APPLICATIONS
- Price Action Trading: Use FVG zones as dynamic support and resistance levels. In an uptrend, look for buying opportunities in bullish FVGs, where price often tests the gap before continuing. Combining with RSI, MACD, or Fibonacci levels enhances the significance of zones.
- Breakout Strategies: Trade based on breakout signals from FVGs. A buy signal after breaking a bearish FVG may indicate a strong upward impulse, especially when supported by a rising MACD or RSI exiting oversold conditions.
Larger FVG gaps (higher multiplier) have a greater chance of retest, as they indicate deeper imbalances.
█ NOTES
- Test the indicator across different timeframes and markets (stocks, forex, crypto) to optimize size filters for your trading style.
- The indicator initializes historical FVGs up to 500 candles back, which may slow loading on longer charts.
- For best results, use on high-liquidity markets where FVGs are more frequently retested.
- In consolidation zones, the indicator may generate more false signals, so additional confirmation is recommended.
Market Regime IndexThe Market Regime Index is a top-down macro regime nowcasting tool that offers a consolidated view of the market’s risk appetite. It tracks 32 of the world’s most influential markets across asset classes to determine investor sentiment by applying trend-following signals to each independent asset. It features adjustable parameters and a built-in alert system that notifies investors when conditions transition between Risk-On and Risk-Off regimes. The selected markets are grouped into equities (7), fixed income (9), currencies (7), commodities (5), and derivatives (4):
 
 Equities = S&P 500 E-mini Index Futures, Nasdaq-100 E-mini Index Futures, Russell 2000 E-mini Index Futures, STOXX Europe 600 Index Futures, Nikkei 225 Index Futures, MSCI Emerging Markets Index Futures, and S&P 500 High Beta (SPHB)/Low Beta (SPLV) Ratio.
 Fixed Income = US 10Y Treasury Yield, US 2Y Treasury Yield, US 10Y-02Y Yield Spread, German 10Y Bund Yield, UK 10Y Gilt Yield, US 10Y Breakeven Inflation Rate, US 10Y TIPS Yield, US High Yield Option-Adjusted Spread, and US Corporate Option-Adjusted Spread.
 Currencies = US Dollar Index (DXY), Australian Dollar/US Dollar, Euro/US Dollar, Chinese Yuan/US Dollar, Pound Sterling/US Dollar, Japanese Yen/US Dollar, and Bitcoin/US Dollar.
 Commodities = ICE Brent Crude Oil Futures, COMEX Gold Futures, COMEX Silver Futures, COMEX Copper Futures, and S&P Goldman Sachs Commodity Index (GSCI) Futures.
 Derivatives = CBOE S&P 500 Volatility Index (VIX), ICE US Bond Market Volatility Index (MOVE), CBOE 3M Implied Correlation Index, and CBOE VIX Volatility Index (VVIX)/VIX.
 
All assets are directionally aligned with their historical correlation to the S&P 500. Each asset contributes equally based on its individual bullish or bearish signal. The overall market regime is calculated as the difference between the number of Risk-On and Risk-Off signals divided by the total number of assets, displayed as the percentage of markets confirming each regime. Green indicates Risk-On and occurs when the number of Risk-On signals exceeds Risk-Off signals, while red indicates Risk-Off and occurs when the number of Risk-Off signals exceeds Risk-On signals.
 
 Bullish Signal = (Fast MA – Slow MA) > (ATR × ATR Margin)
 Bearish Signal = (Fast MA – Slow MA) < –(ATR × ATR Margin)
 Market Regime = (Risk-On signals – Risk-Off signals) ÷ Total assets
 
This indicator is designed with flexibility in mind, allowing users to include or exclude individual assets that contribute to the market regime and adjust the input parameters used for trend signal detection. These parameters apply to each independent asset, and the overall regime signal is smoothed by the signal length to reduce noise and enhance reliability. Investors can position according to the prevailing market regime by selecting factors that have historically outperformed under each regime environment to minimise downside risk and maximise upside potential:
 
 Risk-On Equity Factors = High Beta > Cyclicals > Low Volatility > Defensives.
 Risk-Off Equity Factors = Defensives > Low Volatility > Cyclicals > High Beta.
 Risk-On Fixed Income Factors = High Yield > Investment Grade > Treasuries.
 Risk-Off Fixed Income Factors = Treasuries > Investment Grade > High Yield.
 Risk-On Commodity Factors = Industrial Metals > Energy > Agriculture > Gold.
 Risk-Off Commodity Factors = Gold > Agriculture > Energy > Industrial Metals.
 Risk-On Currency Factors = Cryptocurrencies > Foreign Currencies > US Dollar.
 Risk-Off Currency Factors = US Dollar > Foreign Currencies > Cryptocurrencies.
 
In summary, the Market Regime Index is a comprehensive macro risk-management tool that identifies the current market regime and helps investors align portfolio risk with the market’s underlying risk appetite. Its intuitive, color-coded design makes it an indispensable resource for investors seeking to navigate shifting market conditions and enhance risk-adjusted performance by selecting factors that have historically outperformed. While it has proven historically valuable, asset-specific characteristics and correlations evolve over time as market dynamics change.
XAUUSD/SPX with SMA(48)📊 Gold vs S&P 500 | XAUUSD/SPX Ratio with SMA (48) – Full Pine Script Breakdown
In this video, we build and explain a custom Pine Script that plots the Gold to S&P 500 ratio (XAUUSD/SPX) along with a 48-period Simple Moving Average (SMA).
This ratio helps us analyze how Gold is performing against equities and whether smart money is shifting from risk assets (stocks) to safe haven (gold).
🔧 What’s Included in the Script:
✅ Live ratio of XAUUSD (Gold) / SPX (S&P 500)
✅ 48-period SMA for trend analysis
✅ Clean visual chart in a separate pane
✅ Pine Script v5 compatible
🧠 Why This Matters:
Tracking the XAUUSD/SPX ratio gives deeper insight into macro trends, inflation hedge behavior, and market sentiment.
A rising ratio can signal weakness in equities and strength in precious metals — a key trend for long-term investors and macro traders.
Advanced Volume Profile Pro  Delta + POC + VAH/VAL# Advanced Volume Profile Pro - Delta + POC + VAH/VAL Analysis System
## WHAT THIS SCRIPT DOES
This script creates a comprehensive volume profile analysis system that combines traditional volume-at-price distribution with delta volume calculations, Point of Control (POC) identification, and Value Area (VAH/VAL) analysis. Unlike standard volume indicators that show only total volume over time, this script analyzes volume distribution across price levels and estimates buying vs selling pressure using multiple calculation methods to provide deeper market structure insights.
## WHY THIS COMBINATION IS ORIGINAL AND USEFUL
**The Problem Solved:** Traditional volume indicators show when volume occurs but not where price finds acceptance or rejection. Standalone volume profiles lack directional bias information, while basic delta calculations don't provide structural context. Traders need to understand both volume distribution AND directional sentiment at key price levels.
**The Solution:** This script implements an integrated approach that:
- Maps volume distribution across price levels using configurable row density
- Estimates delta (buying vs selling pressure) using three different methodologies
- Identifies Point of Control (highest volume price level) for key support/resistance
- Calculates Value Area boundaries where 70% of volume traded
- Provides real-time alerts for key level interactions and volume imbalances
**Unique Features:**
1. **Developing POC Visualization**: Real-time tracking of Point of Control migration throughout the session via blue dotted trail, revealing institutional accumulation/distribution patterns before they complete
2. **Multi-Method Delta Calculation**: Price Action-based, Bid/Ask estimation, and Cumulative methods for different market conditions
3. **Adaptive Timeframe System**: Auto-adjusts calculation parameters based on chart timeframe for optimal performance
4. **Flexible Profile Types**: N Bars Back (precise control), Days Back (calendar-based), and Session-based analysis modes
5. **Advanced Imbalance Detection**: Identifies and highlights significant buying/selling imbalances with configurable thresholds
6. **Comprehensive Alert System**: Monitors POC touches, Value Area entry/exit, and major volume imbalances
## HOW THE SCRIPT WORKS TECHNICALLY
### Core Volume Profile Methodology:
**1. Price Level Distribution:**
- Divides price range into user-defined rows (10-50 configurable)
- Calculates row height: `(Highest Price - Lowest Price) / Number of Rows`
- Distributes each bar's volume across price levels it touched proportionally
**2. Delta Volume Calculation Methods:**
**Price Action Method:**
```
Price Range = High - Low
Buy Pressure = (Close - Low) / Price Range
Sell Pressure = (High - Close) / Price Range
Buy Volume = Total Volume × Buy Pressure
Sell Volume = Total Volume × Sell Pressure
Delta = Buy Volume - Sell Volume
```
**Bid/Ask Estimation Method:**
```
Average Price = (High + Low + Close) / 3
Buy Volume = Close > Average ? Volume × 0.6 : Volume × 0.4
Sell Volume = Total Volume - Buy Volume
```
**Cumulative Method:**
```
Buy Volume = Close > Open ? Volume : Volume × 0.3
Sell Volume = Close ≤ Open ? Volume : Volume × 0.3
```
**3. Point of Control (POC) Identification:**
- Scans all price levels to find maximum volume concentration
- POC represents the price level with highest trading activity
- Acts as significant support/resistance level
- **Developing POC Feature**: Tracks POC evolution in real-time via blue dotted trail, showing how institutional interest migrates throughout the session. Upward POC migration indicates accumulation patterns, downward migration suggests distribution, providing early trend signals before price confirmation.
**4. Value Area Calculation:**
- Starts from POC and expands up/down to encompass 70% of total volume
- VAH (Value Area High): Upper boundary of value area
- VAL (Value Area Low): Lower boundary of value area
- Expansion algorithm prioritizes direction with higher volume
**5. Adaptive Range Selection:**
Based on profile type and timeframe optimization:
- **N Bars Back**: Fixed lookback period with performance optimization (20-500 bars)
- **Days Back**: Calendar-based analysis with automatic timeframe adjustment (1-365 days)
- **Session**: Current trading session or custom session times
### Performance Optimization Features:
- **Sampling Algorithm**: Reduces calculation load on large datasets while maintaining accuracy
- **Memory Management**: Clears previous drawings to prevent performance degradation
- **Safety Constraints**: Prevents excessive memory usage with configurable limits
## HOW TO USE THIS SCRIPT
### Initial Setup:
1. **Profile Configuration**: Select profile type based on trading style:
   - N Bars Back: Precise control over data range
   - Days Back: Intuitive calendar-based analysis
   - Session: Real-time session development
2. **Row Density**: Set number of rows (30 default) - more rows = higher resolution, slower performance
3. **Delta Method**: Choose calculation method based on market type:
   - Price Action: Best for trending markets
   - Bid/Ask Estimate: Good for ranging markets
   - Cumulative: Smoothed approach for volatile markets
4. **Visual Settings**: Configure colors, position (left/right), and display options
### Reading the Profile:
**Volume Bars:**
- **Length**: Represents relative volume at that price level
- **Color**: Green = net buying pressure, Red = net selling pressure
- **Intensity**: Darker colors indicate volume imbalances above threshold
**Key Levels:**
- **POC (Blue Line)**: Highest volume price - major support/resistance
- **VAH (Purple Dashed)**: Value Area High - upper boundary of fair value
- **VAL (Orange Dashed)**: Value Area Low - lower boundary of fair value
- **Value Area Fill**: Shaded region showing main trading range
**Developing POC Trail:**
- **Blue Dotted Lines**: Show real-time POC evolution throughout the session
- **Migration Patterns**: Upward trail indicates bullish accumulation, downward trail suggests bearish distribution
- **Early Signals**: POC movement often precedes price movement, providing advance warning of institutional activity
- **Institutional Footprints**: Reveals where smart money concentrated volume before final POC establishment
### Trading Applications:
**Support/Resistance Analysis:**
- POC acts as magnetic price level - expect reactions
- VAH/VAL provide intermediate support/resistance levels
- Profile edges show areas of low volume acceptance
**Developing POC Analysis:**
- **Upward Migration**: POC moving higher = institutional accumulation, bullish bias
- **Downward Migration**: POC moving lower = institutional distribution, bearish bias  
- **Stable POC**: Tight clustering = balanced market, range-bound conditions
- **Early Trend Detection**: POC direction change often precedes price breakouts
**Entry Strategies:**
- Buy at VAL with POC as target (in uptrends)
- Sell at VAH with POC as target (in downtrends)
- Breakout plays above/below profile extremes
**Volume Imbalance Trading:**
- Strong buying imbalance (>60% threshold) suggests continued upward pressure
- Strong selling imbalance suggests continued downward pressure
- Imbalances near key levels provide high-probability setups
**Multi-Timeframe Context:**
- Use higher timeframe profiles for major levels
- Lower timeframe profiles for precise entries
- Session profiles for intraday trading structure
## SCRIPT SETTINGS EXPLANATION
### Volume Profile Settings:
- **Profile Type**: Determines data range for calculation
  - N Bars Back: Exact number of bars (20-500 range)
  - Days Back: Calendar days with timeframe adaptation (1-365 days)
  - Session: Trading session-based (intraday focus)
- **Number of Rows**: Profile resolution (10-50 range)
- **Profile Width**: Visual width as chart percentage (10-50%)
- **Value Area %**: Volume percentage for VA calculation (50-90%, 70% standard)
- **Auto-Adjust**: Automatically optimizes for different timeframes
### Delta Volume Settings:
- **Show Delta Volume**: Enable/disable delta calculations
- **Delta Calculation Method**: Choose methodology based on market conditions
- **Highlight Imbalances**: Visual emphasis for significant volume imbalances
- **Imbalance Threshold**: Percentage for imbalance detection (50-90%)
### Session Settings:
- **Session Type**: Daily, Weekly, Monthly, or Custom periods
- **Custom Session Time**: Define specific trading hours
- **Previous Sessions**: Number of historical sessions to display
### Days Back Settings:
- **Lookback Days**: Number of calendar days to analyze (1-365)
- **Automatic Calculation**: Script automatically converts days to bars based on timeframe:
  - Intraday: Accounts for 6.5 trading hours per day
  - Daily: 1 bar per day
  - Weekly/Monthly: Proportional adjustment
### N Bars Back Settings:
- **Lookback Bars**: Exact number of bars to analyze (20-500)
- **Precise Control**: Best for systematic analysis and backtesting
### Visual Customization:
- **Colors**: Bullish (green), Bearish (red), and level colors
- **Profile Position**: Left or Right side of chart
- **Profile Offset**: Distance from current price action
- **Labels**: Show/hide level labels and values
- **Smooth Profile Bars**: Enhanced visual appearance
### Alert Configuration:
- **POC Touch**: Alerts when price interacts with Point of Control
- **VA Entry/Exit**: Alerts for Value Area boundary interactions
- **Major Imbalance**: Alerts for significant volume imbalances
## VISUAL FEATURES
### Profile Display:
- **Horizontal Bars**: Volume distribution across price levels
- **Color Coding**: Delta-based coloring for directional bias
- **Smooth Rendering**: Optional smoothing for cleaner appearance
- **Transparency**: Configurable opacity for chart readability
### Level Lines:
- **POC**: Solid blue line with optional label
- **VAH/VAL**: Dashed colored lines with value displays
- **Extension**: Lines extend across relevant time periods
- **Value Area Fill**: Optional shaded region between VAH/VAL
### Information Table:
- **Current Values**: Real-time POC, VAH, VAL prices
- **VA Range**: Value Area width calculation
- **Positioning**: Multiple table positions available
- **Text Sizing**: Adjustable for different screen sizes
## IMPORTANT USAGE NOTES
**Realistic Expectations:**
- Volume profile analysis provides structural context, not trading signals
- Delta calculations are estimations based on price action, not actual order flow
- Past volume distribution does not guarantee future price behavior
- Combine with other analysis methods for comprehensive market view
**Best Practices:**
- Use appropriate profile types for your trading style:
  - Day Trading: Session or Days Back (1-5 days)
  - Swing Trading: Days Back (10-30 days) or N Bars Back
  - Position Trading: Days Back (60-180 days)
- Consider market context (trending vs ranging conditions)
- Verify key levels with additional technical analysis
- Monitor profile development for changing market structure
**Performance Considerations:**
- Higher row counts increase calculation complexity
- Large lookback periods may affect chart performance
- Auto-adjust feature optimizes for most use cases
- Consider using session profiles for intraday efficiency
**Limitations:**
- Delta calculations are estimations, not actual transaction data
- Profile accuracy depends on available price/volume history
- Effectiveness varies across different instruments and market conditions
- Requires understanding of volume profile concepts for optimal use
**Data Requirements:**
- Requires volume data for accurate calculations
- Works best on liquid instruments with consistent volume
- May be less effective on very low volume or exotic instruments
This script serves as a comprehensive volume analysis tool for traders who need detailed market structure information with integrated directional bias analysis and real-time POC development tracking for informed trading decisions.
Active PMI Support/Resistance Levels [EdgeTerminal]The PMI Support & Resistance indicator revolutionizes traditional technical analysis by using Pointwise Mutual Information (PMI) - a statistical measure from information theory - to objectively identify support and resistance levels. Unlike conventional methods that rely on visual pattern recognition, this indicator provides mathematically rigorous, quantifiable evidence of price levels where significant market activity occurs.
- The Mathematical Foundation: Pointwise Mutual Information
Pointwise Mutual Information measures how much more likely two events are to occur together compared to if they were statistically independent. In our context:
 
 Event A: Volume spikes occurring (high trading activity)
 Event B: Price being at specific levels
 
The PMI formula calculates: PMI = log(P(A,B) / (P(A) × P(B)))
Where:
 
 P(A,B) = Probability of volume spikes occurring at specific price levels
 P(A) = Probability of volume spikes occurring anywhere
 P(B) = Probability of price being at specific levels
 
High PMI scores indicate that volume spikes and certain price levels co-occur much more frequently than random chance would predict, revealing genuine support and resistance zones.
- Why PMI Outperforms Traditional Methods
Subjective interpretation: What one trader sees as significant, another might ignore
Confirmation bias: Tendency to see patterns that confirm existing beliefs
Inconsistent criteria: No standardized definition of "significant" volume or price action
Static analysis: Doesn't adapt to changing market conditions
No strength measurement: Can't quantify how "strong" a level truly is
PMI Advantages:
✅ Objective & Quantifiable: Mathematical proof of significance, not visual guesswork
✅ Statistical Rigor: Levels backed by information theory and probability
✅ Strength Scoring: PMI scores rank levels by statistical significance
✅ Adaptive: Automatically adjusts to different market volatility regimes
✅ Eliminates Bias: Computer-calculated, removing human interpretation errors
✅ Market Structure Aware: Reveals the underlying order flow concentrations
- How It Works
Data Processing Pipeline:
 
 Volume Analysis: Identifies volume spikes using configurable thresholds
 Price Binning: Divides price range into discrete levels for analysis
 Co-occurrence Calculation: Measures how often volume spikes happen at each price level
 PMI Computation: Calculates statistical significance for each price level
 Level Filtering: Shows only levels exceeding minimum PMI thresholds
 Dynamic Updates: Refreshes levels periodically while maintaining historical traces
 
Visual System:
 
 Current Levels: Bright, thick lines with PMI scores - your actionable levels
 Historical Traces: Faded previous levels showing market structure evolution
 Strength Tiers: Line styles indicate PMI strength (solid/dashed/dotted)
 Color Coding: Green for support, red for resistance
 Info Table: Real-time display of strongest levels with scores
 
- Indicator Settings:
 Core Parameters 
 Lookback Period (Default: 200) 
Lower (50-100): More responsive to recent price action, catches short-term levels
Higher (300-500): Focuses on major historical levels, more stable but less responsive
Best for: Day trading (100-150), Swing trading (200-300), Position trading (400-500)
 Volume Spike Threshold (Default: 1.5) 
Lower (1.2-1.4): More sensitive, catches smaller volume increases, more levels detected
Higher (2.0-3.0): Only major volume surges count, fewer but stronger signals
Market dependent: High-volume stocks may need higher thresholds (2.0+), low-volume stocks lower (1.2-1.3)
 Price Bins (Default: 50) 
Lower (20-30): Broader price zones, less precise but captures wider areas
Higher (70-100): More granular levels, precise but may be overly specific
Volatility dependent: High volatility assets benefit from more bins (70+)
 Minimum PMI Score (Default: 0.5) 
Lower (0.2-0.4): Shows more levels including weaker ones, comprehensive view
Higher (1.0-2.0): Only statistically strong levels, cleaner chart
Progressive filtering: Start with 0.5, increase if too cluttered
 Max Levels to Show (Default: 8) 
Fewer (3-5): Clean chart focusing on strongest levels only
More (10-15): Comprehensive view but may clutter chart
Strategy dependent: Scalpers prefer fewer (3-5), swing traders more (8-12)
 Historical Tracking Settings 
Update Frequency (Default: 20 bars)
Lower (5-10): More frequent updates, captures rapid market changes
Higher (50-100): Less frequent updates, focuses on major structural shifts
Timeframe scaling: 1-minute charts need lower frequency (5-10), daily charts higher (50+)
 Show Historical Levels (Default: True) 
Enables the "breadcrumb trail" effect showing evolution of support/resistance
Disable for cleaner charts focusing only on current levels
 Max Historical Marks (Default: 50) 
Lower (20-30): Less memory usage, shorter history
Higher (100-200): Longer historical context but more resource intensive
 Fade Strength (Default: 0.8) 
Lower (0.5-0.6): Historical levels more visible
Higher (0.9-0.95): Historical levels very subtle
 Visual Settings 
Support/Resistance Colors: Choose colors that contrast well with your chart theme Line Width: Thicker lines (3-4) for better visibility on busy charts Show PMI Scores: Toggle labels showing statistical strength Label Size: Adjust based on screen resolution and chart zoom level
- Most Effective Usage Strategies
For Day Trading:
Setup: Lookback 100-150, Volume Threshold 1.8-2.2, Update Frequency 10-15
Use PMI levels as bounce/rejection points for scalp entries
Higher PMI scores (>1.5) offer better probability setups
Watch for volume spike confirmations at levels
For Swing Trading:
Setup: Lookback 200-300, Volume Threshold 1.5-2.0, Update Frequency 20-30
Enter on pullbacks to high PMI support levels
Target next resistance level with PMI score >1.0
Hold through minor levels, exit at major PMI levels
For Position Trading:
Setup: Lookback 400-500, Volume Threshold 2.0+, Update Frequency 50+
Focus on PMI scores >2.0 for major structural levels
Use for portfolio entry/exit decisions
Combine with fundamental analysis for timing
- Trading Applications:
 Entry Strategies: 
 PMI Bounce Trades 
Price approaches high PMI support level (>1.0)
Wait for volume spike confirmation (orange triangles)
Enter long on bullish price action at the level
Stop loss just below the PMI level
Target: Next PMI resistance level
 PMI Breakout Trades 
Price consolidates near high PMI level
Volume increases (watch for orange triangles)
Enter on decisive break with volume
Previous resistance becomes new support
Target: Next major PMI level
 PMI Rejection Trades 
Price approaches PMI resistance with momentum
Watch for rejection signals and volume spikes
Enter short on failure to break through
Stop above the PMI level
Target: Next PMI support level
 Risk Management: 
 Stop Loss Placement 
Place stops 0.1-0.5% beyond PMI levels (adjust for volatility)
Higher PMI scores warrant tighter stops
Use ATR-based stops for volatile assets
 Position Sizing 
Larger positions at PMI levels >2.0 (highest conviction)
Smaller positions at PMI levels 0.5-1.0 (lower conviction)
Scale out at multiple PMI targets
- Key Warning Signs & What to Watch For
 Red Flags: 
🚨 Very Low PMI Scores (<0.3): Weak statistical significance, avoid trading
 🚨 No Volume Confirmation: PMI level without recent volume spikes may be stale
 🚨 Overcrowded Levels: Too many levels close together suggests poor parameter tuning
 🚨 Outdated Levels: Historical traces are reference only, not tradeable
 Optimization Tips: 
✅ Regular Recalibration: Adjust parameters monthly based on market regime changes
 ✅ Volume Context: Always check for recent volume activity at PMI levels
 ✅ Multiple Timeframes: Confirm PMI levels across different timeframes
 ✅ Market Conditions: Higher thresholds during high volatility periods
Interpreting PMI Scores
PMI Score Ranges:
 
 0.5-1.0: Moderate statistical significance, proceed with caution
 1.0-1.5: Good significance, reliable for most trading strategies
 1.5-2.0: Strong significance, high-confidence trade setups
 2.0+: Very strong significance, institutional-grade levels
 
Historical Context: The historical trace system shows how support and resistance evolve over time. When current levels align with multiple historical traces, it indicates persistent market memory at those prices, significantly increasing the level's reliability.
The Sequences of FibonacciThe Sequences of Fibonacci - Advanced Multi-Timeframe Confluence Analysis System 
 THEORETICAL FOUNDATION & MATHEMATICAL INNOVATION 
 The Sequences of Fibonacci  represents a revolutionary approach to market analysis that synthesizes classical Fibonacci mathematics with modern adaptive signal processing. This indicator transcends traditional Fibonacci retracement tools by implementing a sophisticated multi-dimensional confluence detection system that reveals hidden market structure through mathematical precision.
 Core Mathematical Framework 
 Dynamic Fibonacci Grid System: 
Unlike static Fibonacci tools, this system calculates highest highs and lowest lows across true Fibonacci sequence periods (8, 13, 21, 34, 55 bars) creating a dynamic grid of mathematical support and resistance levels that adapt to market structure in real-time.
 Multi-Dimensional Confluence Detection: 
The engine employs advanced mathematical clustering algorithms to identify areas where multiple derived Fibonacci retracement levels (0.382, 0.500, 0.618) from different timeframe perspectives converge. These "Confluence Zones" are mathematically classified by strength:
-  CRITICAL Zones:  8+ converging Fibonacci levels
-  HIGH Zones:  6-7 converging levels  
-  MEDIUM Zones:  4-5 converging levels
-  LOW Zones:  3+ converging levels
 Adaptive Signal Processing Architecture: 
The system implements adaptive Stochastic RSI calculations with dynamic overbought/oversold levels that adjust to recent market volatility rather than using fixed thresholds. This prevents false signals during changing market conditions.
 COMPREHENSIVE FEATURE ARCHITECTURE 
 Quantum Field Visualization System 
 Dynamic Price Field Mathematics: 
The Quantum Field creates adaptive price channels based on EMA center points and ATR-based amplitude calculations, influenced by the Unified Field metric. This visualization system helps traders understand:
- Expected price volatility ranges
- Potential overextension zones  
- Mathematical pressure points in market structure
- Dynamic support/resistance boundaries
 Field Amplitude Calculation: 
Field Amplitude = ATR × (1 + |Unified Field| / 10)
The system generates three quantum levels:
-  Q⁰ Level:  0.618 × Field Amplitude (Primary channel)
-  Q¹ Level:  1.0 × Field Amplitude (Secondary boundary)  
-  Q² Level:  1.618 × Field Amplitude (Extreme extension)
 Advanced Market Analysis Dashboard 
 Unified Field Analysis: 
A composite metric combining:
- Price momentum (40% weighting)
- Volume momentum (30% weighting) 
- Trend strength (30% weighting)
 Market Resonance Calculation: 
Measures price-volume correlation over 14 periods to identify harmony between price action and volume participation.
 Signal Quality Assessment: 
Synthesizes Unified Field, Market Resonance, and RSI positioning to provide real-time evaluation of setup potential.
 Tiered Signal Generation Logic 
 Tier 1 Signals (Highest Conviction): 
Require ALL conditions:
- Adaptive StochRSI setup (exiting dynamic OB/OS levels)
- Classic StochRSI divergence confirmation
- Strong reversal bar pattern (adaptive ATR-based sizing)
- Level rejection from Confluence Zone or Fibonacci level
- Supportive Unified Field context
 Tier 2 Signals (Enhanced Opportunity Detection): 
Generated when Tier 1 conditions aren't met but exceptional circumstances exist:
- Divergence candidate patterns (relaxed divergence requirements)
- Exceptionally strong reversal bars at critical levels
- Enhanced level rejection criteria
- Maintained context filtering
 Intelligent Visualization Features 
 Fractal Matrix Grid: 
Multi-layer visualization system displaying:
- Shadow Layer: Foundational support (width 5)
- Glow Layer: Core identification (width 3, white)
- Quantum Layer: Mathematical overlay (width 1, dotted)
 Smart Labeling System: 
Prevents overlap using ATR-based minimum spacing while providing:
- Fibonacci period identification
- Topological complexity classification (0, I, II, III)
- Exact price levels
- Strength indicators (○ ◐ ● ⚡)
 Wick Pressure Analysis: 
Dynamic visualization showing momentum direction through:
- Multi-beam projection lines
- Particle density effects
- Progressive transparency for natural flow
- Strength-based sizing adaptation
 PRACTICAL TRADING IMPLEMENTATION 
 Signal Interpretation Framework 
 Entry Protocol: 
1.  Confluence Zone Approach:  Monitor price approaching High/Critical confluence zones
2.  Adaptive Setup Confirmation:  Wait for StochRSI to exit adaptive OB/OS levels  
3.  Divergence Verification:  Confirm classic or candidate divergence patterns
4.  Reversal Bar Assessment:  Validate strong rejection using adaptive ATR criteria
5.  Context Evaluation:  Ensure Unified Field provides supportive environment
 Risk Management Integration: 
-  Stop Placement:  Beyond rejected confluence zone or Fibonacci level
-  Position Sizing:  Based on signal tier and confluence strength
-  Profit Targets:  Next significant confluence zone or quantum field boundary
 Adaptive Parameter System 
 Dynamic StochRSI Levels: 
Unlike fixed 80/20 levels, the system calculates adaptive OB/OS based on recent StochRSI range:
-  Adaptive OB:  Recent minimum + (range × OB percentile)
-  Adaptive OS:  Recent minimum + (range × OS percentile)  
-  Lookback Period:  Configurable 20-100 bars for range calculation
 Intelligent ATR Adaptation: 
Bar size requirements adjust to market volatility:
-  High Volatility:  Reduced multiplier (bars naturally larger)
-  Low Volatility:  Increased multiplier (ensuring significance)
-  Base Multiplier:  0.6× ATR with adaptive scaling
 Optimization Guidelines 
 Timeframe-Specific Settings: 
 Scalping (1-5 minutes): 
- Fibonacci Rejection Sensitivity: 0.3-0.8
- Confluence Threshold: 2-3 levels
- StochRSI Lookback: 20-30 bars
 Day Trading (15min-1H):   
- Fibonacci Rejection Sensitivity: 0.5-1.2
- Confluence Threshold: 3-4 levels
- StochRSI Lookback: 40-60 bars
 Swing Trading (4H-1D): 
- Fibonacci Rejection Sensitivity: 1.0-2.0  
- Confluence Threshold: 4-5 levels
- StochRSI Lookback: 60-80 bars
 Asset-Specific Optimization: 
 Cryptocurrency: 
- Higher rejection sensitivity (1.0-2.5) for volatile conditions
- Enable Tier 2 signals for increased opportunity detection
- Shorter adaptive lookbacks for rapid market changes
 Forex Major Pairs: 
- Moderate sensitivity (0.8-1.5) for stable trending
- Focus on Higher/Critical confluence zones
- Longer lookbacks for institutional flow detection
 Stock Indices: 
- Conservative sensitivity (0.5-1.0) for institutional participation  
- Standard confluence thresholds
- Balanced adaptive parameters
 IMPORTANT USAGE CONSIDERATIONS 
 Realistic Performance Expectations 
 This indicator provides probabilistic advantages based on mathematical confluence analysis, not guaranteed outcomes. Signal quality varies with market conditions, and proper risk management remains essential regardless of signal tier. 
 Understanding Adaptive Features: 
- Adaptive parameters react to historical data, not future market conditions
- Dynamic levels adjust to past volatility patterns
- Signal quality reflects mathematical alignment probability, not certainty
 Market Context Awareness: 
- Strong trending markets may produce fewer reversal signals
- Range-bound conditions typically generate more confluence opportunities
- News events and fundamental factors can override technical analysis
 Educational Value 
 Mathematical Concepts Introduced: 
- Multi-dimensional confluence analysis
- Adaptive signal processing techniques  
- Dynamic parameter optimization
- Mathematical field theory applications in trading
- Advanced Fibonacci sequence applications
 Skill Development Benefits: 
- Understanding market structure through mathematical lens
- Recognition of multi-timeframe confluence principles
- Appreciation for adaptive vs. static analysis methods
- Integration of classical Fibonacci with modern signal processing
 UNIQUE INNOVATIONS 
 First-Ever Implementations 
1.  True Fibonacci Sequence Periods:  First indicator using authentic Fibonacci numbers (8,13,21,34,55) for timeframe analysis
2.  Mathematical Confluence Clustering:  Advanced algorithm identifying true Fibonacci level convergence  
3.  Adaptive StochRSI Boundaries:  Dynamic OB/OS levels replacing fixed thresholds
4.  Tiered Signal Architecture:  Democratic signal weighting with quality classification
5.  Quantum Field Price Visualization:  Mathematical field representation of price dynamics
 Visualization Breakthroughs 
-  Multi-Layer Fibonacci Grid:  Three-layer rendering with intelligent spacing
-  Dynamic Confluence Zones:  Strength-based color coding and sizing
-  Adaptive Parameter Display:  Real-time visualization of dynamic calculations
-  Mathematical Field Effects:  Quantum-inspired price channel visualization
-  Progressive Transparency Systems:  Natural visual flow without chart clutter
 COMPREHENSIVE DASHBOARD SYSTEM 
 Multi-Size Display Options 
 Small Dashboard:  Core metrics for mobile/limited screen space
 Normal Dashboard:  Balanced information density for standard desktop use  
 Large Dashboard:  Complete analysis suite including adaptive parameter values
 Real-Time Metrics Tracking 
 Market Analysis Section: 
- Unified Field strength with visual meter
- Market Resonance percentage  
- Signal Quality assessment with emoji indicators
- Market Bias classification (Bullish/Bearish/Neutral)
 Confluence Intelligence: 
- Total active zones count
- High/Critical zone identification
- Nearest zone distance and strength
- Price-to-zone ATR measurement
 Adaptive Parameters (Large Dashboard): 
- Current StochRSI OB/OS levels
- Active ATR multiplier for bar sizing
- Volatility ratio for adaptive scaling
- Real-time StochRSI positioning
 TECHNICAL SPECIFICATIONS 
 Pine Script Version:  v5 (Latest)
 Calculation Method:  Real-time with confirmed bar processing  
 Maximum Objects:  500 boxes, 500 lines, 500 labels
 Dashboard Positions:  4 corner options with size selection
 Visual Themes:  Quantum, Holographic, Crystalline, Plasma
 Alert Integration:  Complete alert system for all signal types
 Performance Optimizations: 
- Efficient confluence zone calculation using advanced clustering
- Smart label spacing prevents overlap
- Progressive transparency for visual clarity
- Memory-optimized array management
 EDUCATIONAL FRAMEWORK 
 Learning Progression 
 Beginner Level: 
- Understanding Fibonacci sequence applications
- Recognition of confluence zone concepts
- Basic signal interpretation
- Dashboard metric comprehension
 Intermediate Level:   
- Adaptive parameter optimization
- Multi-timeframe confluence analysis
- Signal quality assessment techniques
- Risk management integration
 Advanced Level: 
- Mathematical field theory applications
- Custom parameter optimization strategies
- Market regime adaptation techniques
- Professional trading system integration
 DEVELOPMENT ACKNOWLEDGMENT 
 Special acknowledgment to @AlgoTrader90 - the foundational concepts of this system came from him and we developed it through a collaborative discussions about multi-timeframe Fibonacci analysis. While the original framework came from AlgoTrader90's innovative approach, this implementation represents a complete evolution of the logic with enhanced mathematical precision, adaptive parameters, and sophisticated signal filtering to deliver meaningful, actionable trading signals. 
 CONCLUSION 
 The Sequences of Fibonacci  represents a quantum leap in technical analysis, successfully merging classical Fibonacci mathematics with cutting-edge adaptive signal processing. Through sophisticated confluence detection, intelligent parameter adaptation, and comprehensive market analysis, this system provides traders with unprecedented insight into market structure and potential reversal points.
The mathematical foundation ensures lasting relevance while the adaptive features maintain effectiveness across changing market conditions. From the dynamic Fibonacci grid to the quantum field visualization, every component reflects a commitment to mathematical precision, visual elegance, and practical utility.
Whether you're a beginner seeking to understand market confluence or an advanced trader requiring sophisticated analytical tools, this system provides the mathematical framework for informed decision-making based on time-tested Fibonacci principles enhanced with modern computational techniques.
 Trade with mathematical precision. Trade with the power of confluence. Trade with The Sequences of Fibonacci. 
"Mathematics is the language with which God has written the universe. In markets, Fibonacci sequences reveal the hidden harmonies that govern price movement, and those who understand these mathematical relationships hold the key to anticipating market behavior." 
    * Galileo Galilei (adapted for modern markets)
— Dskyz, Trade with insight. Trade with anticipation.
DCA Investment Tracker Pro [tradeviZion]DCA Investment Tracker Pro: Educational DCA Analysis Tool 
 An educational indicator that helps analyze Dollar-Cost Averaging strategies by comparing actual performance with historical data calculations. 
---
 💡 Why I Created This Indicator 
As someone who practices Dollar-Cost Averaging, I was frustrated with constantly switching between spreadsheets, calculators, and charts just to understand how my investments were really performing. I wanted to see everything in one place - my actual performance, what I should expect based on historical data, and most importantly,  visualize where my strategy could take me over the long term .
What really motivated me was watching friends and family underestimate the incredible power of consistent investing. When Napoleon Bonaparte first learned about compound interest, he reportedly exclaimed  "I wonder it has not swallowed the world"  - and he was right! Yet most people can't visualize how their $500 monthly contributions today could become substantial wealth decades later.
Traditional DCA tracking tools exist, but they share similar limitations:
 
 Require manual data entry and complex spreadsheets
 Use fixed assumptions that don't reflect real market behavior  
 Can't show future projections overlaid on actual price charts
 Lose the visual context of what's happening in the market
 Make compound growth feel abstract rather than tangible 
 
I wanted to create something different - a tool that automatically analyzes real market history, detects volatility periods, and shows you both current performance AND educational projections based on historical patterns right on your TradingView charts. As Warren Buffett said:  "Someone's sitting in the shade today because someone planted a tree a long time ago."   This tool helps you visualize your financial tree growing over time. 
This isn't just another calculator - it's a visualization tool that makes the magic of compound growth impossible to ignore.
---
 🎯 What This Indicator Does 
This educational indicator provides DCA analysis tools. Users can input investment scenarios to study:
 
 Theoretical Performance:  Educational calculations based on historical return data
 Comparative Analysis:  Study differences between actual and theoretical scenarios
 Historical Projections:  Theoretical projections for educational analysis (not predictions)
 Performance Metrics:  CAGR, ROI, and other analytical metrics for study
 Historical Analysis:  Calculates historical return data for reference purposes
 
  
---
 🚀 Key Features 
 Volatility-Adjusted Historical Return Calculation 
 
 Analyzes 3-20 years of actual price data for any symbol
 Automatically detects high-volatility stocks (meme stocks, growth stocks)
 Uses median returns for volatile stocks, standard CAGR for stable stocks
 Provides conservative estimates when extreme outlier years are detected
 Smart fallback to manual percentages when data insufficient
 
 Customizable Performance Dashboard 
 
 Educational DCA performance analysis with compound growth calculations
 Customizable table sizing (Tiny to Huge text options)
 9 positioning options (Top/Middle/Bottom + Left/Center/Right)
 Theme-adaptive colors (automatically adjusts to dark/light mode)
 Multiple display layout options
 
 Future Projection System 
 
 Visual future growth projections
 Timeframe-aware calculations (Daily/Weekly/Monthly charts)
 1-30 year projection options
 Shows projected portfolio value and total investment amounts
 
 Investment Insights 
 
 Performance vs benchmark comparison
 ROI from initial investment tracking
 Monthly average return analysis
 Investment milestone alerts (25%, 50%, 100% gains)
 Contribution tracking and next milestone indicators
 
---
 📊 Step-by-Step Setup Guide 
 1. Investment Settings 💰 
 
 Initial Investment:  Enter your starting lump sum (e.g., $60,000)
 Monthly Contribution:  Set your regular DCA amount (e.g., $500/month)
 Return Calculation:  Choose "Auto (Stock History)" for real data or "Manual" for fixed %
 Historical Period:  Select 3-20 years for auto calculations (default: 10 years)
 Start Year:  When you began investing (e.g., 2020)
 Current Portfolio Value:  Your actual portfolio worth today (e.g., $150,000)
 
 2. Display Settings 📊 
 
 Table Sizes:  Choose from Tiny, Small, Normal, Large, or Huge
 Table Positions:  9 options - Top/Middle/Bottom + Left/Center/Right
 Visibility Toggles:  Show/hide Main Table and Stats Table independently
 
 3. Future Projection 🔮 
 
 Enable Projections:  Toggle on to see future growth visualization
 Projection Years:  Set 1-30 years ahead for analysis
 
 Live Example -  NASDAQ:META  Analysis: 
  
 Settings shown: $60K initial + $500/month + Auto calculation + 10-year history + 2020 start + $150K current value 
---
 🔬 Pine Script Code Examples 
 Core DCA Calculations: 
 
// Calculate total invested over time
months_elapsed = (year - start_year) * 12 + month - 1
total_invested = initial_investment + (monthly_contribution * months_elapsed)
// Compound growth formula for initial investment
theoretical_initial_growth = initial_investment * math.pow(1 + annual_return, years_elapsed)
// Future Value of Annuity for monthly contributions
monthly_rate = annual_return / 12
fv_contributions = monthly_contribution * ((math.pow(1 + monthly_rate, months_elapsed) - 1) / monthly_rate)
// Total expected value
theoretical_total = theoretical_initial_growth + fv_contributions
 
 Volatility Detection Logic: 
 
// Detect extreme years for volatility adjustment
extreme_years = 0
for i = 1 to historical_years
    yearly_return = ((price_current / price_i_years_ago) - 1) * 100
    if yearly_return > 100 or yearly_return < -50
        extreme_years += 1
// Use median approach for high volatility stocks
high_volatility = (extreme_years / historical_years) > 0.2
calculated_return = high_volatility ? median_of_returns : standard_cagr
 
 Performance Metrics: 
 
// Calculate key performance indicators
absolute_gain = actual_value - total_invested
total_return_pct = (absolute_gain / total_invested) * 100
roi_initial = ((actual_value - initial_investment) / initial_investment) * 100
cagr = (math.pow(actual_value / initial_investment, 1 / years_elapsed) - 1) * 100
 
---
 📊 Real-World Examples 
See the indicator in action across different investment types:
 Stable Index Investments: 
 AMEX:SPY  (SPDR S&P 500)  - Shows steady compound growth with standard CAGR calculations
  
 Classic DCA success story: $60K initial + $500/month starting 2020. The indicator shows SPY's historical 10%+ returns, demonstrating how consistent broad market investing builds wealth over time. Notice the smooth theoretical growth line vs actual performance tracking. 
 MIL:VUAA  (Vanguard S&P 500 UCITS)  - Shows both data limitation and solution approaches
  
 Data limitation example: VUAA shows "Manual (Auto Failed)" and "No Data" when default 10-year historical setting exceeds available data. The indicator gracefully falls back to manual percentage input while maintaining all DCA calculations and projections. 
 MIL:VUAA  (Vanguard S&P 500 UCITS)  - European ETF with successful 5-year auto calculation
  
 Solution demonstration: By adjusting historical period to 5 years (matching available data), VUAA auto calculation works perfectly. Shows how users can optimize settings for newer assets. European market exposure with EUR denomination, demonstrating DCA effectiveness across different markets and currencies. 
   NYSE:BRK.B  (Berkshire Hathaway)  - Quality value investment with Warren Buffett's proven track record
   
 Value investing approach: Berkshire Hathaway's legendary performance through DCA lens. The indicator demonstrates how quality companies compound wealth over decades. Lower volatility than tech stocks = standard CAGR calculations used. 
 High-Volatility Growth Stocks: 
 NASDAQ:NVDA  (NVIDIA Corporation)  - Demonstrates volatility-adjusted calculations for extreme price swings
  
 High-volatility example: NVIDIA's explosive AI boom creates extreme years that trigger volatility detection. The indicator automatically switches to "Median (High Vol): 50%" calculations for conservative projections, protecting against unrealistic future estimates based on outlier performance periods. 
 NASDAQ:TSLA  (Tesla)  - Shows how 10-year analysis can stabilize volatile tech stocks
  
 Stable long-term growth: Despite Tesla's reputation for volatility, the 10-year historical analysis (34.8% CAGR) shows consistent enough performance that volatility detection doesn't trigger. Demonstrates how longer timeframes can smooth out extreme periods for more reliable projections. 
 NASDAQ:META  (Meta Platforms)  - Shows stable tech stock analysis using standard CAGR calculations
  
 Tech stock with stable growth: Despite being a tech stock and experiencing the 2022 crash, META's 10-year history shows consistent enough performance (23.98% CAGR) that volatility detection doesn't trigger. The indicator uses standard CAGR calculations, demonstrating how not all tech stocks require conservative median adjustments. 
 Notice how the indicator automatically detects high-volatility periods and switches to median-based calculations for more conservative projections, while stable investments use standard CAGR methods. 
---
 📈 Performance Metrics Explained 
 
 Current Portfolio Value:  Your actual investment worth today
 Expected Value:  What you  should  have based on historical returns (Auto) or your target return (Manual)
 Total Invested:  Your actual money invested (initial + all monthly contributions)
 Total Gains/Loss:  Absolute dollar difference between current value and total invested
 Total Return %:  Percentage gain/loss on your total invested amount
 ROI from Initial Investment:  How your starting lump sum has performed
 CAGR:  Compound Annual Growth Rate of your initial investment  (Note: This shows initial investment performance, not full DCA strategy) 
 vs Benchmark:  How you're performing compared to the expected returns
 
---
 ⚠️ Important Notes & Limitations 
 
 Data Requirements:  Auto mode requires sufficient historical data (minimum 3 years recommended)
 CAGR Limitation:  CAGR calculation is based on initial investment growth only, not the complete DCA strategy
 Projection Accuracy:  Future projections are theoretical and based on historical returns - actual results may vary
 Timeframe Support:  Works ONLY on Daily (1D), Weekly (1W), and Monthly (1M) charts - no other timeframes supported
 Update Frequency:  Update "Current Portfolio Value" regularly for accurate tracking
 
---
 📚 Educational Use & Disclaimer 
This analysis tool can be applied to various stock and ETF charts for educational study of DCA mathematical concepts and historical performance patterns.
 Study Examples:  Can be used with symbols like  AMEX:SPY ,  NASDAQ:QQQ ,  AMEX:VTI ,  NASDAQ:AAPL ,  NASDAQ:MSFT ,  NASDAQ:GOOGL ,  NASDAQ:AMZN ,  NASDAQ:TSLA ,  NASDAQ:NVDA  for learning purposes.
 EDUCATIONAL DISCLAIMER: This indicator is a study tool for analyzing Dollar-Cost Averaging strategies. It does not provide investment advice, trading signals, or guarantees. All calculations are theoretical examples for educational purposes only. Past performance does not predict future results. Users should conduct their own research and consult qualified financial professionals before making any investment decisions. 
---
 © 2025 TradeVizion. All rights reserved.  
$ADD LevelsThis Pine Script is designed to track and visualize the NYSE Advance-Decline Line (ADD). The Advance-Decline Line is a popular market breadth indicator, showing the difference between advancing and declining stocks on the NYSE. It’s often used to gauge overall market sentiment and strength.
1. //@version=5
This line tells TradingView to use Pine Script v5, the latest and most powerful version of Pine.
2. indicator(" USI:ADD  Levels", overlay=false)
	•	This creates a new indicator called ” USI:ADD  Levels”.
	•	overlay=false means it will appear in a separate pane, not on the main price chart.
3. add = request.security(...)
This fetches real-time data from the symbol  USI:ADD  (Advance-Decline Line) using a 1-minute timeframe. You can change the timeframe if needed.
add_symbol = input.symbol(" USI:ADD ", "Market Breadth Symbol")
add = request.security(add_symbol, "1", close)
4. Key Thresholds
These define the market sentiment zones:
Zone.                              Value.                                            Meaning
Overbought                   +1500                                       Extremely bullish
Bullish                            +1000                                  Generally bullish trend
Neutral                            ±500                                     Choppy, unclear market
Bearish                          -1000                                     Generally bearish trend
Oversold                         -1500                                     Extremely bearish
5. Plot the ADD Line  hline(...)
Draws static lines at +1500, +1000, +500, -500, -1000, -1500 for reference so you can visually assess where ADD stands.
6. Horizontal Threshold Lines bgcolor(...)
	•	Green background if ADD > +1500 → extremely bullish.
	•	Red background if ADD < -1500 → extremely bearish.
7. Background Highlights alertcondition(...)
	•	Green background if ADD > +1500 → extremely bullish.
	•	Red background if ADD < -1500 → extremely bearish.
8. Alert Conditions.   alertcondition(...)
Lets you create automatic alerts for:
	•	 USI:ADD  being very high or low.
	•	Crosses above +1000 (bullish trigger).
	•	Crosses below -1000 (bearish trigger).
You can use these to trigger trades or monitor sentiment shifts.
 Summary: When to Use It
	•	Use this script in a market breadth dashboard.
	•	Combine it with price action and volume analysis.
	•	Monitor for ADD crosses to signal potential market reversals or momentum.
Institutional Volume Profile# Institutional Volume Profile (IVP) - Advanced Volume Analysis Indicator
## Overview
The Institutional Volume Profile (IVP) is a sophisticated technical analysis tool that combines traditional volume profile analysis with institutional volume detection algorithms. This indicator helps traders identify key price levels where significant institutional activity has occurred, providing insights into market structure and potential support/resistance zones.
## Key Features
### 🎯 Volume Profile Analysis
- **Point of Control (POC)**: Identifies the price level with the highest volume activity
- **Value Area**: Highlights the price range containing a specified percentage (default 70%) of total volume
- **Multi-Row Distribution**: Displays volume distribution across 10-50 price levels for detailed analysis
- **Customizable Period**: Analyze volume profiles over 10-500 bars
### 🏛️ Institutional Volume Detection
- **Pocket Pivot Volume (PPV)**: Detects bullish institutional buying when up-volume exceeds recent down-volume peaks
- **Pivot Negative Volume (PNV)**: Identifies bearish institutional selling when down-volume exceeds recent up-volume peaks
- **Accumulation Detection**: Spots potential accumulation phases with high volume and narrow price ranges
- **Distribution Analysis**: Identifies distribution patterns with high volume but minimal price movement
### 🎨 Visual Customization Options
- **Multiple Color Schemes**: Heat Map, Institutional, Monochrome, and Rainbow themes
- **Bar Styles**: Solid, Gradient, Outlined, and 3D Effect rendering
- **Volume Intensity Display**: Visual intensity based on volume magnitude
- **Flexible Positioning**: Left or right side profile placement
- **Current Price Highlighting**: Real-time price level indication
### 📊 Advanced Visual Features
- **Volume Labels**: Display volume amounts at key price levels
- **Gradient Effects**: Multi-step gradient rendering for enhanced visibility
- **3D Styling**: Shadow effects for professional appearance
- **Opacity Control**: Adjustable transparency (10-100%)
- **Border Customization**: Configurable border width and styling
## How It Works
### Volume Distribution Algorithm
The indicator analyzes each bar within the specified period and distributes its volume proportionally across the price levels it touches. This creates an accurate representation of where trading activity has been concentrated.
### Institutional Detection Logic
- **PPV Trigger**: Current up-bar volume > highest down-volume in lookback period + above volume MA
- **PNV Trigger**: Current down-bar volume > highest up-volume in lookback period + above volume MA
- **Accumulation**: High volume + narrow range + bullish close
- **Distribution**: Very high volume + minimal price movement
### Value Area Calculation
Starting from the POC, the algorithm expands both upward and downward, adding volume until reaching the specified percentage of total volume (default 70%).
## Configuration Parameters
### Profile Settings
- **Profile Period**: 10-500 bars (default: 50)
- **Number of Rows**: 10-50 levels (default: 24)
- **Profile Width**: 10-100% of screen (default: 30%)
- **Value Area %**: 50-90% (default: 70%)
### Institutional Analysis
- **PPV Lookback Days**: 5-20 periods (default: 10)
- **Volume MA Length**: 10-200 periods (default: 50)
- **Institutional Threshold**: 1.0-2.0x multiplier (default: 1.2)
### Visual Controls
- **Bar Style**: Solid, Gradient, Outlined, 3D Effect
- **Color Scheme**: Heat Map, Institutional, Monochrome, Rainbow
- **Profile Position**: Left or Right side
- **Opacity**: 10-100%
- **Show Labels**: Volume amount display toggle
## Interpretation Guide
### Volume Profile Elements
- **Thick Horizontal Bars**: High volume nodes (strong support/resistance)
- **Thin Horizontal Bars**: Low volume nodes (weak levels)
- **White Line (POC)**: Strongest support/resistance level
- **Blue Highlighted Area**: Value Area (fair value zone)
### Institutional Signals
- **Blue Triangles (PPV)**: Bullish institutional buying detected
- **Orange Triangles (PNV)**: Bearish institutional selling detected
- **Color-Coded Bars**: Different colors indicate institutional activity types
### Color Scheme Meanings
- **Heat Map**: Red (high volume) → Orange → Yellow → Gray (low volume)
- **Institutional**: Blue (PPV), Orange (PNV), Aqua (Accumulation), Yellow (Distribution)
- **Monochrome**: Grayscale intensity based on volume
- **Rainbow**: Color-coded by price level position
## Trading Applications
### Support and Resistance
- POC acts as dynamic support/resistance
- High volume nodes indicate strong price levels
- Low volume areas suggest potential breakout zones
### Institutional Activity
- PPV above Value Area: Strong bullish signal
- PNV below Value Area: Strong bearish signal
- Accumulation patterns: Potential upward breakouts
- Distribution patterns: Potential downward pressure
### Market Structure Analysis
- Value Area defines fair value range
- Profile shape indicates market sentiment
- Volume gaps suggest potential price targets
## Alert Conditions
- PPV Detection at current price level
- PNV Detection at current price level
- PPV above Value Area (strong bullish)
- PNV below Value Area (strong bearish)
## Best Practices
1. Use multiple timeframes for confirmation
2. Combine with price action analysis
3. Pay attention to volume context (above/below average)
4. Monitor institutional signals near key levels
5. Consider overall market conditions
## Technical Notes
- Maximum 500 boxes and 100 labels for optimal performance
- Real-time calculations update on each bar close
- Historical analysis uses complete bar data
- Compatible with all TradingView chart types and timeframes
---
*This indicator is designed for educational and informational purposes. Always combine with other analysis methods and risk management strategies.*
Sector 50MA vs 200MA ComparisonThis TradingView indicator compares the 50-period Moving Average (50MA) and 200-period Moving Average (200MA) of a selected market sector or index, providing a visual and analytical tool to assess relative strength and trend direction. Here's a detailed breakdown of its functionality:
Purpose: The indicator plots the 50MA and 200MA of a chosen sector or index on a separate panel, highlighting their relationship to identify bullish (50MA > 200MA) or bearish (50MA < 200MA) trends. It also includes a histogram and threshold lines to gauge momentum and key levels.
Inputs:
Resolution: Allows users to select the timeframe for calculations (Daily, Weekly, or Monthly; default is Daily).
Sector Selection: Users can choose from a list of sectors or indices, including Tech, Financials, Consumer Discretionary, Utilities, Energy, Communication Services, Materials, Industrials, Health Care, Consumer Staples, Real Estate, S&P 500 Value, S&P 500 Growth, S&P 500, NASDAQ, Russell 2000, and S&P SmallCap 600. Each sector maps to specific ticker pairs for 50MA and 200MA data.
Data Retrieval:
The indicator fetches closing prices for the 50MA and 200MA of the selected sector using the request.security function, based on the chosen timeframe and ticker pairs.
Visual Elements:
Main Chart:
Plots the 50MA (blue line) and 200MA (red line) for the selected sector.
Fills the area between the 50MA and 200MA with green (when 50MA > 200MA, indicating bullishness) or red (when 50MA < 200MA, indicating bearishness).
Threshold Lines:
Horizontal lines at 0 (zero line), 20 (lower threshold), 50 (center), 80 (upper threshold), and 100 (upper limit) provide reference points for the 50MA's position.
Fills between 0-20 (green) and 80-100 (red) highlight key zones for potential overbought or oversold conditions.
Sector Information Table:
A table in the top-right corner displays the selected sector and its corresponding 50MA and 200MA ticker symbols for clarity.
Alerts:
Generates alert conditions for:
Bullish Crossover: When the 50MA crosses above the 200MA (indicating potential upward momentum).
Bearish Crossover: When the 50MA crosses below the 200MA (indicating potential downward momentum).
Use Case:
Traders can use this indicator to monitor the relative strength of a sector's short-term trend (50MA) against its long-term trend (200MA).
The visual fill between the moving averages and the threshold lines helps identify trend direction, momentum, and potential reversal points.
The sector selection feature allows for comparative analysis across different market segments, aiding in sector rotation strategies or market trend analysis.
This indicator is ideal for traders seeking to analyze sector performance, identify trend shifts, and make informed decisions based on moving average crossovers and momentum thresholds.
SPDR Sectors TableThis script generates an interactive and customizable SPDR Sectors Table designed to monitor and analyze the performance of the 11 main sectors of the S&P 500 via sector-specific ETFs. It offers a dynamic overview of daily or periodic sector movements, making it a valuable tool for traders, analysts, and investors implementing sector rotation strategies.
█ DEFINITIONS
SPDR Sectors ETFs are exchange-traded funds managed by State Street Global Advisors, which divide the S&P 500 into the following 11 sectors:
- Communication Services (XLC)
- Consumer Discretionary (XLY)
- Consumer Staples (XLP)
- Energy (XLE)
- Financials (XLF)
- Health Care (XLV)
- Industrials (XLI)
- Materials (XLB)
- Real Estate (XLRE)
- Technology (XLK)
- Utilities (XLU)
These ETFs aim to replicate the performance of their respective sectors as defined by the Global Industry Classification Standard (GICS). The funds are periodically rebalanced to match changes in the S&P 500 composition, offering an accurate snapshot of sectoral trends.
█ INDICATOR
The table displays each sector's ticker and full name, following official GICS terminology and SPDR color coding. It also shows percentage performance, calculated daily on intraday charts or based on the selected time frame.
Users can sort the table by either percentage performance or the relative weight of each ETF in the S&P 500. The default weight values reflect data updated as of 17 April 2025, and can be manually adjusted based on the most recent sector weightings available on the official SPDR website.
Z-Score Normalized Volatility IndicesVolatility is one of the most important measures in financial markets, reflecting the extent of variation in asset prices over time. It is commonly viewed as a risk indicator, with higher volatility signifying greater uncertainty and potential for price swings, which can affect investment decisions. Understanding volatility and its dynamics is crucial for risk management and forecasting in both traditional and alternative asset classes.
Z-Score Normalization in Volatility Analysis
The Z-score is a statistical tool that quantifies how many standard deviations a given data point is from the mean of the dataset. It is calculated as:
Z = \frac{X - \mu}{\sigma}
Where X is the value of the data point, \mu is the mean of the dataset, and \sigma is the standard deviation of the dataset. In the context of volatility indices, the Z-score allows for the normalization of these values, enabling their comparison regardless of the original scale. This is particularly useful when analyzing volatility across multiple assets or asset classes.
This script utilizes the Z-score to normalize various volatility indices:
	
1.	VIX (CBOE Volatility Index): A widely used indicator that measures the implied volatility of S&P 500 options. It is considered a barometer of market fear and uncertainty (Whaley, 2000).
	
2.	VIX3M: Represents the 3-month implied volatility of the S&P 500 options, providing insight into medium-term volatility expectations.
	
3.	VIX9D: The implied volatility for a 9-day S&P 500 options contract, which reflects short-term volatility expectations.
	
4.	VVIX: The volatility of the VIX itself, which measures the uncertainty in the expectations of future volatility.
	
5.	VXN: The Nasdaq-100 volatility index, representing implied volatility in the Nasdaq-100 options.
	
6.	RVX: The Russell 2000 volatility index, tracking the implied volatility of options on the Russell 2000 Index.
	
7.	VXD: Volatility for the Dow Jones Industrial Average.
	
8.	MOVE: The implied volatility index for U.S. Treasury bonds, offering insight into expectations for interest rate volatility.
	
9.	BVIX: Volatility of Bitcoin options, a useful indicator for understanding the risk in the cryptocurrency market.
	
10.	GVZ: Volatility index for gold futures, reflecting the risk perception of gold prices.
	
11.	OVX: Measures implied volatility for crude oil futures.
Volatility Clustering and Z-Score
The concept of volatility clustering—where high volatility tends to be followed by more high volatility—is well documented in financial literature. This phenomenon is fundamental in volatility modeling and highlights the persistence of periods of heightened market uncertainty (Bollerslev, 1986).
Moreover, studies by Andersen et al. (2012) explore how implied volatility indices, like the VIX, serve as predictors for future realized volatility, underlining the relationship between expected volatility and actual market behavior. The Z-score normalization process helps in making volatility data comparable across different asset classes, enabling more effective decision-making in volatility-based strategies.
Applications in Trading and Risk Management
By using Z-score normalization, traders can more easily assess deviations from the mean in volatility, helping to identify periods when volatility is unusually high or low. This can be used to adjust risk exposure or to implement volatility-based trading strategies, such as mean reversion strategies. Research suggests that volatility mean-reversion is a reliable pattern that can be exploited for profit (Christensen & Prabhala, 1998).
References:
	
•	Andersen, T. G., Bollerslev, T., Diebold, F. X., & Vega, C. (2012). Realized volatility and correlation dynamics: A long-run approach. Journal of Financial Economics, 104(3), 385-406.
	
•	Bollerslev, T. (1986). Generalized autoregressive conditional heteroskedasticity. Journal of Econometrics, 31(3), 307-327.
	
•	Christensen, B. J., & Prabhala, N. R. (1998). The relation between implied and realized volatility. Journal of Financial Economics, 50(2), 125-150.
	
•	Whaley, R. E. (2000). Derivatives on market volatility and the VIX index. Journal of Derivatives, 8(1), 71-84.
ZigZag█ Overview 
This Pine Script™ library provides a comprehensive implementation of the ZigZag indicator using advanced object-oriented programming techniques. It serves as a developer resource rather than a standalone indicator, enabling Pine Script™ programmers to incorporate sophisticated ZigZag calculations into their own scripts.
Pine Script™ libraries contain reusable code that can be imported into indicators, strategies, and other libraries. For more information, consult the Libraries section of the Pine Script™ User Manual.
 █ About the Original 
This library is based on  TradingView's official ZigZag implementation .
The original code provides a solid foundation with user-defined types and methods for calculating ZigZag pivot points.
 █ What is ZigZag? 
The ZigZag indicator filters out minor price movements to highlight significant market trends.
It works by:
1. Identifying significant pivot points (local highs and lows)
2. Connecting these points with straight lines
3. Ignoring smaller price movements that fall below a specified threshold
Traders typically use ZigZag for:
- Trend confirmation
- Identifying support and resistance levels
- Pattern recognition (such as Elliott Waves)
- Filtering out market noise
The algorithm identifies pivot points by analyzing price action over a specified number of bars, then only changes direction when price movement exceeds a user-defined percentage threshold.
 █ My Enhancements 
This modified version extends the original library with several key improvements:
1. Support and Resistance Visualization
   - Adds horizontal lines at pivot points
   - Customizable line length (offset from pivot)
   - Adjustable line width and color
   - Option to extend lines to the right edge of the chart
2. Support and Resistance Zones
   - Creates semi-transparent zone areas around pivot points
   - Customizable width for better visibility of important price levels
   - Separate colors for support (lows) and resistance (highs)
   - Visual representation of price areas rather than just single lines
3. Zig Zag Lines
   - Separate colors for upward and downward ZigZag movements
   - Visually distinguishes between bullish and bearish price swings
   - Customizable colors for text
   - Width customization
4. Enhanced Settings Structure
   - Added new fields to the Settings type to support the additional features
   - Extended Pivot type with supportResistance and supportResistanceZone fields
   - Comprehensive configuration options for visual elements
These enhancements make the ZigZag more useful for technical analysis by clearly highlighting support/resistance levels and zones, and providing clearer visual cues about market direction.
█ Technical Implementation
This library leverages Pine Script™'s user-defined types (UDTs) to create a robust object-oriented architecture:
-  Settings : Stores configuration parameters for calculation and display
-  Pivot : Represents pivot points with their visual elements and properties
-  ZigZag : Manages the overall state and behavior of the indicator
The implementation follows best practices from the Pine Script™ User Manual's Style Guide and uses advanced language features like methods and object references. These UDTs represent Pine Script™'s most advanced feature set, enabling sophisticated data structures and improved code organization.
For newcomers to Pine Script™, it's recommended to understand the language fundamentals before working with the UDT implementation in this library.
 █ Usage Example 
 
//@version=6
indicator("ZigZag Example", overlay = true, shorttitle = 'ZZA', max_bars_back = 5000, max_lines_count = 500, max_labels_count = 500, max_boxes_count = 500)
import andre_007/ZigZag/1 as ZIG
var group_1 = "ZigZag Settings"
//@variable Draw Zig Zag on the chart.
bool showZigZag = input.bool(true, "Show Zig-Zag Lines", group = group_1, tooltip = "If checked, the Zig Zag will be drawn on the chart.", inline = "1")
// @variable The deviation percentage from the last local high or low required to form a new Zig Zag point.
float deviationInput = input.float(5.0, "Deviation (%)", minval = 0.00001, maxval = 100.0,
  tooltip = "The minimum percentage deviation from a previous pivot point required to change the Zig Zag's direction.", group = group_1, inline = "2")
// @variable The number of bars required for pivot detection.
int depthInput = input.int(10, "Depth", minval = 1, tooltip = "The number of bars required for pivot point detection.", group = group_1, inline = "3")
// @variable registerPivot (series bool) Optional. If `true`, the function compares a detected pivot 
// point's coordinates to the latest `Pivot` object's `end` chart point, then 
// updates the latest `Pivot` instance or adds a new instance to the `ZigZag` 
// object's `pivots` array. If `false`, it does not modify the `ZigZag` object's 
// data. The default is `true`. 
bool allowZigZagOnOneBarInput = input.bool(true, "Allow Zig Zag on One Bar", tooltip = "If checked, the Zig Zag calculation can register a pivot high and pivot low on the same bar.",
  group = group_1, inline = "allowZigZagOnOneBar")
var group_2 = "Display Settings"
// @variable The color of the Zig Zag's lines (up).
color lineColorUpInput = input.color(color.green, "Line Colors for Up/Down", group = group_2, inline = "4")
// @variable The color of the Zig Zag's lines (down).
color lineColorDownInput = input.color(color.red, "", group = group_2, inline = "4",
  tooltip = "The color of the Zig Zag's lines")
// @variable The width of the Zig Zag's lines.
int lineWidthInput = input.int(1, "Line Width", minval = 1, tooltip = "The width of the Zig Zag's lines.", group = group_2, inline = "w")
// @variable If `true`, the Zig Zag will also display a line connecting the last known pivot to the current `close`.
bool extendInput = input.bool(true, "Extend to Last Bar", tooltip = "If checked, the last pivot will be connected to the current close.",
  group = group_1, inline = "5")
// @variable If `true`, the pivot labels will display their price values.
bool showPriceInput = input.bool(true, "Display Reversal Price", 
  tooltip = "If checked, the pivot labels will display their price values.", group = group_2, inline = "6")
// @variable If `true`, each pivot label will display the volume accumulated since the previous pivot.
bool showVolInput = input.bool(true, "Display Cumulative Volume",
  tooltip = "If checked, the pivot labels will display the volume accumulated since the previous pivot.", group = group_2, inline = "7")
// @variable If `true`, each pivot label will display the change in price from the previous pivot.
bool showChgInput = input.bool(true, "Display Reversal Price Change", 
  tooltip = "If checked, the pivot labels will display the change in price from the previous pivot.", group = group_2, inline = "8")
// @variable Controls whether the labels show price changes as raw values or percentages when `showChgInput` is `true`.
string priceDiffInput = input.string("Absolute", "", options =  ,  
  tooltip = "Controls whether the labels show price changes as raw values or percentages when 'Display Reversal Price Change' is checked.",
  group = group_2, inline = "8")
// @variable If `true`, the Zig Zag will display support and resistance lines.
bool showSupportResistanceInput = input.bool(true, "Show Support/Resistance Lines",
  tooltip = "If checked, the Zig Zag will display support and resistance lines.", group = group_2, inline = "9")
// @variable The number of bars to extend the support and resistance lines from the last pivot point.
int supportResistanceOffsetInput = input.int(50, "Support/Resistance Offset", minval = 0, 
  tooltip = "The number of bars to extend the support and resistance lines from the last pivot point.", group = group_2, inline = "10")
// @variable The width of the support and resistance lines.
int supportResistanceWidthInput = input.int(1, "Support/Resistance Width", minval = 1, 
  tooltip = "The width of the support and resistance lines.", group = group_2, inline = "11")
// @variable The color of the support lines.
color supportColorInput = input.color(color.red, "Support/Resistance Color", group = group_2, inline = "12")
// @variable The color of the resistance lines.
color resistanceColorInput = input.color(color.green, "", group = group_2, inline = "12",
  tooltip = "The color of the support/resistance lines.")
// @variable If `true`, the support and resistance lines will be drawn as zones.
bool showSupportResistanceZoneInput = input.bool(true, "Show Support/Resistance Zones",
  tooltip = "If checked, the support and resistance lines will be drawn as zones.", group = group_2, inline = "12-1")
// @variable The color of the support zones.
color supportZoneColorInput = input.color(color.new(color.red, 70), "Support Zone Color", group = group_2, inline = "12-2")
// @variable The color of the resistance zones.
color resistanceZoneColorInput = input.color(color.new(color.green, 70), "", group = group_2, inline = "12-2",
  tooltip = "The color of the support/resistance zones.")
// @variable The width of the support and resistance zones.
int supportResistanceZoneWidthInput = input.int(10, "Support/Resistance Zone Width", minval = 1, 
  tooltip = "The width of the support and resistance zones.", group = group_2, inline = "12-3")
// @variable If `true`, the support and resistance lines will extend to the right of the chart.
bool supportResistanceExtendInput = input.bool(false, "Extend to Right",
  tooltip = "If checked, the lines will extend to the right of the chart.", group = group_2, inline = "13")
// @variable References a `Settings` instance that defines the `ZigZag` object's calculation and display properties.
var ZIG.Settings settings = 
 ZIG.Settings.new(
     devThreshold               = deviationInput,
     depth                      = depthInput,
     lineColorUp                = lineColorUpInput,
     lineColorDown              = lineColorDownInput,
     textUpColor                = lineColorUpInput,
     textDownColor              = lineColorDownInput,
     lineWidth                  = lineWidthInput,
     extendLast                 = extendInput,
     displayReversalPrice       = showPriceInput,
     displayCumulativeVolume    = showVolInput,
     displayReversalPriceChange = showChgInput,
     differencePriceMode        = priceDiffInput,
     draw                       = showZigZag,
     allowZigZagOnOneBar        = allowZigZagOnOneBarInput,
     drawSupportResistance      = showSupportResistanceInput,
     supportResistanceOffset    = supportResistanceOffsetInput,
     supportResistanceWidth     = supportResistanceWidthInput,
     supportColor               = supportColorInput,
     resistanceColor            = resistanceColorInput,
     supportResistanceExtend    = supportResistanceExtendInput,
     supportResistanceZoneWidth = supportResistanceZoneWidthInput,
     drawSupportResistanceZone  = showSupportResistanceZoneInput,
     supportZoneColor           = supportZoneColorInput,
     resistanceZoneColor        = resistanceZoneColorInput     
 )
// @variable References a `ZigZag` object created using the `settings`.
var ZIG.ZigZag zigZag = ZIG.newInstance(settings)
// Update the `zigZag` on every bar.
zigZag.update()
//#endregion
 
The example code demonstrates how to create a ZigZag indicator with customizable settings. It:
1. Creates a Settings object with user-defined parameters
2. Instantiates a ZigZag object using these settings
3. Updates the ZigZag on each bar to detect new pivot points
4. Automatically draws lines and labels when pivots are detected
This approach provides maximum flexibility while maintaining readability and ease of use.
Money Flow Divergence IndicatorOverview 
The Money Flow Divergence Indicator is designed to help traders and investors identify key macroeconomic turning points by analyzing the relationship between U.S. M2 money supply growth and the S&P 500 Index (SPX). By comparing these two crucial economic indicators, the script highlights periods where market liquidity is outpacing or lagging behind stock market growth, offering potential buy and sell signals based on macroeconomic trends.
 How It Works 
 1. Data Sources 
 
 S&P 500 Index (SPX500USD): Tracks the stock market performance.
 U.S. M2 Money Supply (M2SL - Federal Reserve Economic Data): Represents available liquidity in the economy.
 
 2. Growth Rate Calculation 
 
 SPX Growth: Percentage change in the S&P 500 index over time.
 M2 Growth: Percentage change in M2 money supply over time.
 Growth Gap (Delta): The difference between M2 growth and SPX growth, showing whether liquidity is fueling or lagging behind market performance.
 
 3. Visualization 
 
 A histogram displays the growth gap over time:
       Green Bars: M2 growth exceeds SPX growth (potential bullish signal).
       Red Bars: SPX growth exceeds M2 growth (potential bearish signal).
 A zero line helps distinguish between positive and negative growth gaps.
 
 How to Use It 
✅ Bullish Signal: When green bars appear consistently, indicating that liquidity is outpacing stock market growth. This suggests a favorable environment for buying or holding positions.
❌ Bearish Signal: When red bars appear consistently, meaning stock market growth outpaces liquidity expansion, signaling potential overvaluation or a market correction.
 Best Timeframes for Analysis 
This indicator works best on monthly timeframes (M) since it is designed for long-term investors and macro traders who focus on broad economic cycles.
 Who Should Use This Indicator? 
📈 Long-term investors looking for macroeconomic trends.
📊 Swing traders who incorporate liquidity analysis in their strategies.
💰 Portfolio managers assessing market liquidity conditions.
🚀 Use this indicator to stay ahead of market trends and make informed investment decisions based on macroeconomic liquidity shifts! 🚀
real_time_candlesIntroduction 
The Real-Time Candles Library provides comprehensive tools for creating, manipulating, and visualizing custom timeframe candles in Pine Script. Unlike standard indicators that only update at bar close, this library enables real-time visualization of price action and indicators within the current bar, offering traders unprecedented insight into market dynamics as they unfold.
This library addresses a fundamental limitation in traditional technical analysis: the inability to see how indicators evolve between bar closes. By implementing sophisticated real-time data processing techniques, traders can now observe indicator movements, divergences, and trend changes as they develop, potentially identifying trading opportunities much earlier than with conventional approaches.
 Key Features 
The library supports two primary candle generation approaches:
 
 Chart-Time Candles: Generate real-time OHLC data for any variable (like RSI, MACD, etc.) while maintaining synchronization with chart bars.
 Custom Timeframe (CTF) Candles: Create candles with custom time intervals or tick counts completely independent of the chart's native timeframe.
 
Both approaches support traditional candlestick and Heikin-Ashi visualization styles, with options for moving average overlays to smooth the data.
 Configuration Requirements 
For optimal performance with this library:
 
 Set max_bars_back = 5000 in your script settings
 When using CTF drawing functions, set max_lines_count = 500, max_boxes_count = 500, and max_labels_count = 500
 
These settings ensure that you will be able to draw correctly and will avoid any runtime errors.
 Usage Examples
Basic Chart-Time Candle Visualization 
 // Create real-time candles for RSI
float rsi = ta.rsi(close, 14)
Candle rsi_candle = candle_series(rsi, CandleType.candlestick)
// Plot the candles using Pine's built-in function
plotcandle(rsi_candle.Open, rsi_candle.High, rsi_candle.Low, rsi_candle.Close, 
          "RSI Candles", rsi_candle.candle_color, rsi_candle.candle_color) 
 Multiple Access Patterns 
The library provides three ways to access candle data, accommodating different programming styles:
 // 1. Array-based access for collection operations
Candle  candles = candle_array(source)
// 2. Object-oriented access for single entity manipulation
Candle candle = candle_series(source)
float value = candle.source(Source.HLC3)
// 3. Tuple-based access for functional programming styles
  = candle_tuple(source) 
 Custom Timeframe Examples 
 // Create 20-second candles with EMA overlay
plot_ctf_candles(
    source = close,
    candle_type = CandleType.candlestick,
    sample_type = SampleType.Time,
    number_of_seconds = 20,
    timezone = -5,
    tied_open = true,
    ema_period = 9,
    enable_ema = true
)
// Create tick-based candles (new candle every 15 ticks)
plot_ctf_tick_candles(
    source = close,
    candle_type = CandleType.heikin_ashi,
    number_of_ticks = 15,
    timezone = -5,
    tied_open = true
) 
 Advanced Usage with Custom Visualization 
 // Get custom timeframe candles without automatic plotting
CandleCTF  my_candles = ctf_candles_array(
    source = close,
    candle_type = CandleType.candlestick,
    sample_type = SampleType.Time,
    number_of_seconds = 30
)
// Apply custom logic to the candles
float  ema_values = my_candles.ctf_ema(14)
// Draw candles and EMA using time-based coordinates
my_candles.draw_ctf_candles_time()
ema_values.draw_ctf_line_time(line_color = #FF6D00) 
 Library Components 
 Data Types 
 
 Candle:  Structure representing chart-time candles with OHLC, polarity, and visualization properties
 CandleCTF:  Extended candle structure with additional time metadata for custom timeframes
 TickData:  Structure for individual price updates with time deltas
 
 Enumerations 
 
 CandleType:  Specifies visualization style (candlestick or Heikin-Ashi)
 Source:  Defines price components for calculations (Open, High, Low, Close, HL2, etc.)
 SampleType:  Sets sampling method (Time-based or Tick-based)
 
 Core Functions 
 
 get_tick():  Captures current price as a tick data point
 candle_array():  Creates an array of candles from price updates
 candle_series():  Provides a single candle based on latest data
 candle_tuple():  Returns OHLC values as a tuple
 ctf_candles_array():  Creates custom timeframe candles without rendering
 
 Visualization Functions 
 
 source():  Extracts specific price components from candles
 candle_ctf_to_float():  Converts candle data to float arrays
 ctf_ema():  Calculates exponential moving averages for candle arrays
 draw_ctf_candles_time():  Renders candles using time coordinates
 draw_ctf_candles_index():  Renders candles using bar index coordinates
 draw_ctf_line_time():  Renders lines using time coordinates
 draw_ctf_line_index():  Renders lines using bar index coordinates
 
 Technical Implementation Notes 
This library leverages Pine Script's  varip  variables for state management, creating a sophisticated real-time data processing system. The implementation includes:
 
 Efficient tick capturing:  Samples price at every execution, maintaining temporal tracking with time deltas
 Smart state management:  Uses a hybrid approach with mutable updates at index 0 and historical preservation at index 1+
 Temporal synchronization:  Manages two time domains (chart time and custom timeframe)
 
The tooltip implementation provides crucial temporal context for custom timeframe visualizations, allowing users to understand exactly when each candle formed regardless of chart timeframe.
 Limitations 
 
 Custom timeframe candles cannot be backtested due to Pine Script's limitations with historical tick data
 Real-time visualization is only available during live chart updates
 Maximum history is constrained by Pine Script's array size limits
 
 Applications 
 
 Indicator visualization:  See how RSI, MACD, or other indicators evolve in real-time
 Volume analysis:  Create custom volume profiles independent of chart timeframe
 Scalping strategies:  Identify short-term patterns with precisely defined time windows
 Volatility measurement:  Track price movement characteristics within bars
 Custom signal generation:  Create entry/exit signals based on custom timeframe patterns
 
 Conclusion 
The Real-Time Candles Library bridges the gap between traditional technical analysis (based on discrete OHLC bars) and the continuous nature of market movement. By making indicators more responsive to real-time price action, it gives traders a significant edge in timing and decision-making, particularly in fast-moving markets where waiting for bar close could mean missing important opportunities.
Whether you're building custom indicators, researching price patterns, or developing trading strategies, this library provides the foundation for sophisticated real-time analysis in Pine Script.
 Implementation Details & Advanced Guide 
 Core Implementation Concepts 
The Real-Time Candles Library implements a sophisticated event-driven architecture within Pine Script's constraints. At its heart, the library creates what's essentially a reactive programming framework handling continuous data streams.
 Tick Processing System 
The foundation of the library is the get_tick() function, which captures price updates as they occur:
 export get_tick(series float source = close, series float na_replace = na)=>
    varip float price = na
    varip int series_index = -1
    varip int old_time = 0
    varip int new_time = na
    varip float time_delta = 0
    // ... 
This function:
 
 Samples the current price
 Calculates time elapsed since last update
 Maintains a sequential index to track updates
 
The resulting  TickData  structure serves as the fundamental building block for all candle generation.
 State Management Architecture 
The library employs a sophisticated state management system using  varip  variables, which persist across executions within the same bar. This creates a hybrid programming paradigm that's different from standard Pine Script's bar-by-bar model.
For chart-time candles, the core state transition logic is:
 // Real-time update of current candle
candle_data := Candle.new(Open, High, Low, Close, polarity, series_index, candle_color)
candles.set(0, candle_data)
// When a new bar starts, preserve the previous candle
if clear_state
    candles.insert(1, candle_data)
    price.clear()
    // Reset state for new candle
    Open := Close
    price.push(Open)
    series_index += 1 
This pattern of updating index 0 in real-time while inserting completed candles at index 1 creates an elegant solution for maintaining both current state and historical data.
 Custom Timeframe Implementation 
The custom timeframe system manages its own time boundaries independent of chart bars:
 bool clear_state = switch settings.sample_type
    SampleType.Ticks => cumulative_series_idx >= settings.number_of_ticks
    SampleType.Time => cumulative_time_delta >= settings.number_of_seconds 
This dual-clock system synchronizes two time domains:
 
 Pine's execution clock (bar-by-bar processing)
 The custom timeframe clock (tick or time-based)
 
The library carefully handles temporal discontinuities, ensuring candle formation remains accurate despite irregular tick arrival or market gaps.
 Advanced Usage Techniques 
 1. Creating Custom Indicators with Real-Time Candles 
To develop indicators that process real-time data within the current bar:
 // Get real-time candles for your data
Candle  rsi_candles = candle_array(ta.rsi(close, 14))
// Calculate indicator values based on candle properties
float signal = ta.ema(rsi_candles.first().source(Source.Close), 9)
// Detect patterns that occur within the bar
bool divergence = close > close  and rsi_candles.first().Close < rsi_candles.get(1).Close 
 2. Working with Custom Timeframes and Plotting 
For maximum flexibility when visualizing custom timeframe data:
 // Create custom timeframe candles
CandleCTF  volume_candles = ctf_candles_array(
    source = volume, 
    candle_type = CandleType.candlestick,
    sample_type = SampleType.Time,
    number_of_seconds = 60
)
// Convert specific candle properties to float arrays
float  volume_closes = volume_candles.candle_ctf_to_float(Source.Close)
// Calculate derived values
float  volume_ema = volume_candles.ctf_ema(14)
// Create custom visualization
volume_candles.draw_ctf_candles_time()
volume_ema.draw_ctf_line_time(line_color = color.orange) 
 3. Creating Hybrid Timeframe Analysis 
One powerful application is comparing indicators across multiple timeframes:
 // Standard chart timeframe RSI
float chart_rsi = ta.rsi(close, 14)
// Custom 5-second timeframe RSI
CandleCTF  ctf_candles = ctf_candles_array(
    source = close,
    candle_type = CandleType.candlestick,
    sample_type = SampleType.Time,
    number_of_seconds = 5
)
float  fast_rsi_array = ctf_candles.candle_ctf_to_float(Source.Close)
float fast_rsi = fast_rsi_array.first()
// Generate signals based on divergence between timeframes
bool entry_signal = chart_rsi < 30 and fast_rsi > fast_rsi_array.get(1) 
 Final Notes 
This library represents an advanced implementation of real-time data processing within Pine Script's constraints. By creating a reactive programming framework for handling continuous data streams, it enables sophisticated analysis typically only available in dedicated trading platforms.
The design principles employed—including state management, temporal processing, and object-oriented architecture—can serve as patterns for other advanced Pine Script development beyond this specific application.
------------------------
Library   "real_time_candles" 
A comprehensive library for creating real-time candles with customizable timeframes and sampling methods.
Supports both chart-time and custom-time candles with options for candlestick and Heikin-Ashi visualization.
Allows for tick-based or time-based sampling with moving average overlay capabilities.
 get_tick(source, na_replace) 
  Captures the current price as a tick data point
  Parameters:
     source (float) : Optional - Price source to sample (defaults to close)
     na_replace (float) : Optional - Value to use when source is na
  Returns: TickData structure containing price, time since last update, and sequential index
 candle_array(source, candle_type, sync_start, bullish_color, bearish_color) 
  Creates an array of candles based on price updates
  Parameters:
     source (float) : Optional - Price source to sample (defaults to close)
     candle_type (simple CandleType) : Optional - Type of candle chart to create (candlestick or Heikin-Ashi)
     sync_start (simple bool) : Optional - Whether to synchronize with the start of a new bar
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
  Returns: Array of Candle objects ordered with most recent at index 0
 candle_series(source, candle_type, wait_for_sync, bullish_color, bearish_color) 
  Provides a single candle based on the latest price data
  Parameters:
     source (float) : Optional - Price source to sample (defaults to close)
     candle_type (simple CandleType) : Optional - Type of candle chart to create (candlestick or Heikin-Ashi)
     wait_for_sync (simple bool) : Optional - Whether to wait for a new bar before starting
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
  Returns: A single Candle object representing the current state
 candle_tuple(source, candle_type, wait_for_sync, bullish_color, bearish_color) 
  Provides candle data as a tuple of OHLC values
  Parameters:
     source (float) : Optional - Price source to sample (defaults to close)
     candle_type (simple CandleType) : Optional - Type of candle chart to create (candlestick or Heikin-Ashi)
     wait_for_sync (simple bool) : Optional - Whether to wait for a new bar before starting
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
  Returns: Tuple   representing current candle values
 method source(self, source, na_replace) 
  Extracts a specific price component from a Candle
  Namespace types: Candle
  Parameters:
     self (Candle) 
     source (series Source) : Type of price data to extract (Open, High, Low, Close, or composite values)
     na_replace (float) : Optional - Value to use when source value is na
  Returns: The requested price value from the candle
 method source(self, source) 
  Extracts a specific price component from a CandleCTF
  Namespace types: CandleCTF
  Parameters:
     self (CandleCTF) 
     source (simple Source) : Type of price data to extract (Open, High, Low, Close, or composite values)
  Returns: The requested price value from the candle as a varip
 method candle_ctf_to_float(self, source) 
  Converts a specific price component from each CandleCTF to a float array
  Namespace types: array
  Parameters:
     self (array) 
     source (simple Source) : Optional - Type of price data to extract (defaults to Close)
  Returns: Array of float values extracted from the candles, ordered with most recent at index 0
 method ctf_ema(self, ema_period) 
  Calculates an Exponential Moving Average for a CandleCTF array
  Namespace types: array
  Parameters:
     self (array) 
     ema_period (simple float) : Period for the EMA calculation
  Returns: Array of float values representing the EMA of the candle data, ordered with most recent at index 0
 method draw_ctf_candles_time(self, sample_type, number_of_ticks, number_of_seconds, timezone) 
  Renders custom timeframe candles using bar time coordinates
  Namespace types: array
  Parameters:
     self (array) 
     sample_type (simple SampleType) : Optional - Method for sampling data (Time or Ticks), used for tooltips
     number_of_ticks (simple int) : Optional - Number of ticks per candle (used when sample_type is Ticks), used for tooltips
     number_of_seconds (simple float) : Optional - Time duration per candle in seconds (used when sample_type is Time), used for tooltips
     timezone (simple int) : Optional - Timezone offset from UTC (-12 to +12), used for tooltips
  Returns: void - Renders candles on the chart using time-based x-coordinates
 method draw_ctf_candles_index(self, sample_type, number_of_ticks, number_of_seconds, timezone) 
  Renders custom timeframe candles using bar index coordinates
  Namespace types: array
  Parameters:
     self (array) 
     sample_type (simple SampleType) : Optional - Method for sampling data (Time or Ticks), used for tooltips
     number_of_ticks (simple int) : Optional - Number of ticks per candle (used when sample_type is Ticks), used for tooltips
     number_of_seconds (simple float) : Optional - Time duration per candle in seconds (used when sample_type is Time), used for tooltips
     timezone (simple int) : Optional - Timezone offset from UTC (-12 to +12), used for tooltips
  Returns: void - Renders candles on the chart using index-based x-coordinates
 method draw_ctf_line_time(self, source, line_size, line_color) 
  Renders a line representing a price component from the candles using time coordinates
  Namespace types: array
  Parameters:
     self (array) 
     source (simple Source) : Optional - Type of price data to extract (defaults to Close)
     line_size (simple int) : Optional - Width of the line
     line_color (simple color) : Optional - Color of the line
  Returns: void - Renders a connected line on the chart using time-based x-coordinates
 method draw_ctf_line_time(self, line_size, line_color) 
  Renders a line from a varip float array using time coordinates
  Namespace types: array
  Parameters:
     self (array) 
     line_size (simple int) : Optional - Width of the line, defaults to 2
     line_color (simple color) : Optional - Color of the line
  Returns: void - Renders a connected line on the chart using time-based x-coordinates
 method draw_ctf_line_index(self, source, line_size, line_color) 
  Renders a line representing a price component from the candles using index coordinates
  Namespace types: array
  Parameters:
     self (array) 
     source (simple Source) : Optional - Type of price data to extract (defaults to Close)
     line_size (simple int) : Optional - Width of the line
     line_color (simple color) : Optional - Color of the line
  Returns: void - Renders a connected line on the chart using index-based x-coordinates
 method draw_ctf_line_index(self, line_size, line_color) 
  Renders a line from a varip float array using index coordinates
  Namespace types: array
  Parameters:
     self (array) 
     line_size (simple int) : Optional - Width of the line, defaults to 2
     line_color (simple color) : Optional - Color of the line
  Returns: void - Renders a connected line on the chart using index-based x-coordinates
 plot_ctf_tick_candles(source, candle_type, number_of_ticks, timezone, tied_open, ema_period, bullish_color, bearish_color, line_width, ema_color, use_time_indexing) 
  Plots tick-based candles with moving average
  Parameters:
     source (float) : Input price source to sample
     candle_type (simple CandleType) : Type of candle chart to display
     number_of_ticks (simple int) : Number of ticks per candle
     timezone (simple int) : Timezone offset from UTC (-12 to +12)
     tied_open (simple bool) : Whether to tie open price to close of previous candle
     ema_period (simple float) : Period for the exponential moving average
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
     line_width (simple int) : Optional - Width of the moving average line, defaults to 2
     ema_color (color) : Optional - Color of the moving average line
     use_time_indexing (simple bool) : Optional - When true the function will plot with xloc.time, when false it will plot using xloc.bar_index
  Returns: void - Creates visual candle chart with EMA overlay
 plot_ctf_tick_candles(source, candle_type, number_of_ticks, timezone, tied_open, bullish_color, bearish_color, use_time_indexing) 
  Plots tick-based candles without moving average
  Parameters:
     source (float) : Input price source to sample
     candle_type (simple CandleType) : Type of candle chart to display
     number_of_ticks (simple int) : Number of ticks per candle
     timezone (simple int) : Timezone offset from UTC (-12 to +12)
     tied_open (simple bool) : Whether to tie open price to close of previous candle
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
     use_time_indexing (simple bool) : Optional - When true the function will plot with xloc.time, when false it will plot using xloc.bar_index
  Returns: void - Creates visual candle chart without moving average
 plot_ctf_time_candles(source, candle_type, number_of_seconds, timezone, tied_open, ema_period, bullish_color, bearish_color, line_width, ema_color, use_time_indexing) 
  Plots time-based candles with moving average
  Parameters:
     source (float) : Input price source to sample
     candle_type (simple CandleType) : Type of candle chart to display
     number_of_seconds (simple float) : Time duration per candle in seconds
     timezone (simple int) : Timezone offset from UTC (-12 to +12)
     tied_open (simple bool) : Whether to tie open price to close of previous candle
     ema_period (simple float) : Period for the exponential moving average
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
     line_width (simple int) : Optional - Width of the moving average line, defaults to 2
     ema_color (color) : Optional - Color of the moving average line
     use_time_indexing (simple bool) : Optional - When true the function will plot with xloc.time, when false it will plot using xloc.bar_index
  Returns: void - Creates visual candle chart with EMA overlay
 plot_ctf_time_candles(source, candle_type, number_of_seconds, timezone, tied_open, bullish_color, bearish_color, use_time_indexing) 
  Plots time-based candles without moving average
  Parameters:
     source (float) : Input price source to sample
     candle_type (simple CandleType) : Type of candle chart to display
     number_of_seconds (simple float) : Time duration per candle in seconds
     timezone (simple int) : Timezone offset from UTC (-12 to +12)
     tied_open (simple bool) : Whether to tie open price to close of previous candle
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
     use_time_indexing (simple bool) : Optional - When true the function will plot with xloc.time, when false it will plot using xloc.bar_index
  Returns: void - Creates visual candle chart without moving average
 plot_ctf_candles(source, candle_type, sample_type, number_of_ticks, number_of_seconds, timezone, tied_open, ema_period, bullish_color, bearish_color, enable_ema, line_width, ema_color, use_time_indexing) 
  Unified function for plotting candles with comprehensive options
  Parameters:
     source (float) : Input price source to sample
     candle_type (simple CandleType) : Optional - Type of candle chart to display
     sample_type (simple SampleType) : Optional - Method for sampling data (Time or Ticks)
     number_of_ticks (simple int) : Optional - Number of ticks per candle (used when sample_type is Ticks)
     number_of_seconds (simple float) : Optional - Time duration per candle in seconds (used when sample_type is Time)
     timezone (simple int) : Optional - Timezone offset from UTC (-12 to +12)
     tied_open (simple bool) : Optional - Whether to tie open price to close of previous candle
     ema_period (simple float) : Optional - Period for the exponential moving average
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
     enable_ema (bool) : Optional - Whether to display the EMA overlay
     line_width (simple int) : Optional - Width of the moving average line, defaults to 2
     ema_color (color) : Optional - Color of the moving average line
     use_time_indexing (simple bool) : Optional - When true the function will plot with xloc.time, when false it will plot using xloc.bar_index
  Returns: void - Creates visual candle chart with optional EMA overlay
 ctf_candles_array(source, candle_type, sample_type, number_of_ticks, number_of_seconds, tied_open, bullish_color, bearish_color) 
  Creates an array of custom timeframe candles without rendering them
  Parameters:
     source (float) : Input price source to sample
     candle_type (simple CandleType) : Type of candle chart to create (candlestick or Heikin-Ashi)
     sample_type (simple SampleType) : Method for sampling data (Time or Ticks)
     number_of_ticks (simple int) : Optional - Number of ticks per candle (used when sample_type is Ticks)
     number_of_seconds (simple float) : Optional - Time duration per candle in seconds (used when sample_type is Time)
     tied_open (simple bool) : Optional - Whether to tie open price to close of previous candle
     bullish_color (color) : Optional - Color for bullish candles
     bearish_color (color) : Optional - Color for bearish candles
  Returns: Array of CandleCTF objects ordered with most recent at index 0
 Candle 
  Structure representing a complete candle with price data and display properties
  Fields:
     Open (series float) : Opening price of the candle
     High (series float) : Highest price of the candle
     Low (series float) : Lowest price of the candle
     Close (series float) : Closing price of the candle
     polarity (series bool) : Boolean indicating if candle is bullish (true) or bearish (false)
     series_index (series int) : Sequential index identifying the candle in the series
     candle_color (series color) : Color to use when rendering the candle
     ready (series bool) : Boolean indicating if candle data is valid and ready for use
 TickData 
  Structure for storing individual price updates
  Fields:
     price (series float) : The price value at this tick
     time_delta (series float) : Time elapsed since the previous tick in milliseconds
     series_index (series int) : Sequential index identifying this tick
 CandleCTF 
  Structure representing a custom timeframe candle with additional time metadata
  Fields:
     Open (series float) : Opening price of the candle
     High (series float) : Highest price of the candle
     Low (series float) : Lowest price of the candle
     Close (series float) : Closing price of the candle
     polarity (series bool) : Boolean indicating if candle is bullish (true) or bearish (false)
     series_index (series int) : Sequential index identifying the candle in the series
     open_time (series int) : Timestamp marking when the candle was opened (in Unix time)
     time_delta (series float) : Duration of the candle in milliseconds
     candle_color (series color) : Color to use when rendering the candle
Mogwai Method with RSI and EMA - BTCUSD 15mThis is a custom TradingView indicator designed for trading Bitcoin (BTCUSD) on a 15-minute timeframe. It’s based on the Mogwai Method—a mean-reversion strategy—enhanced with the Relative Strength Index (RSI) for momentum confirmation. The indicator generates buy and sell signals, visualized as green and red triangle arrows on the chart, to help identify potential entry and exit points in the volatile cryptocurrency market.
Components
Bollinger Bands (BB):
Purpose: Identifies overextended price movements, signaling potential reversions to the mean.
Parameters: 
Length: 20 periods (standard for mean-reversion).
Multiplier: 2.2 (slightly wider than the default 2.0 to suit BTCUSD’s volatility).
Role: 
Buy signal when price drops below the lower band (oversold).
Sell signal when price rises above the upper band (overbought).
Relative Strength Index (RSI):
Purpose: Confirms momentum to filter out false signals from Bollinger Bands.
Parameters:
Length: 14 periods (classic setting, effective for crypto).
Overbought Level: 70 (price may be overextended upward).
Oversold Level: 30 (price may be overextended downward).
Role: 
Buy signal requires RSI < 30 (oversold).
Sell signal requires RSI > 70 (overbought).
Exponential Moving Averages (EMAs) (Plotted but not currently in signal logic):
Purpose: Provides trend context (included in the script for visualization, optional for signal filtering).
Parameters:
Fast EMA: 9 periods (short-term trend).
Slow EMA: 50 periods (longer-term trend).
Role: Can be re-added to filter signals (e.g., buy only when Fast EMA > Slow EMA).
Signals (Triangles):
Buy Signal: Green upward triangle below the bar when price is below the lower Bollinger Band and RSI is below 30.
Sell Signal: Red downward triangle above the bar when price is above the upper Bollinger Band and RSI is above 70.
How It Works
The indicator combines Bollinger Bands and RSI to spot mean-reversion opportunities:
Buy Condition: Price breaks below the lower Bollinger Band (indicating oversold conditions), and RSI confirms this with a reading below 30.
Sell Condition: Price breaks above the upper Bollinger Band (indicating overbought conditions), and RSI confirms this with a reading above 70.
The strategy assumes that extreme price movements in BTCUSD will often revert to the mean, especially in choppy or ranging markets.
Visual Elements
Green Upward Triangles: Appear below the candlestick to indicate a buy signal.
Red Downward Triangles: Appear above the candlestick to indicate a sell signal.
Bollinger Bands: Gray lines (upper, middle, lower) plotted for reference.
EMAs: Blue (Fast) and Orange (Slow) lines for trend visualization.
How to Use the Indicator
Setup
Open TradingView:
Log into TradingView and select a BTCUSD chart from a supported exchange (e.g., Binance, Coinbase, Bitfinex).
Set Timeframe:
Switch the chart to a 15-minute timeframe (15m).
Add the Indicator:
Open the Pine Editor (bottom panel in TradingView).
Copy and paste the script provided.
Click “Add to Chart” to apply it.
Verify Display:
You should see Bollinger Bands (gray), Fast EMA (blue), Slow EMA (orange), and buy/sell triangles when conditions are met.
Trading Guidelines
Buy Signal (Green Triangle Below Bar):
What It Means: Price is oversold, potentially ready to bounce back toward the Bollinger Band middle line.
Action:
Enter a long position (buy BTCUSD).
Set a take-profit near the middle Bollinger Band (bb_middle) or a resistance level.
Place a stop-loss 1-2% below the entry (or based on ATR, e.g., ta.atr(14) * 2).
Best Context: Works well in ranging markets; avoid during strong downtrends.
Sell Signal (Red Triangle Above Bar):
What It Means: Price is overbought, potentially ready to drop back toward the middle line.
Action:
Enter a short position (sell BTCUSD) or exit a long position.
Set a take-profit near the middle Bollinger Band or a support level.
Place a stop-loss 1-2% above the entry.
Best Context: Effective in ranging markets; avoid during strong uptrends.
Trend Filter (Optional):
To reduce false signals in trending markets, you can modify the script:
Add and ema_fast > ema_slow to the buy condition (only buy in uptrends).
Add and ema_fast < ema_slow to the sell condition (only sell in downtrends).
Check the Fast EMA (blue) vs. Slow EMA (orange) alignment visually.
Tips for BTCUSD on 15-Minute Charts
Volatility: BTCUSD can be erratic. If signals are too frequent, increase bb_mult (e.g., to 2.5) or adjust RSI levels (e.g., 75/25).
Confirmation: Use volume spikes or candlestick patterns (e.g., doji, engulfing) to confirm signals.
Time of Day: Mean-reversion works best during low-volume periods (e.g., Asian session in crypto).
Backtesting: Use TradingView’s Strategy Tester (convert to a strategy by adding entry/exit logic) to evaluate performance with historical BTCUSD data up to March 13, 2025.
Risk Management
Position Size: Risk no more than 1-2% of your account per trade.
Stop Losses: Always use stops to protect against BTCUSD’s sudden moves.
Avoid Overtrading: Wait for clear signals; don’t force trades in choppy or unclear conditions.
Example Scenario
Chart: BTCUSD, 15-minute timeframe.
Buy Signal: Price drops to $58,000, below the lower Bollinger Band, RSI at 28. A green triangle appears.
Action: Buy at $58,000, target $59,000 (middle BB), stop at $57,500.
Sell Signal: Price rises to $60,500, above the upper Bollinger Band, RSI at 72. A red triangle appears.
Action: Sell at $60,500, target $59,500 (middle BB), stop at $61,000.
This indicator is tailored for mean-reversion trading on BTCUSD. Let me know if you’d like to tweak it further (e.g., add filters, alerts, or alternative indicators)!
2xSPYTIPS Strategy by Fra public versionThis is a test strategy with S&P500, open source so everyone can suggest everything, I'm open to any advice.
Rules of the "2xSPYTIPS" Strategy :
This trading strategy is designed to operate on the S&P 500 index and the TIPS ETF. Here’s how it works:  
1. Buy Conditions ("BUY"):  
   - The S&P 500 must be above its **200-day simple moving average (SMA 200)**.  
   - This condition is checked at the **end of each month**.  
2. Position Management:  
   - If leverage is enabled (**2x leverage**), the purchase quantity is increased based on a configurable percentage.  
3. Take Profit:  
   - A **Take Profit** is set at a fixed percentage above the entry price.  
4. Visualization & Alerts:  
   - The **SMA 200** for both S&P 500 and TIPS is plotted on the chart.  
   - A **BUY signal** appears visually and an alert is triggered.  
What This Strategy Does NOT Do
- It does not use a **Stop Loss** or **Trailing Stop**.  
- It does not directly manage position exits except through Take Profit.  
PT Least Squares Moving AveragePT LSMA Multi-Period Indicator 
The  PT Least Squares Moving Average (LSMA) Multi-Period Indicator  is a powerful tool designed for investors who want to track market trends across multiple time horizons in a single, convenient indicator. This indicator calculates the LSMA for four different periods— 25 bars, 50 bars, 450 bars, and 500 bars  providing a comprehensive view of short-term and long-term market movements.  
 Key Features:  
- Multi-Timeframe Trend Analysis: Tracks both short-term (25 & 50 bars) and long-term (450 & 500 bars) market trends, helping investors make informed decisions.  
- Smoothing Capability: The LSMA reduces noise by fitting a linear regression line to past price data, offering a clearer trend direction compared to traditional moving averages.  
- One-Indicator Solution: Combines multiple LSMA periods into a single chart, reducing clutter and enhancing visual clarity.  
- Versatile Applications: Suitable for trend identification, market timing, and spotting potential reversals across different timeframes.  
- Customizable Styling: Allows users to customize colors and line styles for each period to suit their preferences.  
 How to Use: 
1. Short-Term Trends (25 & 50 bars):Ideal for identifying recent price movements and short-term trade opportunities.  
2. Long-Term Trends (450 & 500 bars): Helps investors gauge broader market sentiment and position themselves accordingly for longer holding periods.  
3. Trend Confirmation: When shorter LSMA periods cross above longer ones, it may signal bullish momentum, whereas the opposite may indicate bearish sentiment.  
4. Support and Resistance: The LSMA lines can act as dynamic support and resistance levels during trending markets.  
 Best For:  
- Long-term investors looking to align their positions with dominant market trends.  
- Swing traders seeking confirmation from multiple time horizons.  
- Portfolio managers tracking price momentum across various investment durations.  
This LSMA Multi-Period Indicator equips investors with a well-rounded perspective on price movements, offering a strategic edge in navigating market cycles with confidence.
Created by  Prince Thomas
Master Bitcoin & Litecoin Stock To Flow (S2F) ModelMaster Bitcoin & Litecoin Stock-to-Flow (S2F) Model
This indicator visualizes the Stock-to-Flow (S2F) models for Bitcoin (BTC) and Litecoin (LTC) based on Plan B's methodology. It calculates S2F and projects price models for both assets, incorporating daily changes in circulating supply. The script is designed exclusively for daily timeframes.
Features:
LTC & BTC S2F Models:
Calculates Stock-to-Flow values for both assets using daily new supply and circulating supply data.
Models S2F values with a customizable multiplier for precise adjustments.
500-Day Moving Average Models:
Smoothens the S2F model by applying a 500-day (18-month) moving average, providing a long-term trend perspective.
Customizable Inputs:
Adjust LTC and BTC multipliers to fine-tune the models.
Alert for Timeframe:
Alerts users to switch to the daily timeframe if another period is selected.
Plots:
LTC S2F Model: Blue line representing Litecoin’s calculated S2F-based price model.
BTC S2F Model: Orange line representing Bitcoin’s calculated S2F-based price model.
500-Day Avg Models: Smoothened S2F models for both LTC and BTC.
Notes:
Requires daily timeframe (1D) for accurate calculations.
Supply data is sourced from GLASSNODE:LTC_SUPPLY and GLASSNODE:BTC_SUPPLY.
Disclaimer:
This model is derived from Plan B's S2F methodology and is intended for educational and entertainment purposes only. It does not reflect official predictions or financial advice. Always conduct your own research before making investment decisions.
TICK Charting & DivergencesOverview 
The TICK index measures the number of NYSE stocks making an uptick versus a downtick. This indicator identifies divergences between price action and TICK readings, potentially signaling trend reversals.
 Key Features 
 Real-time TICK monitoring during market hours (9:30 AM - 4:00 PM ET)
 Customizable smoothing factor for TICK values
 Regular and hidden divergences detection
 Reference lines at ±500 and ±1000 levels
 Current TICK value display
 
 TICK Internals Interpretation 
 Above +1000: Strong buying pressure, potential exhaustion
 Above +500: Moderate buying pressure
 Below -500: Moderate selling pressure
 Below -1000: Strong selling pressure, potential exhaustion
 
 Best Practices 
 
 Use in conjunction with support/resistance levels, market trend direction, and time of day.
 Higher probability setups with multiple timeframe confirmation, divergence at key price levels, and extreme TICK readings (±1000).
 
 Settings Optimization 
 
 Smoothing Factor: 1-3 (lower for faster signals)
 Pivot Lookback: 5-10 bars (adjust based on timeframe)
 Range: 5-60 bars (wider for longer-term signals)
 
 Warning Signs 
 
 Multiple failed divergences
 Choppy price action
 Low volume periods
 Major news events pending
 
 Remember: TICK divergences are not guaranteed signals. Always use proper risk management and combine with other technical analysis tools.
Psychological Levels- Rounding Numbers Psychological Levels Indicator 
 Overview: 
The Psychological Levels Indicator automatically identifies and plots significant price levels based on psychological thresholds, which are key areas where market participants often focus their attention. These levels act as potential support or resistance zones due to human behavioral tendencies to round off numbers. This indicator dynamically adjusts the levels based on the stock's price range and ensures seamless visibility across the chart.
 Key Features:
Dynamic Step Sizes: 
The indicator adjusts the levels dynamically based on the stock price:
For prices below 500: Levels are spaced at 10.
For prices between 500 and 3000: Levels are spaced at 50, 100, and 1000.
For prices between 3000 and 10,000: Levels are spaced at 100 and 1000.
For prices above 10,000: Levels are spaced at 500 and 1000.
 Extended Visibility: 
The plotted levels are extended across the entire chart for improved visualization, ensuring traders can easily monitor these critical zones over time.
 Customization Options: 
Line Color: Choose the color for the levels to suit your charting style.
Line Style: Select from solid, dashed, or dotted lines.
Line Width: Adjust the thickness of the lines for better clarity.
Clean and Efficient Design:
The indicator only plots levels relevant to the visible chart range, avoiding unnecessary clutter and ensuring a clean workspace.
 How It Works: 
It calculates the relevant step sizes based on the price:
Smaller step sizes for lower-priced stocks.
Larger step sizes for higher-priced stocks.
Primary, secondary, and (if applicable) tertiary levels are plotted dynamically:
Primary Levels: The most granular levels based on the stock price.
Secondary Levels: Higher-order levels for broader significance.
Tertiary Levels: Additional levels for lower-priced stocks to enhance detail.
These levels are plotted across the chart, allowing traders to visualize key psychological areas effortlessly.
 Use Cases: 
Day Trading: Identify potential intraday support and resistance levels.
Swing Trading: Recognize key price zones where trends may pause or reverse.
Long-Term Investing: Gain insights into significant price zones for entry or exit strategies.






















