Market Internal Strength (DJI/Nasdaq/S&P)Market Health Dow, Nasdaq & S\&P 500 Breadth
Track the true internal health of the US market's three most important indices the Dow Jones Industrial Average (DJI), the Nasdaq 100 (NDX), and the S\&P 500 (SPX).
Price action alone can be deceiving. A rising index might be driven by only a handful of mega-cap stocks, masking underlying weakness. This indicator provides a crucial look "under the hood" to measure the market's true breadth.
It visualizes the percentage of stocks within each index that are trading above their key moving averages (5, 20, 50, 100, 150, and 200-day). This allows you to instantly gauge whether a market trend is broadly supported by the majority of its constituent stocks.
Key Features
  * Covers 3 Major US Indices Seamlessly switch your analysis between the Dow Jones, Nasdaq 100, and S\&P 500.
  * Complete Breadth Picture Six MA periods offer a full view, from short-term momentum (5D, 20D) to the long-term institutional trend (150D, 200D).
  * Fully Customizable Toggle the visibility of any line and adjust overbought/oversold levels to fit your personal strategy.
How to Use
1. Extreme Readings (Overbought/Oversold)
      * Above 80% Signals a very strong, potentially overbought market. Caution is advised as a pullback could be near.
      * Below 20% Signals a deeply oversold market, often indicating capitulation and potential buying opportunities.
2. Divergence (Powerful Warning Signal)
      * Bearish The index price makes a new high, but this indicator makes a lower high. This warns that the rally is not broad-based and may be losing steam.
      * Bullish The index price makes a new low, but this indicator makes a higher low. This suggests internal strength is building and a bottom may be forming.
3. Trend Confirmation
When the long-term lines (150D, 200D) remain high (e.g., \> 50%), the primary market trend is healthy and confirmed.
Recherche dans les scripts pour "美元指数跌破100大关"
Advanced Price Ranges ICTThis indicator automatically divides price into fixed ranges (configurable in points or pips) and plots important reference levels such as the high, low, 50% midpoint, and 25%/75% quarters. It is designed to help traders visualize structured price movement, spot confluence zones, and frame their trading bias around clean range-based levels.
🔹 Key Features
Custom Range Size: Define ranges in points (e.g., 100, 50, 25, 10) or in Forex pips.
Forex Mode: Automatically adapts pip size (0.0001 or 0.01 for JPY pairs).
Dynamic Anchoring: Price ranges automatically align to the current price, snapping into blocks.
Multiple Ranges: Option to extend visualization above and below the current active block for a complete grid.
Level Types:
High / Low of the range
50% midpoint
25% and 75% quarters
Custom Styling: Adjustable line colors and widths for each level type.
Labels: Optional right-edge labels showing level type and exact price.
Alerts: Built-in alerts for when price crosses the range high, low, or 50% midpoint.
🔹 Use Cases
Quickly map out 100/50/25/10 point structures like Zeussy’s advanced price range method.
Identify key reaction levels where liquidity is often built or swept.
Support ICT-style concepts like range-based bias, fair value gaps, and liquidity pools.
Works for indices, futures, crypto, and forex.
🔹 Customization
Range increments can be set to any size (default 100).
Toggle which levels are shown (High/Low, Midpoint, Quarters).
Adjustable line widths, colors, and label visibility.
Extend ranges above and below for broader market context.
T-Virus Sentiment [hapharmonic]🧬  T-Virus Sentiment: Visualize the Market's DNA 
 Remember the iconic T-Virus vial from the first Resident Evil? That powerful, swirling helix of potential has always fascinated me. It sparked an idea: what if we could visualize the market's underlying health in a similar way? What if we could capture the "genetic code" of market sentiment and contain it within a dynamic, 3D indicator? This project is the result of that idea, brought to life with Pine Script. 
The indicator's main goal is to measure the strength and direction of market sentiment by analyzing the "genetic code" of price action through a variety of trusted indicators. The result is displayed as a liquid level within a DNA helix, a bubble density representing buying pressure, and a T-Virus mascot that reflects the overall mood.
🧐  Core Concept: How It Works 
The primary output of the indicator is the "Active %" gauge you see on the right side of the vial. This percentage represents the overall sentiment score, calculated as an average from 7 different technical analysis tools. Each tool is analyzed on every bar and assigned a score from 1 (strong bearish pressure) to 5 (strong bullish potential).
  
In this indicator, we re-imagine market dynamics through the lens of a viral outbreak. A strong  bear market  is like a  virus  taking hold, pulling all technical signals down into a state of weakness. Conversely, a powerful  bull market  is like an  antiviral serum ; positive signals rise and spread toward the top of the vial, indicating that the system is being injected with strength.
This is not just another line on a chart. It's a comprehensive sentiment dashboard designed to give an immediate, at-a-glance understanding of the confluence between 7 classic technical indicators. The incredible 3D model of the vial itself was inspired by a design concept found  here .
⚛️  The 4 Core Elements of T-Virus Sentiment 
These four elements work in harmony to give a complete, multi-faceted picture of market sentiment. Each component tells a different part of the story.
  
 
   The Virus Mascot:  An instant emotional cue. This character provides the quickest possible read on the overall market mood, combining sentiment with volume pressure.
   The Antiviral Serum Level:  The main quantitative output. This is the liquid level in the DNA helix and the percentage gauge on the right, representing the average sentiment score from all 7 indicators.
   Buy Pressure & Bubble Density:  This visualizes volume flow. The density of bubbles represents the intensity of accumulation (buying) versus distribution (selling). It's the "power" behind the move.
   The Signal Distribution:  This shows the confluence (or dispersion) of sentiment. Are all signals bullish and clustered at the top, or are they scattered, indicating a conflicted market? The position of the indicator labels is crucial, as each is assigned to one of five distinct zones:
     
       Base Bottom:  The market is at its weakest. Signals here suggest strong bearish control and distribution.
       Lower Zone:  The market is still bearish, but signals may be showing early signs of accumulation or bottoming.
       Neutral Core (Center):  A state of balance or sideways consolidation. The market is waiting for a new direction.
       Upper Zone:  Bullish momentum is becoming clear. Signals are strengthening and showing bullish control.
       Top Cap:  The market is "heating up" with strong bullish sentiment, potentially nearing overbought conditions.
     
 
🐂🐻  The Virus Mascot: The At-a-Glance Indicator 
This character acts as a shortcut to confirm market health. It combines the sentiment score with volume, preventing false confidence in a low-volume rally.
  
Its state is determined by a dual-check: the overall "Antiviral Serum Level" and the "Buy Pressure" must  both  be above 50%.
 
   Green & Smiling:  The 'all clear' signal. This means that not only is the overall technical sentiment bullish, but it's also being supported by real buying pressure. This is a sign of a healthy bull market.
   Red & Angry:  A warning sign. This appears if either the sentiment is weak,  or  a bullish sentiment is not being confirmed by buying volume. The latter could indicate a potential "bull trap" or an exhaustive move.
 
 This mascot can be disabled from the settings page under "Virus Mascot Styling" if a cleaner look is preferred. 
🫧  Bubble Density: Gauging Buy vs. Sell Pressure 
The bubbles visualize the battle between buyers and sellers. There are two modes to control how this is calculated:
 Mode 1: Visible Range (The 'Big Picture' View) 
  
This default mode is best for getting a broad, contextual understanding of the current session. It dynamically analyzes the volume of  every single candlestick currently visible on the screen  to calculate the buy/sell pressure ratio. It answers the question: "Over the entire period I'm looking at, who is in control?" As you zoom in or out, the calculation adapts.
 Mode 2: Custom Lookback (The 'Precision' View) 
  
This mode is for traders who need to analyze short-term pressure. You can define a fixed number of recent bars to analyze, which is perfect for scalping or understanding the volume dynamics leading into a key level. It answers the question: "What is happening  right now ?" In the example above, a lookback of 2 focuses only on the most recent action, clearly showing intense, immediate selling pressure (few bubbles) and a corresponding drop in the sentiment score to 29%.
ℹ️  Interactive Tooltips: Dive Deeper 
We believe in transparency, not 'black box' indicators. This feature transforms the indicator from a visual aid into an active learning tool.
  
Simply hover the mouse over any indicator label (like EMA, OBV, etc.) to get a detailed tooltip. It will explain the specific data points and thresholds that signal met to be placed in its current zone. This helps build trust in the signals and allows users to fine-tune the indicator settings to better match their own trading style.
🎯  The Scoring Logic Breakdown 
The "Antiviral Serum Level" gauge is the average score from 7 technical analysis tools. Each is graded on a 5-point scale (1=Strong Bearish to 5=Strong Bullish). Here’s a detailed, transparent look at how each "gene" is evaluated:
 
   Relative Strength Index (RSI) 
Measures momentum and overbought/oversold conditions.
 
   Group 1 (Strong Bearish):  RSI > 80 (Extreme Overbought)
   Group 2 (Bearish):  70 < RSI ≤ 80 (Overbought)
   Group 3 (Neutral):  30 ≤ RSI ≤ 70
   Group 4 (Bullish):  20 ≤ RSI < 30 (Oversold)
   Group 5 (Strong Bullish):  RSI < 20 (Extreme Oversold)
 
   Exponential Moving Averages (EMA) 
Evaluates the trend's strength and structure based on the alignment of multiple EMAs (9, 21, 50, 100, 200, 250).
 
   Group 1 (Strong Bearish):  A perfect bearish sequence (9 < 21 < 50 < ...)
   Group 2 (Bearish Transition):  Early signs of a potential reversal (e.g., 9 > 21 but still below 50)
   Group 3 (Neutral / Mixed):  MAs are intertwined or showing a partial bullish sequence.
   Group 4 (Bullish):  A strong bullish sequence is forming (e.g., 9 > 21 > 50 > 100)
   Group 5 (Strong Bullish):  A perfect bullish sequence (9 > 21 > 50 > 100 > 200 > 250)
 
   Moving Average Convergence Divergence (MACD) 
Analyzes the relationship between two moving averages to gauge momentum.
 
   Group 1 (Strong Bearish):  MACD & Histogram are negative and momentum is falling.
   Group 2 (Weakening Bearish):  MACD is negative but the histogram is rising or positive.
   Group 3 (Neutral / Crossover):  A crossover event is occurring near the zero line.
   Group 4 (Bullish):  MACD & Histogram are positive.
   Group 5 (Strong Bullish):  MACD & Histogram are positive, rising strongly, and accelerating.
 
   Average Directional Index (ADX) 
Measures trend strength, not direction. The score is based on both ADX value and the dominance of DI+ vs DI-.
 
   Group 1 (Bearish / No Trend):  ADX < 20 and DI- is dominant.
   Group 2 (Developing Bearish Trend):  20 ≤ ADX < 25 and DI- is dominant.
   Group 3 (Neutral / Indecision):  Trend is weak or DI+ and DI- are nearly equal.
   Group 4 (Developing Bullish Trend):  25 ≤ ADX ≤ 40 and DI+ is dominant.
   Group 5 (Strong Bullish Trend):  ADX > 40 and DI+ is dominant.
 
   Ichimoku Cloud (IKH) 
A comprehensive indicator that defines support/resistance, momentum, and trend direction.
 
   Group 1 (Strong Bearish):  Price is below the Kumo, Tenkan < Kijun, and Chikou is below price.
   Group 2 (Bearish):  Price is inside or below the Kumo, with mixed secondary signals.
   Group 3 (Neutral / Ranging):  Price is inside the Kumo, often with a Tenkan/Kijun cross.
   Group 4 (Bullish):  Price is above the Kumo with strong primary signals.
   Group 5 (Strong Bullish):  All signals are aligned bullishly: price above Kumo, bullish Tenkan/Kijun cross, bullish future Kumo, and Chikou above price.
 
   Bollinger Bands (BB) 
Measures volatility and relative price levels.
 
   Group 1 (Strong Bearish):  Price is below the lower band.
   Group 2 (Bearish Territory):  Price is between the lower band and the basis line.
   Group 3 (Neutral):  Price is hovering around the basis line.
   Group 4 (Bullish Territory):  Price is between the basis line and the upper band.
   Group 5 (Strong Bullish):  Price is above the upper band.
 
   On-Balance Volume (OBV) 
Uses volume flow to predict price changes. The score is based on OBV's trend and its position relative to its moving average.
 
   Group 1 (Strong Bearish):  OBV is below its MA and falling.
   Group 2 (Weakening Bearish):  OBV is below its MA but showing signs of rising.
   Group 3 (Neutral):  OBV is very close to its MA.
   Group 4 (Bullish):  OBV is above its MA and rising.
   Group 5 (Strong Bullish):  OBV is above its MA, rising strongly, and showing signs of a volume spike.
 
 
🧭  How to Use the T-Virus Sentiment Indicator 
 IMPORTANT: This indicator is a  sentiment dashboard , not a direct buy/sell signal generator. Its strength lies in showing confluence and providing a quick, holistic view of the market's technical health. 
 
   Confirmation Tool:  Use the "Active %" gauge to confirm a trade setup from your primary strategy. For example, if you see a bullish chart pattern, a high and rising sentiment score can add confidence to your trade.
   Momentum & Trend Gauge:  A consistently high score (e.g., > 75%) suggests strong, established bullish momentum. A consistently low score (< 25%) suggests strong bearish control. A score hovering around 50% often indicates a ranging or indecisive market.
   Divergence & Warning System:  Pay attention to divergences. If the price is making new highs but the sentiment score is failing to follow or is actively decreasing, it could be an early warning sign that the underlying momentum is weakening.
 
⚙️  Settings & Customization 
The indicator is highly customizable to fit any trading style.
 
   Position & Anchor:  Control where the vial appears on the chart.
   Styling (Vial, Helix, etc.):  Nearly every visual element can be color-customized.
   Signals:  This is where the real power is. All underlying indicator parameters (RSI length, MACD settings, etc.) can be fine-tuned to match a personal strategy. The text labels can also be disabled if the chart feels cluttered.
 
Enjoy visualizing the market's DNA with the  T-Virus Sentiment  indicator
Volume-Weighted Money Flow [sgbpulse]Overview 
The  VWMF  indicator is an advanced technical analysis tool that combines and summarizes five leading momentum and volume indicators  (OBV, PVT, A/D, CMF, MFI)  into one clear oscillator.  The indicator helps to provide a clear picture of  market sentiment  by measuring the pressure from buyers and sellers. Unlike single indicators, VWMF provides a comprehensive view of market money flow by weighting existing indicators and presenting them in a uniform and understandable format.
 Indicator Components 
VWMF combines the following indicators, each normalized to a range of 0 to 100 before being weighted:
 
 On-Balance Volume (OBV):  A cumulative indicator that measures positive and negative volume flow.
 Price-Volume Trend (PVT):  Similar to OBV, but incorporates relative price change for a more precise measure.
 Accumulation/Distribution Line (A/D):  Used to identify whether an asset is being bought (accumulated) or sold (distributed).
 Chaikin Money Flow (CMF):  Measures the money flow over a period based on the close price's position relative to the candle's range.
 Money Flow Index (MFI):  A momentum oscillator that combines price and volume to measure buying and selling pressure.
 
 Understanding the Normalized Oscillators 
The indicator combines the five different momentum indicators by normalizing each one to a uniform range of  0 to 100 .
 Why is Normalization Important? 
Indicators like OBV, PVT, and the A/D Line are  cumulative indicators  whose values can become very large. To assess their trend, we use a Moving Average as a  dynamic reference line . The Moving Average allows us to understand whether the indicator is currently trending up or down relative to its average behavior over time.
 How Does Normalization Work? 
Our normalization fully preserves the original trend of each indicator.
 
 For Cumulative Indicators (OBV, PVT, A/D):  We calculate the difference between the current indicator value and its Moving Average. This difference is then passed to the normalization process.
- If the indicator is above its Moving Average, the difference will be positive, and the normalized value will be above 50.
- If the indicator is below its Moving Average, the difference will be negative, and the normalized value will be below 50.
 Handling Extreme Values:  To overcome the issue of extreme values in indicators like  OBV, PVT, and the A/D Line , the function calculates the highest absolute value over the selected period. This value is used to prevent sharp spikes or drops in a single indicator from compromising the accuracy of the normalization over time. It's a sophisticated method that ensures the oscillators remain relevant and accurate.
 For Bounded Indicators (CMF, MFI):  These indicators already operate within a known range (for example, CMF is between -1 and 1, and MFI is between 0 and 100), so they are normalized directly without an additional reference line.
 
 Reference Line Settings: 
 
 Moving Average Type:  Allows the user to choose between a Simple Moving Average (SMA) and an Exponential Moving Average (EMA).
 Volume Flow MA Length:  Allows the user to set the lookback period for the Moving Average, which affects the indicator's sensitivity.
 
The 50 line serves as the new "center line." This ensures that, even after normalization, the determination of whether a specific indicator supports a bullish or bearish trend remains clear.
 Settings and Visual Tools 
The indicator offers several customization options to provide a rich analysis experience:
 
 VWMF Oscillator (Blue Line):  Represents the weighted average of all five indicators. Values above 50 indicate bullish momentum, and values below 50 indicate bearish momentum.
 Strength Metrics (Bullish/Bearish Strength %):  Two metrics that appear on the status line, showing the percentage of indicators supporting the current trend. They range from 0% to 100%, providing a quick view of the strength of the consensus.
 Dynamic Background Colors:  The background color of the chart automatically changes to bullish (a blue shade by default) or bearish (a default brown-gray shade) based on the trend. The transparency of the color shows the consensus strength—the more opaque the background, the more indicators support the trend.
 Advanced Settings: 
-  Background Color Logic:  Allows the user to choose the trigger for the background color:  Weighted Value  (based on the combined oscillator) or  Strength  (based on the majority of individual indicators).
- Weights:  Provides full control over the weight of each of the five indicators in the final oscillator.
 
 Using the Data Window 
TradingView provides a useful  Data Window  that allows you to see the exact numerical values of each normalized oscillator separately, in addition to the trend strength data.
You can use this window to:
 
 Get more detailed information on each indicator:  Viewing the precise numerical data of each of the five indicators can help in making trading decisions.
 Calibrate weights:  If you want to manually adjust the indicator weights (in the settings menu), you can do so while tracking the impact of each indicator on the weighted oscillator in the Data Window.
 
The indicator's  default  setting is an equal weight of  20%  for each of the five indicators.
 Alert Conditions 
The indicator comes with a variety of built-in alerts that can be configured through the TradingView alerts menu:
 
 VWMF Cross Above 50:  An alert when the VWMF oscillator crosses above the 50 line, indicating a potential bullish momentum shift.
 VWMF Cross Below 50:  An alert when the VWMF oscillator crosses below the 50 line, indicating a potential bearish momentum shift.
 Bullish Strength: High But Not Absolute Consensus:  An alert when the bullish trend strength reaches 60% or more but is less than 100%, indicating a high but not absolute consensus.
 Bullish Strength at 100%:  An alert when all five indicators (MFI, OBV, PVT, A/D, CMF) show bullish strength, indicating a full and absolute consensus.
 Bearish Strength: High But Not Absolute Consensus:  An alert when the bearish trend strength reaches 60% or more but is less than 100%, indicating a high but not absolute consensus.
 Bearish Strength at 100%:  An alert when all five indicators (MFI, OBV, PVT, A/D, CMF) show bearish strength, indicating a full and absolute consensus.
 
 Summary 
The VWMF indicator is a powerful, all-in-one tool for analyzing market momentum, money flow, and sentiment. By combining and normalizing five different indicators into a single oscillator, it offers a holistic and accurate view of the market's underlying trend. Its dynamic visual features and customizable settings, including the ability to adjust indicator weights, provide a flexible experience for both novice and experienced traders. The built-in alerts for momentum shifts and trend consensus make it an effective tool for spotting trading opportunities with confidence. In essence, VWMF distills complex market data into clear, actionable signals.
 Important Note: Trading Risk 
This indicator is intended for educational and informational purposes only and does not constitute investment advice or a recommendation for trading in any form whatsoever.
Trading in financial markets involves significant risk of capital loss. It is important to remember that past performance is not indicative of future results. All trading decisions are your sole responsibility. Never trade with money you cannot afford to lose.
Gott's Copernican Trend PredictorThe  Gott's Copernican Trend Predictor  predicts trend duration using the Copernican Principle - Based on astrophysicist Richard Gott's temporal prediction method.
I had the idea to create this indicator after reading the book The Doomsday Calculation by William Poundstone.
 Background & Theory 
This indicator implements J. Richard Gott III's Copernican Principle - a statistical method that famously predicted the fall of the Berlin Wall and the duration of Broadway shows with remarkable accuracy.
 The Copernican Principle Explained 
Named after Copernicus who showed that Earth is not at the center of the universe, this principle assumes that you are not observing something at a special moment in time. When you observe a trend at any random point, you're statistically more likely to be seeing it during the "middle portion" of its lifetime rather than at its very beginning or end.
 The Mathematics 
Gott's formula provides a 95% confidence interval for how much longer a trend will continue:
 Minimum remaining duration = Current Age ÷ 39
Maximum remaining duration = Current Age × 39 
The factor of 39 comes from statistical analysis where:
 
 There's only a 2.5% chance you're observing in the first 1/40th of the trend's life
 There's only a 2.5% chance you're observing in the last 1/40th of the trend's life
 
This gives us 95% confidence that the trend will last between Age/39 and Age×39
 How It Works 
Trend Detection
The indicator uses dual moving averages (default: 50 & 200 period) to identify trend changes:
 
 Bullish Cross: Fast MA crosses above Slow MA → Uptrend begins
 Bearish Cross: Fast MA crosses below Slow MA → Downtrend begins
 
Real-Time Predictions
Once a trend is detected, the indicator continuously calculates:
 
 Trend Age: How long the current trend has been active
 Gott's 95% CI: Statistical range for remaining trend duration
 Projected End Dates: Calendar dates when the trend might end
 
 How to Use 
Setup
 
 Add the indicator to any timeframe (works on minutes, hours, days, weeks)
 Customize MA periods and type (SMA, EMA, WMA)
 Choose table position and font size for optimal viewing
 
Interpretation
 
 Example: If a trend is 100 hours old:
 Minimum duration: 100 ÷ 39 = ~3 more hours
 Maximum duration: 100 × 39 = ~3,900 more hours
 95% confidence: The trend will end between these times
 
This indicator might be useful for swing traders, trend followers, and quantitative analysts. 
 Coca-Cola example: 
Coca-Cola's chart shows an uptrend spanning 810 weeks, approximately 15.5 years. According to Gott's Copernican Principle, this trend age generates a 95% confidence interval predicting the trend will continue for a minimum of 20 weeks and a maximum of 31,590 weeks.
On the other hand, a shorter trend age produces a proportionally smaller minimum duration and different risk profile in terms of statistical continuation probability. For this reason, more recent trends (and more recent companies) are likely to remain in trend for shorter. 
Trendlines Oscillator [LuxAlgo]The  Trendlines Oscillator  helps traders identify trends and momentum based on the normalized distances between the current price and the most recently detected bullish and bearish trend lines. 
The indicator features bullish and bearish momentum, a signal line with crossings, and multiple smoothing options.
🔶  USAGE 
  
The indicator displays three lines: two for momentum and one for the signal. When one of the momentum lines (bullish or bearish) crosses the signal line, the tool displays a dot to indicate which momentum is gaining strength.
As a general rule, when the green bullish momentum line is above the red bearish momentum line, it indicates buyer strength. This means that the actual prices are farther from the support trend lines than the resistance trend lines. The opposite is true for seller strength.
To calculate bullish momentum, the tool first identifies bullish trend lines acting as support below the price. Then, it measures the delta between the price and those trend lines and normalizes the reading into the displayed momentum values.
The same process is used for bearish momentum, but with bearish trendlines acting as resistance above the price.
🔹  Length & Memory 
  
Modifying the Length and Memory values will cause the tool to display different momentum values.
Traders can adjust the length to detect larger trendlines and adjust the memory to indicate how many trendlines the tool should consider.
As the chart above shows, smaller values make the tool more responsive, while larger values are useful for detecting larger trends.
🔹  Smoothing 
  
By default, the data is not smoothed, and the signal uses a triangular moving average with a length of 10. Traders can smooth both the data and the signal line.
Traders can choose from up to ten different methods, or none. Some examples are shown on the chart above.
🔶  DETAILS 
The steps for the calculations are as follows:
1. Gather the pivots, highs, and lows.
 ph      = fixnan(ta.pivothigh(lengthInput, lengthInput))
pl      = fixnan(ta.pivotlow(lengthInput, lengthInput)) 
2. Calculate the slope and y-intercept for each trendline between contiguous lower highs (resistance) or higher lows (support).
 if ph < ph 
    slope = (ph - ph )/(n-lengthInput - phx1)
    res.unshift(l.new(ph  - slope * phx1, slope))
if pl > pl 
    slope = (pl - pl )/(n-lengthInput - plx1)
    sup.unshift(l.new(pl  - slope * plx1, slope)) 
3. Calculate the value of each trendline on the current bar, then calculate the difference with the current price (delta). To calculate the relative sum of deltas, only consider trendlines below the price for support or above the price for resistance.
 method get_point(l id, x)=>
    id.slope * x + id.intercept
	
	for element in sup
    point = element.get_point(n)
    if sourceInput > point
        sup_sum += sourceInput - point
    
    sup_den += math.abs(sourceInput - point)
for element in res
    point = element.get_point(n)
    if sourceInput < point
        res_sum += point - sourceInput
    res_den += math.abs(point - sourceInput) 
4. Normalize the value from 0 to 100 by taking the sum of the relative values of the deltas divided by the sum of the absolute values of the deltas.	
 float supportLine       = sup_sum / sup_den * 100
float resistanceLine    = res_sum / res_den * 100 
5. Smooth both values, then calculate the signal line as the difference between them.
 float smoothSupport     = smooth(supportLine,dataSmoothingInput,dataSmoothingLengthInput)
float smoothResistance  = smooth(resistanceLine,dataSmoothingInput,dataSmoothingLengthInput)
float signal            = math.abs(smoothSupport - smoothResistance)
float signalLine        = smooth(signal,smoothingInput,smoothingLengthInput) 
6. Calculate the crossing signals against the signal line, using only the first signal from each series of bullish or bearish crossings.
 bullSignal      = smoothSupport > signalLine and smoothSupport  < signalLine 
bearSignal      = smoothResistance > signalLine and smoothResistance  < signalLine 
lastSignal      := bullSignal and lastSignal == BEAR ? BULL : bearSignal and lastSignal == BULL ? BEAR : lastSignal
firstBull       = ta.change(lastSignal) > 0
firstBear       = ta.change(lastSignal) < 0 
🔶  SETTINGS 
 
 Length: The size of the market structure used for trendline detection.
 Memory: The number of trendlines used in calculations.
 Source: The source for the calculations is closing prices by default.
 
🔹  Smoothing 
 
 Data Smoothing: Choose the smoothing method and length
 Signal Smoothing: Choose the smoothing method and length
 
Six Meridian Divine Swords [theUltimator5]The Six Meridian Divine Sword is a legendary martial arts technique in the classic wuxia novel “Demi-Gods and Semi-Devils” (天龙八部) by Jin Yong (金庸).  The technique uses powerful internal energy (qi) to shoot invisible sword-like energy beams from the six meridians of the hand.  Each of the six fingers/meridians corresponds to a “sword,” giving six different sword energies.
The Six Meridian Divine Swords indicator is a compact “signal dashboard” that fuses six classic indicators (fingers)—MACD, KDJ, RSI, LWR (Williams %R), BBI, and MTM—into one pane. Each row is a traffic-light dot (green/bullish, red/bearish, gray/neutral). When all six align, the script draws a confirmation line (“All Bullish” or “All Bearish”). It’s designed for quick consensus reads across trend, momentum, and overbought/oversold conditions.
 How to Read the Dashboard 
 The pane has 6 horizontal rows (explained in depth later): 
 
 MACD
 KDJ
 RSI
 LWR (Larry Williams %R)
 BBI (Bull & Bear Index)
 MTM (Momentum)
 
 Each tick in the row is a dot, with sentiment identified by a color. 
 
 Green = bullish condition met
 Red = bearish condition met
 Gray = inside a neutral band (filtering chop), shown when Use Neutral (Gray) Colors is ON
 
There are two lines that track the dots on the top or bottom of the pane.
 
 All Bullish Signal Line: appears only if all 6 are strongly bullish (default color = white)
 All Bearish Signal Line: appears only if all 6 are strongly bearish (default color = fuchsia)
 
 The Six Meridians (Indicators) — What They Mean: 
 1) MACD — Trend & Momentum 
 What it is: A trend-following momentum indicator based on the relationship between two moving averages (typically 12-EMA and 26-EMA) 
 
 Logic used: Classic MACD line (EMA12−EMA26) vs its 9-EMA signal.
 Bullish: MACD > Signal and |MACD−Signal| > Neutral Threshold
 Bearish: MACD < Signal and |diff| > threshold
 Neutral: |diff| ≤ threshold
 Why: Small crosses can whipsaw. The neutral band ignores tiny separations to reduce noise.
 Inputs: Fast/Slow/Signal lengths, Neutral Threshold.
 
 2) KDJ — Stochastic with J-line boost 
 What it is: A variation of the stochastic oscillator popular in Chinese trading systems 
 
 Logic used: K = SMA(Stochastic, smooth), D = SMA(K, smooth), J = 3K − 2D.
 Bullish: K > D and |K−D| > 2
 Bearish: K < D and |K−D| > 2
 Neutral: |K−D| ≤ 2
 Why: K–D separation filters tiny wiggles; J offers an “extreme” early-warning context in the value label.
 Inputs: Length, Smoothing.
 
 3) RSI — Momentum balance (0–100) 
 What it is: A momentum oscillator measuring speed and magnitude of price changes (0–100) 
 
 Logic used: RSI(N).
 Bullish: RSI > 50 + Neutral Zone
 Bearish: RSI < 50 − Neutral Zone
 Neutral: Between those bands
 Why: Centerline/adaptive bands (around 50) give a directional bias without relying on fixed 70/30.
 Inputs: Length, Neutral Zone (± around 50).
 
 4) LWR (Williams %R) — Overbought/Oversold 
 What it is: An oscillator similar to stochastic, measuring how close the close is to the high-low range over N periods 
 
 Logic used: %R over N bars (0 to −100).
 Bullish: %R > −50 + Neutral Zone
 Bearish: %R < −50 − Neutral Zone
 Neutral: Between those bands
 Why: Uses a centered band around −50 instead of only −20/−80, making it act like a directional filter.
 Inputs: Length, Neutral Zone (± around −50).
 
 5) BBI (Bull & Bear Index) — Smoothed trend bias 
 What it is: A composite moving average, essentially the average of several different moving averages (often 3, 6, 12, 24 periods) 
 
 Logic used: Average of 4 SMAs (3/6/12/24 by default):
 BBI = (MA3 + MA6 + MA12 + MA24) / 4
 Bullish: Close > BBI and |Close−BBI| > 0.2% of BBI
 Bearish: Close < BBI and |diff| > threshold
 Neutral: |diff| ≤ threshold
 Why: Multiple MAs blended together reduce single-MA whipsaw. A dynamic 0.2% band ignores tiny drift.
 Inputs: 4 lengths (default 3/6/12/24). Threshold is auto-scaled at 0.2% of BBI.
 
 6) MTM (Momentum) — Rate of change in price 
 What it is: A simple measure of rate of change 
 
 Logic used: MTM = Close − Close 
 Bullish: MTM > 0.5% of Close
 Bearish: MTM < −0.5% of Close
 Neutral: |MTM| ≤ threshold
 Why: A percent-based gate adapts across prices (e.g., $5 vs $500) and mutes insignificant moves.
 Inputs: Length. Threshold auto-scaled to 0.5% of current Close.
 Display & Inputs You Can Tweak
 
 🎨 Use Neutral (Gray) Colors 
ON (default): 3-color mode with clear “no-trade”/“weak” states.
OFF: classic binary (green/red) without neutral filtering.
Relative Strength Range RankRelative Strength Range Rank – Chart Asset vs. Benchmarks 
 Description: 
This indicator calculates and ranks the relative strength position of the current chart’s asset against up to five user-defined comparison symbols. By default, the comparison set is USDT.D, USDC.D and  DAI.D.
 Calculation method: 
The same oscillator calculation is applied identically to the current chart’s asset and all comparison symbols:
For each symbol:
Determine the lowest low over  LOWEST  bars.
Determine the highest high over  HIGHEST  bars.
Calculate normalized position within range:
 raw_osc = (close - lowest_low) / (highest_high - lowest_low) * 100 
Apply a 10-period EMA to smooth  raw_osc. 
Invert and scale to match assets direction:
 raw_osc = 100 - EMA_10(raw_osc) 
Apply weighted smoothing:
 smoothed = 0.191 * previous_value + 0.809 * current_value 
Apply a final 1-period EMA to reduce jitter.
Output is the inverted smoothed oscillator value, representing the relative strength rank.
This function is implemented as  calculate_oscillator()  and used for all input symbols plus the current chart symbol, ensuring consistency in comparative analysis.
 Plotting: 
Each comparison symbol oscillator is plotted in the indicator pane.
The current chart oscillator is always plotted in black.
 Alert condition: 
Boolean  chart_osc_above_all  is true when the current chart oscillator is strictly greater than all other comparison oscillator values.
The alert  chart_osc_crossed_above  triggers only on the first bar where  chart_osc_above_all  changes from false to true.
Smoothing advantage:
The smoothing sequence  (EMA → weighted smoothing → EMA)  is designed to reduce short-term noise while preserving responsiveness to changes in price position.
The initial EMA(10) filters random fluctuations.
The weighted smoothing step  (0.191 * prev + 0.809 * current)  reduces overshoot and dampens oscillations without introducing significant lag, unlike longer EMAs.
The final EMA(1) step ensures stability in the plotted oscillator without visible jaggedness.
This combination yields a signal that is both smooth and reactive, making relative strength comparisons more precise.
 Inputs: 
Sym 1–5: up to five comparison tickers.
Lowest low lookback period ( LOWEST ).
Highest high lookback period ( HIGHEST ).
Color for plotted comparison lines.
 Output: 
Oscillator values from 0 to 100, where higher values indicate that the asset’s current price is closer to the highest high of the lookback period, and lower values indicate proximity to the lowest low.
Sorted table showing all selected assets ranked by oscillator value.
Optional alert when the current chart asset leads all selected assets in oscillator value.
Short Description:
Computes range-normalized oscillator values for the chart asset and up to 5 symbols, using EMA and weighted smoothing to reduce noise while preserving responsiveness; optional alert when the chart asset exceeds all others.
ADR/ATR Session No Probability Table by LKHere you go—clear, English docs you can drop into your script’s description or share with teammates.
ADR/ATR Session by LK — Overview
This indicator summarizes Average Daily Range (ADR) and Average True Range (ATR) for two horizons:
	•	Session H4 (e.g., 06:00–13:00 on a 4‑hour chart)
	•	Daily (D)
It shows:
	•	Current ADR/ATR values (using your chosen smoothing method)
	•	How much of ADR/ATR today/this bar has already been consumed (% of ADR/ATR)
	•	ADR/ATR as a percent of price
	•	Optional probability blocks: likelihood that %ADR will exceed user‑defined thresholds over a lookback window
	•	Optional on‑chart lines for the current H4 and Daily candles: Open, ADR High, ADR Low
⸻
What the metrics mean
	•	ADR (H4 / D): Moving average of the bar range (high - low).
	•	ATR (H4 / D): Moving average of True Range (max(hi-lo, |hi-close |, |lo-close |)).
	•	% of ADR (curr H4): (H4 range of the current H4 bar) / ADR(H4) × 100. Updates live even if the current time is outside the session.
	•	% of ADR (Daily): (today’s intra‑day range) / ADR(D) × 100.
	•	% of ATR (curr H4 / Daily): TR / ATR × 100 for that horizon.
	•	ADR % of Price / ATR % of Price: ADR or ATR divided by current price × 100 (a quick “volatility vs. price” gauge).
Session logic (H4): ADR/ATR(H4) only update on bars that fall inside the configured session window; outside the window the values hold steady (no recalculation “bleed”).
Daily range tracking: The indicator tracks today’s high/low in real‑time and resets at the day change.
⸻
Inputs (quick reference)
Core
	•	Length (ADR/ATR): smoothing length for ADR/ATR (default 21).
	•	Wait for Higher TF Bar Close: if true, updates ADR/ATR only after the higher‑TF bar closes when using request.security.
Timeframes
	•	Session Timeframe (H4): default 240.
	•	Daily Timeframe: default D.
Session time
	•	Session Timezone: “Chart” (default) or a fixed timezone.
	•	Session Start Hour, End Hour (minutes are fixed to 0 in this version).
Smoothing methods
	•	H4 ADR Method / H4 ATR Method: SMA/EMA/RMA/WMA.
	•	Daily ADR Method / Daily ATR Method: SMA/EMA/RMA/WMA.
Table appearance
	•	Table BG, Table Text, Table Font Size.
Lines (optional)
	•	Show current H4 segments, Show current Daily segments
	•	Line colors for Open / ADR High / ADR Low
	•	Line width
Probability
	•	H4 Probability Lookback (bars): number of H4 bars to examine (e.g., 300).
	•	Daily Probability Lookback (days): number of D bars (e.g., 180).
	•	ADR thresholds (%): CSV list of thresholds (e.g., 25,50,55,60,65,70,75,80,85,90,95,100,125,150).
The table will show the % of lookback bars where %ADR ≥ threshold.
Tip: If you want probabilities only for session H4 bars (not every H4 bar), ask and I can add a toggle to filter by inSess.
⸻
How to read the table
H4 block
	•	ADR (method) / ATR (method): the session‑aware averages.
	•	% of ADR (curr H4): live progress of this H4 bar toward the session ADR.
	•	ADR % of Price: ADR(H4) relative to price.
	•	% of ATR (curr H4) and ATR % of Price: same idea for ATR.
H4 Probability (lookback N bars)
	•	Rows like “≥ 80% ADR” show the fraction (in %) of the last N H4 bars that reached at least 80% of ADR(H4).
Daily block
	•	Mirrors the H4 block, but for Daily.
Daily Probability (lookback M days)
	•	Rows like “≥ 100% ADR” show the fraction of the last M daily bars whose daily range reached at least 100% of ADR(D).
⸻
Practical usage
	•	Use % of ADR (curr H4 / Daily) to judge exhaustion or room left in the day/session.
E.g., if Daily %ADR is already 95%, be cautious with momentum continuation trades.
	•	The probability tables give a quick historical context:
If “≥ 125% ADR” is ~18%, the market rarely stretches that far; your trade sizing/targets can reflect that.
	•	ADR/ATR % of Price helps normalize volatility between instruments.
⸻
Troubleshooting
	•	If probability rows are blank: ensure lookback windows are large enough (and that the chart has enough history).
	•	If ADR/ATR show … (NA): usually you don’t have enough bars for the chosen length/TF yet.
	•	If line segments are missing: verify you’re on a chart with visible current H4/D bars and the toggles are enabled.
⸻
Notes & customization ideas
	•	Add a toggle to count only session bars in H4 probability.
	•	Add separate thresholds for H4 vs Daily.
	•	Let users pick minutes for session start/end if needed.
	•	Add alerts when %ADR crosses specified thresholds.
If you want me to bundle any of the “ideas” above into the code, say the word and I’ll ship a clean patch.
On-Chain Signals [LuxAlgo]The  On-Chain Signals  indicator uses fundamental blockchain metrics to provide traders with an objective technical view of their favorite cryptocurrencies. 
It uses IntoTheBlock datasets integrated within TradingView to generate four key signals: Net Network Growth, In the Money, Concentration, and Large Transactions.
Together, these four signals provide traders with an overall directional bias of the market. All of the data can be visualized as a gauge, table, historical plot, or average.
🔶  USAGE 
  
The main goal of this tool is to provide an overall directional bias based on four blockchain signals, each with three possible biases: bearish, neutral, or bullish. The thresholds for each signal bias can be adjusted on the settings panel.
These signals are based on IntoTheBlock's On-Chain Signals.
 
 Net network growth: Change in the total number of addresses over the last seven periods; i.e., how many new addresses are being created.
 In the Money: Change in the seven-period moving average of the total supply in the money. This shows how many addresses are profitable.
 Concentration: Change in the aggregate addresses of whales and investors from the previous period. These are addresses holding at least 0.1% of the supply. This shows how many addresses are in the hands of a few.
 Large Transactions: Changes in the number of transactions over $100,000. This metric tracks convergence or divergence from the 21- and 30-day EMAs and indicates the momentum of large transactions.
 
All of these signals together form the blockchain's overall directional bias.
 
 Bearish: The number of bearish individual signals is greater than the number of bullish individual signals.
 Neutral: The number of bearish individual signals is equal to the number of bullish individual signals.
 Bullish: The number of bullish individual signals is greater than the number of bearish individual signals.
 
If the overall directional bias is bullish, we can expect the price of the observed cryptocurrency to increase. If the bias is bearish, we can expect the price to decrease. If the signal is neutral, the price may be more likely to stay the same.
Traders should be aware of two things. First, the signals provide optimal results when the chart is set to the daily timeframe. Second, the tool uses IntoTheBlock data, which is available on TradingView. Therefore, some cryptocurrencies may not be available.
🔹  Display Mode 
  
Traders have three different display modes at their disposal. These modes can be easily selected from the settings panel. The gauge is set by default.
🔹  Gauge 
  
The gauge will appear in the center of the visible space. Traders can adjust its size using the Scale parameter in the Settings panel. They can also give it a curved effect.
The number of bars displayed directly affects the gauge's resolution: More bars result in better resolution.
The chart above shows the effect that different scale configurations have on the gauge.
🔹  Historical Data 
  
The chart above shows the historical data for each of the four signals.
Traders can use this mode to adjust the thresholds for each signal on the settings panel to fit the behavior of each cryptocurrency. They can also analyze how each metric impacts price behavior over time.
🔹  Average 
  
This display mode provides an easy way to see the overall bias of past prices in order to analyze price behavior in relation to the underlying blockchain's directional bias.
The average is calculated by taking the values of the overall bias as -1 for bearish, 0 for neutral, and +1 for bullish, and then applying a triangular moving average over 20 periods by default. Simple and exponential moving averages are available, and traders can select the period length from the settings panel.
🔶  DETAILS 
The four signals are based on IntoTheBlock's On-Chain Signals. We gather the data, manipulate it, and build the signals depending on each threshold.
 
 Net network growth
 float netNetworkGrowthData      = customData('_TOTALADDRESSES')
float netNetworkGrowth          = 100*(netNetworkGrowthData /netNetworkGrowthData  - 1) 
 In the Money
 float inTheMoneyData            = customData('_INOUTMONEYIN')
float averageBalance            = customData('_AVGBALANCE')
float inTheMoneyBalance         = inTheMoneyData*averageBalance
float sma                       = ta.sma(inTheMoneyBalance,7)
float inTheMoney                = ta.roc(sma,1) 
 Concentration
 float whalesData                = customData('_WHALESPERCENTAGE')
float inverstorsData            = customData('_INVESTORSPERCENTAGE')
float bigHands                  = whalesData+inverstorsData
float concentration             = ta.change(bigHands )*100 
 Large Transactions
 float largeTransacionsData      = customData('_LARGETXCOUNT')
float largeTX21                 = ta.ema(largeTransacionsData,21) 
float largeTX30                 = ta.ema(largeTransacionsData,30) 
float largeTransacions          = ((largeTX21 - largeTX30)/largeTX30)*100 
 
🔶  SETTINGS 
 
 Display mode: Select between gauge, historical data and average.
 Average: Select a smoothing method and length period.
 
🔹  Thresholds 
 
 Net Network Growth : Bullish and bearish thresholds for this signal.
 In The Money : Bullish and bearish thresholds for this signal.
 Concentration : Bullish and bearish thresholds for this signal.
 Transactions : Bullish and bearish thresholds for this signal.
 
🔹  Dashboard 
 
 Dashboard : Enable/disable dashboard display
 Position : Select dashboard location
 Size : Select dashboard size
 
🔹  Gauge 
 
 Scale : Select the size of the gauge
 Curved : Enable/disable curved mode
 Select Gauge colors for bearish, neutral and bullish bias
 
🔹  Style 
 
 Net Network Growth : Enable/disable historical plot and choose color
 In The Money : Enable/disable historical plot and choose color
 Concentration : Enable/disable historical plot and choose color
 Large Transacions : Enable/disable historical plot and choose color
Game Theory Trading StrategyGame Theory Trading Strategy: Explanation and Working Logic
This Pine Script (version 5) code implements a trading strategy named "Game Theory Trading Strategy" in TradingView. Unlike the previous indicator, this is a full-fledged strategy with automated entry/exit rules, risk management, and backtesting capabilities. It uses Game Theory principles to analyze market behavior, focusing on herd behavior, institutional flows, liquidity traps, and Nash equilibrium to generate buy (long) and sell (short) signals. Below, I'll explain the strategy's purpose, working logic, key components, and usage tips in detail.
1. General Description
Purpose: The strategy identifies high-probability trading opportunities by combining Game Theory concepts (herd behavior, contrarian signals, Nash equilibrium) with technical analysis (RSI, volume, momentum). It aims to exploit market inefficiencies caused by retail herd behavior, institutional flows, and liquidity traps. The strategy is designed for automated trading with defined risk management (stop-loss/take-profit) and position sizing based on market conditions.
Key Features:
Herd Behavior Detection: Identifies retail panic buying/selling using RSI and volume spikes.
Liquidity Traps: Detects stop-loss hunting zones where price breaks recent highs/lows but reverses.
Institutional Flow Analysis: Tracks high-volume institutional activity via Accumulation/Distribution and volume spikes.
Nash Equilibrium: Uses statistical price bands to assess whether the market is in equilibrium or deviated (overbought/oversold).
Risk Management: Configurable stop-loss (SL) and take-profit (TP) percentages, dynamic position sizing based on Game Theory (minimax principle).
Visualization: Displays Nash bands, signals, background colors, and two tables (Game Theory status and backtest results).
Backtesting: Tracks performance metrics like win rate, profit factor, max drawdown, and Sharpe ratio.
Strategy Settings:
Initial capital: $10,000.
Pyramiding: Up to 3 positions.
Position size: 10% of equity (default_qty_value=10).
Configurable inputs for RSI, volume, liquidity, institutional flow, Nash equilibrium, and risk management.
Warning: This is a strategy, not just an indicator. It executes trades automatically in TradingView's Strategy Tester. Always backtest thoroughly and use proper risk management before live trading.
2. Working Logic (Step by Step)
The strategy processes each bar (candle) to generate signals, manage positions, and update performance metrics. Here's how it works:
a. Input Parameters
The inputs are grouped for clarity:
Herd Behavior (🐑):
RSI Period (14): For overbought/oversold detection.
Volume MA Period (20): To calculate average volume for spike detection.
Herd Threshold (2.0): Volume multiplier for detecting herd activity.
Liquidity Analysis (💧):
Liquidity Lookback (50): Bars to check for recent highs/lows.
Liquidity Sensitivity (1.5): Volume multiplier for trap detection.
Institutional Flow (🏦):
Institutional Volume Multiplier (2.5): For detecting large volume spikes.
Institutional MA Period (21): For Accumulation/Distribution smoothing.
Nash Equilibrium (⚖️):
Nash Period (100): For calculating price mean and standard deviation.
Nash Deviation (0.02): Multiplier for equilibrium bands.
Risk Management (🛡️):
Use Stop-Loss (true): Enables SL at 2% below/above entry price.
Use Take-Profit (true): Enables TP at 5% above/below entry price.
b. Herd Behavior Detection
RSI (14): Checks for extreme conditions:
Overbought: RSI > 70 (potential herd buying).
Oversold: RSI < 30 (potential herd selling).
Volume Spike: Volume > SMA(20) x 2.0 (herd_threshold).
Momentum: Price change over 10 bars (close - close ) compared to its SMA(20).
Herd Signals:
Herd Buying: RSI > 70 + volume spike + positive momentum = Retail buying frenzy (red background).
Herd Selling: RSI < 30 + volume spike + negative momentum = Retail selling panic (green background).
c. Liquidity Trap Detection
Recent Highs/Lows: Calculated over 50 bars (liquidity_lookback).
Psychological Levels: Nearest round numbers (e.g., $100, $110) as potential stop-loss zones.
Trap Conditions:
Up Trap: Price breaks recent high, closes below it, with a volume spike (volume > SMA x 1.5).
Down Trap: Price breaks recent low, closes above it, with a volume spike.
Visualization: Traps are marked with small red/green crosses above/below bars.
d. Institutional Flow Analysis
Volume Check: Volume > SMA(20) x 2.5 (inst_volume_mult) = Institutional activity.
Accumulation/Distribution (AD):
Formula: ((close - low) - (high - close)) / (high - low) * volume, cumulated over time.
Smoothed with SMA(21) (inst_ma_length).
Accumulation: AD > MA + high volume = Institutions buying.
Distribution: AD < MA + high volume = Institutions selling.
Smart Money Index: (close - open) / (high - low) * volume, smoothed with SMA(20). Positive = Smart money buying.
e. Nash Equilibrium
Calculation:
Price mean: SMA(100) (nash_period).
Standard deviation: stdev(100).
Upper Nash: Mean + StdDev x 0.02 (nash_deviation).
Lower Nash: Mean - StdDev x 0.02.
Conditions:
Near Equilibrium: Price between upper and lower Nash bands (stable market).
Above Nash: Price > upper band (overbought, sell potential).
Below Nash: Price < lower band (oversold, buy potential).
Visualization: Orange line (mean), red/green lines (upper/lower bands).
f. Game Theory Signals
The strategy generates three types of signals, combined into long/short triggers:
Contrarian Signals:
Buy: Herd selling + (accumulation or down trap) = Go against retail panic.
Sell: Herd buying + (distribution or up trap).
Momentum Signals:
Buy: Below Nash + positive smart money + no herd buying.
Sell: Above Nash + negative smart money + no herd selling.
Nash Reversion Signals:
Buy: Below Nash + rising close (close > close ) + volume > MA.
Sell: Above Nash + falling close + volume > MA.
Final Signals:
Long Signal: Contrarian buy OR momentum buy OR Nash reversion buy.
Short Signal: Contrarian sell OR momentum sell OR Nash reversion sell.
g. Position Management
Position Sizing (Minimax Principle):
Default: 1.0 (10% of equity).
In Nash equilibrium: Reduced to 0.5 (conservative).
During institutional volume: Increased to 1.5 (aggressive).
Entries:
Long: If long_signal is true and no existing long position (strategy.position_size <= 0).
Short: If short_signal is true and no existing short position (strategy.position_size >= 0).
Exits:
Stop-Loss: If use_sl=true, set at 2% below/above entry price.
Take-Profit: If use_tp=true, set at 5% above/below entry price.
Pyramiding: Up to 3 concurrent positions allowed.
h. Visualization
Nash Bands: Orange (mean), red (upper), green (lower).
Background Colors:
Herd buying: Red (90% transparency).
Herd selling: Green.
Institutional volume: Blue.
Signals:
Contrarian buy/sell: Green/red triangles below/above bars.
Liquidity traps: Red/green crosses above/below bars.
Tables:
Game Theory Table (Top-Right):
Herd Behavior: Buying frenzy, selling panic, or normal.
Institutional Flow: Accumulation, distribution, or neutral.
Nash Equilibrium: In equilibrium, above, or below.
Liquidity Status: Trap detected or safe.
Position Suggestion: Long (green), Short (red), or Wait (gray).
Backtest Table (Bottom-Right):
Total Trades: Number of closed trades.
Win Rate: Percentage of winning trades.
Net Profit/Loss: In USD, colored green/red.
Profit Factor: Gross profit / gross loss.
Max Drawdown: Peak-to-trough equity drop (%).
Win/Loss Trades: Number of winning/losing trades.
Risk/Reward Ratio: Simplified Sharpe ratio (returns / drawdown).
Avg Win/Loss Ratio: Average win per trade / average loss per trade.
Last Update: Current time.
i. Backtesting Metrics
Tracks:
Total trades, winning/losing trades.
Win rate (%).
Net profit ($).
Profit factor (gross profit / gross loss).
Max drawdown (%).
Simplified Sharpe ratio (returns / drawdown).
Average win/loss ratio.
Updates metrics on each closed trade.
Displays a label on the last bar with backtest period, total trades, win rate, and net profit.
j. Alerts
No explicit alertconditions defined, but you can add them for long_signal and short_signal (e.g., alertcondition(long_signal, "GT Long Entry", "Long Signal Detected!")).
Use TradingView's alert system with Strategy Tester outputs.
3. Usage Tips
Timeframe: Best for H1-D1 timeframes. Shorter frames (M1-M15) may produce noisy signals.
Settings:
Risk Management: Adjust sl_percent (e.g., 1% for volatile markets) and tp_percent (e.g., 3% for scalping).
Herd Threshold: Increase to 2.5 for stricter herd detection in choppy markets.
Liquidity Lookback: Reduce to 20 for faster markets (e.g., crypto).
Nash Period: Increase to 200 for longer-term analysis.
Backtesting:
Use TradingView's Strategy Tester to evaluate performance.
Check win rate (>50%), profit factor (>1.5), and max drawdown (<20%) for viability.
Test on different assets/timeframes to ensure robustness.
Live Trading:
Start with a demo account.
Combine with other indicators (e.g., EMAs, support/resistance) for confirmation.
Monitor liquidity traps and institutional flow for context.
Risk Management:
Always use SL/TP to limit losses.
Adjust position_size for risk tolerance (e.g., 5% of equity for conservative trading).
Avoid over-leveraging (pyramiding=3 can amplify risk).
Troubleshooting:
If no trades are executed, check signal conditions (e.g., lower herd_threshold or liquidity_sensitivity).
Ensure sufficient historical data for Nash and liquidity calculations.
If tables overlap, adjust position.top_right/bottom_right coordinates.
4. Key Differences from the Previous Indicator
Indicator vs. Strategy: The previous code was an indicator (VP + Game Theory Integrated Strategy) focused on visualization and alerts. This is a strategy with automated entries/exits and backtesting.
Volume Profile: Absent in this strategy, making it lighter but less focused on high-volume zones.
Wick Analysis: Not included here, unlike the previous indicator's heavy reliance on wick patterns.
Backtesting: This strategy includes detailed performance metrics and a backtest table, absent in the indicator.
Simpler Signals: Focuses on Game Theory signals (contrarian, momentum, Nash reversion) without the "Power/Ultra Power" hierarchy.
Risk Management: Explicit SL/TP and dynamic position sizing, not present in the indicator.
5. Conclusion
The "Game Theory Trading Strategy" is a sophisticated system leveraging herd behavior, institutional flows, liquidity traps, and Nash equilibrium to trade market inefficiencies. It’s designed for traders who understand Game Theory principles and want automated execution with robust risk management. However, it requires thorough backtesting and parameter optimization for specific markets (e.g., forex, crypto, stocks). The backtest table and visual aids make it easy to monitor performance, but always combine with other analysis tools and proper capital management.
If you need help with backtesting, adding alerts, or optimizing parameters, let me know!
Time-Decaying Percentile Oscillator [BackQuant]Time-Decaying Percentile Oscillator 
 1. Big-picture idea 
Traditional percentile or stochastic oscillators treat every bar in the look-back window as equally important. That is fine when markets are slow, but if volatility regime changes quickly yesterday’s print should matter more than last month’s. The  Time-Decaying Percentile Oscillator  attempts to fix that blind spot by assigning an adjustable weight to every past price before it is ranked. The result is a percentile score that “breathes” with market tempo much faster to flag new extremes yet still smooth enough to ignore random noise.
 2. What the script actually does 
Build a weight curve
• You pick a look-back length (default 28 bars).
• You decide whether weights fall  Linearly ,  Exponentially , by  Power-law  or  Logarithmically .
• A decay factor (lower = faster fade) shapes how quickly the oldest price loses influence.
• The array is normalised so all weights still sum to 1.
Rank prices by weighted mass
• Every close in the window is paired with its weight.
• The pairs are sorted from low to high.
• The cumulative weight is walked until it equals your chosen percentile level (default 50 = median).
• That price becomes the  Time-Decayed Percentile .
Find dispersion with robust statistics
• Instead of a fragile standard deviation the script measures  weighted Median-Absolute-Deviation  about the new percentile.
• You multiply that deviation by the  Deviation Multiplier  slider (default 1.0) to get a non-parametric volatility band.
Build an adaptive channel
• Upper band = percentile + (multiplier × deviation)
• Lower band = percentile – (multiplier × deviation)
Normalise into a 0-100 oscillator
• The current close is mapped inside that band:
0 = lower band, 50 = centre, 100 = upper band.
• If the channel squeezes, tiny moves still travel the full scale; if volatility explodes, it automatically widens.
Optional smoothing
• A second-stage moving average (EMA, SMA, DEMA, TEMA, etc.) tames the jitter.
• Length 22 EMA by default—change it to tune reaction speed.
Threshold logic
•  Upper Threshold  70 and  Lower Threshold  30 separate standard overbought/oversold states.
•  Extreme bands  85 and 15 paint background heat when aggressive fade or breakout trades might trigger.
Divergence engine
• Looks back twenty bars.
• Flags  Bullish divergence  when price makes a lower low but oscillator refuses to confirm (value < 40).
• Flags  Bearish divergence  when price prints a higher high but oscillator stalls (value > 60).
 3. Component walk-through 
•  Source  – Any price series. Close by default, switch to typical price or custom OHLC4 for futures spreads.
•  Look-back Period  – How many bars to rank. Short = faster, long = slower.
•  Base Percentile Level  – 50 shows relative position around the median; set to 25 / 75 for quartile tracking or 90 / 10 for extreme tails.
•  Deviation Multiplier  – Higher values widen the dynamic channel, lowering whipsaw but delaying signals.
•  Decay Settings 
–  Type  decides the curve shape. Exponential (default 1.16) mimics EMA logic.
–  Factor  < 1 shrinks influence faster; > 1 spreads influence flatter.
– Toggle  Enable Time Decay  off to compare with classic equal-weight stochastic.
•  Smoothing Block  – Choose one of seven MA flavours plus length.
•  Thresholds  – Overbought / Oversold / Extreme levels. Push them out when working on very mean-reverting assets like FX; pull them in for trend monsters like crypto.
•  Display toggles  – Show or hide threshold lines, extreme filler zones, bar colouring, divergence labels.
•  Colours  – Bullish green, bearish red, neutral grey. Every gradient step is automatically blended to generate a heat map across the 0-100 range.
 4. How to read the chart 
• Oscillator creeping above 70 = market auctioning near the top of its adaptive range.
• Fast poke above 85 with no follow-through = exhaustion fade candidate.
• Slow grind that lives above 70 for many bars = valid bullish trend, not a fade.
• Cross back through 50 shows balance has shifted; treat it like a micro trend change.
• Divergence arrows add extra confidence when you already see two-bar reversal candles at range extremes.
• Background shading (semi-transparent red / green) warns of extreme states and throttles your position size.
 5. Practical trading playbook 
 Mean-reversion scalps 
 1. Wait for oscillator to reach your desired OB/ OS levels
 2. Check the slope of the smoothing MA—if it is flattening the squeeze is mature.
 3. Look for a one- or two-bar reversal pattern.
 4. Enter against the move; first target = midline 50, second target = opposite threshold.
 5. Stop loss just beyond the extreme band.
 Trend continuation pullbacks 
 1. Identify a clean directional trend on the price chart.
 2. During the trend, TDP will oscillate between midline and extreme of that side.
 3. Buy dips when oscillator hits OS levels, and the same for OB levels & shorting
 4. Exit when oscillator re-tags the same-side extreme or prints divergence.
 Volatility regime filter 
 • Use the  Enable Time Decay  switch as a regime test.
 • If equal-weight oscillator and decayed oscillator diverge widely, market is entering a new volatility regime—tighten stops and trade smaller.
 Divergence confirmation for other indicators 
 • Pair TDP divergence arrows with MACD histogram or RSI to filter false positives.
 • The weighted nature means TDP often spots divergence a bar or two earlier than standard RSI.
 Swing breakout strategy 
 1. During consolidation, band width compresses and oscillator oscillates around 50.
 2. Watch for sudden expansion where oscillator blasts through extreme bands and stays pinned.
 3. Enter with momentum in breakout direction; trail stop behind upper or lower band as it re-expands.
 6. Customising decay mathematics 
 Linear  – Each older bar loses the same fixed amount of influence. Intuitive and stable; good for slow swing charts.
 Exponential  – Influence halves every “decay factor” steps. Mirrors EMA thinking and is fastest to react.
 Power-law  – Mid-history bars keep more authority than exponential but oldest data still fades. Handy for commodities where seasonality matters.
 Logarithmic  – The gentlest curve; weight drops sharply at first then levels off. Mimics how traders remember dramatic moves for weeks but forget ordinary noise quickly.
Turn decay off to verify the tool’s added value; most users never switch back.
 7. Alert catalogue 
• TD Overbought / TD Oversold – Cross of regular thresholds.
• TD Extreme OB / OS – Breach of danger zones.
• TD Bullish / Bearish Divergence – High-probability reversal watch.
• TD Midline Cross – Momentum shift that often precedes a window where trend-following systems perform.
 8. Visual hygiene tips 
• If you already plot price on a dark background pick  Bullish Color  and  Bearish Color  default; change to pastel tones for light themes.
• Hide threshold lines after you memorise the zones to declutter scalping layouts.
• Overlay mode set to false so the oscillator lives in its own panel; keep height about 30 % of screen for best resolution.
 9. Final notes 
Time-Decaying Percentile Oscillator marries robust statistical ranking, adaptive dispersion and decay-aware weighting into a simple oscillator. It respects both recent order-flow shocks and historical context, offers granular control over responsiveness and ships with divergence and alert plumbing out of the box. Bolt it onto your price action framework, trend-following system or volatility mean-reversion playbook and see how much sooner it recognises genuine extremes compared to legacy oscillators.
Backtest thoroughly, experiment with decay curves on each asset class and remember: in trading, timing beats timidity but patience beats impulse. May this tool help you find that edge.
Candle Channel█ OVERVIEW
The "Candle Channel" indicator is a versatile technical analysis tool that plots a price channel based on the Simple Moving Average (SMA) of candlestick midpoints. The channel bands, calculated based on candlestick volatility, form dynamic support and resistance levels that adapt to price movements. The script generates signals for reversals from the bands and SMA breakouts, making it useful for both short-term and long-term traders. By adjusting the SMA length, the channel can vary in nature—from a wide channel encapsulating price movement to narrower support/resistance or trend-following bands. The channel width can be further customized using a scaling parameter, allowing adaptation to different trading styles and markets.
█ MECHANISM
Band Calculation
The indicator is based on the following calculations:  
Candlestick Midpoint: Calculated as the arithmetic average of the candle’s high and low prices: (high + low) / 2.  
Simple Moving Average (SMA): The average of candlestick midpoints over a specified length (default: 20 candles), forming the channel’s centerline.  
Average Candle Height: Calculated as the average difference between the high and low prices (high - low) over the same SMA length, serving as a measure of market volatility.  
Band Scaling: The user specifies a percentage of the average candle height (default: 200%), which is multiplied by the average height to create an offset. The upper band is SMA + offset, and the lower band is SMA - offset.Example: For an average candle height of 10 points and 200% scaling, the offset is 20 points, meaning the bands are ±20 points from the SMA.  
Channel Characteristics: The SMA length determines the channel’s dynamics. Shorter SMA values (10–30) create a wide channel that contains price movement, ideal for scalping or short-term trading. Longer SMA values (above 30, e.g., 50–100) transform the channel into narrower support/resistance or trend-following bands, suitable for longer-term analysis. Band scaling further adjusts the channel width to match market volatility.
Signals  
Reversal from Bands: Signals are generated when the price closes outside the band (above the upper or below the lower) and then returns to the channel, indicating a potential trend reversal.  
SMA Breakout: Signals are generated when the price crosses the SMA upward (bullish signal) or downward (bearish signal), suggesting potential trend changes.
Visualization  
Centerline: The SMA of candlestick midpoints, displayed as a thin line.  
Channel Bands: Upper and lower channel boundaries, with customizable colors.  
Fill: Options include a gradient (smooth color transition between bands) or solid color. The fill can also be disabled for greater clarity.
█ FEATURES AND SETTINGS  
SMA Length: Determines the moving average period (default: 20). Values of 10–30 are suitable for a wide channel containing price movement, ideal for short-term timeframes. Longer values (e.g., 50–100) create narrower support/resistance or trend-following bands, better suited for higher timeframes.  
Band Scaling: Percentage of the average candle height (default: 200%). Adjusts the channel width to match market volatility—smaller values (e.g., 50–100%) for narrower bands, larger values (e.g., 200–300%) for wider channels.  
Fill Type: Gradient, solid, or no fill, allowing customization to user preferences.  
Colors: Options to change the colors of bands, fill, and signals for better readability.  
Signals: Options to enable/disable reversal signals from bands and SMA breakout signals.
█ HOW TO USE  
Add the script to your chart in TradingView by clicking "Add to Chart" in the Pine Editor.  
Adjust input parameters in the script settings:  
SMA Length: Set to 10–30 for a wide channel containing price movement, suitable for scalping or short-term trading. Set above 30 (e.g., 50–100) for narrower support/resistance or trend-following bands.  
Band Scaling: Adjust the channel width to market volatility. Smaller values (50–100%) for tighter support/resistance bands, larger values (200–300%) for wider channels containing price movement.  
Fill Type and Colors: Choose a gradient for aesthetics or a solid fill for clarity.
Analyze signals:  
Reversal Signals: Triangles above (bearish) or below (bullish) candles indicate potential reversal points.  
SMA Breakout Signals: Circles above (bearish) or below (bullish) candles indicate trend changes.
Test the indicator on different instruments and timeframes to find optimal settings for your trading style.
█ LIMITATIONS  
The indicator may generate false signals in highly volatile or consolidating markets.  
On low-liquidity charts (e.g., exotic currency pairs), the bands may be less reliable.  
Effectiveness depends on properly matching parameters to the market and timeframe.
MERV: Market Entropy & Rhythm Visualizer [BullByte]The  MERV (Market Entropy & Rhythm Visualizer)  indicator analyzes market conditions by measuring entropy (randomness vs. trend), tradeability (volatility/momentum), and cyclical rhythm. It provides traders with an easy-to-read dashboard and oscillator to understand when markets are structured or choppy, and when trading conditions are optimal.
 Purpose of the Indicator   
MERV’s goal is to help traders identify different market regimes. It quantifies how structured or random recent price action is (entropy), how strong and volatile the movement is (tradeability), and whether a repeating cycle exists. By visualizing these together, MERV highlights trending vs. choppy environments and flags when conditions are favorable for entering trades. For example, a low entropy value means prices are following a clear trend line, whereas high entropy indicates a lot of noise or sideways action. The indicator’s combination of measures is original: it fuses statistical trend-fit (entropy), volatility trends (ATR and slope), and cycle analysis to give a comprehensive view of market behavior.
 Why a Trader Should Use It   
Traders often need to know when a market trend is reliable vs. when it is just noise. MERV helps in several ways: it shows when the market has a strong direction (low entropy, high tradeability) and when it’s ranging (high entropy). This can prevent entering trend-following strategies during choppy periods, or help catch breakouts early. The  “Optimal Regime”  marker (a star) highlights moments when entropy is very low and tradeability is very high, typically the best conditions for trend trades. By using MERV, a trader gains an empirical “go/no-go” signal based on price history, rather than guessing from price alone. It’s also adaptable: you can apply it to stocks, forex, crypto, etc., on any timeframe. For example, during a bullish phase of a stock, MERV will turn green (Trending Mode) and often show a star, signaling good follow-through. If the market later grinds sideways, MERV will shift to magenta (Choppy Mode), warning you that trend-following is now risky.
 Why These Components Were Chosen   
 Market Entropy (via R²) : This measures how well recent prices fit a straight line. We compute a linear regression on the last len_entropy bars and calculate R². Entropy = 1 - R², so entropy is low when prices follow a trend (R² near 1) and high when price action is erratic (R² near 0). This single number captures trend strength vs noise.
 Tradeability (ATR + Slope) : We combine two familiar measures: the Average True Range (ATR) (normalized by price) and the absolute slope of the regression line (scaled by ATR). Together they reflect how active and directional the market is. A high ATR or strong slope means big moves, making a trend more “tradeable.” We take a simple average of the normalized ATR and slope to get tradeability_raw. Then we convert it to a percentile rank over the lookback window so it’s stable between 0 and 1.
 Percentile Ranks : To make entropy and tradeability values easy to interpret, we convert each to a 0–100 rank based on the past len_entropy periods. This turns raw metrics into a consistent scale. (For example, an entropy rank of 90 means current entropy is higher than 90% of recent values.) We then divide by 100 to plot them on a 0–1 scale.
 Market Mode (Regime) : Based on those ranks, MERV classifies the market: 
 Trending (Green) : Low entropy rank (<40%) and high tradeability rank (>60%). This means the market is structurally trending with high activity.
 Choppy (Magenta) : High entropy rank (>60%) and low tradeability rank (<40%). This is a mostly random, low-momentum market.
 Neutral (Cyan) : All other cases. This covers mixed regimes not strongly trending or choppy.
The mode is shown as a colored bar at the bottom: green for trending, magenta for choppy, cyan for neutral.
 Optimal Regime Signal : Separately, we mark an “optimal” condition when entropy_norm < 0.3 and tradeability > 0.7 (both normalized 0–1). When this is true, a ★ star appears on the bottom line. This star is colored white when truly optimal, gold when only tradeability is high (but entropy not quite low enough), and black when neither condition holds. This gives a quick visual cue for very favorable conditions.
 What Makes MERV Stand Out   
 Holistic View : Unlike a single-oscillator, MERV combines trend, volatility, and cycle analysis in one tool. This multi-faceted approach is unique.
 Visual Dashboard : The fixed on-chart dashboard (shown at your chosen corner) summarizes all metrics in bar/gauge form. Even a non-technical user can glance at it: more “█” blocks = a higher value, colors match the plots. This is more intuitive than raw numbers.   
 Adaptive Thresholds : Using percentile ranks means MERV auto-adjusts to each market’s character, rather than requiring fixed thresholds.
 Cycle Insight : The rhythm plot adds information rarely found in indicators – it shows if there’s a repeating cycle (and its period in bars) and how strong it is. This can hint at natural bounce or reversal intervals.
 Modern Look : The neon color scheme and glow effects make the lines easy to distinguish (blue/pink for entropy, green/orange for tradeability, etc.) and the filled area between them highlights when one dominates the other.
 Recommended Timeframes   
MERV can be applied to any timeframe, but it will be more reliable on higher timeframes. The default len_entropy = 50 and len_rhythm = 30 mean we use 30–50 bars of history, so on a daily chart that’s ~2–3 months of data; on a 1-hour chart it’s about 2–3 days. In practice:
 Swing/Position  traders might prefer Daily or 4H charts, where the calculations smooth out small noise. Entropy and cycles are more meaningful on longer trends.
 Day trader s could use 15m or 1H charts if they adjust the inputs (e.g. shorter windows). This provides more sensitivity to intraday cycles.
 Scalpers  might find MERV too “slow” unless input lengths are set very low.
In summary, the indicator works anywhere, but the defaults are tuned for capturing medium-term trends. Users can adjust len_entropy and len_rhythm to match their chart’s volatility. The dashboard position can also be moved (top-left, bottom-right, etc.) so it doesn’t cover important chart areas.
 How the Scoring/Logic Works (Step-by-Step)   
 Compute Entropy : A linear regression line is fit to the last len_entropy closes. We compute R² (goodness of fit). Entropy = 1 – R². So a strong straight-line trend gives low entropy; a flat/noisy set of points gives high entropy.
 Compute Tradeability : We get ATR over len_entropy bars, normalize it by price (so it’s a fraction of price). We also calculate the regression slope (difference between the predicted close and last close). We scale |slope| by ATR to get a dimensionless measure. We average these (ATR% and slope%) to get tradeability_raw. This represents how big and directional price moves are.
 Convert to Percentiles : Each new entropy and tradeability value is inserted into a rolling array of the last 50 values. We then compute the percentile rank of the current value in that array (0–100%) using a simple loop. This tells us where the current bar stands relative to history. We then divide by 100 to plot on  .
 Determine Modes and Signal : Based on these normalized metrics: if entropy < 0.4 and tradeability > 0.6 (40% and 60% thresholds), we set mode = Trending (1). If entropy > 0.6 and tradeability < 0.4, mode = Choppy (-1). Otherwise mode = Neutral (0). Separately, if entropy_norm < 0.3 and tradeability > 0.7, we set an optimal flag. These conditions trigger the colored mode bars and the star line.
 Rhythm Detection : Every bar, if we have enough data, we take the last len_rhythm closes and compute the mean and standard deviation. Then for lags from 5 up to len_rhythm, we calculate a normalized autocorrelation coefficient. We track the lag that gives the maximum correlation (best match). This “best lag” divided by len_rhythm is plotted (a value between 0 and 1). Its color changes with the correlation strength. We also smooth the best correlation value over 5 bars to plot as “Cycle Strength” (also 0 to 1). This shows if there is a consistent cycle length in recent price action.
 Heatmap (Optional) : The background color behind the oscillator panel can change with entropy. If “Neon Rainbow” style is on, low entropy is blue and high entropy is pink (via a custom color function), otherwise a classic green-to-red gradient can be used. This visually reinforces the entropy value.
 Volume Regime (Dashboard Only) : We compute vol_norm = volume / sma(volume, len_entropy). If this is above 1.5, it’s considered high volume (neon orange); below 0.7 is low (blue); otherwise normal (green). The dashboard shows this as a bar gauge and percentage. This is for context only.
 Oscillator Plot – How to Read It   
The main panel (oscillator) has multiple colored lines on a 0–1 vertical scale, with horizontal markers at 0.2 (Low), 0.5 (Mid), and 0.8 (High). Here’s each element:
 Entropy Line (Blue→Pink) : This line (and its glow) shows normalized entropy (0 = very low, 1 = very high). It is blue/green when entropy is low (strong trend) and pink/purple when entropy is high (choppy). A value near 0.0 (below 0.2 line) indicates a very well-defined trend. A value near 1.0 (above 0.8 line) means the market is very random. Watch for it dipping near 0: that suggests a strong trend has formed.
 Tradeability Line (Green→Yellow) : This represents normalized tradeability. It is colored bright green when tradeability is low, transitioning to yellow as tradeability increases. Higher values (approaching 1) mean big moves and strong slopes. Typically in a market rally or crash, this line will rise. A crossing above ~0.7 often coincides with good trend strength.
 Filled Area (Orange Shade) : The orange-ish fill between the entropy and tradeability lines highlights when one dominates the other. If the area is large, the two metrics diverge; if small, they are similar. This is mostly aesthetic but can catch the eye when the lines cross over or remain close.
 Rhythm (Cycle) Line : This is plotted as (best_lag / len_rhythm). It indicates the relative period of the strongest cycle. For example, a value of 0.5 means the strongest cycle was about half the window length. The line’s color (green, orange, or pink) reflects how strong that cycle is (green = strong). If no clear cycle is found, this line may be flat or near zero.
 Cycle Strength Line : Plotted on the same scale, this shows the autocorrelation strength (0–1). A high value (e.g. above 0.7, shown in green) means the cycle is very pronounced. Low values (pink) mean any cycle is weak and unreliable.
 Mode Bars (Bottom) : Below the main oscillator, thick colored bars appear: a green bar means Trending Mode, magenta means Choppy Mode, and cyan means Neutral. These bars all have a fixed height (–0.1) and make it very easy to see the current regime.   
 Optimal Regime Line (Bottom) : Just below the mode bars is a thick horizontal line at –0.18. Its color indicates regime quality: White (★) means “Optimal Regime” (very low entropy and high tradeability). Gold (★) means not quite optimal (high tradeability but entropy not low enough). Black means neither condition. This star line quickly tells you when conditions are ideal (white star) or simply good (gold star).
 Horizontal Guides : The dotted lines at 0.2 (Low), 0.5 (Mid), and 0.8 (High) serve as reference lines. For example, an entropy or tradeability reading above 0.8 is “High,” and below 0.2 is “Low,” as labeled on the chart. These help you gauge values at a glance.
 Dashboard (Fixed Corner Panel)   
MERV also includes a compact table (dashboard) that can be positioned in any corner. It summarizes key values each bar. Here is how to read its rows:
 Entropy : Shows a bar of blocks (█ and ░). More █ blocks = higher entropy. It also gives a percentage (rounded). A full bar (10 blocks) with a high % means very chaotic market. The text is colored similarly (blue-green for low, pink for high).
 Rhythm : Shows the best cycle period in bars (e.g. “15 bars”). If no calculation yet, it shows “n/a.” The text color matches the rhythm line.
 Cycle Strength : Gives the cycle correlation as a percentage (smoothed, as shown on chart). Higher % (green) means a strong cycle.
 Tradeability : Displays a 10-block gauge for tradeability. More blocks = more tradeable market. It also shows “gauge” text colored green→yellow accordingly.
 Market Mode : Simply shows “Trending”, “Choppy”, or “Neutral” (cyan text) to match the mode bar color.
 Volume Regime : Similar to tradeability, shows blocks for current volume vs. average. Above-average volume gives orange blocks, below-average gives blue blocks. A % value indicates current volume relative to average. This row helps see if volume is abnormally high or low.  
 Optimal Status (Large Row) : In bold, either “★ Optimal Regime” (white text) if the star condition is met, “★ High Tradeability” (gold text) if tradeability alone is high, or “— Not Optimal” (gray text) otherwise. This large row catches your eye when conditions are ripe.
In short, the dashboard turns the numeric state into an easy read: filled bars, colors, and text let you see current conditions without reading the plot. For instance, five blue blocks under Entropy and “25%” tells you entropy is low (good), and a row showing “Trending” in green confirms a trend state.
 Real-Life Example   
 Example : Consider a daily chart of a trending stock (e.g. “AAPL, 1D”). During a strong uptrend, recent prices fit a clear upward line, so Entropy would be low (blue line near bottom, perhaps below the 0.2 line). Volatility and slope are high, so Tradeability is high (green-yellow line near top). In the dashboard, Entropy might show only 1–2 blocks (e.g. 10%) and Tradeability nearly full (e.g. 90%). The Market Mode bar turns green (Trending), and you might see a white ★ on the optimal line if conditions are very good. The Volume row might light orange if volume is above average during the rally. In contrast, imagine the same stock later in a tight range: Entropy will rise (pink line up, more blocks in dashboard), Tradeability falls (fewer blocks), and the Mode bar turns magenta (Choppy). No star appears in that case.
 Consolidated Use Case : Suppose on XYZ stock the dashboard reads “Entropy: █░░░░░░░░ 20%”, “Tradeability: ██████████ 80%”, Mode = Trending (green), and “★ Optimal Regime.” This tells the trader that the market is in a strong, low-noise trend, and it might be a good time to follow the trend (with appropriate risk controls). If instead it reads “Entropy: ████████░░ 80%”, “Tradeability: ███▒▒▒▒▒▒ 30%”, Mode = Choppy (magenta), the trader knows the market is random and low-momentum—likely best to sit out until conditions improve.
 Example: How It Looks in Action   
 Screenshot 1:  Trending Market with High Tradeability (SOLUSD, 30m)  
  
 What it means:   
The market is in a clear, strong trend with excellent conditions for trading. Both trend-following and active strategies are favored, supported by high tradeability and strong volume.  
 Screenshot 2:  Optimal Regime, Strong Trend (ETHUSD, 1h)  
  
 What it means:   
This is an ideal environment for trend trading. The market is highly organized, tradeability is excellent, and volume supports the move. This is when the indicator signals the highest probability for success.  
 Screenshot 3:  Choppy Market with High Volume (BTC Perpetual, 5m)  
  
 What it means:   
The market is highly random and choppy, despite a surge in volume. This is a high-risk, low-reward environment, avoid trend strategies, and be cautious even with mean-reversion or scalping.  
 Settings and Inputs   
The script is fully open-source; here are key inputs the user can adjust:
 Entropy Window (len_entropy) : Number of bars used for entropy and tradeability (default 50). Larger = smoother, more lag; smaller = more sensitivity. 
 Rhythm Window (len_rhythm ): Bars used for cycle detection (default 30). This limits the longest cycle we detect.
 Dashboard Position : Choose any corner (Top Right default) so it doesn’t cover chart action.
 Show Heatmap : Toggles the entropy background coloring on/off.  
 Heatmap Style : “Neon Rainbow” (colorful) or “Classic” (green→red).
 Show Mode Bar : Turn the bottom mode bar on/off.
 Show Dashboard : Turn the fixed table panel on/off.
Each setting has a tooltip explaining its effect. In the description we will mention typical settings (e.g. default window sizes) and that the user can move the dashboard corner as desired.
 Oscillator Interpretation (Recap)   
 Lines : Blue/Pink = Entropy (low=trend, high=chop); Green/Yellow = Tradeability (low=quiet, high=volatile).
 Fill : Orange tinted area between them (for visual emphasis).
 Bars : Green=Trending, Magenta=Choppy, Cyan=Neutral (at bottom).
 Star Line : White star = ideal conditions, Gold = good but not ideal.
 Horizontal Guides : 0.2 and 0.8 lines mark low/high thresholds for each metric.
Using the chart, a coder or trader can see exactly what each output represents and make decisions accordingly.
 Disclaimer   
This indicator is provided as-is for educational and analytical purposes only. It does not guarantee any particular trading outcome. Past market patterns may not repeat in the future. Users should apply their own judgment and risk management; do not rely solely on this tool for trading decisions. Remember, TradingView scripts are tools for market analysis, not personalized financial advice. We encourage users to test and combine MERV with other analysis and to trade responsibly.
-BullByte
Stochastic Ribbon & EMAsHere's a comprehensive description for publishing your indicator:
---
# **Stochastic Ribbon & EMAs**
A clean and powerful trading indicator that combines **Stochastic Support/Resistance levels** with **Essential Moving Averages** for comprehensive market analysis.
## **📊 What It Does**
This indicator provides **7 key reference lines** on your chart:
- **3 Stochastic levels** (20%, 50%, 80%) - Dynamic support/resistance zones
- **4 Essential EMAs** (20, 50, 100, 200) - Trend direction and momentum
## **🎯 Key Features**
### **Stochastic Ribbon (3 Yellow Lines)**
- **80% Line**: Dynamic resistance level - potential selling zone
- **50% Line**: Market equilibrium - trend direction reference  
- **20% Line**: Dynamic support level - potential buying zone
- **Default 50-period lookback** for stable, reliable levels
- **All lines in yellow** for clean, consistent visualization
### **Essential EMAs (4 Colored Lines)**
- **20 EMA** (Purple): Short-term trend and entry timing
- **50 EMA** (Dark Cyan): Medium-term trend direction
- **100 EMA** (Rosy Brown): Long-term trend confirmation
- **200 EMA** (Brown): Major trend and institutional levels
## **📈 How to Use**
### **For Support & Resistance:**
- **Above 80% line**: Look for selling opportunities (overbought zone)
- **Between 50-80%**: Bullish bias, pullbacks to 50% line for entries
- **Around 50% line**: Key equilibrium - watch for direction
- **Between 20-50%**: Bearish bias, bounces to 50% line for exits
- **Below 20% line**: Look for buying opportunities (oversold zone)
### **For Trend Analysis:**
- **EMA Stack Order**: Higher timeframe EMAs above lower = uptrend
- **Price above all EMAs**: Strong bullish momentum
- **Price below all EMAs**: Strong bearish momentum
- **EMA as dynamic support/resistance**: Bounces and rejections
### **For Entry Signals:**
- **Confluence zones**: Where Stochastic levels meet EMA levels
- **Breakouts**: Price breaking through multiple levels simultaneously
- **Reversals**: Price rejection at extreme Stochastic levels with EMA confirmation
## **⚙️ Settings**
### **Stochastic Ribbon**
- **Show/Hide**: Toggle the 3 Stochastic lines
- **Length**: Period for high/low calculation (default: 50)
- **Start**: Multiplier for calculation (default: 1)
### **EMAs**
- **Individual toggles**: Show/hide each EMA separately
- **Custom periods**: Adjust each EMA length (defaults: 20, 50, 100, 200)
- **Custom colors**: Personalize each EMA color
## **🚀 Why This Indicator?**
✅ **Clean & Simple**: No cluttered charts - just essential levels  
✅ **Multi-Timeframe**: Works on all timeframes from 1m to 1W  
✅ **Versatile**: Suitable for scalping, day trading, and swing trading  
✅ **Low Lag**: Dynamic levels that adapt to current market conditions  
✅ **Proven Components**: Combines two well-established technical concepts  
✅ **Customizable**: Adjust all parameters to fit your trading style  
## **💡 Pro Tips**
- **Use multiple timeframes**: Check higher timeframe alignment for stronger signals
- **Combine with volume**: Look for volume confirmation at key levels
- **Watch for confluences**: Best signals occur where multiple levels align
- **Respect the 50% line**: Often acts as the most important level for trend direction
## **📋 Technical Details**
- **Version**: Pine Script v5
- **Overlay**: Yes (displays on main price chart)
- **Plots**: 7 total (well within Pine Script limits)
- **Performance**: Optimized for fast loading and smooth operation
---
**Perfect for traders who want clear, actionable levels without chart clutter. Whether you're a beginner learning support/resistance or an experienced trader looking for clean reference points, this indicator delivers exactly what you need.**
Trigonometric StochasticTrigonometric Stochastic - Mathematical Smoothing Oscillator 
 Overview 
A revolutionary approach to stochastic oscillation using sine wave mathematical smoothing. This indicator transforms traditional stochastic calculations through trigonometric functions, creating an ultra-smooth oscillator that reduces noise while maintaining sensitivity to price changes.
 Mathematical Foundation 
Unlike standard stochastic oscillators, this version applies sine wave smoothing:
• Raw Stochastic: (close - lowest_low) / (highest_high - lowest_low) × 100
• Trigonometric Smoothing: 50 + 50 × sin(2π × raw_stochastic / 100)  
• Result: Naturally smooth oscillator with mathematical precision
 Key Features 
 Advanced Smoothing Technology 
• Sine Wave Filter: Eliminates choppy movements while preserving signal integrity
• Natural Boundaries: Mathematically constrained between 0-100
• Reduced False Signals: Trigonometric smoothing filters market noise effectively
 Traditional Stochastic Levels 
• Overbought Zone: 80 level (dashed line)
• Oversold Zone: 20 level (dashed line)
• Midline: 50 level (dotted line) - equilibrium point
• Visual Clarity: Clean oscillator panel with clear level markings
 Smart Signal Generation 
• Anti-Repaint Logic: Uses confirmed previous bar values
• Buy Signals: Generated when crossing above 30 from oversold territory
• Sell Signals: Generated when crossing below 70 from overbought territory
• Crossover Detection: Precise entry/exit timing
 Professional Presentation 
• Separate Panel: Dedicated oscillator window (overlay=false)
• Price Format: Formatted as price indicator with 2-decimal precision
• Theme Adaptive: Automatically matches your chart color scheme
 Parameters 
•  Cycle Length  (5-200): Period for highest/lowest calculations
  - Shorter periods = more sensitive, more signals
  - Longer periods = smoother, fewer but stronger signals
 Trading Applications 
 Momentum Analysis 
• Overbought/Oversold: Clear visual identification of extreme levels
• Momentum Shifts: Early detection of momentum changes
• Trend Strength: Monitor oscillator position relative to midline
 Signal Trading 
• Long Entries: Buy when crossing above 30 (oversold bounce)
• Short Entries: Sell when crossing below 70 (overbought rejection)
• Confirmation Tool: Use with trend indicators for higher probability trades
 Divergence Detection 
• Bullish Divergence: Price makes lower lows, oscillator makes higher lows
• Bearish Divergence: Price makes higher highs, oscillator makes lower highs
• Early Warning: Spot potential trend reversals before they occur
 Trading Strategies 
 Scalping (5-15min timeframes) 
• Use cycle length 10-14 for quick signals
• Focus on 20/80 level bounces
• Combine with price action confirmation
 Swing Trading (1H-4H timeframes) 
• Use cycle length 20-30 for reliable signals
• Wait for clear crossovers with momentum
• Monitor divergences for reversal setups
 Position Trading (Daily+ timeframes) 
• Use cycle length 50+ for major signals
• Focus on extreme readings (below 10, above 90)
• Combine with fundamental analysis
 Advantages Over Standard Stochastic 
1.  Smoother Action:  Sine wave smoothing reduces whipsaws
2.  Mathematical Precision:  Trigonometric functions provide consistent behavior
3.  Maintained Sensitivity:  Smoothing doesn't compromise signal quality
4.  Reduced Noise:  Cleaner signals in volatile markets
5.  Visual Appeal:  More aesthetically pleasing oscillator movement
 Best Practices 
•  Market Context:  Consider overall trend direction
•  Multiple Timeframe:  Confirm signals on higher timeframes
•  Risk Management:  Always use proper position sizing
•  Backtesting:  Test parameters on your preferred instruments
•  Combination:  Works excellently with trend-following indicators
 Built-in Alerts 
• Buy Alert: Trigonometric stochastic oversold crossover
• Sell Alert: Trigonometric stochastic overbought crossunder
 Technical Specifications 
• Pine Script Version: v6
• Panel: Separate oscillator window
• Format: Price indicator with 2-decimal precision
• Performance: Optimized for all timeframes
• Compatibility: Works with all instruments
 Free and open-source indicator. Modify, improve, and share with the community! 
 Educational Value:  Perfect for traders wanting to understand how mathematical smoothing improves oscillators and trigonometric applications in technical analysis.
Fibonacci Sequence Moving Average [BackQuant]Fibonacci Sequence Moving Average with Adaptive Oscillator  
 1. Overview 
The Fibonacci Sequence Moving Average indicator is a two‑part trading framework that combines a custom moving average built from the famous Fibonacci number set with a fully featured oscillator, normalisation engine and divergence suite. The moving average half delivers an adaptive trend line that respects natural market rhythms, while the oscillator half translates that trend information into a bounded momentum stream that is easy to read, easy to compare across assets and rich in confluence signals. Everything from weighting logic to colour palettes can be customised, so the tool comfortably fits scalpers zooming into one‑minute candles as well as position traders running multi‑month trend following campaigns.
 2. Core Calculation 
 Fibonacci periods  – The default length array is 5, 8, 13, 21, 34. A single multiplier input lets you scale the whole family up or down without breaking the golden‑ratio spacing. For example a multiplier of 3 yields 15, 24, 39, 63, 102.
 Component averages  – Each period is passed through Simple Moving Average logic to produce five baseline curves (ma1 through ma5).
 Weighting methods  – You decide how those five values are blended:
• Equal weighting treats every curve the same.
• Linear weighting applies factors 1‑to‑5 so the slowest curve counts five times as much as the fastest.
• Exponential weighting doubles each step for a fast‑reacting yet still smooth line.
• Fibonacci weighting multiplies each curve by its own period value, honouring the spirit of ratio mathematics.
 Smoothing engine  – The blended average is then smoothed a second time with your choice of SMA, EMA, DEMA, TEMA, RMA, WMA or HMA. A short smoothing length keeps the result lively, while longer lengths create institution‑grade glide paths that act like dynamic support and resistance.
 3. Oscillator Construction 
Once the smoothed Fib MA is in place, the script generates a raw oscillator value in one of three flavours:
• Distance – Percentage distance between price and the average. Great for mean‑reversion.
• Momentum – Percentage change of the average itself. Ideal for trend acceleration studies.
• Relative – Distance divided by Average True Range for volatility‑aware scaling.
That raw series is pushed through a look‑back normaliser that rescales every reading into a fixed −100 to +100 window. The normalisation window defaults to 100 bars but can be tightened for fast markets or expanded to capture long regimes.
 4. Visual Layer 
The oscillator line is gradient‑coloured from deep red through sky blue into bright green, so you can spot subtle momentum shifts with peripheral vision alone. There are four horizontal guide lines: Extreme Bear at −50, Bear Threshold at −20, Bull Threshold at +20 and Extreme Bull at +50. Soft fills above and below the thresholds reinforce the zones without cluttering the chart.
The smoothed Fib MA can be plotted directly on price for immediate trend context, and each of the five component averages can be revealed for educational or research purposes. Optional bar‑painting mirrors oscillator polarity, tinting candles green when momentum is bullish and red when momentum is bearish.
 5. Divergence Detection 
The script automatically looks for four classes of divergences between price pivots and oscillator pivots:
Regular Bullish, signalling a possible bottom when price prints a lower low but the oscillator prints a higher low.
Hidden Bullish, often a trend‑continuation cue when price makes a higher low while the oscillator slips to a lower low.
Regular Bearish, marking potential tops when price carves a higher high yet the oscillator steps down.
Hidden Bearish, hinting at ongoing downside when price posts a lower high while the oscillator pushes to a higher high.
Each event is tagged with an ℝ or ℍ label at the oscillator pivot, colour‑coded for clarity. Look‑back distances for left and right pivots are fully adjustable so you can fine‑tune sensitivity.
 6. Alerts 
Five ready‑to‑use alert conditions are included:
• Bullish when the oscillator crosses above +20.
• Bearish when it crosses below −20.
• Extreme Bullish when it pops above +50.
• Extreme Bearish when it dives below −50.
• Zero Cross for momentum inflection.
Attach any of these to TradingView notifications and stay updated without staring at charts.
 7. Practical Applications 
 Swing trading trend filter  – Plot the smoothed Fib MA on daily candles and only trade in its direction. Enter on oscillator retracements to the 0 line.
 Intraday reversal scouting  – On short‑term charts let Distance mode highlight overshoots beyond ±40, then fade those moves back to mean.
 Volatility breakout timing  – Use Relative mode during earnings season or crypto news cycles to spot momentum surges that adjust for changing ATR.
 Divergence confirmation  – Layer the oscillator beneath price structure to validate double bottoms, double tops and head‑and‑shoulders patterns.
 8. Input Summary 
• Source, Fibonacci multiplier, weighting method, smoothing length and type
• Oscillator calculation mode and normalisation look‑back
• Divergence look‑back settings and signal length
• Show or hide options for every visual element
• Full colour and line width customisation
 9. Best Practices 
Avoid using tiny multipliers on illiquid assets where the shortest Fibonacci window may drop under three bars. In strong trends reduce divergence sensitivity or you may see false counter‑trend flags. For portfolio scanning set oscillator to Momentum mode, hide thresholds and colour bars only, which turns the indicator into a heat‑map that quickly highlights leaders and laggards.
 10. Final Notes 
The Fibonacci Sequence Moving Average indicator seeks to fuse the mathematical elegance of the golden ratio with modern signal‑processing techniques. It is not a standalone trading system, rather a multi‑purpose information layer that shines when combined with market structure, volume analysis and disciplined risk management. Always test parameters on historical data, be mindful of slippage and remember that past performance is never a guarantee of future results. Trade wisely and enjoy the harmony of Fibonacci mathematics in your technical toolkit.
Multi SMA AnalyzerMulti SMA Analyzer with Custom SMA Table & Advanced Session Logic
A feature-rich SMA analysis suite for traders, offering up to 7 configurable SMAs, in-depth trend detection, real-time table, and true session-aware calculations.
Ideal for those who want to combine intraday, swing, and higher-timeframe trend analysis with maximum chart flexibility.
Key Features
📊 Multi-SMA Overlay
- 7 SMAs (default: 5, 20, 50, 100, 200, 21, 34)—individually configurable (period, source, color, line style)
- Show/hide each SMA, custom line style (solid, stepline, circles), and color logic
- Dynamic color: full opacity above SMA, reduced when below
⏰ Session-Aware SMAs
- Each SMA can be calculated using only user-defined session hours/days/timezone
- “Ignore extended hours” option for accurate intraday trend
📋 Smart Data Table
- Live SMA values, % distance from price, and directional arrows (↑/↓/→)
- Bull/Bear/Sideways trend classification
- Custom table position, size, colors, transparency
- Table can run on chart or custom (higher) timeframe for multi-TF analysis
🎯 Golden/Death Cross Detection
- Flexible crossover engine: select any two from (5, 10, 20, 50, 100, 200) for fast/slow SMA cross signals
- Plots icons (★ Golden, 💀 Death), optional crossover labels with custom size/colors
🏷️ SMA Labels
- Optional on-chart SMA period labels
- Custom placement (above/below/on line), size, color, offset
🚨 Signal & Trend Engine
- Bull/Bear/Sideways logic: price vs. multiple SMAs (not just one pair)
- Volume spike detection (2x 20-period SMA)
- Bullish engulfing candlestick detection
- All signals can use chart or custom table timeframe
🎨 Visual Customization
- Dynamic background color (Bull: green, Bear: red, Neutral: gray)
- Every visual aspect is customizable: label/table colors, transparency, size, position
🔔 Built-in Alerts
- Crossovers (SMA20/50, Golden/Death)
- Bull trend, volume spikes, engulfing pattern—all alert-ready
How It Works
- Session Filtering:
 - SMAs can be set to count only bars from your chosen market session, for true intraday/trading-hour signals
Dynamic Table & Signals:
- Table and all signal logic run on your selected chart or custom timeframe
Flexible Crossover:
- Choose any pair (5, 10, 20, 50, 100, 200) for cross detection—SMA 10 is available for crossover even if not shown as an SMA line
Everything is modular:
- Toggle features, set visuals, and alerts to your workflow
🚨 How to Use Alerts 
- All key signals (crossovers, trend shifts, volume spikes, engulfing patterns) are available as alert conditions.
To enable:
- Click the “Alerts” (clock) icon at the top of TradingView.
- Select your desired signal (e.g., “Golden Cross”) from the condition dropdown.
- Set your alert preferences and create the alert.
- Now, you’ll get notified automatically whenever a signal occurs!
Perfect For
- Multi-timeframe and swing traders seeking higher timeframe SMA confirmation
- Intraday traders who want to ignore pre/post-market data
- Anyone wanting a modern, powerful, fully customizable multi-SMA overlay
// P.S: Experiment with Golden Cross where Fast SMA is 5 and Slow SMA is 20.
// Set custom timeframe for 4 hr while monitoring your chart on 15 min time frame.
// Enable Background Color and Use Table Timeframe for Background.
// Uncheck Pine labels in Style tab.
Clean, open-source, and loaded with pro features—enjoy!
Like, share, and let me know if you'd like any new features added.
Fibonacci Extension Distance Table## 🧾 **Script Name**: Fibonacci Extension Distance Table
### 🎯 Purpose:
This script helps traders visually track **key Fibonacci extension levels** on any chart and immediately see:
* The **price target** at each extension
* The **distance in percentage** from the current market price
It is especially helpful for:
* **Profit targets in trending trades**
* Monitoring **potential resistance zones** in uptrends
* Planning **entry/exit timing**
---
## 🧮 **How It Works**
1. **Swing Logic (A → B → C)**
   * It automatically finds:
     * `A`: the **lowest low** in the last `swingLen` bars
     * `B`: the **highest high** in that same lookback
     * `C`: current bar’s low is used as the **retracement point** (simplified)
2. **Extension Formula**
   Using the Fibonacci formula:
   ```text
   Extension Price = C + (B - A) × Fibonacci Ratio
   ```
   The script calculates projected target prices at:
   * **100%**
   * **127.2%**
   * **161.8%** (Golden Ratio)
   * **200%**
   * **261.8%**
3. **Distance Calculation**
   For each level, it calculates:
   * The **absolute difference** between current price and the extension level
   * The **percentage difference**, which helps quickly assess how close or far the market is from that target
---
## 📋 **Table Output in Top Right**
| Level  | Target ₹   | Dist % from current price |
| ------ | ---------- | ------------------------- |
| 100%   | Calculated | % Above/Below             |
| 127.2% | Calculated | % Above/Below             |
| 161.8% | Calculated | % Above/Below             |
| 200%   | Calculated | % Above/Below             |
| 261.8% | Calculated | % Above/Below             |
* The table updates **live on each bar**
* It **highlights levels** where price is nearing
* Useful in **any time frame** and **any market** (stocks, crypto, forex)
---
## 🔔 Example Use Case
You bought a stock at ₹100, and recent swing shows:
* A = ₹80
* B = ₹110
* C = ₹100
The 161.8% extension = 100 + (110 − 80) × 1.618 = ₹148.54
If the current price is ₹144, the table will show:
* Golden Ratio Target: ₹148.54
* Distance: −4.54
* Distance %: −3.05%
You now know your **target is near** and can plan your **exit or trailing stop**.
---
## 🧠 Benefits
* No need to draw extensions manually
* Automatically adapts to new swing structures
* Supports **scalping**, **swing**, and **positional** strategies
ATRWhat the Indicator Shows:
A compact table with four cells is displayed in the bottom-left corner of the chart:
| ATR | % | Level | Lvl+ATR |
Explanation of the Columns:
ATR — The averaged daily range (volatility) calculated with filtering of abnormal bars (extremely large or small daily candles are ignored).
% — The percentage of the daily ATR that the price has already covered today (the difference between the daily Open and Close relative to ATR).
Level — A custom user-defined level set through the indicator settings.
Lvl+ATR — The sum of the daily ATR and the user-defined level. This can be used, for example, as a target or stop-loss reference.
Color Highlighting of the "%" Cell:
The background color of the "%" ATR cell changes depending on the value:
✅ If the value is less than 10% — the cell is green (market is calm, small movement).
➖ If the value is between 10% and 50% — no highlighting (average movement, no signal).
🟡 If the value is between 50% and 70% — the cell is yellow (movement is increasing, be alert).
🔴 If the value is above 70% — the cell is red (the market is actively moving, high volatility).
Key Features:
✔ All ATR calculations and percentage progress are performed strictly based on daily data, regardless of the chart's current timeframe.
✔ The indicator is ideal for intraday traders who want to monitor daily volatility levels.
✔ The table always displays up-to-date information for quick decision-making.
✔ Filtering of abnormal bars makes ATR more stable and objective.
What is Adaptive ATR in this Indicator:
Instead of the classic ATR, which simply averages the true range, this indicator uses a custom algorithm:
✅ It analyzes daily bars over the past 100 days.
✅ Calculates the range High - Low for each bar.
✅ If the bar's range deviates too much from the average (more than 1.8 times higher or lower), the bar is considered abnormal and ignored.
✅ Only "normal" bars are included in the calculation.
✅ The average range of these normal bars is the adaptive ATR.
Detailed Algorithm of the getAdaptiveATR() Function:
The function takes the number of bars to include in the calculation (for example, 5):
The average of the last 5 normal bars is calculated.
pinescript
Копировать
Редактировать
adaptiveATR = getAdaptiveATR(5)
Step-by-Step Process:
An empty array ranges is created to store the ranges.
Daily bars with indices from 1 to 100 are iterated over.
For each bar:
🔹 The daily High and Low with the required offset are loaded via request.security().
🔹 The range High - Low is calculated.
🔹 The temporary average range of the current array is calculated.
🔹 The bar is checked for abnormality (too large or too small).
🔹 If the bar is normal or it's the first bar — its range is added to the array.
Once the array accumulates the required number of bars (count), their average is calculated — this is the adaptive ATR.
If it's not possible to accumulate the required number of bars — na is returned.
Что показывает индикатор:
На графике внизу слева отображается компактная таблица из четырех ячеек:
ATR	%	Уровень	Ур+ATR
Пояснения к столбцам:
ATR — усреднённый дневной диапазон (волатильность), рассчитанный с фильтрацией аномальных баров (слишком большие или маленькие дневные свечи игнорируются).
% — процент дневного ATR, который уже "прошла" цена на текущий день (разница между открытием и закрытием относительно ATR).
Уровень — пользовательский уровень, который задаётся вручную через настройки индикатора.
Ур+ATR — сумма уровня и дневного ATR. Может использоваться, например, как ориентир для целей или стопов.
Цветовая подсветка ячейки "%":
Цвет фона ячейки с процентом ATR меняется в зависимости от значения:
✅ Если значение меньше 10% — ячейка зелёная (рынок пока спокоен, маленькое движение).
➖ Если значение от 10% до 50% — фон не подсвечивается (среднее движение, нет сигнала).
🟡 Если значение от 50% до 70% — ячейка жёлтая (движение усиливается, повышенное внимание).
🔴 Если значение выше 70% — ячейка красная (рынок активно движется, высокая волатильность).
Особенности работы:
✔ Все расчёты ATR и процентного прохождения производятся исключительно по дневным данным, независимо от текущего таймфрейма графика.
✔ Индикатор подходит для трейдеров, которые торгуют внутри дня, но хотят ориентироваться на дневные уровни волатильности.
✔ В таблице всегда отображается актуальная информация для принятия быстрых торговых решений.
✔ Фильтрация аномальных баров делает ATR более устойчивым и объективным.
 Что такое адаптивный ATR в этом индикаторе
Вместо классического ATR, который просто усредняет истинный диапазон, здесь используется собственный алгоритм:
✅ Он берет дневные бары за последние 100 дней.
✅ Для каждого из них рассчитывает диапазон High - Low.
✅ Если диапазон бара слишком сильно отличается от среднего (более чем в 1.8 раза больше или меньше), бар считается аномальным и игнорируется.
✅ Только нормальные бары попадают в расчёт.
✅ В итоге считается среднее из диапазонов этих нормальных баров — это и есть адаптивный ATR.
 Подробный алгоритм функции getAdaptiveATR()
Функция принимает количество баров для расчёта (например, 5):
 Считается 5 последних нормальных баров  
pinescript
Копировать
Редактировать
adaptiveATR = getAdaptiveATR(5)
Пошагово:
Создаётся пустой массив ranges для хранения диапазонов.
Перебираются дневные бары с индексами от 1 до 100.
Для каждого бара:
🔹 Через request.security() подгружаются дневные High и Low с нужным смещением.
🔹 Считается диапазон High - Low.
🔹 Считается временное среднее диапазона по текущему массиву.
🔹 Проверяется, не является ли бар аномальным (слишком большой или маленький).
🔹 Если бар нормальный или это самый первый бар — его диапазон добавляется в массив.
Как только массив набирает заданное количество баров (count), берётся их среднее значение — это и есть адаптивный ATR.
Если не удалось набрать нужное количество баров — возвращается na.
Relative Measured Volatility (RMV)RMV • Volume-Sensitive Consolidation Indicator
A lightweight Pine Script that highlights true low-volatility, low-volume bars in a single squeeze measure.
  
What it does
Calculates each bar’s raw High-Low range.
Down-weights bars where volume is below its 30-day average, emphasizing genuine quiet periods.
Normalizes the result over the prior 15 bars (excluding the current bar), scaling from 0 (tightest) to 100 (most volatile).
Draws the series as a step plot, shades true “tight” bars below the user threshold, and marks sustained squeezes with a small arrow.
Key inputs
Lookback (bars): Number of bars to use for normalization (default 15).
Tight Threshold: RMV value under which a bar is considered squeezed (default 15).
Volume SMA Period: Period for the volume moving average benchmark (default 30).
How it works
Raw range: barRange = high - low
Volume ratio: volRatio = min(volume / sma(volume,30), 1)
Weighted range: vwRange = barRange * volRatio
Rolling min/max (prior 15 bars): exclude today so a new low immediately registers a 0.
Normalize: rmv = clamp(100 * (vwRange - min) / (max - min), 0, 100)
Visualization & signals
Step line for exact bar-by-bar values.
Shaded background when RMV < threshold.
Consecutive-bar filter ensures arrows only appear when tightness lasts at least two bars, cutting noise.
Why use it
Quickly spot consolidation zones that combine narrow price action with genuine dry volume—ideal for swing entries ahead of breakouts.
Contrarian RSIContrarian RSI Indicator
Pairs nicely with Contrarian 100 MA (optional hide/unhide buy/sell signals)
Description
The Contrarian RSI is a momentum-based technical indicator designed to identify potential reversal points in price action by combining a unique RSI calculation with a predictive range model inspired by the "Contrarian 5 Levels" logic. Unlike traditional RSI, which measures price momentum based solely on price changes, this indicator integrates a smoothed, weighted momentum calculation and predictive price ranges to generate contrarian signals. It is particularly suited for traders looking to capture reversals in trending or range-bound markets.
This indicator is versatile and can be used across various timeframes, though it performs best on higher timeframes (e.g., 1H, 4H, or Daily) due to reduced noise and more reliable signals. Lower timeframes may require additional testing and careful parameter tuning to optimize performance.
How It Works
The Contrarian RSI combines two primary components:
Predictive Ranges (5 Levels Logic): This calculates a smoothed price average that adapts to market volatility using an ATR-based mechanism. It helps identify significant price levels that act as potential support or resistance zones.
Contrarian RSI Calculation: A modified RSI calculation that uses weighted momentum from the predictive ranges to measure buying and selling pressure. The result is smoothed and paired with a user-defined moving average to generate clear signals.
The indicator generates buy (long) and sell (exit) signals based on crossovers and crossunders of user-defined overbought and oversold levels, making it ideal for contrarian trading strategies.
Calculation Overview
Predictive Ranges (5 Levels Logic):
Uses a custom function (pred_ranges) to calculate a dynamic price average (avg) based on the ATR (Average True Range) multiplied by a user-defined factor (mult).
The average adjusts only when the price moves beyond the ATR threshold, ensuring responsiveness to significant price changes while filtering out noise.
This calculation is performed on a user-specified timeframe (tf5Levels) for multi-timeframe analysis.
Contrarian RSI:
Compares consecutive predictive range values to calculate gains (g) and losses (l) over a user-defined period (crsiLength).
Applies a Gaussian weighting function (weight = math.exp(-math.pow(i / crsiLength, 2))) to prioritize recent price movements.
Computes a "wave ratio" (net_momentum / total_energy) to normalize momentum, which is then scaled to a 0–100 range (qrsi = 50 + 50 * wave_ratio).
Smooths the result with a 2-period EMA (qrsi_smoothed) for stability.
Moving Average:
Applies a user-selected moving average (SMA, EMA, WMA, SMMA, or VWMA) with a customizable length (maLength) to the smoothed RSI (qrsi_smoothed) to generate the final indicator value (qrsi_ma).
Signal Generation:
Long Entry: Triggered when qrsi_ma crosses above the oversold level (oversoldLevel, default: 1).
Long Exit: Triggered when qrsi_ma crosses below the overbought level (overboughtLevel, default: 99).
Entry and Exit Rules
Long Entry: Enter a long position when the Contrarian RSI (qrsi_ma) crosses above the oversold level (default: 1). This suggests the asset is potentially oversold and due for a reversal.
Long Exit: Exit the long position when the Contrarian RSI (qrsi_ma) crosses below the overbought level (default: 99), indicating a potential overbought condition and a reversal to the downside.
Customization: Adjust overboughtLevel and oversoldLevel to fine-tune sensitivity. Lower timeframes may benefit from tighter levels (e.g., 20 for oversold, 80 for overbought), while higher timeframes can use extreme levels (e.g., 1 and 99) for stronger reversals.
Timeframe Considerations
Higher Timeframes (Recommended): The indicator is optimized for higher timeframes (e.g., 1H, 4H, Daily) due to its reliance on predictive ranges and smoothed momentum, which perform best with less market noise. These timeframes typically yield more reliable reversal signals.
Lower Timeframes: The indicator can be used on lower timeframes (e.g., 5M, 15M), but signals may be noisier and require additional confirmation (e.g., from price action or other indicators). Extensive backtesting and parameter optimization (e.g., adjusting crsiLength, maLength, or mult) are recommended for lower timeframes.
Inputs
Contrarian RSI Length (crsiLength): Length for RSI momentum calculation (default: 5).
RSI MA Length (maLength): Length of the moving average applied to the RSI (default: 1, effectively no MA).
MA Type (maType): Choose from SMA, EMA, WMA, SMMA, or VWMA (default: SMA).
Overbought Level (overboughtLevel): Upper threshold for exit signals (default: 99).
Oversold Level (oversoldLevel): Lower threshold for entry signals (default: 1).
Plot Signals on Main Chart (plotOnChart): Toggle to display signals on the price chart or the indicator panel (default: false).
Plotted on Lower:
Plotted on Chart:
5 Levels Length (length5Levels): Length for predictive range calculation (default: 200).
Factor (mult): ATR multiplier for predictive ranges (default: 6.0).
5 Levels Timeframe (tf5Levels): Timeframe for predictive range calculation (default: chart timeframe).
Visuals
Contrarian RSI MA: Plotted as a yellow line, representing the smoothed Contrarian RSI with the applied moving average.
Overbought/Oversold Lines: Red line for overbought (default: 99) and green line for oversold (default: 1).
Signals: Blue circles for long entries, white circles for long exits. Signals can be plotted on the main chart (plotOnChart = true) or the indicator panel (plotOnChart = false).
Usage Notes
Use the indicator in conjunction with other tools (e.g., support/resistance, trendlines, or volume) to confirm signals.
Test extensively on your chosen timeframe and asset to optimize parameters like crsiLength, maLength, and mult.
Be cautious with lower timeframes, as false signals may occur due to market noise.
The indicator is designed for contrarian strategies, so it works best in markets with clear reversal patterns.
Disclaimer
This indicator is provided for educational and informational purposes only. Always conduct thorough backtesting and risk management before using any indicator in live trading. The author is not responsible for any financial losses incurred.
Normalized Open InterestNormalized Open Interest (nOI) — Indicator Overview
What it does
Normalized Open Interest (nOI) transforms raw futures open-interest data into a 0-to-100 oscillator, so you can see at a glance whether participation is unusually high or low—similar in spirit to an RSI but applied to open interest. The script positions today’s OI inside a rolling high–low range and paints it with contextual colours.
Core logic
Data source – Loads the built-in “_OI” symbol that TradingView provides for the current market.
Rolling range – Looks back a user-defined number of bars (default 500) to find the highest and lowest OI in that window.
Normalization – Calculates
nOI = (OI – lowest) / (highest – lowest) × 100
so 0 equals the minimum of the window and 100 equals the maximum.
Visual cues – Plots the oscillator plus fixed horizontal levels at 70 % and 30 % (or your own numbers). The line turns teal above the upper level, red below the lower, and neutral grey in between.
User inputs
Window Length (bars) – How many candles the indicator scans for the high–low range; larger numbers smooth the curve, smaller numbers make it more reactive.
Upper Threshold (%) – Default 70. Anything above this marks potentially crowded or overheated interest.
Lower Threshold (%) – Default 30. Anything below this marks low or capitulating interest.
Practical uses
Spot extremes – Values above the upper line can warn that the long side is crowded; values below the lower line suggest disinterest or short-side crowding.
Confirm breakouts – A price breakout backed by a sharp rise in nOI signals genuine engagement.
Look for divergences – If price makes a new high but nOI does not, participation might be fading.
Combine with volume or RSI – Layer nOI with other studies to filter false signals.
Tips
On intraday charts for non-crypto symbols the script automatically fetches daily OI data to avoid gaps.
Adjust the thresholds to 80/20 or 60/40 to fit your market and risk preferences.
Alerts, shading, or additional signal logic can be added easily because the oscillator is already normalised.






















