Volume Percentile Supertrend [BackQuant]Volume Percentile Supertrend  
  A volatility and participation aware Supertrend that automatically widens or tightens its bands based on where current volume sits inside its recent distribution. The goal is simple: fewer whipsaws when activity surges, faster reaction when the tape is quiet. 
 What it does 
  
  Calculates a standard Supertrend framework from an ATR on a volume weighted price source.
  Measures current volume against its recent percentile and converts that context into a dynamic ATR multiplier.
  Widens bands when volume is unusually high to reduce chop. Tightens bands when volume is unusually low to catch turns earlier.
  Paints candles, draws the active Supertrend line and optional bands, and prints clear Long and Short signal markers.
  
 Why volume percentile 
  
  Fixed ATR multipliers assume all bars are equal. They are not. When participation spikes, price swings expand and a static band gets sliced.
  Percentiles place the current bar inside a recent distribution. If volume is in the top slice, the Supertrend allows more room. If volume is in the bottom slice, it expects smaller noise and tightens.
  This keeps the same playbook usable across busy sessions and sleepy ones without constant manual retuning.
  
 How it works 
  
  Volume distribution  - A rolling window computes the Pth percentile of volume. Above that is flagged as high volume. A lower reference percentile marks quiet bars.
  Dynamic multiplier  - Start from a Base Multiplier. If bar is high volume, scale it up by a function of volume-to-average and a Sensitivity knob. If bar is low volume, scale it down. Smooth the result with an EMA to avoid jitter.
  VWMA source  - The price input for bands is a short volume weighted moving average of close. Heavy prints matter more.
  ATR envelope  - Compute ATR on your length. UpperBasic = VWMA + Multiplier x ATR. LowerBasic = VWMA - Multiplier x ATR.
  Trailing logic  - The final lines trail price so they only move in a direction that preserves Supertrend behavior. This prevents sudden flips from transient pokes.
  Direction and signals  - Direction flips when price crosses through the relevant trailing line. SupertrendLong and SupertrendShort mark those flips. The plotted Supertrend is the active trailing side.
  
 Inputs and what they change 
  
  Volume Lookback  - Window for percentile and average. Larger window = stabler percentile, smaller = snappier.
  Volume Percentile Level  - Threshold that defines high volume. Example 70 means top 30 percent of recent bars are treated as high activity.
  Volume Sensitivity  - Gain from volume ratio to the dynamic multiplier. Higher = bands expand more when volume spikes.
  VWMA Source Length  - Smoothing of the volume weighted price source for the bands.
  ATR Length  - Standard ATR window. Larger = slower, smaller = quicker.
  Base Multiplier  - Core band width before volume adjustment. Think of this as your neutral volatility setting.
  Multiplier Smoothing  - EMA on the dynamic multiplier. Reduces back and forth changes when volume oscillates around the threshold.
  Show Supertrend on chart  - Toggles the active line.
  Show Upper Lower Bands  - Draws both sides even when inactive. Good for context.
  Paint candles according to Trend  - Colors bars by trend direction.
  Show Long and Short Signals  - Prints 𝕃 and 𝕊 markers at flips.
  Colors  - Choose your long and short palette.
  
 Reading the plot 
  
  Supertrend line  - Thick line that hugs price from above in downtrends and from below in uptrends. Its distance breathes with volume.
  Bands  - Optional upper and lower rails. Useful to see the inactive side and judge how wide the envelope is right now.
  Signals  - 𝕃 prints when the trend flips long. 𝕊 prints when the trend flips short.
  Candle colors  - Quick bias read at a glance when painting is enabled.
  
 Typical workflows 
  
  Trend following  - Use 𝕃 flips to initiate longs and ride while bars remain colored long and price respects the lower trailing line. Mirror for shorts with 𝕊 and the upper trailing line. During high volume phases the line will give more room, which helps stay in the move.
  Pullback adds  - In an established trend, shallow tags toward the active line after a high volume expansion can be add points. The dynamic envelope adjusts to the session so your add distance is not fixed to a stale volatility regime.
  Mean reversion filter  - In quiet tape the multiplier contracts and flips come earlier. If you prefer fading, watch for quick toggles around the bands when volume percentile remains low. In high volume, avoid fading into the widened line unless you have other strong reasons.
  
 Notes on behavior 
  
  High volume bar: the percentile gate opens, volRatio > 1 powers up the multiplier through the Sensitivity lever, bands widen, fewer false flips.
  Low volume bar: multiplier contracts, bands tighten, flips can happen earlier which is useful when you want to catch regime changes in quiet conditions.
  Smoothing matters: both the price source (VWMA) and the multiplier are smoothed to keep structure readable while still adapting.
  
 Quick checklist 
  
  If you see frequent chop and today feels busy: check that volume is above your percentile. Wider bands are expected. Consider letting the trend prove itself against the expanded line before acting.
  If everything feels slow and you want earlier entries: percentile likely marks low volume, so bands tighten and 𝕃 or 𝕊 can appear sooner.
  If you want more or fewer flips overall: adjust Base Multiplier first. If you want more reaction specifically tied to volume surges: raise Volume Sensitivity. If the envelope breathes too fast: raise Multiplier Smoothing.
  
 What the signals mean 
  
  SupertrendLong  - Direction changed from non-long to long. 𝕃 marker prints. The active line switches to support below price.
  SupertrendShort  - Direction changed from non-short to short. 𝕊 marker prints. The active line switches to resistance above price.
  Trend color  - Bars painted long or short help validate context for entries and management.
  
 Summary 
  Volume Percentile Supertrend adapts the classic Supertrend to the day you are trading. Volume percentile sets the mood, sensitivity translates it into dynamic band width, and smoothing keeps it clean. The result is a single plot that aims to stay conservative when the tape is loud and act decisively when it is quiet, without you having to constantly retune settings. 
Trading
Opening Candle Zone with ATR Bands by nkChartsThis indicator highlights the opening range of each trading session and projects dynamic ATR-based zones around it.
 Key Features 
 
 Plots high and low levels of the opening candle for each new daily session.
 Extends these levels across the session, providing clear intraday support and resistance zones.
 Adds ATR-based offset bands above and below the opening range for volatility-adjusted levels.
 Customizable colors, ATR length, and multiplier for flexible use across markets and timeframes.
 Adjustable session history limit to control how many past levels remain on the chart.
 
 How to Use: 
 
 The opening range high/low often acts as strong intraday support or resistance.
 The ATR bands give an adaptive volatility buffer, useful for breakout or mean-reversion strategies.
 Works on any market with clear session opens.
 
This tool is designed for traders who want to combine session-based price action with volatility insights, helping identify potential breakouts, reversals, or consolidation areas throughout the day.
 ⚠️ Disclaimer: This indicator is for educational purposes only. It does not provide financial advice or guarantee profits. Always perform your own analysis before making trading decisions.
Z-Score Trend Channels [BackQuant]Z-Score Trend Channels  
 A self-contained price-statistics framework that turns a rolling z-score into price channels, bias states, and trade markers. Run either trend-following or mean-reversion from the same tool with clear, on-chart context. 
 What it is 
  
  A rolling statistical map that measures how far price is from its recent average in standard-deviation units (z-score).
  Adaptive channels drawn in price space from fixed z thresholds, so the rails breathe with volatility.
  A simple trend proxy from z-score momentum to separate trending from ranging conditions.
  On-chart signals for pullback entries, stretched extremes, and practical exits.
  
 Core idea (plain English math) 
  
  Rolling mean and volatility  - Over a lookback you get the average price and its standard deviation.
  Z-score  - How many standard deviations the current price is above or below its average: z = (price - mean) / stdev. z near 0 means near average; positive is above; negative is below.
  Noise control  - An EMA smooths the raw z to reduce jitter and false flickers.
  Channels back in price  - Fixed z levels are converted back to price to form the upper, lower, and extreme rails.
  Trend proxy  - A smoothed change in z is used as a lightweight trend-strength line. Positive strength with positive z favors uptrend; negative strength with negative z favors downtrend.
  
 What you see on the chart 
  
  Channels and fills  - Mean, upper, lower, and optional extreme lines. The area mean->upper tints with the bearish color, mean->lower tints with the bullish color.
  Background tint (optional)  - Soft green, red, or neutral based on detected trend state.
  Signals  - Bullish Entry (triangle up) when z exits the oversold zone upward; Bearish Entry (triangle down) when z exits the overbought zone downward; Extreme markers (diamonds) at the extreme bands with a one-bar turn.
  Table  - Current z, trend state, trend strength, distance to bands, market state tag, and a quick volatility regime label.
  Edge labels  - MEAN, OB, and OS labels slightly projected forward with level values.
  
 Inputs you will actually use 
  
  Z-Score Period  - Lookback for mean and stdev. Larger = slower and steadier rails, smaller = more reactive.
  Smoothing Period  - EMA on z. Lower = earlier but choppier flips; higher = later but cleaner.
  Price Source  - Default hlc3. Choose close if you prefer session-close logic.
  Upper and Lower Thresholds  - Default around +2.0 and -2.0. Tighten for more signals, widen for fewer and stronger.
  Extreme Upper and Lower  - Deeper stretch guards, e.g., +/- 2.5.
  Strength Period  - EMA on z momentum. Sets how fast the trend proxy flips.
  Trend Threshold  - Minimum absolute z to accept a directional bias.
  Visual toggles  - Channels, signals, background tint, stats table, colors, and optional last-bar trend label.
  
 How to use it: trend-following playbook 
  
  Read the state  - Uptrend when z > Trend Threshold and trend strength > 0. Downtrend when z < -Trend Threshold and trend strength < 0. Neutral otherwise.
  Entries  - In an uptrend, prefer Bullish Entry signals that fire near the lower channel. In a downtrend, prefer Bearish Entry signals that fire near the upper channel.
  Stops  - Conservative: beyond the extreme channel on your side. Tighter: just outside the standard band that framed the signal.
  Exits  - For longs, exit or trim on a cross back through z = 0 or a clean tag of the upper threshold. For shorts, mirror with z = 0 up-cross or tag of the lower threshold. You can also reduce if trend strength flips against you.
  Adds  - In strong trends, additional signals near your side’s band can be add points. Avoid adding once z hovers near the opposite band for several bars.
  
 How to use it: mean-reversion playbook 
  
  Find stretch  - Standard reversions: Bullish Entry when z leaves the oversold zone upward; Bearish Entry when z leaves the overbought zone downward. Aggressive reversions: Extreme markers at extreme bands with a one-bar turn.
  Entries  - Take the signal as price exits the zone. Prefer setups where trend strength is near zero or tilting against the prior push.
  Targets  - First target is the mean line. A runner can aim for the opposite standard channel if momentum keeps flipping.
  Stops  - Outside the extreme band beyond your entry. If fading without extremes, place risk just beyond the opposite standard band.
  Filters  - Optional: skip counter-trend fades against a very strong trend state unless your risk is tight and predefined.
  
 Reading the stats table 
  
  Current Z-Score  - Magnitude and sign of displacement now.
  Trend State  - Uptrend, Downtrend, or Ranging.
  Trend Strength  - Smoothed z momentum. Higher absolute values imply stronger directional conviction.
  Distance to Upper/Lower  - Percent distance from price to each band, useful for sizing targets or judging room left.
  Market State  - Overbought, Oversold, Extreme OB, Extreme OS, or Normal.
  Volatility Regime  - High, Normal, or Low relative to recent distribution. Expect bands to widen in High and tighten in Low.
  
 Parameter guidance (conceptual) 
  
  Z-Score Period  - Choose longer for a structural mean, shorter for a reactive mean.
  Smoothing Period  - Lower for earlier but noisier reads; higher for slower but steadier reads.
  Thresholds  - Start around +/- 2.0. Tighten for scalping or quiet ranges. Widen for noisy or fast markets.
  Trend Threshold and Strength Period  - Raise to avoid weak, transient bias. Lower to capture earlier regime shifts.
  
 Practical examples 
  
  Trend pullback long  - State shows Uptrend. Price tests the lower channel; z dips near or below the lower threshold; a Bullish Entry prints. Stop just below extreme lower; first target mean; keep a runner if trend strength stays positive.
  Mean-revert short  - State is Ranging. z tags the extreme upper, an Extreme Bearish marker prints, then a Bearish Entry prints on the leave. Stop above extreme upper; target the mean; consider a runner toward the lower channel if strength turns negative.
  
 Potential Questions you might have 
  
  Why z-score instead of fixed offsets  - Because the bands adapt with volatility. When the tape gets quiet the rails tighten, when it runs hot the rails expand. Your entries stay normalized.
  Do I need both modes  - No. Many users run only trend pullbacks or only mean-reversions. The tool lets you toggle what you need and keep the chart readable.
  Multi-timeframe workflow  - A common approach is to set bias from a higher timeframe’s trend state and execute on a lower timeframe’s signals that align with it.
  
 Summary 
  Z-Score Trend Channels gives you an adaptive mean, volatility-aware rails, a simple trend lens, and clear signals. Trade the trend by buying pullbacks in green and selling pullbacks in red, or fade stretched extremes back to the mean with defined risk. One framework, two strategies, consistent logic. 
MACD  Josh MACD Study — Visual Crossover Tags
Overview:
This script displays MACD signals in a clear, visual way by showing:
Histogram = EMA(Fast) − EMA(Slow)
Signal = EMA(Histogram, Signal Length)
It adds labels and arrows to help you see crossover events between the Histogram and the Signal line more easily.
⚠️ Disclaimer: This tool is for educational and research purposes only. It is not financial advice or an investment recommendation. Past performance does not guarantee future results. Users should make their own decisions and manage risk responsibly.
Features
Central Zero Line with Signal and Histogram plots
Optional labels/arrows to highlight Histogram–Signal crossovers
Alerts for crossover and crossunder events, integrated with TradingView’s alert system
Standard adjustable inputs: Fast EMA, Slow EMA, Signal EMA
How to Interpret (for study only)
When the Histogram crosses above the Signal, a visual label/arrow marks a positive MACD event
When the Histogram crosses below the Signal, a visual label/arrow marks a negative MACD event
The “BUY/SELL” labels are visual study tags only — they do not represent trade instructions or recommendations
Responsible Usage Tips
Test across multiple timeframes and different assets
Combine with higher-timeframe trend, support/resistance, or volume for confirmation
Use alerts with caution, and always test in a demo environment first
Technical Notes
The script does not use future data and does not repaint signals once bars are closed
Results depend on market conditions and may vary across assets and timeframes
License & Credits
Written in Pine Script® v5 for TradingView
The indicator name shown on chart is for labeling purposes only and carries no implication of advice or solicitation
Options Max Pain Calculator [BackQuant]Options Max Pain Calculator  
A visualization tool that models option expiry dynamics by calculating "max pain" levels, displaying synthetic open interest curves, gamma exposure profiles, and pin-risk zones to help identify where market makers have the least payout exposure.
 What is Max Pain? 
Max Pain is the theoretical expiration price where the total dollar value of outstanding options would be minimized. At this price level, option holders collectively experience maximum losses while option writers (typically market makers) have minimal payout obligations. This creates a natural gravitational pull as expiration approaches.
 Core Features 
 Visual Analysis Components: 
 
 Max Pain Line: Horizontal line showing the calculated minimum pain level
 Strike Level Grid: Major support and resistance levels at key option strikes  
 Pin Zone: Highlighted area around max pain where price may gravitate
 Pain Heatmap: Color-coded visualization showing pain distribution across prices
 Gamma Exposure Profile: Bar chart displaying net gamma at each strike level
 Real-time Dashboard: Summary statistics and risk metrics
 
 Synthetic Market Modeling** 
Since Pine Script cannot access live options data, the indicator creates realistic synthetic open interest distributions based on configurable market parameters including volume patterns, put/call ratios, and market maker positioning.
 How It Works 
 Strike Generation: 
The tool creates a grid of option strikes centered around the current price. You can control the range, density, and whether strikes snap to realistic market increments.
 Open Interest Modeling: 
Using your inputs for average volume, put/call ratios, and market maker behavior, the indicator generates synthetic open interest that mirrors real market dynamics:
 
 Higher volume at-the-money with decay as strikes move further out
 Adjustable put/call bias to reflect current market sentiment  
 Market maker inventory effects and typical short-gamma positioning
 Weekly options boost for near-term expirations
 
 Pain Calculation: 
For each potential expiry price, the tool calculates total option payouts:
 
 Call options contribute pain when finishing in-the-money
 Put options contribute pain when finishing in-the-money
 The strike with minimum total pain becomes the Max Pain level
 
 Gamma Analysis: 
Net gamma exposure is calculated at each strike using standard option pricing models, showing where hedging flows may be most intense. Positive gamma creates price support while negative gamma can amplify moves.
 Key Settings 
 Basic Configuration: 
 
 Number of Strikes: Controls grid density (recommended: 15-25)
 Days to Expiration: Time until option expiry
 Strike Range: Price range around current level (recommended: 8-15%)
 Strike Increment: Spacing between strikes
 
 Market Parameters: 
 
 Average Daily Volume: Baseline for synthetic open interest
 Put/Call Volume Ratio: Market sentiment bias (>1.0 = bearish, <1.0 = bullish)  It does not work if set to 1.0
 Implied Volatility: Current option volatility estimate
 Market Maker Factors: Dealer positioning and hedging intensity
 
 Display Options: 
 
 Model Complexity: Simple (line only), Standard (+ zones), Advanced (+ heatmap/gamma)
 Visual Elements: Toggle individual components on/off
 Theme: Dark/Light mode
 Update Frequency: Real-time or daily calculation
 
 Reading the Display 
 Dashboard Table (Top Right): 
 
 Current Price vs Max Pain Level
 Distance to Pain: Percentage gap (smaller = higher pin risk)
 Pin Risk Assessment: HIGH/MEDIUM/LOW based on proximity and time
 Days to Expiry and Strike Count
 Model complexity level
 
 Visual Elements: 
 
 Red Line: Max Pain level where payout is minimized
 Colored Zone: Pin risk area around max pain
 Dotted Lines: Major strike levels (green = support, orange = resistance)
 Color Bar: Pain heatmap (blue = high pain, red = low pain/max pain zones)
 Horizontal Bars: Gamma exposure (green = positive, red = negative)
 Yellow Dotted Line: Gamma flip level where hedging behavior changes
 
 Trading Applications 
 Expiration Pinning: 
When price is near max pain with limited time remaining, there's increased probability of gravitating toward that level as market makers hedge their positions.
 Support and Resistance: 
High open interest strikes often act as magnets, with max pain representing the strongest gravitational pull.
 Volatility Expectations: 
 
 Above gamma flip: Expect dampened volatility (long gamma environment)  
 Below gamma flip: Expect amplified moves (short gamma environment)
 
 Risk Assessment: 
The pin risk indicator helps gauge likelihood of price manipulation near expiry, with HIGH risk suggesting potential range-bound action.
 Best Practices 
 Setup Recommendations 
 
 Start with Model Complexity set to "Standard"
 Use realistic strike ranges (8-12% for most assets)  
 Set put/call ratio based on current market sentiment
 Adjust implied volatility to match current levels
 
 Interpretation Guidelines: 
 
 Small distance to pain + short time = high pin probability
 Large gamma bars indicate key hedging levels to monitor
 Heatmap intensity shows strength of pain concentration
 Multiple nearby strikes can create wider pin zones
 
 Update Strategy: 
 
 Use "Daily" updates for cleaner visuals during trading hours
 Switch to "Every Bar" for real-time analysis near expiration
 Monitor changes in max pain level as new options activity emerges
 
 Important Disclaimers 
 
 This is a modeling tool using synthetic data, not live market information. While the calculations are mathematically sound and the modeling realistic, actual market dynamics involve numerous factors not captured in any single indicator.
 Max pain represents theoretical minimum payout levels and suggests where natural market forces may create gravitational pull, but it does not guarantee price movement or predict exact expiration levels. Market gaps, news events, and changing volatility can override these dynamics.
 Use this tool as additional context for your analysis, not as a standalone trading signal. The synthetic nature of the data makes it most valuable for understanding market structure and potential zones of interest rather than precise price prediction.
 
 Technical Notes 
The indicator uses established option pricing principles with simplified implementations optimized for Pine Script performance. Gamma calculations use standard financial models while pain calculations follow the industry-standard definition of minimized option payouts.
All visual elements use fixed positioning to prevent movement when scrolling charts, and the tool includes performance optimizations to handle real-time calculation without timeout errors.
Price Level Highlighter [ldlwtrades]This indicator is a minimalist and highly effective tool designed for traders who incorporate institutional concepts into their analysis. It automates the identification of key psychological price levels and adds a unique, dynamic layer of information to help you focus on the most relevant area of the market. Inspired by core principles of market structure and liquidity, it serves as a powerful visual guide for anticipating potential support and resistance. 
The core idea is simple: specific price points, particularly those ending in round numbers or common increments, often act as magnets or barriers for price. While many indicators simply plot static lines, this tool goes further by intelligently highlighting the single most significant level in real-time. This dynamic feature allows you to quickly pinpoint where the market is currently engaged, offering a clear reference point for your trading decisions. It reduces chart clutter and enhances your focus on the immediate price action.
 Features 
 Customizable Price Range:  Easily define a specific Start Price and End Price to focus the indicator on the most relevant area of your chart, preventing unnecessary clutter.
 Adjustable Increment:  Change the interval of the lines to suit your trading style, from high-frequency increments (e.g., 10 points) for scalping to wider intervals (e.g., 50 or 100 points) for swing trading.
 Intelligent Highlighting:  A key feature that automatically identifies and highlights the single horizontal line closest to the current market price with a distinct color and thickness. This gives you an immediate visual cue for the most relevant price level.
 Highly Customizabile:  Adjust the line color, style, and width for both the main lines and the highlighted line to fit your personal chart aesthetic.
 Usage 
 
 Apply the indicator to your chart.
 In the settings, input your desired price range (Start Price and End Price) to match the market you are trading.
 Set the Price Increment to your preferred density.
 Monitor the chart for the highlighted line. This is your active price level and a key area of interest.
 Combine this tool with other confirmation signals (e.g., order blocks, fair value gaps, liquidity pools) to build higher-probability trade setups.
 
 Best Practices 
 Pairing:  This tool is effective across all markets, including stocks, forex, indices, and crypto. It is particularly useful for volatile markets where price moves rapidly between psychological levels.
 Mindful Analysis:   Use the highlighted level as a reference point for your analysis, not as a standalone signal. A break above or below this level can signify a shift in market control.
 Backtesting:  Always backtest the indicator on your preferred market and timeframe to understand how it performs under different conditions.
Dynamic Stop Loss Optimizer [BackQuant]Dynamic Stop Loss Optimizer  
 Overview 
 Stop placement decides expectancy. This tool gives you three professional-grade, adaptive stop engines, ATR, Volatility, and Hybrid. So your exits scale with current conditions instead of guessing fixed ticks. It trails intelligently, redraws as the market evolves, and annotates the chart with clean labels/lines and a compact stats table. Pick the engine that fits the trade, or switch on the fly.
 What it does 
  
  Calculates three adaptive stops in real time  (ATR-based, Volatility-based, and Hybrid) and keeps them trailed as price makes progress.
  Shows exactly where your risk lives  with on-chart levels, color-coded markers (long/short), and precise “Risk %” labels at the current bar.
  Surfaces context you actually use  - current ATR, daily volatility, selected method, and the live stop level—in a tidy, movable table.
  Fires alerts on stop hits  so you can automate exits or journal outcomes without staring at the screen.
  
 Why it matters 
  
  Adaptive risk control:  Stops expand in fast tape and tighten in quiet tape. You’re not punished for volatility; you’re aligned with it.
  Consistency across assets:  The same playbook works whether you’re trading indexes, FX, crypto, or equities, because the engine normalizes to each symbol’s behavior.
  Cleaner decision-making:  One chart shows your entry idea and its invalidation in the same breath. If price trespasses, you know it instantly.
  
 The three methods (choose your engine) 
 1) ATR Based  “Structure-aware” distance
 This classic approach keys off Average True Range to set a stop just beyond typical bar-to-bar excursion. It adapts smoothly to changing ranges and respects swing structure.
  Use when:  you want a steady, intuitive buffer that tracks trend legs without hugging price.
  See it in action:  
 2) Volatility Based  “Behavior-aware” distance
 This engine derives stop distance from current return volatility (annualized, then scaled back down to the session). It reacts to regime shifts quickly and normalizes risk across symbols with very different prices.
  Use when:  you want the stop to breathe with realized volatility and respond faster to heat-ups/cool-downs.
  See it in action:  
 3) Hybrid  “Best of both worlds”
 The Hybrid blends the ATR and Volatility distances into one consensus level, then trails it intelligently. You get the structural common sense of ATR and the regime sensitivity of Vol.
  Use when:  you want robust, all-weather behavior without micromanaging inputs.
  See it in action:  
 How it trails 
  
  Longs:  The stop ratchets up with favorable movement and holds its ground on shallow pullbacks. If price closes back into the risk zone, the level refreshes to the newest valid distance.
  Shorts:  Mirror logic ratchets down with trend, resists noise, and refreshes if price reclaims the zone.
  Hybrid trailing:  Uses the blended distance and the same “no give-backs” principle to keep gains protected as structure builds.
  
 Reading the chart 
  
  Markers:  Circles = ATR stops, Crosses = Vol stops, Diamonds = Hybrid. Colors indicate long (red level under price) vs short (green level above price).
  Lines:  The latest active stop is extended with a dashed line so you can see it at a glance.
  Labels:  “Long SL / Short SL” shows the exact price and current risk % from the last close no math required.
  Table:  ATR value, Daily Vol %, your chosen Method, the Current SL, and Risk %—all in one compact block that you can pin top-left/right/center.
  
 Quick workflow 
  
  Define the idea:  Long or Short, and which engine fits the tape (ATR, Vol, or Hybrid).
  Place and trail:  Let the optimizer print the level; trail automatically as the move develops.
  Manage outcomes:  If the line is tagged, you’re out clean. If it holds, you’ve contained heat while giving the trade room to work.
  
 Inputs you’ll actually touch 
  Calculation Settings 
  
  ATR Length / Multiplier:  Controls the “structural” cushion.
  Volatility Length / Multiplier:  Controls the “behavioral” cushion.
  Trading Days:  252 or 365 to keep the volatility math aligned with the asset’s trading calendar.
  
 Stop Loss Method 
  
  ATR Based | Volatility Based | Hybrid : Switch engines instantly to fit the trade.
  
 Position Type 
  
  Long | Short | Both : Show only what you need for the current strategy.
  
 Visual Settings 
  
  Show ATR / Vol / Hybrid Stops:  Toggle families on/off.
  Show Labels:  Print price + Risk % at the live stop.
  Table Position:  Park the metrics where you like.
  
 Coloring 
  
  Long/Short/Hybrid colors:  Set a palette that matches your theme and stands out on your background.
  
 Practical patterns to watch 
  
  Trend-pullback continuation:  The stop ratchets behind higher lows (long) or lower highs (short). If price tests the level and rejects, that’s your risk-defined continuation cue.
  Break-and-run:  After a clean break, the Hybrid will usually sit slightly wider than pure Vol, use it to avoid getting shaken on the first retest.
  Range compression:  When the ATR and Vol distances converge, the table will show small Risk %. That’s your green light to size up with the same dollar risk, or keep it conservative if you expect expansion.
  
 Alerts 
  
  Long Stop Loss Hit : Notifies when price crosses below the live long stop.
  Short Stop Loss Hit : Notifies when price crosses above the live short stop.
  
 Why this feels “set-and-serious” 
 You get a single look that answers three questions in real time: “Where’s my line in the sand?”, “How much heat am I taking right now?”, and “Is this distance appropriate for current conditions?” With ATR, Vol, and Hybrid in one tool, you can run the exact same playbook across symbols and regimes while keeping your chart clean and your risk explicit.
USD-TRADER-ROYThe USD-TRADER-ROY is a custom TradingView indicator designed for crypto and USD market analysis. It tracks a smoothed ratio between USDT dominance and historical averages (similar to the Puell Multiple concept) to highlight potential buy or sell zones.
Key features include:
Dynamic Buy/Sell Zones: Visual horizontal levels to indicate potential accumulation or profit-taking areas.
Visual Feedback: Colored backgrounds and bar colors to quickly show whether conditions suggest caution, accumulation, or potential selling.
Custom Alerts: Built-in alert conditions that notify traders when the market approaches critical thresholds, making it easier to act on opportunities without constant monitoring.
Flexible Parameters: Adjustable inputs for thresholds and risk levels to suit different strategies or risk tolerances.
This tool is aimed at traders who want a visual, alert-based system for gauging market extremes and managing entries/exits efficiently. It works best when combined with your own analysis and risk management.
FSVZO [Alpha Extract]A sophisticated volume-weighted momentum oscillator that combines Fourier smoothing with Volume Zone Oscillator methodology to deliver institutional-grade flow analysis and divergence detection. Utilizing advanced statistical filtering including ADF trend analysis and multi-dimensional volume dynamics, this indicator provides comprehensive market sentiment assessment through volume-price relationships with extreme zone detection and intelligent divergence recognition for high-probability reversal and continuation signals.
🔶 Advanced VZO Calculation Engine 
Implements enhanced Volume Zone Oscillator methodology using relative volume analysis combined with smoothed price changes to create momentum-weighted oscillator values. The system applies exponential smoothing to both volume and price components before calculating positive and negative momentum ratios with trend factor integration for market regime awareness.
🔶 Fourier-Based Smoothing Architecture 
Features advanced Fourier approximation smoothing using cosine-weighted calculations to reduce noise while preserving signal integrity. The system applies configurable Fourier length parameters with weighted sum normalization for optimal signal clarity across varying market conditions with enhanced responsiveness to genuine trend changes.
 // Fourier Smoothing Algorithm
fourier_smooth(src, length) =>
    sum = 0
    weightSum = 0
    for i = 0 to length - 1
        weight = cos(2 * π * i / length)
        sum += src  * weight
        weightSum += weight
    sum / weightSum 
🔶 Intelligent Divergence Detection System 
Implements comprehensive divergence analysis using pivot point methodology with configurable lookback periods for both standard and hidden divergence patterns. The system validates divergence conditions through range analysis and provides visual confirmation through plot lines, labels, and color-coded identification for precise timing analysis.
15MIN
  
4H
  
12H 
  
🔶 Flow Momentum Analysis Framework 
Calculates flow momentum by measuring oscillator deviation from its exponential moving average, providing secondary confirmation of volume flow dynamics. The system creates momentum-based fills and visual indicators that complement the primary oscillator analysis for comprehensive market flow assessment.
🔶 Extreme Zone Detection Engine 
Features sophisticated extreme zone identification at ±98 levels with specialized marker system including white X markers for signals occurring in extreme territory and directional triangles for potential reversal points. The system provides clear visual feedback for overbought/oversold conditions with institutional-level threshold accuracy.
🔶 Dynamic Visual Architecture 
Provides advanced visualization engine with bullish/bearish color transitions, dynamic fill regions between oscillator and signal lines, and flow momentum overlay with configurable transparency levels. The system includes flip markers aligned to color junction points for precise signal timing with optional bar close confirmation to prevent repainting.
🔶 ADF Trend Filtering Integration 
Incorporates Augmented Dickey-Fuller inspired trend filtering using normalized price statistics to enhance signal quality during trending versus ranging market conditions. The system calculates trend factors based on mean deviation and standard deviation analysis for improved oscillator accuracy across market regimes.
🔶 Comprehensive Alert System
Features intelligent multi-tier alert framework covering bullish/bearish flow detection, extreme zone reversals, and divergence confirmations with customizable message templates. The system provides real-time notifications for critical volume flow changes and structural market shifts with exchange and ticker integration.
🔶 Performance Optimization Framework 
Utilizes efficient calculation methods with optimized variable management and configurable smoothing parameters to balance signal quality with computational efficiency. The system includes automatic pivot validation and range checking for consistent performance across extended analysis periods with minimal resource usage.
This indicator delivers sophisticated volume-weighted momentum analysis through advanced Fourier smoothing and comprehensive divergence detection capabilities. Unlike traditional volume oscillators that focus solely on volume patterns, the FSVZO integrates volume dynamics with price momentum and statistical trend filtering to provide institutional-grade flow analysis. The system's combination of extreme zone detection, intelligent divergence recognition, and multi-dimensional visual feedback makes it essential for traders seeking systematic approaches to volume-based market analysis across cryptocurrency, forex, and equity markets with clearly defined reversal and continuation signals.
Wavelet Kernal ATR [BackQuant]Wavelet Kernal ATR  
 Introduction 
 Wavelet Kernal ATR is a closed-source, chart-side tool that fuses an edge-preserving “wavelet kernal” smoother with an ATR-aware regime line. The goal is simple: follow the real move, ignore the static, and give you clean, visual places to manage risk. It can color the trend directly on price, flip states when regime changes, and (optionally) add a secondary moving-average overlay for confirmation all while keeping the chart readable.
 What it is 
 A single adaptive baseline designed to act like a “bias rail.” When it’s up, you favor longs; when it’s down, you favor shorts. It updates in a way that’s responsive to fresh information but resistant to insignificant wiggles. Around that baseline, an ATR-scaled envelope governs how and when the line concedes to volatility, which helps avoid flip-flopping in chop. Because this release is closed source, the following focuses on behavior and practical use rather than internal math.
 What it’s used for 
  
  Bias & context:  Read the backdrop with one glance; green = bullish regime, red = bearish regime.
  Timing:  Use slope changes and pullbacks to the line for entries aligned with the dominant push.
  Risk placement:  The line and its volatility envelope give intuitive zones for stops and targets.
  Clarity:  Paint candles by state and keep other overlays to a minimum to reduce decision noise.
  
 Why “Wavelet Kernal” matters (plain English) 
 A wavelet kernal is a localized, scale-aware weighting profile. Instead of averaging every bar equally—or with a single, fixed decay—it emphasizes the most informative part of the recent window while softly down-weighting points that are either too old or too extreme. Three practical benefits result:
  
  Edge preservation:  Turning points are less “smeared” than with conventional smoothers, so the line can pivot sooner on genuine breakouts without chasing every tick.
  Multi-scale sensitivity:  The kernal “listens” to structure at multiple scales inside a compact window, helping it track swing-sized movement while suppressing micro-chop.
  Lag vs. noise balance:  Because the weighting is localized and shape-aware, you get a calmer line at similar responsiveness compared to common filters; fewer false flips, more meaningful ones.
  
 You don’t need to know the internals to use it: think of the wavelet kernal as a smart stethoscope for price. It hears the heartbeat (trend/impulse) and ignores the coughs (random spikes).
 How it behaves 
  
  Trend mode:  When price expands directionally, the line “sticks” to the move and stays colored in that direction. Pullbacks that remain shallow relative to volatility usually do not flip the state.
  Transition mode:  After a large push, the line may flatten as volatility compresses. Flat + frequent small flips is the platform telling you: edge is low, wait for expansion.
  Shock handling:  On sudden spikes, the ATR envelope acts like a reality check—minor overreactions are absorbed, while statistically meaningful breaks force the baseline to concede and re-anchor.
  
 Reading the line (quick heuristics) 
  
  Green + rising:  Bias long; look for pullbacks toward the line that stall and resume.
  Red + falling:  Bias short; look for rallies into the line that fade.
  Flat + rapid color flips:  Stand down or scale down—let the next expansion choose the side.
  Color flip at a prior S/R:  Treat as a higher-quality signal than flips in the middle of nowhere.
  
 Baseline + ATR corridor (concept) 
 The volatility envelope isn’t drawn as two fat bands here; it’s used internally to keep the baseline honest. You can think of it as a “breathing room” rule: the line is allowed to adapt with trend, but it shouldn’t jump the fence unless price movement is large enough relative to recent volatility. That’s why the tool feels calm in chop and decisive during actual breaks.
 Optional MA Overlay (confluence) 
 You can overlay a moving average of the baseline itself for slower-regime confirmation. When both agree (baseline direction and its MA slope), you have trend alignment. When they diverge, expect digestion or a possible transition. Keep this overlay subtle; it’s a context layer, not another signal firehose.
 What it plots 
  
  Wavelet ATR line  — the adaptive baseline that flips color with regime.
  Optional MA of the baseline  — slower confirmation, on or off.
  Candle painting  — bars can inherit long/short state for instant read-through.
  Alerts  — available for state flips up/down.
  
 Inputs explained (effect on behavior) 
 Wavelet ATR Calculation 
  
  Price Source  — Default  hlc3 ; choose your preferred composite of OHLC.
  Kernal Calculation Length  — The horizon the kernal “listens to.”  Longer  = steadier, fewer flips;  shorter  = snappier, more flips.
  Kernal Alpha  — How strongly the kernal prioritizes the freshest data inside that horizon. Higher alpha = quicker to acknowledge new pushes; lower alpha = more patience.
  ATR Period  — Determines the volatility memory. Shorter = envelope reacts faster; longer = envelope demands more evidence to concede.
  ATR Factor  — Scales how “strict” the envelope is. Larger factor = more tolerance (fewer flips); smaller = more sensitivity (earlier regime shifts).
  
 Confluence 
  
  Show Atr Moving Average  — Turns on the secondary overlay.
  MA Type  — Choose the flavor you read best (simple, exponential, linear regression, etc.).
  Moving Average Period  — The overlay’s horizon; treat it as a background current.
  Volume Factor / Sigma (when applicable)  — Specialized parameter used by certain MA types to shape smoothness.
  
 Plotting & UI 
  
  Plot Wavelet ATR  — Toggle the main line.
  Paint Candles According to Trend  — Color bars by the baseline’s state.
  Long/Short Colors  — Match your chart theme.
  
 A practical playbook 
  
  Trend-pullback continuation 
  Setup:  Baseline is green and rising. Price pulls back toward it, stalls (small bodies or wicks into the line), then resumes upward.
  Idea:  Enter on the resumption. Protective stop often lives just below the line or the last swing low. Scale targets through prior highs or measured projections.
 Breakout + acceptance 
  Setup:  Baseline flattens after consolidation. Price expands away; baseline turns green/red and  stays  that way as two or three bars “accept” the new area.
  Idea:  Join on the first controlled retest toward the line. If the line instantly loses color again, treat it as a fakeout.
 Failed test / flip-and-go 
  Setup:  Price challenges the line from the wrong side but cannot close through it convincingly; shortly after, the baseline flips color back in the original direction.
  Idea:  Use that failed test as a springboard—risk tucked beyond the failed side.
  
 Quality checks before you click 
  
  Structure context:  Is the flip happening near prior highs/lows, session opens, or well-observed levels? Flips at structure carry more information.
  Volatility posture:  If range is compressing, be picky. If range is expanding, respect the first pullback after the flip.
  Clutter discipline:  Use the fewest layers that earn their place. Trend line + candle painting is often enough.
  
 Common questions 
  
  “Why did the line not flip on that spike?”  Because the move wasn’t large or sustained enough relative to recent volatility. The envelope forces patience.
  “Why did it flip and then flip back?”  That’s what digestion looks like. The kernal preserves edges, but when the market truly has no edge, brief flips are information: sit tight.
  “Do I need the overlay MA?”  No. It’s optional context. If it helps you filter marginal trades, keep it. If it adds noise, turn it off.
  
 Troubleshooting & fine-tuning (principles, not prescriptions) 
  
  Too many flips?  Increase the Kernal Calculation Length  or  the ATR Factor. You’re asking for a steadier bias.
  Feels late on strong trends?  Nudge Kernal Alpha higher  or  shorten the Kernal Length. You’re asking for earlier acknowledgment.
  Stops feel random?  Place initial risk just beyond the baseline (or the last swing beyond it), then trail only when fresh structure appears.
  Charts feel crowded?  Keep the baseline + candle coloring; hide the overlay and other ornaments.
  
 Alerts 
  
  Wavelet ATR Trend Up
  Wavelet ATR Trend Down
  
 Final notes 
 This tool is built to minimize analysis fatigue: one adaptive line, strong visual feedback, and enough discipline from volatility logic to avoid the “every blip is a signal” trap. The internal math, weighting shapes, and state logic are proprietary and intentionally not disclosed here; you still have full control of behavior through the inputs above. As always, align the settings with your own trade plan, keep the chart readable, and let confluence—not clutter—do the heavy lifting.
Price Action Trader [BackQuant]Price Action Trader  
 Introduction 
 Price Action Trader is an all-in-one, chart-side workflow for reading trend, timing impulses, and mapping high-probability zones the way discretionary traders actually trade. It blends an ensemble trend engine with clean price-action building blocks—Market Structure (BOS/MSB), Fair Value Gaps, Order Blocks, and Volumetric Support/Resistance—so you can form a bias, find confluence, and execute with context.
 What is it 
 A modular “price-action stack” that:
  
  Paints  trend bias  and  impulse shifts  on the chart (optional candle coloring).
  Auto-annotates  internal & swing structure  (BOS / MSB).
  Finds  FVGs  on your chosen timeframe and draws them cleanly.
  Detects  Order Blocks  (with optional FVG confirmation).
  Builds  volumetric S/R  levels that adapt to liquidity.
  Emits  alerts  for key events (new levels, touches, breaks, OB creation/touch).
  
 Everything is configurable—keep it minimal (trend + a few zones) or run the full toolkit.
 What’s it used for 
  
  Bias first, trade second:  establish direction/conviction, then execute where structure, gaps, blocks, and volume agree.
  Timing:  impulse flips and level touches provide actionable triggers.
  Risk placement:  OB edges, FVG midlines, and volumetric bands give logical stop/target references.
  Review & journaling:  optional session shading and labeled structures make post-trade notes simple.
  
 Composite Trend Model 
 A lightweight signal line (default: 30-period) that turns  green  when the composite regime is bullish and  red  when bearish. Under the hood, multiple cues (adaptive momentum, de-noised oscillation, volatility-aware filters) are blended into a single directional score; when thresholds flip, the line recolors and optional Long/Short dots appear.
  How to use 
  
  Treat the line as your  bias rail : favor longs while green, shorts while red.
  Flat/rapid flips = stand down or reduce size.
  Prefer clean charts? Keep only the line and (optionally) trend-painted candles.
  
  Inputs to know 
  
  Show Trend Signal Line / Width.
  Paint Candles by Trend.
  Long/Bearish color controls.
  
 
 Impulse Model 
 Highlights short-term pressure shifts with optional impulse candle coloring and ▲/▼ markers. Great for entries in the prevailing trend and for early warnings when impulses fire against bias.
  How to use 
  
  Up-bias: look for the next  impulse-up  near structure/FVG/OB or volumetric support.
  Down-bias: mirror the logic.
  Frequent counter-impulses → expect chop or regime change.
  
  Inputs to know 
  
  Show Impulse Signals.
  Paint Impulse Candles.
  
 
 Market Structure 
 Automatic  Internal  (tight lookback) and  Swing  (wider lookback) structure with BOS and MSB (CHoCH) labels. You decide what to show—All, BOS only, MSB only—independently for internal vs swing.
  How to use 
  
  Use  Swing  labels for the primary map;  Internal  for entry refinement.
  After a  bullish MSB , seek the first HL back into support/FVG/OB.
  After a  bearish BOS , favor LH fades into resistance/FVG/OB.
  
  Inputs to know 
  
  Swing Lookback / Internal Lookback.
  Swing/Internal Structure:  All | BOS | MSB | None .
  Separate bull/bear color controls for both layers.
  
 
 Fair Value Gaps 
 Detects bullish/bearish FVGs on the current or higher TF, draws boxes, and can extend them forward. Midlines provide quick visual targeting.
  How to use 
  
  In-trend fills:  in an up-bias, tags of bullish FVGs often offer high-quality continuation entries, especially with structure/OB confluence.
  Failed fills:  rejections at the midline can signal emerging strength/weakness.
  
  Inputs to know 
  
  Show FVG / Show Last N / Extend.
  Timeframe (blank = chart TF; set higher TF for macro FVGs).
  Bull/Bear colors (tune opacity to taste).
  
 
 Volumetric Support and Resistance 
 Builds adaptive S/R from price interaction + relative volume over a rolling lookback. Levels store touch counts; you can show volume stats on labels or inside boxes. Transparency and border thickness can scale with volume so stronger levels are visually louder. Broken levels can auto-remove.
  How to use 
  
  Use as  confluence  with structure, OBs, and FVGs. A long at volumetric support + Bull OB + FVG midline is qualitatively different from a naked level.
  If a level breaks on strong volume, stop fading—flip expectations or wait for a clean retest.
  
  Inputs to know 
  
  Detection Sensitivity / Volume Multiplier.
  Analysis Period / Max Levels / Min Distance (%).
  Remove Broken / Extend Right / Show Volume Info / Text Inside.
  Support/Resistance colors (+ high-vol variants).
  
  Alerts 
  
  New Support/Resistance Level Created.
  Level Touch.
  Level Break.
  
 Order Blocks 
 Detects bullish/bearish OBs using configurable fractals (3- or 5-bar) with a break confirmation (by Close or High/Low). Optional FVG proximity filter, right-extension, and auto-delete when filled.
  How to use 
  
  Bullish bias: stalk pullbacks into fresh  Bull OBs  aligned with a bullish FVG or volumetric support.
  If price fills an opposing OB and fails to continue, reassess bias—context may be shifting.
  
  Inputs to know 
  
  Fractal Type & Break Method (Close / HL).
  Filter with FVG + Max FVG Distance.
  Extend Blocks / Delete When Filled / Show Labels.
  
  Alerts 
  
  New Order Block Created.
  Order Block Touch.
  
 
 Final Notes 
  Suggested workflow 
  
  Start with  Composite Trend  (bias).
  Mark  Swing structure  in that direction.
  Wait for an  Impulse  in-direction near an OB / FVG / Volumetric level.
  Risk = nearest opposite level or OB edge; targets = FVG midlines / next S/R.
  
  Timeframes & assets 
  
  Defaults suit liquid intraday and 1–4H swing.
  Slower markets → lengthen lookbacks, lower sensitivity.
  Very noisy crypto → keep trend visible, trim drawings (e.g., MSB only, last 3–5 FVGs, 8–12 volume levels).
  
  Keep it readable 
  
  Turn off modules you don’t need today—fewer, higher-quality signals beat clutter.
  
  About this release 
  
  Internal scoring, smoothing, and detection logic are proprietary. Behavior is controlled via inputs described above.
  
Trade with a plan, test your settings, and let  confluence  do the heavy lifting.
EMA 50 & 200 (TF-specific)This script plots EMA 50 and EMA 200 only on the timeframes where they matter most:
EMA 50 (gray): visible on 1H, 4H, and 12H charts – often used by intraday traders.
EMA 200 (black): visible on Daily and Weekly charts – a classic long-term trend indicator.
🔹 Why use it?
Avoids clutter by showing each EMA only on the relevant timeframe.
Helps align intraday trading with higher timeframe trends.
Simple, clean, and effective for both swing and day trading.
Session AnchorsDescription
This indicator highlights the four main global trading sessions — London, New York AM, New York PM, and Asia — as color-coded boxes on the chart. Each session is defined by fixed start/end times (New York time) and dynamically updates with the evolving high and low during that interval. This provides a clear view of how volatility and structure shift as trading activity passes from one region to another.
How to use
• Works on any timeframe.
• Toggle sessions on/off based on your trading hours.
• Observe price behavior as one session closes and another opens.
• Use session boxes as context for liquidity, volatility, and structure analysis.
Originality
This script delivers a clean, customizable visualization of global market hours and session ranges, avoiding extra overlays so traders can isolate session-based behavior without distraction.
⚠️ Disclaimer
This indicator does not generate signals. It provides a structural mapping of global sessions for contextual analysis only.
Weekly Session BreakThis indicator plots a vertical line at the end of the trading week (Friday) to mark the weekly session break. It is designed to be used on intraday charts (sub-1 hour timeframes).
The line's appearance is fully customizable via the Inputs tab, allowing you to change its color, style (solid, dotted, or dashed), and thickness.
 Key Features: 
 
 End-of-Week Marker: Accurately draws a vertical line on the last bar of the trading week.
 Timeframe Specific: Lines are only visible on intraday charts (1-minute to 59-minute timeframes) to prevent clutter on higher timeframes.
 Customizable: Adjust the line's color, style, and thickness from the Inputs menu.
Key Levels: Daily, Weekly, Monthly [BackQuant]Key Levels: Daily, Weekly, Monthly  
  Map the market’s “memory” in one glance—yesterday’s range, this week’s chosen day high/low, and D/W/M opens—then auto-clean levels once they break. 
 What it does 
 This tool plots three families of high-signal reference lines and keeps them tidy as price evolves:
  
  Chosen Day High/Low (per week)  — Pick a weekday (e.g., Monday). For each past week, the script records that day’s session  high  and  low  and projects them forward for a configurable number of bars. These act like “memory levels” that price often revisits.
  Daily / Weekly / Monthly Opens  — Plots the opening price of each new day, week, and month with separate styling. These opens frequently behave like magnets/flip lines intraday and anchors for regime on higher timeframes.
  Auto-pruning  — When price  breaks  a stored level, the script can automatically remove it to reduce clutter and refocus you on still-active lines. See:  (broken levels removed).
  
 Why these levels matter 
  
  Liquidity pockets  — Prior day’s high/low and the daily open concentrate stops and pending orders. Mapping them quickly reveals likely sweep or fade zones. Example: previous day highs + daily open highlighting liquidity: 
  Context & regime  — Monthly opens frame macro bias; trading above a rising cluster of monthly opens vs. below gives a clean top-down read. Example: monthly-only “macro outlook” view: 
  Cleaner charts  — Auto-remove broken lines so you focus on what still matters right now.
  
 What it plots (at a glance) 
  
  Past  Chosen Day  High/Low for up to N prior weeks (your choice), extended right.
  Current  Daily Open ,  Weekly Open , and  Monthly Open , each with its own color, label, and forward extension.
  Optional short labels (e.g., “Mon High”) or full labels (with week/month info).
  
 How breaks are detected & cleaned 
 You control both the  evidence  and the  timing  of a “break”:
  
  Break uses  — Choose  Close  (more conservative) or  Wick  (more sensitive).
  Inclusive?  — If enabled, equality counts (≥ high or ≤ low). If disabled, you need a strict cross.
  Allow intraday breaks?  — If on, a level can break during the tracked day; if off, the script only counts breaks  after  the session completes.
  Remove Broken Levels  — When a break is confirmed, the line/label is deleted automatically. (See the demo: )
  
 Quick start 
  
  Pick a  Day of Week to Track  (e.g., Monday).
  Set how many  weeks back  to show (e.g., 8–10).
  Choose how far to  extend  each family (bars to the right for chosen-day H/L and D/W/M opens).
  Decide if a break uses  Close  or  Wick , and whether equality counts.
  Toggle  Remove Broken Levels  to keep the chart clean automatically.
  
 Tips by use-case 
  
  Intraday bias  — Watch the  Daily Open  as a magnet/flip. If price gaps above and holds, pullbacks to the daily open often decide direction. Pair with last day’s high/low for sweep→reversal or true breakout cues. See: 
  Weekly structure  — Track the week’s chosen day (e.g., Monday) high/low across prior weeks. If price stalls near a cluster of old “Monday Highs,” look for sweep/reject patterns or continuation on reclaim.
  Macro regime  — Hide daily/weekly lines and keep only  Monthly Opens  to read bigger cycles at a glance (BTC/crypto especially). Example: 
  
 Customization 
  
  Use wicks or bodies  for highs/lows (wicks capture extremes; bodies are stricter).
  Line style & thickness  — solid/dashed/dotted, width 1–5, plus global transparency.
  Labels  — Abbreviated (“Mon High”, “D Open”) or full (month/week/day info).
  Color scheme  — Separate colors for highs, lows, and each of D/W/M opens.
  Capacity controls  — Set how many daily/weekly/monthly opens and how many weeks of chosen-day H/L to keep visible.
  
 What’s under the hood 
  
  On your selected weekday, the script records that session’s  true high  and  true low  (using wicks or body-based extremes—your choice), then projects a horizontal line forward for the next bars.
  At each new  day/week/month , it records the opening price and projects that line forward as well.
  Each bar, the script checks your “break” rules; once broken, lines/labels are removed if auto-cleaning is on.
  Everything updates in real time; past levels don’t repaint after the session finishes.
  
 Recommended presets 
  
  Day trading  — Weeks back: 6–10; extend D/W opens: 50–100 bars; Break uses:  Close ; Inclusive: off; Auto-remove: on.
  Swing  — Fewer daily opens, more weekly opens (2–6), and 8–12 weeks of chosen-day H/L.
  Macro  — Show only  Monthly Opens  (1–6 months), dashed style, thicker lines for clarity.
  
 Reading the examples 
  
  Broken lines disappear  — decluttering in action: 
  Macro outlook  — monthly opens as cycle rails: 
  Liquidity map  — previous day highs + daily open: 
  
 Final note 
 These are not “signals”—they’re  reference points  that many participants watch. By standardising how you draw them and automatically clearing the ones that no longer matter, you turn a noisy chart into a focused map: where liquidity likely sits, where price memory lives, and which lines are still in play.
Quantile Regression Bands [BackQuant]Quantile Regression Bands  
  Tail-aware trend channeling built from quantiles of real errors, not just standard deviations. 
 What it does 
 This indicator fits a simple linear trend over a rolling lookback and then measures how price has actually deviated from that trend during the window. It then places two pairs of bands at user-chosen quantiles of those deviations (inner and outer). Because bands are based on empirical quantiles rather than a symmetric standard deviation, they adapt to skewed and fat-tailed behaviour and often hug price better in trending or asymmetric markets.
 Why “quantile” bands instead of Bollinger-style bands? 
  
  Bollinger Bands assume a (roughly) symmetric spread around the mean; quantiles don’t—upper and lower bands can sit at different distances if the error distribution is skewed.
  Quantiles are robust to outliers; a single shock won’t inflate the bands for many bars.
  You can choose tails precisely (e.g., 1%/99% or 5%/95%) to match your risk appetite.
  
 How it works (intuitive) 
  
  Center line  — a rolling linear regression approximates the local trend.
  Residuals  — for each bar in the lookback, the indicator looks at the gap between actual price and where the line “expected” price to be.
  Quantiles  — those gaps are sorted; you select which percentiles become your inner/outer offsets.
  Bands  — the chosen quantile offsets are added to the current end of the regression line to draw parallel support/resistance rails.
  Smoothing  — a light EMA can be applied to reduce jitter in the line and bands.
  
 What you see 
  
  Center (linear regression) line (optional).
  Inner quantile bands (e.g., 25th/75th) with optional translucent fill.
  Outer quantile bands (e.g., 1st/99th) with a multi-step gradient to visualise “tail zones.”
  Optional bar coloring: bars trend-colored by whether price is rising above or falling below the center line.
  Alerts when price crosses the outer bands (upper or lower).
  
 How to read it 
  
  Trend & drift  — the slope of the center line is your local trend. Persistent closes on the same side of the center line indicate directional drift.
  Pullbacks  — tags of the inner band often mark routine pullbacks within trend. Reaction back to the center line can be used for continuation entries/partials.
  Tails & squeezes  — outer-band touches highlight statistically rare excursions for the chosen window. Frequent outer-band activity can signal regime change or volatility expansion.
  Asymmetry  — if the upper band sits much further from the center than the lower (or vice versa), recent behaviour has been skewed. Trade management can be adjusted accordingly (e.g., wider take-profit upslope than downslope).
  
A simple trend interpretation can be derived from the bar colouring
 Good use-cases 
  
  Volatility-aware mean reversion  — fade moves into outer bands back toward the center when trend is flat.
  Trend participation  — buy pullbacks to the inner band above a rising center; flip logic for shorts below a falling center.
  Risk framing  — set dynamic stops/targets at quantile rails so position sizing respects recent tail behaviour rather than fixed ticks.
  
 Inputs (quick guide) 
  
  Source  — price input used for the fit (default: close).
  Lookback Length  — bars in the regression window and residual sample. Longer = smoother, slower bands; shorter = tighter, more reactive.
  Inner/Outer Quantiles (τ)  — choose your “typical” vs “tail” levels (e.g., 0.25/0.75 inner, 0.01/0.99 outer).
  Show toggles  — independently toggle center line, inner bands, outer bands, and their fills.
  Colors & transparency  — customize band and fill appearance; gradient shading highlights the tail zone.
  Band Smoothing Length  — small EMA on lines to reduce stair-step artefacts without meaningfully changing levels.
  Bar Coloring  — optional trend tint from the center line’s momentum.
  
 Practical settings 
  
  Swing trading  — Length 75–150; inner τ = 0.25/0.75, outer τ = 0.05/0.95.
  Intraday  — Length 50–100 for liquid futures/FX; consider 0.20/0.80 inner and 0.02/0.98 outer in high-vol assets.
  Crypto  — Because of fat tails, try slightly wider outers (0.01/0.99) and keep smoothing at 2–4 to tame weekend jumps.
  
 Signal ideas 
  
  Continuation  — in an uptrend, look for pullback into the lower inner band with a close back above the center as a timing cue.
  Exhaustion probe  — in ranges, first touch of an outer band followed by a rejection candle back inside the inner band often precedes mean-reversion swings.
  Regime shift  — repeated closes beyond an outer band or a sharp re-tilt in the center line can mark a new trend phase; adjust tactics (stop-following along the opposite inner band).
  
 Alerts included 
  
  “Price Crosses Upper Outer Band” — potential overextension or breakout risk.
  “Price Crosses Lower Outer Band” — potential capitulation or breakdown risk.
  
 Notes 
  
  The fit and quantiles are computed on a fixed rolling window and do not repaint; bands update as the window moves forward.
  Quantiles are based on the recent distribution; if conditions change abruptly, expect band widths and skew to adapt over the next few bars.
  Parameter choices directly shape behaviour: longer windows favour stability, tighter inner quantiles increase touch frequency, and extreme outer quantiles highlight only the rarest moves.
  
 Final thought 
 Quantile bands answer a simple question: “How unusual is this move given the current trend and the way price has been missing it lately?” By scoring that question with real, distribution-aware limits rather than one-size-fits-all volatility you get cleaner pullback zones in trends, more honest “extreme” tags in ranges, and a framework for risk that matches the market’s recent personality.
Cumulative Returns by Session [BackQuant]Cumulative Returns by Session  
 What this is 
 This tool breaks the trading day into three user-defined sessions and tracks how much each session contributes to return, volatility, and volume. It then aggregates results over a rolling window so you can see which session has been pulling its weight, how streaky each session has been, and how sessions relate to one another through a compact correlation heatmap.
We’ve also given the functionality for the user to use a simplified table, just by switching off all settings they are not interested in.
 How it works 
  1) Session segmentation 
 You define APAC, EU, and US sessions with explicit hours and time zones. The script detects when each session starts and ends on every intraday bar and records its open, intraday high and low, close, and summed volume.
 2) Per-session math 
 At each session end the script computes:
  
  Return  — either Percent: (Close−Open)÷Open×100(Close − Open) ÷ Open × 100(Close−Open)÷Open×100 or Points: (Close−Open)(Close − Open)(Close−Open), based on your selection.
  Volatility  — either Range: (High−Low)÷Open×100(High − Low) ÷ Open × 100(High−Low)÷Open×100 or ATR scaled by price: ATR÷Open×100ATR ÷ Open × 100ATR÷Open×100.
  Volume  — total volume transacted during that session.
  
 3) Storage and lookback 
 Each day’s three session stats are stored as a row. You choose how many recent sessions to keep in memory. The script then:
  
  Builds cumulative returns for APAC, EU, US across the lookback.
  Computes averages, win rates, and a Sharpe-like ratio avgreturn÷avgvolatilityavg return ÷ avg volatilityavgreturn÷avgvolatility per session.
  Tracks streaks of positive or negative sessions to show momentum.
  Tracks drawdowns on cumulative returns to show worst runs from peak.
  Computes rolling means over a short window for short-term drift.
  
 4) Correlation heatmap 
 Using the stored arrays of session returns, the script calculates Pearson correlations between APAC–EU, APAC–US, and EU–US, and colors the matrix by strength and sign so you can spot coupling or decoupling at a glance.
 What it plots 
  
  Three lines: cumulative return for APAC, EU, US over the chosen lookback.
  Zero reference line for orientation.
  A statistics table with cumulative %, average %, positive session rate, and optional columns for volatility, average volume, max drawdown, current streak, return-to-vol ratio, and rolling average.
  A small correlation heatmap table showing APAC, EU, US cross-session correlations.
  
 How to use it 
  
  Pick the asset  — leave Custom Instrument empty to use the chart symbol, or point to another symbol for cross-asset studies.
  Set your sessions and time zones  — defaults approximate APAC, EU, and US hours, but you can align them to exchange times or your workflow.
  Choose calculation modes  — Percent vs Points for return, Range vs ATR for volatility. Points are convenient for futures and fixed-tick assets, Percent is comparable across symbols.
  Decide the lookback  — more sessions smooths lines and stats; fewer sessions makes the tool more reactive.
  Toggle analytics  — add volatility, volume, drawdown, streaks, Sharpe-like ratio, rolling averages, and the correlation table as needed.
  
 Why session attribution helps 
 Different sessions are driven by different flows. Asia often sets the overnight tone, Europe adds liquidity and direction changes, and the US session can dominate range expansion. Separating contributions by session helps you:
  
  Identify which session has been the main driver of net trend.
  Measure whether volatility or volume is concentrated in a specific window.
  See if one session’s gains are consistently given back in another.
  Adapt tactics: fade during a mean-reverting session, press during a trending session.
  
 Reading the tables 
  
  Cumulative %  — sum of session returns over the lookback. The sign and slope tell you who is carrying the move.
  Avg Return % and Positive Sessions %  — direction and hit rate. A low average but high hit rate implies many small moves; the reverse implies occasional big swings.
  Avg Volatility %  — typical intrabars range for that session. Compare with Avg Return to judge efficiency.
  Return/Vol Ratio  — return per unit of volatility. Higher is better for stability.
  Max Drawdown %  — worst cumulative give-back within the lookback. A quick way to spot riskiness by session.
  Current Streak  — consecutive up or down sessions. Useful for mean-reversion or regime awareness.
  Rolling Avg %  — short-window drift indicator to catch recent turnarounds.
  Correlation matrix  — green clusters indicate sessions tending to move together; red indicates offsetting behavior.
  
 Settings overview 
  Basic 
  
  Number of Sessions — how many recent days to include.
  Custom Instrument — analyze another ticker while staying on your current chart.
  
  Session Configuration and Times 
  
  Enable or hide APAC, EU, US rows.
  Set hours per session and the specific time zone for each.
  
  Calculation Methods 
  
  Return Calculation — Percent or Points.
  Volatility Calculation — Range or ATR; ATR Length when applicable.
  
  Advanced Analytics 
  
  Correlation, Drawdown, Momentum, Sharpe-like ratio, Rolling Statistics, Rolling Period.
  
  Display Options and Colors 
  
  Show Statistics Table and its position.
  Toggle columns for Volatility and Volume.
  Pick individual colors for each session line and row accents.
  
 Common applications 
  
  Session bias mapping  — find which window tends to trend in your market and plan exposure accordingly.
  Strategy scheduling  — allocate attention or risk to the session with the best return-to-vol ratio.
  News and macro awareness  — see if correlation rises around central bank cycles or major data releases.
  Cross-asset monitoring  — set the Custom Instrument to a driver (index future, DXY, yields) to see if your symbol reacts in a particular session.
  
 Notes 
 This indicator works on intraday charts, since sessions are defined within a day. If you change session clocks or time zones, give the script a few bars to accumulate fresh rows. Percent vs Points and Range vs ATR choices affect comparability across assets, so be consistent when comparing symbols.
Session context is one of the simplest ways to explain a messy tape. By separating the day into three windows and scoring each one on return, volatility, and consistency, this tool shows not just where price ended up but when and how it got there. Use the cumulative lines to spot the steady driver, read the table to judge quality and risk, and glance at the heatmap to learn whether the sessions are amplifying or canceling one another. Adjust the hours to your market and let the data tell you which session deserves your focus.
Deadband Hysteresis Supertrend [BackQuant]Deadband Hysteresis Supertrend  
  A two-stage trend tool that first filters price with a deadband baseline, then runs a Supertrend around that baseline with optional flip hysteresis and ATR-based adverse exits. 
 What this is 
 A hybrid of two ideas:
  
  Deadband Hysteresis Baseline  that only advances when price pulls far enough from the baseline to matter. This suppresses micro noise and gives you a stable centerline.
  Supertrend bands  wrapped around that baseline instead of raw price. Flips are further gated by an extra margin so side changes are more deliberate.
  
 The goal is fewer whipsaws in chop and clearer regime identification during trends.
 How it works (high level) 
  
  Deadband step  — compute a per-bar “deadband” size from one of four modes: ATR, Percent of price, Ticks, or Points. If price deviates from the baseline by more than this amount, move the baseline forward by a fraction of the excess. If not, hold the line.
  Centered Supertrend  — build upper and lower bands around the baseline using ATR and a user factor. Track the usual trailing logic that tightens a band while price moves in its favor.
  Flip hysteresis  — require price to exceed the active band by an extra  flip offset × ATR  before switching sides. This adds stickiness at the boundary.
  Adverse exit  — once a side is taken, trigger an exit if price moves against the entry by  K × ATR .
  
 If you would like to check out the filter by itself: 
 
 What it plots 
  
  DBHF baseline  (optional) as a smooth centerline.
  DBHF Supertrend  as the active trailing band.
  Candle coloring  by trend side for quick read.
  Signal markers  𝕃 and 𝕊 at flips plus ✖ on adverse exits.
  
 Inputs that matter 
  
  Price Source  — series being filtered. Close is typical. HL2 or HLC3 can be steadier.
  Deadband mode  — ATR, Percent, Ticks, or Points. This defines the “it’s big enough to matter” zone.
  ATR Length / Mult (DBHF)  — only used when mode = ATR. Larger values widen the do-nothing zone.
  Percent / Ticks / Points  — alternatives to ATR; pick what fits your market’s convention.
  Enter Mult  — scales the deadband you must clear before the baseline moves. Increase to filter more noise.
  Response  — fraction of the excess applied to baseline movement. Higher responds faster; lower is smoother.
  Supertrend ATR Period & Factor  — traditional band size controls; higher factor widens and flips less often.
  Flip Offset ATR  — extra ATR buffer required to flip. Useful in choppy regimes.
  Adverse Stop K·ATR  — per-trade danger brake that forces an exit if price moves K×ATR against entry.
  UI  — toggle baseline, supertrend, signals, and bar painting; choose long and short colors.
  
 How to read it 
  
  Green regime  — candles painted long and the Supertrend running below price. Pullbacks toward the baseline that fail to breach the opposite band often resume higher.
  Red regime  — candles painted short and the Supertrend running above price. Rallies that cannot reclaim the band may roll over.
  Frequent side swaps  — reduce sensitivity by increasing Enter Mult, using ATR mode, raising the Supertrend factor, or adding Flip Offset ATR.
  
 Use cases 
  
  Bias filter  — allow entries only in the direction of the current side. Use your preferred triggers inside that bias.
  Trailing logic  — treat the active band as a dynamic stop. If the side flips or an adverse K·ATR exit prints, reduce or close exposure.
  Regime map  — on higher timeframes, the combination baseline + band produces a clean up vs down template for allocation decisions.
  
 Tuning guidance 
  
  Fast markets  — ATR deadband, modest Enter Mult (0.8–1.2), response 0.2–0.35, Supertrend factor 1.7–2.2, small Flip Offset (0.2–0.5 ATR).
  Choppy ranges  — widen deadband or raise Enter Mult, lower response, and add more Flip Offset so flips require stronger evidence.
  Slow trends  — longer ATR periods and higher Supertrend factor to keep you on side longer; use a conservative adverse K.
  
 Included alerts 
  
  DBHF ST Long  — side flips to long.
  DBHF ST Short  — side flips to short.
  Adverse Exit Long / Short  — K·ATR stop triggers against the current side.
  
 Strengths 
  
  Deadbanded baseline reduces micro whipsaws before Supertrend logic even begins.
  Flip hysteresis adds a second layer of confirmation at the boundary.
  Optional adverse ATR stop provides a uniform risk cut across assets and regimes.
  Clear visuals and minimal parameters to adjust for symbol behavior.
  
 Putting it together 
 Think of this tool as two decisions layered into one view. The deadband baseline answers “does this move even count,” then the Supertrend wrapped around that baseline answers “if it counts, which side should I be on and where do I flip.” When both parts agree you tend to stay on the correct side of a trend for longer, and when they disagree you get an early warning that conditions are changing.
 
  When the baseline bends and price cannot reclaim the opposite band , momentum is usually continuing. Pullbacks into the baseline that stall before the far band often resolve in trend.
  When the baseline flattens and the bands compress , expect indecision. Use the Flip Offset ATR to avoid reacting to the first feint. Wait for a clean band breach with follow through.
  When an adverse K·ATR exit prints while the side has not flipped , treat it as a risk event rather than a full regime change. Many users cut size, re-enter only if the side reasserts, and let the next flip confirm a new trend.
  
 Final thoughts 
 Deadband Hysteresis Supertrend is best read as a regime lens. The baseline defines your tolerance for noise, the bands define your trailing structure, and the flip offset plus adverse ATR stop define how forgiving or strict you want to be at the boundary. On strong trends it helps you hold through shallow shakeouts. In choppy conditions it encourages patience until price does something meaningful. Start with settings that reflect the cadence of your market, observe how often flips occur, then nudge the deadband and flip offset until the tool spends most of its time describing the move you care about rather than the noise in between.
ATAI Volume analysis with price action V 1.00ATAI Volume Analysis with Price Action  
 1. Introduction 
 1.1 Overview 
ATAI Volume Analysis with Price Action is a composite indicator designed for TradingView. It combines  per‑side volume data —that is, how much buying and selling occurs during each bar—with standard price‑structure elements such as swings, trend lines and support/resistance. By blending these elements the script aims to help a trader understand which side is in control, whether a breakout is genuine, when markets are potentially exhausted and where liquidity providers might be active.
The indicator is built around TradingView’s up/down volume feed accessed via the TradingView/ta/10 library. The following excerpt from the script illustrates how this feed is configured:
import TradingView/ta/10 as tvta
// Determine lower timeframe string based on user choice and chart resolution
string lower_tf_breakout = use_custom_tf_input ? custom_tf_input :
     timeframe.isseconds  ? "1S" :
     timeframe.isintraday ? "1"  :
     timeframe.isdaily    ? "5"  : "60"
// Request up/down volume (both positive)
  = tvta.requestUpAndDownVolume(lower_tf_breakout)
 Lower‑timeframe selection.  If you do not specify a custom lower timeframe, the script chooses a default based on your chart resolution:  1 second  for second charts,  1 minute  for intraday charts,  5 minutes  for daily charts and  60 minutes  for anything longer. Smaller intervals provide a more precise view of buyer and seller flow but cover fewer bars. Larger intervals cover more history at the cost of granularity.
 Tick vs. time bars.  Many trading platforms offer  a tick / intrabar calculation  mode that updates an indicator on every trade rather than only on bar close. Turning on one‑tick calculation will give the most accurate split between buy and sell volume on the current bar, but it typically reduces the amount of historical data available. For the highest fidelity in live trading you can enable this mode; for studying longer histories you might prefer to disable it. When volume data is completely unavailable (some instruments and crypto pairs), all modules that rely on it will remain silent and only the price‑structure backbone will operate.
  
 Figure caption,  Each panel shows the indicator’s info table for a different volume sampling interval. In the left chart, the parentheses “(5)” beside the buy‑volume figure denote that the script is aggregating volume over five‑minute bars; the center chart uses “(1)” for one‑minute bars; and the right chart uses “(1T)” for a one‑tick interval. These notations tell you which lower timeframe is driving the volume calculations. Shorter intervals such as 1 minute or 1 tick provide finer detail on buyer and seller flow, but they cover fewer bars; longer intervals like five‑minute bars smooth the data and give more history.
   
 Figure caption, The values in parentheses inside the info table come directly from the Breakout — Settings. The first row shows the custom lower-timeframe used for volume calculations (e.g., “(1)”, “(5)”, or “(1T)”)
 2. Price‑Structure Backbone 
Even without volume, the indicator draws structural features that underpin all other modules. These features are always on and serve as the reference levels for subsequent calculations.
 2.1 What it draws 
•	 Pivots:  Swing  highs  and  lows  are detected using the pivot_left_input and pivot_right_input settings. A pivot high is identified when the high recorded pivot_right_input bars ago exceeds the highs of the preceding pivot_left_input bars and is also higher than (or equal to) the highs of the subsequent pivot_right_input bars; pivot lows follow the inverse logic. The indicator retains only a fixed number of such pivot points per side, as defined by point_count_input, discarding the oldest ones when the limit is exceeded.
•	 Trend lines:  For each side, the indicator connects the earliest stored pivot and the most recent pivot (oldest high to newest high, and oldest low to newest low). When a new pivot is added or an old one drops out of the lookback window, the line’s endpoints—and therefore its slope—are recalculated accordingly.
•	 Horizontal support/resistance:  The highest high and lowest low within the lookback window defined by length_input are plotted as horizontal dashed lines. These serve as short‑term support and resistance levels.
•	 Ranked labels:  If showPivotLabels is enabled the indicator prints labels such as “HH1”, “HH2”, “LL1” and “LL2” near each pivot. The ranking is determined by comparing the price of each stored pivot: HH1 is the highest high, HH2 is the second highest, and so on; LL1 is the lowest low, LL2 is the second lowest. In the case of equal prices the newer pivot gets the better rank. Labels are offset from price using  ½ × ATR × label_atr_multiplier,  with the ATR length defined by label_atr_len_input. A dotted connector links each label to the candle’s wick.
 2.2 Key settings 
•	 length_input:  Window length for finding the highest and lowest values and for determining trend line endpoints. A larger value considers more history and will generate longer trend lines and S/R levels.
•	 pivot_left_input, pivot_right_input:  Strictness of swing confirmation. Higher values require more bars on either side to form a pivot; lower values create more pivots but may include minor swings.
•	 point_count_input:  How many pivots are kept in memory on each side. When new pivots exceed this number the oldest ones are discarded.
•	 label_atr_len_input and label_atr_multiplier:  Determine how far pivot labels are offset from the bar using ATR. Increasing the multiplier moves labels further away from price.
•	 Styling inputs  for trend lines, horizontal lines and labels (color, width and line style).
  
 Figure caption,  The chart illustrates how the indicator’s price‑structure backbone operates. In this daily example, the script scans for bars where the high (or low) pivot_right_input bars back is higher (or lower) than the preceding pivot_left_input bars and higher or lower than the subsequent pivot_right_input bars; only those bars are marked as pivots.
     These pivot points are stored and ranked: the highest high is labelled “HH1”, the second‑highest “HH2”, and so on, while lows are marked “LL1”, “LL2”, etc. Each label is offset from the price by half of an ATR‑based distance to keep the chart clear, and a dotted connector links the label to the actual candle.
     The red diagonal line connects the earliest and latest stored high pivots, and the green line does the same for low pivots; when a new pivot is added or an old one drops out of the lookback window, the end‑points and slopes adjust accordingly. Dashed horizontal lines mark the highest high and lowest low within the current lookback window, providing visual support and resistance levels. Together, these elements form the structural backbone that other modules reference, even when volume data is unavailable.
 3. Breakout Module 
 3.1 Concept 
This module confirms that a price break beyond a recent high or low is supported by a genuine shift in buying or selling pressure. It requires price to clear the highest high (“HH1”) or lowest low (“LL1”) and, simultaneously, that the winning side shows a significant volume spike, dominance and ranking. Only  when all volume and price conditions pass  is a breakout labelled.
 3.2 Inputs 
•	 lookback_break_input :  This controls the number of bars used to compute moving averages and percentiles for volume. A larger value smooths the averages and percentiles but makes the indicator respond more slowly.
•	 vol_mult_input : The “spike” multiplier; the current buy or sell volume must be at least this multiple of its moving average over the lookback window to qualify as a breakout.
•	 rank_threshold_input (0–100) :  Defines a volume percentile cutoff: the current buyer/seller volume must be in the top (100−threshold)%(100−threshold)% of all volumes within the lookback window. For example, if set to 80, the current volume must be in the top 20 % of the lookback distribution.
•	 ratio_threshold_input (0–1) :  Specifies the minimum share of total volume that the buyer (for a bullish breakout) or seller (for bearish) must hold on the current bar; the code also requires that the cumulative buyer volume over the lookback window exceeds the seller volume (and vice versa for bearish cases).
•	 use_custom_tf_input / custom_tf_input :  When enabled, these inputs override the automatic choice of lower timeframe for up/down volume; otherwise the script selects a sensible default based on the chart’s timeframe.
•	 Label appearance settings :  Separate options control the ATR-based offset length, offset multiplier, label size and colors for bullish and bearish breakout labels, as well as the connector style and width.
 3.3 Detection logic 
 1.	Data preparation : Retrieve per‑side volume from the lower timeframe and take absolute values. Build rolling arrays of the last lookback_break_input values to compute simple moving averages (SMAs), cumulative sums and percentile ranks for buy and sell volume.
 2.	Volume spike:  A spike is flagged when the current buy (or, in the bearish case, sell) volume is at least vol_mult_input times its SMA over the lookback window.
 3.	Dominance test:  The buyer’s (or seller’s) share of total volume on the current bar must meet or exceed ratio_threshold_input. In addition, the cumulative sum of buyer volume over the window must exceed the cumulative sum of seller volume for a bullish breakout (and vice versa for bearish). A separate requirement checks the sign of delta: for bullish breakouts delta_breakout must be non‑negative; for bearish breakouts it must be non‑positive.
 4.	Percentile rank:  The current volume must fall within the top (100 – rank_threshold_input) percent of the lookback distribution—ensuring that the spike is unusually large relative to recent history.
 5.	Price test:  For a bullish signal, the closing price must close above the highest pivot (HH1); for a bearish signal, the close must be below the lowest pivot (LL1).
 6.	Labeling:  When all conditions above are satisfied, the indicator prints “Breakout ↑” above the bar (bullish) or “Breakout ↓” below the bar (bearish). Labels are offset using half of an ATR‑based distance and linked to the candle with a dotted connector.
  
 Figure caption,  (Breakout ↑ example) , On this daily chart, price pushes above the red trendline and the highest prior pivot (HH1). The indicator recognizes this as a valid breakout because the buyer‑side volume on the lower timeframe spikes above its recent moving average and buyers dominate the volume statistics over the lookback period; when combined with a close above HH1, this satisfies the breakout conditions. The “Breakout ↑” label appears above the candle, and the info table highlights that up‑volume is elevated relative to its 11‑bar average, buyer share exceeds the dominance threshold and money‑flow metrics support the move.
  
 Figure caption,  In this daily example, price breaks below the lowest pivot (LL1) and the lower green trendline. The indicator identifies this as a bearish breakout because sell‑side volume is sharply elevated—about twice its 11‑bar average—and sellers dominate both the bar and the lookback window. With the close falling below LL1, the script triggers a Breakout ↓ label and marks the corresponding row in the info table, which shows strong down volume, negative delta and a seller share comfortably above the dominance threshold.
 4. Market Phase Module (Volume Only) 
 4.1 Concept 
Not all markets trend; many cycle between periods of  accumulation  (buying pressure building up),  distribution  (selling pressure dominating) and  neutral  behavior. This module classifies the current bar into one of these phases  without using ATR , relying solely on buyer and seller volume statistics. It looks at net flows, ratio changes and an OBV‑like cumulative line with dual‑reference (1‑ and 2‑bar) trends. The result is displayed both as on‑chart labels and in a dedicated row of the info table.
 4.2 Inputs 
•	 phase_period_len:  Number of bars over which to compute sums and ratios for phase detection.
•	 phase_ratio_thresh : Minimum buyer share (for accumulation) or minimum seller share (for distribution, derived as 1 − phase_ratio_thresh) of the total volume.
•	 strict_mode:  When enabled, both the 1‑bar and 2‑bar changes in each statistic must agree on the direction (strict confirmation); when disabled, only one of the two references needs to agree (looser confirmation).
•	 Color customisation  for info table cells and label styling for accumulation and distribution phases, including ATR length, multiplier, label size, colors and connector styles.
•	 show_phase_module:  Toggles the entire phase detection subsystem.
•	 show_phase_labels:  Controls whether on‑chart labels are drawn when accumulation or distribution is detected.
 4.3 Detection logic 
The module computes three families of statistics over the volume window defined by phase_period_len:
 1.	Net sum (buyers minus sellers):  net_sum_phase = Σ(buy) − Σ(sell). A positive value indicates a predominance of buyers. The code also computes the differences between the current value and the values 1 and 2 bars ago (d_net_1, d_net_2) to derive up/down trends.
 2.	Buyer ratio:  The instantaneous ratio TF_buy_breakout / TF_tot_breakout and the window ratio Σ(buy) / Σ(total). The current ratio must exceed phase_ratio_thresh for accumulation or fall below 1 − phase_ratio_thresh for distribution. The first and second differences of the window ratio (d_ratio_1, d_ratio_2) determine trend direction.
 3.	OBV‑like cumulative net flow:  An on‑balance volume analogue obv_net_phase increments by TF_buy_breakout − TF_sell_breakout each bar. Its differences over the last 1 and 2 bars (d_obv_1, d_obv_2) provide trend clues.
The algorithm then combines these signals:
•	For  strict mode , accumulation requires: (a) current ratio ≥ threshold, (b) cumulative ratio ≥ threshold, (c) both ratio differences ≥ 0, (d) net sum differences ≥ 0, and (e) OBV differences ≥ 0. Distribution is the mirror case.
•	For  loose mode , it relaxes the directional tests: either the 1‑ or the 2‑bar difference needs to agree in each category.
If all conditions for accumulation are satisfied, the phase is labelled  “Accumulation” ; if all conditions for distribution are satisfied, it’s labelled  “Distribution” ; otherwise the phase is  “Neutral” .
 4.4 Outputs 
•	 Info table row : Row 8 displays “Market Phase (Vol)” on the left and the detected phase (Accumulation, Distribution or Neutral) on the right. The text colour of both cells matches a user‑selectable palette (typically green for accumulation, red for distribution and grey for neutral).
•	 On‑chart labels : When show_phase_labels is enabled and a phase persists for at least one bar, the module prints a label above the bar ( “Accum” ) or below the bar ( “Dist” ) with a dashed or dotted connector. The label is offset using ATR based on phase_label_atr_len_input and phase_label_multiplier and is styled according to user preferences.
  
 Figure caption, The chart displays a red “Dist” label above a particular bar, indicating that the accumulation/distribution module identified a distribution phase at that point. The detection is based on seller dominance: during that bar, the net buyer-minus-seller flow and the OBV‑style cumulative flow were trending down, and the buyer ratio had dropped below the preset threshold. These conditions satisfy the distribution criteria in strict mode. The label is placed above the bar using an ATR‑based offset and a dashed connector. By the time of the current bar in the screenshot, the phase indicator shows “Neutral” in the info table—signaling that neither accumulation nor distribution conditions are currently met—yet the historical “Dist” label remains to mark where the prior distribution phase began.
  
 Figure caption, In this example the market phase module has signaled an Accumulation phase. Three bars before the current candle, the algorithm detected a shift toward buyers: up‑volume exceeded its moving average, down‑volume was below average, and the buyer share of total volume climbed above the threshold while the on‑balance net flow and cumulative ratios were trending upwards. The blue “Accum” label anchored below that bar marks the start of the phase; it remains on the chart because successive bars continue to satisfy the accumulation conditions. The info table confirms this: the “Market Phase (Vol)” row still reads Accumulation, and the ratio and sum rows show buyers dominating both on the current bar and across the lookback window.
 5. OB/OS Spike Module 
 5.1 What overbought/oversold means here 
In many markets, a rapid extension up or down is often followed by a period of consolidation or reversal. The indicator interprets overbought (OB) conditions as abnormally strong selling risk at or after a price rally and oversold (OS) conditions as unusually strong buying risk after a decline. Importantly, these are not direct trade signals; rather they flag areas where caution or contrarian setups may be appropriate.
 5.2 Inputs 
•	 minHits_obos (1–7):  Minimum number of oscillators that must agree on an overbought or oversold condition for a label to print.
•	 syncWin_obos:  Length of a small sliding window over which oscillator votes are smoothed by taking the maximum count observed. This helps filter out choppy signals.
•	 Volume spike criteria:  kVolRatio_obos (ratio of current volume to its SMA) and zVolThr_obos (Z‑score threshold) across volLen_obos. Either threshold can trigger a spike.
•	 Oscillator toggles and periods:  Each of RSI, Stochastic (K and D), Williams %R, CCI, MFI, DeMarker and Stochastic RSI can be independently enabled; their periods are adjustable.
•	 Label appearance:  ATR‑based offset, size, colors for OB and OS labels, plus connector style and width.
 5.3 Detection logic 
 1.	Directional volume spikes:  Volume spikes are computed separately for buyer and seller volumes. A sell volume spike (sellVolSpike) flags a potential OverBought bar, while a buy volume spike (buyVolSpike) flags a potential OverSold bar. A spike occurs when the respective volume exceeds kVolRatio_obos times its simple moving average over the window or when its Z‑score exceeds zVolThr_obos.
 2.	Oscillator votes:  For each enabled oscillator, calculate its overbought and oversold state using standard thresholds (e.g., RSI ≥ 70 for OB and ≤ 30 for OS; Stochastic %K/%D ≥ 80 for OB and ≤ 20 for OS; etc.). Count how many oscillators vote for OB and how many vote for OS.
 3.	Minimum hits:  Apply the smoothing window syncWin_obos to the vote counts using a maximum‑of‑last‑N approach. A candidate bar is only considered if the smoothed OB hit count ≥ minHits_obos (for OverBought) or the smoothed OS hit count ≥ minHits_obos (for OverSold).
 4.	Tie‑breaking:  If both OverBought and OverSold spike conditions are present on the same bar, compare the smoothed hit counts: the side with the higher count is selected; ties default to OverBought.
 5.	Label printing:  When conditions are met, the bar is labelled as “OverBought X/7” above the candle or “OverSold X/7” below it. “X” is the number of oscillators confirming, and the bracket lists the abbreviations of contributing oscillators. Labels are offset from price using half of an ATR‑scaled distance and can optionally include a dotted or dashed connector line.
  
 Figure caption,  In this chart the overbought/oversold module has flagged an OverSold signal. A sell‑off from the prior highs brought price down to the lower trend‑line, where the bar marked “OverSold 3/7 DeM” appears. This label indicates that on that bar the module detected a buy‑side volume spike and that at least three of the seven enabled oscillators—in this case including the DeMarker—were in oversold territory. The label is printed below the candle with a dotted connector, signaling that the market may be temporarily exhausted on the downside. After this oversold print, price begins to rebound towards the upper red trend‑line and higher pivot levels.
  
 Figure caption, This example shows the overbought/oversold module in action. In the left‑hand panel you can see the OB/OS settings where each oscillator  (RSI, Stochastic, Williams %R, CCI, MFI, DeMarker and Stochastic RSI)  can be enabled or disabled, and the ATR length and label offset multiplier adjusted. On the chart itself, price has pushed up to the descending red trendline and triggered an “OverBought 3/7” label. That means the sell‑side volume spiked relative to its average and three out of the seven enabled oscillators were in overbought territory. The label is offset above the candle by half of an ATR and connected with a dashed line, signaling that upside momentum may be overextended and a pause or pullback could follow.
 6. Buyer/Seller Trap Module 
 6.1 Concept 
A bull trap occurs when price appears to break above resistance, attracting buyers, but fails to sustain the move and quickly reverses, leaving a long upper wick and trapping late entrants. A bear trap is the opposite: price breaks below support, lures in sellers, then snaps back, leaving a long lower wick and trapping shorts. This module detects such traps by looking for price structure sweeps, order‑flow mismatches and dominance reversals. It uses a scoring system to differentiate risk from confirmed traps.
 6.2 Inputs 
•	 trap_lookback_len:  Window length used to rank extremes and detect sweeps.
•	 trap_wick_threshold:  Minimum proportion of a bar’s range that must be wick (upper for bull traps, lower for bear traps) to qualify as a sweep.
•	 trap_score_risk:  Minimum aggregated score required to flag a trap risk. (The code defines a trap_score_confirm input, but confirmation is actually based on price reversal rather than a separate score threshold.)
•	 trap_confirm_bars:  Maximum number of bars allowed for price to reverse and confirm the trap. If price does not reverse in this window, the risk label will expire or remain unconfirmed.
•	 Label settings:  ATR length and multiplier for offsetting, size, colours for risk and confirmed labels, and connector style and width. Separate settings exist for bull and bear traps.
•	 Toggle inputs:  show_trap_module and show_trap_labels enable the module and control whether labels are drawn on the chart.
 6.3 Scoring logic 
The module assigns points to several conditions and sums them to determine whether a trap risk is present. For bull traps, the score is built from the following (bear traps mirror the logic with highs and lows swapped):
 1.	Sweep (2 points):  Price trades above the high pivot (HH1) but fails to close above it and leaves a long upper wick at least trap_wick_threshold × range. For bear traps, price dips below the low pivot (LL1), fails to close below and leaves a long lower wick.
 2.	Close break (1 point):  Price closes beyond HH1 or LL1 without leaving a long wick.
 3.	Candle/delta mismatch (2 points):  The candle closes bullish yet the order flow delta is negative or the seller ratio exceeds 50%, indicating hidden supply. Conversely, a bearish close with positive delta or buyer dominance suggests hidden demand.
 4.	Dominance inversion (2 points):  The current bar’s buyer volume has the highest rank in the lookback window while cumulative sums favor sellers, or vice versa.
 5.	Low‑volume break (1 point):  Price crosses the pivot but total volume is below its moving average.
The total score for each side is compared to trap_score_risk. If the score is high enough, a  “Bull Trap Risk”  or  “Bear Trap Risk”  label is drawn, offset from the candle by half of an ATR‑scaled distance using a dashed outline. If, within trap_confirm_bars, price reverses beyond the opposite level—drops back below the high pivot for bull traps or rises above the low pivot for bear traps—the label is upgraded to a solid  “Bull Trap”  or  “Bear Trap” . In this version of the code, there is no separate score threshold for confirmation: the variable trap_score_confirm is unused; confirmation depends solely on a successful price reversal within the specified number of bars.
  
 Figure caption, In this example the trap module has flagged a Bear Trap Risk. Price initially breaks below the most recent low pivot (LL1), but the bar closes back above that level and leaves a long lower wick, suggesting a failed push lower. Combined with a mismatch between the candle direction and the order flow (buyers regain control) and a reversal in volume dominance, the aggregate score exceeds the risk threshold, so a dashed “Bear Trap Risk” label prints beneath the bar. The green and red trend lines mark the current low and high pivot trajectories, while the horizontal dashed lines show the highest and lowest values in the lookback window. If, within the next few bars, price closes decisively above the support, the risk label would upgrade to a solid “Bear Trap” label.
  
 Figure caption, In this example the trap module has identified both ends of a price range. Near the highs, price briefly pushes above the descending red trendline and the recent pivot high, but fails to close there and leaves a noticeable upper wick. That combination of a sweep above resistance and order‑flow mismatch generates a Bull Trap Risk label with a dashed outline, warning that the upside break may not hold. At the opposite extreme, price later dips below the green trendline and the labelled low pivot, then quickly snaps back and closes higher. The long lower wick and subsequent price reversal upgrade the previous bear‑trap risk into a confirmed Bear Trap (solid label), indicating that sellers were caught on a false breakdown. Horizontal dashed lines mark the highest high and lowest low of the lookback window, while the red and green diagonals connect the earliest and latest pivot highs and lows to visualize the range.
 7. Sharp Move Module 
 7.1 Concept 
Markets sometimes display absorption or climax behavior—periods when one side steadily gains the upper hand before price breaks out with a sharp move. This module evaluates several order‑flow and volume conditions to anticipate such moves. Users can choose how many conditions must be met to flag a risk and how many (plus a price break) are required for confirmation.
 7.2 Inputs 
 •	sharp Lookback:  Number of bars in the window used to compute moving averages, sums, percentile ranks and reference levels.
 •	sharpPercentile:  Minimum percentile rank for the current side’s volume; the current buy (or sell) volume must be greater than or equal to this percentile of historical volumes over the lookback window.
 •	sharpVolMult:  Multiplier used in the volume climax check. The current side’s volume must exceed this multiple of its average to count as a climax.
 •	sharpRatioThr:  Minimum dominance ratio (current side’s volume relative to the opposite side) used in both the instant and cumulative dominance checks.
 •	sharpChurnThr:  Maximum ratio of a bar’s range to its ATR for absorption/churn detection; lower values indicate more absorption (large volume in a small range).
 •	sharpScoreRisk:  Minimum number of conditions that must be true to print a risk label.
 •	sharpScoreConfirm:  Minimum number of conditions plus a price break required for confirmation.
 •	sharpCvdThr:  Threshold for cumulative delta divergence versus price change (positive for bullish accumulation, negative for bearish distribution).
 •	Label settings:  ATR length (sharpATRlen) and multiplier (sharpLabelMult) for positioning labels, label size, colors and connector styles for bullish and bearish sharp moves.
 •	Toggles:  enableSharp activates the module; show_sharp_labels controls whether labels are drawn.
 7.3 Conditions (six per side) 
For each side, the indicator computes six boolean conditions and sums them to form a score:
 1.	Dominance (instant and cumulative): 
–	 Instant dominance:  current buy volume ≥ sharpRatioThr × current sell volume.
–	 Cumulative dominance:  sum of buy volumes over the window ≥ sharpRatioThr × sum of sell volumes (and vice versa for bearish checks).
 2.	Accumulation/Distribution divergence:  Over the lookback window, cumulative delta rises by at least sharpCvdThr while price fails to rise (bullish), or cumulative delta falls by at least sharpCvdThr while price fails to fall (bearish).
 3.	Volume climax:  The current side’s volume is ≥ sharpVolMult × its average and the product of volume and bar range is the highest in the lookback window.
 4.	Absorption/Churn:  The current side’s volume divided by the bar’s range equals the highest value in the window and the bar’s range divided by ATR ≤ sharpChurnThr (indicating large volume within a small range).
 5.	Percentile rank:  The current side’s volume percentile rank is ≥ sharp Percentile.
 6.	Mirror logic for sellers:  The above checks are repeated with buyer and seller roles swapped and the price break levels reversed.
Each condition that passes contributes one point to the corresponding side’s score (0 or 1). Risk and confirmation thresholds are then applied to these scores.
 7.4 Scoring and labels 
 •	Risk:  If scoreBull ≥ sharpScoreRisk, a “Sharp ↑ Risk” label is drawn above the bar. If scoreBear ≥ sharpScoreRisk, a “Sharp ↓ Risk” label is drawn below the bar.
 •	Confirmation:  A risk label is upgraded to “Sharp ↑” when scoreBull ≥ sharpScoreConfirm and the bar closes above the highest recent pivot (HH1); for bearish cases, confirmation requires scoreBear ≥ sharpScoreConfirm and a close below the lowest pivot (LL1).
 •	Label positioning:  Labels are offset from the candle by ATR × sharpLabelMult (full ATR times multiplier), not half, and may include a dashed or dotted connector line if enabled.
  
 Figure caption, In this chart both bullish and bearish sharp‑move setups have been flagged. Earlier in the range, a  “Sharp ↓ Risk”  label appears beneath a candle: the sell‑side score met the risk threshold, signaling that the combination of strong sell volume, dominance and absorption within a narrow range suggested a potential sharp decline. The price did not close below the lower pivot, so this label remains a “risk” and no confirmation occurred. Later, as the market recovered and volume shifted back to the buy side, a  “Sharp ↑ Risk”  label prints above a candle near the top of the channel. Here, buy‑side dominance, cumulative delta divergence and a volume climax aligned, but price has not yet closed above the upper pivot (HH1), so the alert is still a risk rather than a confirmed sharp‑up move.
  
 Figure caption, In this chart a Sharp ↑ label is displayed above a candle, indicating that the sharp move module has confirmed a bullish breakout. Prior bars satisfied the risk threshold — showing buy‑side dominance, positive cumulative delta divergence, a volume climax and strong absorption in a narrow range — and this candle closes above the highest recent pivot, upgrading the earlier “Sharp ↑ Risk” alert to a full Sharp ↑ signal. The green label is offset from the candle with a dashed connector, while the red and green trend lines trace the high and low pivot trajectories and the dashed horizontals mark the highest and lowest values of the lookback window.
 8. Market‑Maker / Spread‑Capture Module 
 8.1 Concept 
Liquidity providers often  “capture the spread”  by buying and selling in almost equal amounts within a very narrow price range. These bars can signal temporary congestion before a move or reflect algorithmic activity. This module flags bars where  both buyer and seller volumes are high,  the price range is only a few ticks and the buy/sell split remains close to 50%. It helps traders spot potential liquidity pockets.
 8.2 Inputs 
 •	scalpLookback:  Window length used to compute volume averages.
 •	scalpVolMult:  Multiplier applied to each side’s average volume; both buy and sell volumes must exceed this multiple.
 •	scalpTickCount:  Maximum allowed number of ticks in a bar’s range (calculated as (high − low) / minTick). A value of 1 or 2 captures ultra‑small bars; increasing it relaxes the range requirement.
 •	scalpDeltaRatio:  Maximum deviation from a perfect 50/50 split. For example, 0.05 means the buyer share must be between 45% and 55%.
 •	Label settings:  ATR length, multiplier, size, colors, connector style and width.
 •	Toggles :  show_scalp_module and show_scalp_labels to enable the module and its labels.
 8.3 Signal 
When, on the current bar, both TF_buy_breakout and TF_sell_breakout exceed scalpVolMult times their respective averages and (high − low)/minTick ≤ scalpTickCount and the buyer share is within scalpDeltaRatio of 50%, the module prints a  “Spread ↔”  label above the bar. The label uses the same ATR offset logic as other modules and draws a connector if enabled.
  
 Figure caption, In this chart the spread‑capture module has identified a potential liquidity pocket. Buyer and seller volumes both spiked above their recent averages, yet the candle’s range measured only a couple of ticks and the buy/sell split stayed close to 50 %. This combination met the module’s criteria, so it printed a grey “Spread ↔” label above the bar. The red and green trend lines link the earliest and latest high and low pivots, and the dashed horizontals mark the highest high and lowest low within the current lookback window.
 9. Money Flow Module 
 9.1 Concept 
To translate volume into a monetary measure, this module multiplies each side’s volume by the closing price. It tracks buying and selling system money default currency on a per-bar basis and sums them over a chosen period. The difference between buy and sell currencies (Δ$) shows net inflow or outflow.
 9.2 Inputs 
 •	mf_period_len_mf:  Number of bars used for summing buy and sell dollars.
 •	Label appearance settings:  ATR length, multiplier, size, colors for up/down labels, and connector style and width.
 •	Toggles:  Use enableMoneyFlowLabel_mf and showMFLabels to control whether the module and its labels are displayed.
 9.3 Calculations 
 •	Per-bar money:  Buy $ = TF_buy_breakout × close; Sell $ = TF_sell_breakout × close. Their difference is Δ$ = Buy $ − Sell $.
 •	Summations:  Over mf_period_len_mf bars, compute Σ Buy $, Σ Sell $ and ΣΔ$ using math.sum().
 •	Info table entries:  Rows 9–13 display these values as texts like “↑ USD 1234 (1M)” or “ΣΔ USD −5678 (14)”, with colors reflecting whether buyers or sellers dominate.
 •	Money flow status:  If Δ$ is positive the bar is marked  “Money flow in” ; if negative,  “Money flow out” ; if zero, “Neutral”. The cumulative status is similarly derived from ΣΔ.Labels print at the bar that changes the sign of ΣΔ, offset using ATR × label multiplier and styled per user preferences.
  
 Figure caption, The chart illustrates a steady rise toward the highest recent pivot (HH1) with price riding between a rising green trend‑line and a red trend‑line drawn through earlier pivot highs. A green Money flow in label appears above the bar near the top of the channel, signaling that net dollar flow turned positive on this bar: buy‑side dollar volume exceeded sell‑side dollar volume, pushing the cumulative sum ΣΔ$ above zero. In the info table, the  “Money flow (bar)”  and  “Money flow Σ”  rows both read In, confirming that the indicator’s money‑flow module has detected an inflow at both bar and aggregate levels, while other modules (pivots, trend lines and support/resistance) remain active to provide structural context.
  
In this example the Money Flow module signals a net outflow. Price has been trending downward: successive high pivots form a falling red trend‑line and the low pivots form a descending green support line. When the latest bar broke below the previous low pivot (LL1), both the bar‑level and cumulative net dollar flow turned negative—selling volume at the close exceeded buying volume and pushed the cumulative Δ$ below zero. The module reacts by printing a red  “Money flow out”  label beneath the candle; the info table confirms that the “Money flow (bar)” and “Money flow Σ” rows both show Out, indicating sustained dominance of sellers in this period.
 10. Info Table 
 10.1 Purpose 
When enabled, the Info Table appears in the lower right of your chart. It summarises key values computed by the indicator—such as buy and sell volume, delta, total volume, breakout status, market phase, and money flow—so you can see at a glance which side is dominant and which signals are active.
 10.2 Symbols 
•	↑ / ↓ — Up (↑) denotes buy volume or money; down (↓) denotes sell volume or money.
•	MA — Moving average. In the table it shows the average value of a series over the lookback period.
•	Σ (Sigma) — Cumulative sum over the chosen lookback period.
•	Δ (Delta) — Difference between buy and sell values.
•	B / S — Buyer and seller share of total volume, expressed as percentages.
•	Ref. Price — Reference price for breakout calculations, based on the latest pivot.
•	Status — Indicates whether a breakout condition is currently active (True) or has failed.
 10.3 Row definitions 
1.	Up volume / MA up volume – Displays current buy volume on the lower timeframe and its moving average over the lookback period.
2.	Down volume / MA down volume – Shows current sell volume and its moving average; sell values are formatted in red for clarity.
3.	Δ / ΣΔ – Lists the difference between buy and sell volume for the current bar and the cumulative delta volume over the lookback period.
4.	Σ / MA Σ (Vol/MA) – Total volume (buy + sell) for the bar, with the ratio of this volume to its moving average; the right cell shows the average total volume.
5.	B/S ratio – Buy and sell share of the total volume: current bar percentages and the average percentages across the lookback period.
6.	Buyer Rank / Seller Rank – Ranks the bar’s buy and sell volumes among the last (n) bars; lower rank numbers indicate higher relative volume.
7.	Σ Buy / Σ Sell – Sum of buy and sell volumes over the lookback window, indicating which side has traded more.
8.	Breakout UP / DOWN – Shows the breakout thresholds (Ref. Price) and whether the breakout condition is active (True) or has failed.
9.	Market Phase (Vol) – Reports the current volume‑only phase: Accumulation, Distribution or Neutral.
10.	Money Flow – The final rows display dollar amounts and status:
–	↑ USD / Σ↑ USD – Buy dollars for the current bar and the cumulative sum over the money‑flow period.
–	↓ USD / Σ↓ USD – Sell dollars and their cumulative sum.
–	Δ USD / ΣΔ USD – Net dollar difference (buy minus sell) for the bar and cumulatively.
–	Money flow (bar) – Indicates whether the bar’s net dollar flow is positive (In), negative (Out) or neutral.
–	Money flow Σ – Shows whether the cumulative net dollar flow across the chosen period is positive, negative or neutral.
  
The chart above shows a sequence of different signals from the indicator. A Bull Trap Risk appears after price briefly pushes above resistance but fails to hold, then a green Accum label identifies an accumulation phase. An upward breakout follows, confirmed by a Money flow in print. Later, a Sharp ↓ Risk warns of a possible sharp downturn; after price dips below support but quickly recovers, a Bear Trap label marks a false breakdown. The highlighted info table in the center summarizes key metrics at that moment, including current and average buy/sell volumes, net delta, total volume versus its moving average, breakout status (up and down), market phase (volume), and bar‑level and cumulative money flow (In/Out).
 11. Conclusion & Final Remarks 
This indicator was developed as a holistic study of market structure and order flow. It brings together several well‑known concepts from technical analysis—breakouts, accumulation and distribution phases, overbought and oversold extremes, bull and bear traps, sharp directional moves, market‑maker spread bars and money flow—into a single Pine Script tool. Each module is based on widely recognized trading ideas and was implemented after consulting reference materials and example strategies, so you can see in real time how these concepts interact on your chart.
A distinctive feature of this indicator is its reliance on per‑side volume: instead of tallying only total volume, it separately measures buy and sell transactions on a lower time frame. This approach gives a clearer view of who is in control—buyers or sellers—and helps filter breakouts, detect phases of accumulation or distribution, recognize potential traps, anticipate sharp moves and gauge whether liquidity providers are active. The money‑flow module extends this analysis by converting volume into currency values and tracking net inflow or outflow across a chosen window.
Although comprehensive, this indicator is intended solely as a guide. It highlights conditions and statistics that many traders find useful, but it does not generate trading signals or guarantee results. Ultimately, you remain responsible for your positions. Use the information presented here to inform your analysis, combine it with other tools and risk‑management techniques, and always make your own decisions when trading.
Turtle Body Setup by TradeTech AnalysisOverview 
 Turtle Body Setup  is a minimalist, rules-based pattern detector built around a simple idea: a sequence of shrinking candle bodies (compression) often precedes a directional expansion (breakout). The script identifies those compression phases and then flags the first candle whose body expands significantly beyond the recent average, with polarity taken from the candle’s direction.
This is not a mash-up of many public indicators. It focuses on one original micro-structure concept:  strict body-contraction → body-expansion . The logic is fully described below so traders and moderators can understand what it does and how to use it.
 How it Works 
 1.	Compression detection (body contraction): 
	•	Over a user-defined window Compression Lookback (N), the script counts strictly shrinking candle bodies (|close-open|).
	•	When the count ≥ Min Shrinking Candles, we mark the market as in compression.
 2.	Expansion / Breakout qualification: 
	•	Compute avgBody = SMA(body, N).
	•	A candle is a breakout when current body > avgBody × Breakout Body Multiplier.
	•	Polarity: green (close>open) → Bullish breakout; red (close
Deadband Hysteresis Filter [BackQuant]Deadband Hysteresis Filter  
 What this is 
This tool builds a “debounced” price baseline that ignores small fluctuations and only reacts when price meaningfully departs from its recent path. It uses a deadband to define how much deviation matters and a hysteresis scheme to avoid rapid flip-flops around the decision boundary. The baseline’s slope provides a simple trend cue, used to color candles and to trigger up and down alerts.
 Why deadband and hysteresis help 
  
  They filter micro noise so the baseline does not react to every tiny tick.
  They stabilize state changes. Hysteresis means the rule to start moving is stricter than the rule to keep holding, which reduces whipsaw.
  They produce a stepped, readable path that advances during sustained moves and stays flat during chop.
  
 How it works (conceptual) 
 At each bar the script maintains a running baseline  dbhf  and compares it to the input price  p .
 
  Compute a base threshold  baseTau  using the selected mode (ATR, Percent, Ticks, or Points).
  Build an  enter  band  tauEnter = baseTau × Enter Mult  and an  exit  band  tauExit = baseTau × Exit Mult  where typically  Exit Mult < Enter Mult .
  Let  diff = p − dbhf .
  
  If  diff > +tauEnter , raise the baseline by  response × (diff − tauEnter) .
  If  diff < −tauEnter , lower the baseline by  response × (diff + tauEnter) .
  Otherwise, hold the prior value.
  
  Trend state is derived from slope:  dbhf > dbhf  → up trend,  dbhf < dbhf  → down trend.
  
 Inputs and what they control 
 Threshold mode 
  
  ATR  —  baseTau = ATR(atrLen) × atrMult . Adapts to volatility. Useful when regimes change.
  Percent  —  baseTau = |price| × pctThresh% . Scale-free across symbols of different prices.
  Ticks  —  baseTau = syminfo.mintick × tickThresh . Good for futures where tick size matters.
  Points  —  baseTau = ptsThresh . Fixed distance in price units.
  
 Band multipliers and response 
  
  Enter Mult  — outer band. Price must travel at least this far from the baseline before an update occurs. Larger values reject more noise but increase lag.
  Exit Mult  — inner band for hysteresis. Keep this smaller than Enter Mult to create a hold zone that resists small re-entries.
  Response  — step size when outside the enter band. Higher response tracks faster; lower response is smoother.
  
 UI settings 
  
  Show Filtered Price  — plots the baseline on price.
  Paint candles  — colors bars by the filtered slope using your long/short colors.
  
 How it can be used 
  
  Trend qualifier  — take entries only in the direction of the baseline slope and skip trades against it.
  Debounced crossovers  — use the baseline as a stabilized surrogate for price in moving-average or channel crossover rules.
  Trailing logic  — trail stops a small distance beyond the baseline so small pullbacks do not eject the trade.
  Session aware filtering  — widen Enter Mult or switch to ATR mode for volatile sessions; tighten in quiet sessions.
  
 Parameter interactions and tuning 
  
  Enter Mult vs Response  — both govern sensitivity. If you see too many flips, increase Enter Mult or reduce Response. If turns feel late, do the opposite.
  Exit Mult  — widening the gap between Enter and Exit expands the hold zone and reduces oscillation around the threshold.
  Mode choice  — ATR adapts automatically; Percent keeps behavior consistent across instruments; Ticks or Points are useful when you think in fixed increments.
  Timeframe coupling  — on higher timeframes you can often lower Enter Mult or raise Response because raw noise is already reduced.
  
 Concrete starter recipes 
  
  General purpose  — ATR mode,  atrLen=14 ,  atrMult=1.0–1.5 ,  Enter=1.0 ,  Exit=0.5 ,  Response=0.20 . Balanced noise rejection and lag.
  Choppy range filter  — ATR mode, increase  atrMult  to 2.0, keep  Response≈0.15 . Stronger suppression of micro-moves.
  Fast intraday  — Percent mode,  pctThresh=0.1–0.3 ,  Enter=1.0 ,  Exit=0.4–0.6 ,  Response=0.30–0.40 . Quicker turns for scalping.
  Futures ticks  — Ticks mode, set  tickThresh  to a few spreads beyond typical noise; start with  Enter=1.0 ,  Exit=0.5 ,  Response=0.25 .
  
 Strengths 
  
  Clear, explainable logic with an explicit noise budget.
  Multiple threshold modes so the same tool fits equities, futures, and crypto.
  Built-in hysteresis that reduces flip-flop near the boundary.
  Slope-based coloring and alerts that make state changes obvious in real time.
  
 Limitations and notes 
  
  All filters add lag. Larger thresholds and smaller response trade faster reaction for fewer false turns.
  Fixed Points or Ticks can under- or over-filter when volatility regime shifts. ATR adapts, but will also expand bands during spikes.
  On extremely choppy symbols, even a well tuned band will step frequently. Widen Enter Mult or reduce Response if needed.
  This is a chart study. It does not include commissions, slippage, funding, or gap risks.
  
 Alerts 
  
  DBHF Up Slope  — baseline turns from down to up on the latest bar.
  DBHF Down Slope  — baseline turns from up to down on the latest bar.
  
 Implementation details worth knowing 
  
  Initialization sets the baseline to the first observed price to avoid a cold-start jump.
  Slope is evaluated bar-to-bar. The up and down alerts check for a change of slope rather than raw price crossings.
  Candle colors and the baseline plot share the same long/short palette with transparency applied to the line.
  
 Practical workflow 
  
  Pick a mode that matches how you think about distance. ATR for volatility aware, Percent for scale-free, Ticks or Points for fixed increments.
  Tune Enter Mult until the number of flips feels appropriate for your timeframe.
  Set Exit Mult clearly below Enter Mult to create a real hold zone.
  Adjust Response last to control “how fast” the baseline chases price once it decides to move.
  
 Final thoughts 
 Deadband plus hysteresis gives you a principled way to “only care when it matters.” With a sensible threshold and response, the filter yields a stable, low-chop trend cue you can use directly for bias or plug into your own entries, exits, and risk rules.
Martingale Strategy Simulator [BackQuant]Martingale Strategy Simulator  
 Purpose 
This indicator lets you study how a martingale-style position sizing rule interacts with a simple long or short trading signal. It computes an equity curve from bar-to-bar returns, adapts position size after losing streaks, caps exposure at a user limit, and summarizes risk with portfolio metrics. An optional Monte Carlo module projects possible future equity paths from your realized daily returns.
 What a martingale is 
A martingale sizing rule increases stake after losses and resets after a win. In its classical form from gambling, you double the bet after each loss so that a single win recovers all prior losses plus one unit of profit. In markets there is no fixed “even-money” payout and returns are multiplicative, so an exact recovery guarantee does not exist. The core idea is unchanged:
  
  Lose one leg → increase next position size
  Lose again → increase again
  Win → reset to the base size
  
  The expectation of your strategy still depends on the signal’s edge. Sizing does not create positive expectancy on its own. A martingale raises variance and tail risk by concentrating more capital as a losing streak develops. 
 What it plots 
  
  Equity  – simulated portfolio equity including compounding
  Buy & Hold  – equity from holding the chart symbol for context
  Optional helpers – last trade outcome, current streak length, current allocation fraction
  Optional diagnostics – daily portfolio return, rolling drawdown, metrics table
  Optional Monte Carlo probability cone – p5, p16, p50, p84, p95 aggregate bands
  
 Model assumptions 
 
 Bar-close execution with no slippage or commissions
 Shorting allowed and frictionless
 No margin interest, borrow fees, or position limits
 No intrabar moves or gaps within a bar (returns are close-to-close)
 Sizing applies to equity fraction only and is capped by your setting
 
All results are hypothetical and for education only.
 How the simulator applies it 
 1) Directional signal 
 You pick a simple directional rule that produces +1 for long or −1 for short each bar. Options include 100 HMA slope, RSI above or below 50, EMA or SMA crosses, CCI and other oscillators, ATR move, BB basis, and more. The stance is evaluated bar by bar. When the stance flips, the current trade ends and the next one starts.
 2) Sizing after losses and wins 
 Position size is a fraction of equity:
  
  Initial allocation  – the starting fraction, for example 0.15 means 15 percent of equity
  Increase after loss  – multiply the  next  allocation by your factor after a losing leg, for example 2.00 to double
  Reset after win  – return to the initial allocation
  Max allocation cap  – hard ceiling to prevent runaway growth
  
 At a high level the size after  k  consecutive losses is
  alloc(k) = min( cap , base × factor^k ) .
 In practice the simulator changes size only when a leg ends and its PnL is known.
 3) Equity update 
 Let  r_t = close_t / close_{t-1} − 1  be the symbol’s bar return,  d_{t−1} ∈ {+1, −1}  the prior bar stance, and  a_{t−1}  the prior bar allocation fraction. The simulator compounds:
  eq_t = eq_{t−1} × (1 + a_{t−1} × d_{t−1} × r_t) .
  This is bar-based and avoids intrabar lookahead. Costs, slippage, and borrowing costs are not modeled. 
 Why traders experiment with martingale sizing 
  
  Mean-reversion contexts  – if the signal often snaps back after a string of losses, adding size near the tail of a move can pull the average entry closer to the turn
  Behavioral or microstructure edges  – some rules have modest edge but frequent small whipsaws; size escalation may shorten time-to-recovery when the edge manifests
  Exploration and stress testing  – studying the relationship between streaks, caps, and drawdowns is instructive even if you do not deploy martingale sizing live
  
 Why martingale is dangerous 
 Martingale concentrates capital when the strategy is performing worst. The main risks are structural, not cosmetic:
  
  Loss streaks are inevitable  – even with a 55 percent win rate you should expect multi-loss runs. The probability of at least one k-loss streak in N trades rises quickly with N.
  Size explodes geometrically  – with factor 2.0 and base 10 percent, the sequence is 10, 20, 40, 80, 100 (capped) after five losses. Without a strict cap, required size becomes infeasible.
  No fixed payout  – in gambling, one win at even odds resets PnL. In markets, there is no guaranteed bounce nor fixed profit multiple. Trends can extend and gaps can skip levels.
  Correlation of losses  – losses cluster in trends and in volatility bursts. A martingale tends to be largest just when volatility is highest.
  Margin and liquidity constraints  – leverage limits, margin calls, position limits, and widening spreads can force liquidation before a mean reversion occurs.
  Fat tails and regime shifts  – assumptions of independent, Gaussian returns can understate tail risk. Structural breaks can keep the signal wrong for much longer than expected.
  
 The simulator exposes these dynamics in the equity curve, Max Drawdown, VaR and CVaR, and via Monte Carlo sketches of forward uncertainty.
 Interpreting losing streaks with numbers 
 A rough intuition: if your per-trade win probability is  p  and loss probability is  q=1−p , the chance of a specific run of k consecutive losses is  q^k . Over many trades, the chance that at least one k-loss run occurs grows with the number of opportunities. As a sanity check:
  
  If  p=0.55 , then  q=0.45 . A 6-loss run has probability  q^6 ≈ 0.008  on any six-trade window. Across hundreds of trades, a 6 to 8-loss run is not rare.
  If your size factor is 1.5 and your base is 10 percent, after 8 losses the requested size is  10% × 1.5^8 ≈ 25.6% . With factor 2.0 it would try to be  10% × 2^8 = 256%  but your cap will stop it. The equity curve will still wear the compounded drawdown from the sequence that led to the cap.
  
 This is why the cap setting is central. It does not remove tail risk, but it prevents the sizing rule from demanding impossible positions
Note: The p and q math is illustrative. In live data the win rate and distribution can drift over time, so real streaks can be longer or shorter than the simple q^k intuition suggests..
 Using the simulator productively 
 Parameter studies 
 Start with conservative settings. Increase one element at a time and watch how the equity, Max Drawdown, and CVaR respond.
  
  Initial allocation  – lower base reduces volatility and drawdowns across the board
  Increase factor  – set modestly above 1.0 if you want the effect at all; doubling is aggressive
  Max cap  – the most important brake; many users keep it between 20 and 50 percent
  
 Signal selection 
Keep sizing fixed and rotate signals to see how streak patterns differ. Trend-following signals tend to produce long wrong-way streaks in choppy ranges. Mean-reversion signals do the opposite. Martingale sizing interacts very differently with each.
 Diagnostics to watch 
 Use the built-in metrics to quantify risk:
  
  Max Drawdown  – worst peak-to-trough equity loss
  Sharpe and Sortino  – volatility and downside-adjusted return
  VaR 95 percent and CVaR  – tail risk measures from the realized distribution
  Alpha and Beta  – relationship to your chosen benchmark
  
If you would like to check out the original performance metrics script with multiple assets with a better explanation on all metrics please see 
 Monte Carlo exploration 
 
 When enabled, the forecast draws many synthetic paths from your realized daily returns:
  
  Choose a horizon and a number of runs
  Review the bands: p5 to p95 for a wide risk envelope; p16 to p84 for a narrower range; p50 as the median path
  Use the table to read the expected return over the horizon and the tail outcomes
  Remember it is a sketch based on your recent distribution, not a predictor
  
 Concrete examples 
 Example A: Modest martingale 
 Base 10 percent, factor 1.25, cap 40 percent, RSI>50 signal. You will see small escalations on 2 to 4 loss runs and frequent resets. The equity curve usually remains smooth unless the signal enters a prolonged wrong-way regime. Max DD may rise moderately versus fixed sizing.
 Example B: Aggressive martingale 
 Base 15 percent, factor 2.0, cap 60 percent, EMA cross signal. The curve can look stellar during favorable regimes, then a single extended streak pushes allocation to the cap, and a few more losses drive deep drawdown. CVaR and Max DD jump sharply. This is a textbook case of high tail risk.
 Strengths 
  
  Bar-by-bar, transparent computation of equity from stance and size
  Explicit handling of wins, losses, streaks, and caps
  Portable signal inputs so you can A–B test ideas quickly
  Risk diagnostics and forward uncertainty visualization in one place
  
Example, Rolling Max Drawdown 
 Limitations and important notes 
  
  Martingale sizing can escalate drawdowns rapidly. The cap limits position size but not the possibility of extended adverse runs.
  No commissions, slippage, margin interest, borrow costs, or liquidity limits are modeled.
  Signals are evaluated on closes. Real execution and fills will differ.
  Monte Carlo assumes independent draws from your recent return distribution. Markets often have serial correlation, fat tails, and regime changes.
  All results are hypothetical. Use this as an educational tool, not a production risk engine.
  
 Practical tips 
  
  Prefer gentle factors such as 1.1 to 1.3. Doubling is usually excessive outside of toy examples.
  Keep a strict cap. Many users cap between 20 and 40 percent of equity per leg.
  Stress test with different start dates and subperiods. Long flat or trending regimes are where martingale weaknesses appear.
  Compare to an anti-martingale (increase after wins, cut after losses) to understand the other side of the trade-off.
  If you deploy sizing live, add external guardrails such as a daily loss cut, volatility filters, and a global max drawdown stop.
  
 Settings recap 
  
  Backtest start date and initial capital
  Initial allocation, increase-after-loss factor, max allocation cap
  Signal source selector
  Trading days per year and risk-free rate
  Benchmark symbol for Alpha and Beta
  UI toggles for equity, buy and hold, labels, metrics, PnL, and drawdown
  Monte Carlo controls for enable, runs, horizon, and result table
  
 Final thoughts 
 A martingale is not a free lunch. It is a way to tilt capital allocation toward losing streaks. If the signal has a real edge and mean reversion is common, careful and capped escalation can reduce time-to-recovery. If the signal lacks edge or regimes shift, the same rule can magnify losses at the worst possible moment. This simulator makes those trade-offs visible so you can calibrate parameters, understand tail risk, and decide whether the approach belongs anywhere in your research workflow.






















