KST Strategy [Skyrexio]Overview 
KST Strategy   leverages Know Sure Thing (KST) indicator in conjunction with the Williams Alligator and Moving average to obtain the high probability setups. KST is used for for having the high probability to enter in the direction of a current trend when momentum is rising, Alligator is used as a short term trend filter, while Moving average approximates the long term trend and allows trades only in its direction. Also strategy has the additional optional filter on Choppiness Index which does not allow trades if market is choppy, above the user-specified threshold. Strategy has the user specified take profit and stop-loss numbers, but multiplied by Average True Range (ATR) value on the moment when trade is open. The strategy opens only long trades.
 Unique Features 
 
 ATR based stop-loss and take profit.  Instead of fixed take profit and stop-loss percentage strategy utilizes user chosen numbers multiplied by ATR for its calculation.
 Configurable Trading Periods.  Users can tailor the strategy to specific market windows, adapting to different market conditions.
 Optional Choppiness Index filter.  Strategy allows to choose if it will use the filter trades with Choppiness Index and set up its threshold.
 
 Methodology 
The strategy opens long trade when the following price met the conditions:
 
 Close price is above the Alligator's jaw line
 Close price is above the filtering Moving average
 KST line of Know Sure Thing indicator shall cross over its signal line (details in justification of methodology)
 If the Choppiness Index filter is enabled its value shall be less than user defined threshold
 
When the long trade is executed algorithm defines the stop-loss level as the low minus user defined number, multiplied by ATR at the trade open candle. Also it defines take profit with close price plus user defined number, multiplied by ATR at the trade open candle. While trade is in progress, if high price on any candle above the calculated take profit level or low price is below the calculated stop loss level, trade is closed.
 Strategy settings 
In the inputs window user can setup the following strategy settings:
 
 ATR Stop Loss  (by default = 1.5, number of ATRs to calculate stop-loss level)
 ATR Take Profit  (by default = 3.5, number of ATRs to calculate take profit level)
 Filter MA Type  (by default = Least Squares MA, type of moving average which is used for filter MA)
 Filter MA Length  (by default = 200, length for filter MA calculation)
 Enable Choppiness Index Filter  (by default = true, setting to choose the optional filtering using Choppiness index)
 Choppiness Index Threshold  (by default = 50, Choppiness Index threshold, its value shall be below it to allow trades execution)
 Choppiness Index Length  (by default = 14, length used in Choppiness index calculation)
 KST ROC Length #1  (by default = 10, value used in KST indicator calculation, more information in Justification of Methodology)
 KST ROC Length #2  (by default = 15, value used in KST indicator calculation, more information in Justification of Methodology)
 KST ROC Length #3  (by default = 20, value used in KST indicator calculation, more information in Justification of Methodology)
 KST ROC Length #4  (by default = 30, value used in KST indicator calculation, more information in Justification of Methodology)
 KST SMA Length #1  (by default = 10, value used in KST indicator calculation, more information in Justification of Methodology)
 KST SMA Length #2  (by default = 10, value used in KST indicator calculation, more information in Justification of Methodology)
 KST SMA Length #3  (by default = 10, value used in KST indicator calculation, more information in Justification of Methodology)
 KST SMA Length #4  (by default = 15, value used in KST indicator calculation, more information in Justification of Methodology)
 KST Signal Line Length  (by default = 10, value used in KST indicator calculation, more information in Justification of Methodology)
 
User can choose the optimal parameters during backtesting on certain price chart.
 Justification of Methodology 
Before understanding why this particular combination of indicator has been chosen let's briefly explain what is KST, Williams Alligator, Moving Average, ATR and Choppiness Index.
The KST (Know Sure Thing) is a momentum oscillator developed by Martin Pring. It combines multiple Rate of Change (ROC) values, smoothed over different timeframes, to identify trend direction and momentum strength. First of all, what is ROC? ROC (Rate of Change) is a momentum indicator that measures the percentage change in price between the current price and the price a set number of periods ago.
 ROC = 100 * (Current Price - Price N Periods Ago) / Price N Periods Ago 
In our case N is the KST ROC Length inputs from settings, here we will calculate 4 different ROCs to obtain KST value:
 KST = ROC1_smooth × 1 + ROC2_smooth × 2 + ROC3_smooth × 3 + ROC4_smooth × 4 
 ROC1 = ROC(close, KST ROC Length #1), smoothed by KST SMA Length #1,
ROC2 = ROC(close, KST ROC Length #2), smoothed by KST SMA Length #2,
ROC3 = ROC(close, KST ROC Length #3), smoothed by KST SMA Length #3,
ROC4 = ROC(close, KST ROC Length #4), smoothed by KST SMA Length #4 
Also for this indicator the signal line is calculated:
 Signal = SMA(KST, KST Signal Line Length) 
When the KST line rises, it indicates increasing momentum and suggests that an upward trend may be developing. Conversely, when the KST line declines, it reflects weakening momentum and a potential downward trend. A crossover of the KST line above its signal line is considered a buy signal, while a crossover below the signal line is viewed as a sell signal. If the KST stays above zero, it indicates overall bullish momentum; if it remains below zero, it points to bearish momentum. The KST indicator smooths momentum across multiple timeframes, helping to reduce noise and provide clearer signals for medium- to long-term trends.
Next, let’s discuss the short-term trend filter, which combines the Williams Alligator and Williams Fractals. Williams Alligator
Developed by Bill Williams, the Alligator is a technical indicator that identifies trends and potential market reversals. It consists of three smoothed moving averages:
 
 Jaw (Blue Line):  The slowest of the three, based on a 13-period smoothed moving average shifted 8 bars ahead.
 Teeth (Red Line):  The medium-speed line, derived from an 8-period smoothed moving average shifted 5 bars forward.
 Lips (Green Line):  The fastest line, calculated using a 5-period smoothed moving average shifted 3 bars forward.
 
When the lines diverge and align in order, the "Alligator" is "awake," signaling a strong trend. When the lines overlap or intertwine, the "Alligator" is "asleep," indicating a range-bound or sideways market. This indicator helps traders determine when to enter or avoid trades.
The next indicator is Moving Average. It has a lot of different types which can be chosen to filter trades and the Least Squares MA is used by default settings. Let's briefly explain what is it.
The Least Squares Moving Average (LSMA) — also known as Linear Regression Moving Average — is a trend-following indicator that uses the least squares method to fit a straight line to the price data over a given period, then plots the value of that line at the most recent point. It draws the best-fitting straight line through the past N prices (using linear regression), and then takes the endpoint of that line as the value of the moving average for that bar. The LSMA aims to reduce lag and highlight the current trend more accurately than traditional moving averages like SMA or EMA.
Key Features:
 
 It reacts faster to price changes than most moving averages.
 It is smoother and less noisy than short-term EMAs.
 It can be used to identify trend direction, momentum, and potential reversal points.
 
ATR (Average True Range) is a volatility indicator that measures how much an asset typically moves during a given period. It was introduced by J. Welles Wilder and is widely used to assess market volatility, not direction.
To calculate it first of all we need to get True Range (TR), this is the greatest value among:
 
 High - Low
 abs(High - Previous Close)
 abs(Low - Previous Close)
 
 ATR = MA(TR, n) , where n is number of periods for moving average, in our case equals 14.
ATR shows how much an asset moves on average per candle/bar. A higher ATR means more volatility; a lower ATR means a calmer market.
The Choppiness Index is a technical indicator that quantifies whether the market is trending or choppy (sideways). It doesn't indicate trend direction — only the strength or weakness of a trend. Higher Choppiness Index usually approximates the sideways market, while its low value tells us that there is a high probability of a trend.
 Choppiness Index = 100 × log10(ΣATR(n) / (MaxHigh(n) - MinLow(n))) / log10(n) 
where:
 
 ΣATR(n)  = sum of the Average True Range over n periods
 MaxHigh(n)  = highest high over n periods
 MinLow(n)  = lowest low over n periods
 log10  = base-10 logarithm
 
Now let's understand how these indicators work in conjunction and why they were chosen for this strategy. KST indicator approximates current momentum, when it is rising and KST line crosses over the signal line there is high probability that short term trend is reversing to the upside and strategy allows to take part in this potential move. Alligator's jaw (blue) line is used as an approximation of a short term trend, taking trades only above it we want to avoid trading against trend to increase probability that long trade is going to be winning.
Almost the same for Moving Average, but it approximates the long term trend, this is just the additional filter. If we trade in the direction of the long term trend we increase probability that higher risk to reward trade will hit the take profit. Choppiness index is the optional filter, but if it turned on it is used for approximating if now market is in sideways or in trend. On the range bounded market the potential moves are restricted. We want to decrease probability opening trades in such condition avoiding trades if this index is above threshold value.
When trade is open script sets the stop loss and take profit targets. ATR approximates the current volatility, so we can make a decision when to exit a trade based on current market condition, it can increase the probability that strategy will avoid the excessive stop loss hits, but anyway user can setup how many ATRs to use as a stop loss and take profit target. As was said in the Methodology stop loss level is obtained by subtracting number of ATRs from trade opening candle low, while take profit by adding to this candle's close.
 Backtest Results 
 
 Operating window:  Date range of backtests is 2023.01.01 - 2025.05.01. It is chosen to let the strategy to close all opened positions.
 Commission and Slippage:  Includes a standard Binance commission of 0.1% and accounts for possible slippage over 5 ticks.
 Initial capital:  10000 USDT
 Percent of capital used in every trade:  60%
 Maximum Single Position Loss:  -5.53%
 Maximum Single Profit:  +8.35%
 Net Profit:  +5175.20 USDT (+51.75%)
 Total Trades:  120 (56.67% win rate)
 Profit Factor:  1.747
 Maximum Accumulated Loss:  1039.89 USDT (-9.1%)
 Average Profit per Trade:  43.13 USDT (+0.6%)
 Average Trade Duration:  27 hours
 
These results are obtained with realistic parameters representing trading conditions observed at major exchanges such as Binance and with realistic trading portfolio usage parameters.
 How to Use 
Add the script to favorites for easy access.
Apply to the desired timeframe and chart (optimal performance observed on 1h BTC/USDT).
Configure settings using the dropdown choice list in the built-in menu.
Set up alerts to automate strategy positions through web hook with the text: {{strategy.order.alert_message}}
 Disclaimer: 
Educational and informational tool reflecting Skyrexio commitment to informed trading. Past performance does not guarantee future results. Test strategies in a simulated environment before live implementation.
ابحث في النصوص البرمجية عن "机械革命无界15+时不时闪屏"
Aftershock Playbook: Stock Earnings Drift EngineStrategy type 
Event-driven post-earnings momentum engine (long/short) built for single-stock charts or ADRs that publish quarterly results.
 What it does 
Detects the exact earnings bar (request.earnings, lookahead_off).
Scores the surprise and launches a position on that candle’s close.
Tracks PnL: if the first leg closes green, the engine automatically re-enters on the very next bar, milking residual drift.
Blocks mid-cycle trades after a loss until the next earnings release—keeping the risk contained to one cycle.
Think of it as a sniper that fires on the earnings pop, reloads once if the shot lands, then goes silent until the next report.
 Core signal inputs 
Component	Default	Purpose
EPS Surprise %	+0 % / –5 %	Minimum positive / negative shock to trigger longs/shorts.
Reverse signals?	Off	Quick flip for mean-reversion experiments.
Time Risk Mgt.	Off	Optional hard exit after 45 calendar days (auto-scaled to any TF).
 Risk engine 
ATR-based stop (ATR × 2 by default, editable).
Bar time stop (15-min → Daily: Have to select the bar value ).
No pyramiding beyond the built-in “double-tap”.
All positions sized as % of equity via Strategy Properties.
 Visual aids
 Yellow triangle marks the earnings bar.
Diagnostics table (top-right) shows last Actual, Estimate, and Surprise %.
Status-line tool-tips on every input.
 Default inputs 
Setting	Value
Positive surprise ≥	0 %
Negative surprise ≤	–5 %
ATR stop ×	2
ATR length	50
Hold horizon	350 ( 1h timeframe chart bars)
 Back-test properties 
Initial capital  10 000
Order size    5 % of equity
Pyramiding    1 (internal re-entry only)
Commission   0.03 %
Slippage     5 ticks
Fills      Bar magnifier ✔ · On bar close ✔ · Standard OHLC ✔
 How to use 
Add the script to any earnings-driven stock (AAPL, MSFT, TSLA…).
Turn on Time Risk Management if you want stricter risk management
Back-test different ATR multipliers to fit the stock’s volatility.
Sync commission & slippage with your broker before forward-testing.
 Important notes 
Works on every timeframe from 15 min to 1 D. Sweet spot around 30min/1h
All request.earnings() & request.security() calls use lookahead_off—zero repaint.
The “double-tap” re-entry occurs once per winning cycle to avoid drift-chasing loops.
Historical stats ≠ future performance. Size positions responsibly.
Simple Sessions & LevelsWhat this indicator does:
This script marks out two essential types of price levels for intraday and swing traders:
 
 The high and low of a customizable 15-minute opening range after the market/session open.
 The previous day’s high, midpoint (“halfback”), and low.
 
 How it works: 
 
 The script lets you set the session start time (hour and minute) to match your market.
 It then calculates the high and low of the first 15 minutes after the session opens and plots those as solid lines.
 It also plots the prior day’s high, halfback (midpoint), and low on your chart for easy reference.
 Each line and each label can be toggled on or off independently in the settings for maximum customization.
 Colors for each level are also fully customizable.
 
 
 How to use it: 
 
 Add the script to your chart.
 Set the session start hour and minute to match the open of the market or instrument you trade.
 Choose which levels and labels you want displayed by using the toggles in the settings.
 The indicator will automatically draw the session range and prior day levels for you.
 Use these lines as reference for key support, resistance, and potential trade entry/exit points.
 
 
 What makes it unique and useful: 
This tool combines a flexible session opening range with classic daily reference levels in one package. You have complete control over which levels and labels are shown, making it adaptable for any trading style. It’s especially useful for day traders who want to quickly identify volatility windows and the most important price levels from the previous session.
15m ORB Pip Run with Range HighlightThis marks up the first 15 minute range of the NYSE at 9:30 AM EST.  
Then it counts the number of pips that price has run in the direction of the breakout.
The script it not anything amazing.
I just wrote it to help me backtest the 15 minute ORB strategy quickly.
80% Rule Indicator (ETH Session + SVP Prior Session)I created this script to show the 80% opportunity on chart if setting lines up.
"80% rule: Open outside the vah or Val. Spend 30 mins outside there then break back inside spend 15 mins below or above depending which way u broke. Then come back and retest the vah/val and take it to the poc as a first target with the final target being the other Val/vah "
📌 Script Summary
The "80% Rule Indicator (ETH Session + SVP Prior Session)" overlays your chart with prior session value area levels (VAH, VAL, and POC) calculated from extended-hours 30-minute data. It tracks when the price reenters the value area and confirms 80% Rule setups during your chosen trading session. You can optionally trigger alerts, show/hide market sessions, and fine-tune line appearance for a clean, modular workflow.
⚙️ Options & Settings Breakdown
- Use 24-Hour Session (All Markets)
When checked, the indicator ignores time zones and tracks signals during a full 24-hour period (0000-0000), helpful if you're outside U.S. trading hours or want consistent behavior globally.
- Market Session
Dropdown to select one of three key market zones:
- New York (09:30–16:00 ET)
- London (08:00–16:30 local)
- Tokyo (09:00–15:00 local)
Used to gate entry signals during relevant hours unless you choose the 24-hour option.
- Show PD VAH/VAL/POC Lines
Toggle to show or hide prior day’s levels (based on the 30-min extended session). Turning this off removes both the lines and their white text labels.
- Extend Lines Right
When enabled, the VAH/VAL/POC lines extend into the current day’s session. If disabled, they appear only at their anchor point.
- Highlight Selected Session
Adds a soft blue background to help visualize the active session you selected.
- Enable Alert Conditions
Allows TradingView alerts to be created for long/short 80% Rule entries.
- Enable Audible Alerts
Plays an in-chart sound with a popup message (“80% Rule LONG” or “SHORT”) when signals trigger. Requires the chart to be active and sounds enabled in TradingView.
LilSpecCodes1. Killzone Background Highlighting:
It highlights 4 key market sessions:
Killzone	           Time (EST)	                Color
Silver Bullet	   9:30 AM – 12:00 PM   	Light Blue
London Killzone	   2:00 AM – 5:00 AM   	Light Green
NY PM Killzone	   1:30 PM – 4:00 PM	         Light Purple
Asia Open	            7:00 PM – 11:00 PM	  Light Red
These are meant to help you focus during high-probability trading times.
__________________________________________________
2. Previous Day High/Low (PDH/PDL):
Plots green line = PDH
Plots red line = PDL
Tracks the current day’s session high/low and sets it as PDH/PDL on a new trading day
CHANGES WITH ETH/RTH
3. Inside Bar Marker:
Plots a small black triangle under bars where the high is lower than the previous bar’s high and the low is higher than the previous bar’s low (inside bars)
Useful for spotting potential breakout or continuation setups
4. Vertical Time Markers (White Dashed Lines)
Time (EST) Label
4:00 AM End of London Silver Bullet
9:30 AM NYSE Open
10:00 AM Start of NY Silver Bullet
11:00 AM End of NY Silver Bullet
11:30 AM (Customizable Input)
3:00 PM PM Killzone Ends
3:15 PM Futures Market Close
7:15 PM Asia Session Watch
Week Window AlgorithmWeek Window Algorithm
 The Week Window Algorithm is an advanced intraday trading overlay built for precision session tracking and key level visualization.
🔹 Features:
 1. Time Lines 
Automatically plots vertical lines 30 minutes ahead of specific London times (07, 08, 09, 13, 14, 15UK), with adjustable height in pips and custom color.
 2. Session Boxes 
Draws price range boxes for:
Asia (22:00–06:00 UK)
Europe AM (08:00–09:00 UK)
Europe PM (14:00–15:00 UK)
Each box auto-updates during the session and fades after 3 days. Fill color is fully customizable via settings.
 3. Yesterday’s High/Low Levels 
Captures and plots yesterday’s high and low at 23:00 UK. Lines extend through today and highlight first-time hits.
🛠️ Customization:
Enable/disable sessions individually
Set pip size for early lines
Choose colors for each session box and line style
🕒 Recommended Timeframes:
Optimized for 1–15 minute charts. Works best on intraday setups.
Super MTF Clouds (4x3 Pairs)Overview: 
This script is based on Ripster's MTF clouds, which transcends the standard moving average cloud indicator by offering a powerful and deeply customizable Multi-Timeframe (MTF) analysis. Instead of being limited to the moving averages of your current charts from the current timeframe, this tool allows you to project and visualize the trend and key support/resistance zones from up to 4 different timeframes simultaneously. User can input up to 6 different EMA values which will form 3 pairs of EMA clouds, for each of the timeframes.
The primary purpose is to provide traders with immediate confluence. By observing how price interacts with moving average clouds from higher timeframes (e.g., Hourly, Daily, Weekly), you can make more informed decisions on your active trading timeframe (e.g., 10 Minute). It's designed as a complete MTF Cloud toolkit, allowing you to display all necessary MTFs in a single script to build a comprehensive view of the market structure without having to flick to different timeframe to look for cloud positions.
 Key features: 
 
 Four Independent Multi-Timeframe Slots: Each slot can be assigned any timeframe available on TradingView (e.g., D, W, M, 4H).
 Three MA Pairs Per Timeframe: For each timeframe, configure up to three separate MA clouds (e.g., a 9/12 EMA pair, a 20/50 EMA pair, and a 100/200 SMA pair).
 Complete Customisation: For every single moving average (24 in total), you can independently control:
 MA Type: Choose between EMA or SMA.
 Length: Any period you require.
 Line Color: Full colour selection.
 Line Thickness: Adjust the visual weight of each line.
 Cloud Control: For every pair (12 in total), you can set the fill colour and transparency.
 
 How To Use This Script: 
This tool is best used for confirmation and context. Here are some practical strategies that one can adopt:
 
 Trend Confluence: Before taking a trade based on a signal on your current timeframe, glance at the higher timeframe clouds. If you see a buy signal on the 15-minute chart and the price is currently trading above a thick, bullish Daily cloud, the probability of that trade succeeding is significantly higher. Conversely, shorting into strong HTF support is a low-probability trade.
 Dynamic Support & Resistance: The edges of the higher timeframe clouds often act as powerful, dynamic levels of support and resistance. A pullback to the 4-Hour 50 EMA on your 15-minute chart can be a prime area to look for entries in the direction of the larger trend.
 Gauging Market Regimes: Use the toggles in the settings to quickly switch between different views. You can have a "risk-on" view with short-term clouds and a "macro" view with weekly and monthly clouds. This helps you adapt your trading style to the current market conditions.
 
 Key Settings: 
1. Global Setting
Source For All MAs: This determines the price data point used for every single moving average calculation.
 Default:  hl2 (an average of the High and Low of each bar). This gives a smooth midpoint price.
 Options:  You can change this to Close (the most common method), Open, High, Low, or ohlc4 (an average of the open, high, low, and close), among others.
Recommendation: For most standard trend analysis, the default hl2 is the common choice.
2. The Timeframe Group Structure
The rest of the settings are organized into four identical, collapsible groups: "Timeframe 1 Settings" through "Timeframe 4 Settings". Each group acts as a self-contained control panel for one multi-timeframe view.
Within each timeframe group, you have two master controls:
 
 Enable Timeframe: This is the main power switch for the entire group. Uncheck this box to instantly hide all three clouds and lines associated with this timeframe. This is perfect for quickly decluttering your chart or focusing on a different set of analyses.
 Timeframe: This dropdown menu is the heart of the MTF feature. Here, you select the higher timeframe you want to analyse (e.g., 1D for Daily, 1W for Weekly, 4H for 4-Hour). All calculations for the three pairs within this group will be based on the timeframe you select here.
 
 3. Pair-Specific Controls 
Inside each timeframe group, there are three sections for "Pair 1", "Pair 2", and "Pair 3". These control each individual moving average cloud.
Enable Pair: Just like the master switch for the timeframe, this checkbox turns a single cloud and its two MA lines on or off.
For each pair, the settings are further broken down:
 
 Moving Average Lines (A and B): These two rows control the two moving averages that form the cloud. 'A' is typically used for the shorter-period MA and 'B' for the longer-period one.
 Type (A/B): A dropdown menu to select either EMA (Exponential Moving Average) or SMA (Simple Moving Average). EMAs react more quickly to recent price changes, while SMAs are smoother and react more slowly.
 Length (A/B): The lookback period for the moving average (e.g., 21, 50, 200).
 Color (A/B): Sets the specific colour of the MA line itself on your chart.
 Cloud Fill Settings
 Fill Color: This controls the colour of the shaded area (the "cloud") between the two moving average lines. For a consistent look, you can set this to the same colour as your shorter MA line.
 Transparency: Controls how see-through the cloud is, on a scale of 0 to 100. 0 is a solid, opaque colour, while 100 is completely invisible. The default of 85 provides a light, "cloud-like" appearance that doesn't obscure the price action.
 
----------------------------------------------------------------------
If anything is not clear please let me know!
Support & Resistance External/Internal & BoS [sgbpulse]Market Structure Support & Resistance External/Internal & BoS    
 
 Overview: Smart & Fast Market Structure Analysis  
The Market Structure "Support & Resistance External/Internal & BoS  " indicator is designed to empower your technical analysis by automatically and precisely identifying significant support and resistance levels. It achieves this by pinpointing high and low Pivot Points, plus key Pre-Market High/Low levels. 
Its unique strength lies in its dynamic adaptability to any timeframe and any asset you choose. This tool analyzes the relevant market structure for the current timeframe and asset, providing you with accurate and relevant levels in real-time. The indicator maintains a clean chart and swiftly displays all support, resistance, and Pre-Market levels for any asset, saving valuable analysis time and enabling you to get a clear and quick snapshot of the market. 
 
 How the Indicator Works  
The indicator identifies and displays three critical types of key levels: 
 
 External Pivots: These are more significant pivot points, indicating important reversal points across a broader range of price movement, considering the current timeframe. The indicator draws dark green support lines (for low pivots) and dark red resistance lines (for high pivots) from these points. 
 Internal Pivots: These are shorter-term pivot points, signifying smaller corrections or reversals within the overall structure of the current timeframe. These lines provide additional areas of interest within the ranges of the External Pivots. 
 Pre-Market High/Low Levels: The indicator displays the High and Low reached during pre-market hours as distinct lines on the chart. Please note: These levels will only appear when the selected timeframe is lower than one day (e.g., 1-hour, 15-minute) and provided that the "Session extended trading hours" option is enabled in your TradingView chart settings. These levels are crucial for identifying potential opening ranges and critical support/resistance areas upon regular market open, especially for intraday trading. 
 
 
 Break of Structure (BoS) Identification  
A key feature of this indicator is its ability to identify Break of Structure (BoS). When a support or resistance line is breached, the indicator changes the line's color to gray and displays a "Break of Structure" label, indicating a potential trend change or continuation: 
 
 External BoS: When an external support/resistance line is broken, a "BoS" label in red will appear. This is a strong signal for a potential shift in the primary market structure or a strong trend continuation. 
 Internal BoS: When an internal support/resistance line is broken, an "iBoS" label in green will appear. This indicates a break within the existing market structure, which can be used to confirm direction or identify shorter-term entry/exit opportunities. 
 
 Full Indicator Customization  
The indicator provides maximum flexibility to suit any trading style and timeframe: 
 
 Number of Lines Displayed: You can choose how many support and resistance lines you want to see on your chart. The default is 15 lines, but you can increase or decrease this number according to your needs and desired level of detail. 
 External Pivot Settings: Define the number of bars before and after a pivot point required for External Pivot identification. 
 Internal Pivot Settings: Define the number of bars before and after a pivot point required for Internal Pivot identification. 
 Color Customization: Full control over colors! You can change the colors of the support and resistance lines, the colors of the Pre-Market levels, and also the colors of the BoS and iBoS labels to create a visual appearance that perfectly matches your personal preferences. 
 
This flexibility allows you to adapt the indicator to your trading style and any timeframe you operate in, without needing to manually change settings each time. 
 Recommended Uses  
 
 Clean Chart & Quick Analysis: The indicator displays important levels clearly, enabling quick identification of areas of interest without visual clutter on the chart. This significantly saves analysis time and allows you to make faster decisions. 
 Critical Levels for Any Timeframe & Asset: Get precise and adaptive support and resistance, plus essential Pre-Market levels (in relevant timeframes), for any timeframe and on any asset you choose. 
 Trend Direction Identification: Clear support and resistance lines help understand market structure. 
 Breakout Confirmation: The BoS label provides visual confirmation of key level breaches, helping to confirm potential trend changes. 
 Locating Entry & Exit Points: Use these levels as potential areas of interest for trades, after confirming a breakout or reversal. 
 Finding Stop-Loss & Take-Profit Points: Strategically place protective stops and profit targets around these support and resistance levels. 
 
 
 Important Note  
Like any technical indicator, Market Structure "Support & Resistance External/Internal & BoS  " is a supplementary tool. It's highly recommended to use it in conjunction with additional analysis methods (such as price action analysis, other indicators, and fundamental analysis) for informed trading decisions. Financial markets are dynamic, and trading always carries inherent risk. 
Multi TF Oscillators Screener [TradingFinder] RSI / ATR / Stoch🔵 Introduction 
The oscillator screener is designed to simplify multi-timeframe analysis by allowing traders and analysts to monitor one or multiple symbols across their preferred timeframes—all at the same time. Users can track a single symbol through various timeframes simultaneously or follow multiple symbols in selected intervals. This flexibility makes the tool highly effective for analyzing diverse markets concurrently.
At the core of this screener lie two essential oscillators: RSI (Relative Strength Index) and the Stochastic Oscillator. The RSI measures the speed and magnitude of recent price movements and helps identify overbought or oversold conditions. 
It's one of the most reliable indicators for spotting potential reversals. The Stochastic Oscillator, on the other hand, compares the current price to recent highs and lows to detect momentum strength and potential trend shifts. It’s especially effective in identifying divergences and short-term reversal signals.
In addition to these two primary indicators, the screener also displays helpful supplementary data such as the dominant candlestick type (Bullish, Bearish, or Doji), market volatility indicators like ATR and TR, and the four key OHLC prices (Open, High, Low, Close) for each symbol and timeframe. This combination of data gives users a comprehensive technical view and allows for quick, side-by-side comparison of symbols and timeframes.
  
🔵 How to Use 
This tool is built for users who want to view the behavior of a single symbol across several timeframes simultaneously. Instead of jumping between charts, users can quickly grasp the state of a symbol like gold or Bitcoin across the 15-minute, 1-hour, and daily timeframes at a glance. This is particularly useful for traders who rely on multi-timeframe confirmation to strengthen their analysis and decision-making.
  
The tool also supports simultaneous monitoring of multiple symbols. Users can select and track various assets based on the timeframes that matter most to them. For example, if you’re looking for entry opportunities, the screener allows you to compare setups across several markets side by side—making it easier to choose the most favorable trade. Whether you’re a scalper focused on low timeframes or a swing trader using higher ones, the tool adapts to your workflow.
  
The screener utilizes the widely-used RSI indicator, which ranges from 0 to 100 and highlights market exhaustion levels. Readings above 70 typically indicate potential pullbacks, while values below 30 may suggest bullish reversals. Viewing RSI across timeframes can reveal meaningful divergences or alignments that improve signal quality.
Another key indicator in the screener is the Stochastic Oscillator, which analyzes the closing price relative to its recent high-low range. When the %K and %D lines converge and cross within the overbought or oversold zones, it often signals a momentum reversal. This oscillator is especially responsive in lower timeframes, making it ideal for spotting quick entries or exits.
Beyond these oscillators, the table includes other valuable data such as candlestick type (bullish, bearish, or doji), volatility measures like ATR and TR, and complete OHLC pricing. This layered approach helps users understand both market momentum and structure at a glance.
Ultimately, this screener allows analysts and traders to gain a full market overview with just one look—empowering faster, more informed, and lower-risk decision-making. It not only saves time but also enhances the precision and clarity of technical analysis.
🔵 Settings 
🟣 Display Settings 
 Table Size : Lets you adjust the table’s visual size with options such as: auto, tiny, small, normal, large, huge.
 Table Position : Sets the screen location of the table. Choose from 9 possible positions, combining vertical (top, middle, bottom) and horizontal (left, center, right) alignments.
🟣 Symbol Settings 
 Each of the 10 symbol slots comes with a full set of customizable parameters :
 Enable Symbol : A checkbox to activate or hide each symbol from the table.
 Symbol : Define or select the asset (e.g., XAUUSD, BTCUSD, EURUSD, etc.).
 Timeframe : Set your desired timeframe for each symbol (e.g., 15, 60, 240, 1D).
 RSI Length : Defines the period used in RSI calculation (default is 14).
 Stochastic Length : Sets the period for the Stochastic Oscillator.
 ATR Length : Sets the length used to calculate the Average True Range, a key volatility metric.
🔵 Conclusion 
By combining powerful oscillators like RSI and Stochastic with full customization over symbols and timeframes, this tool provides a fast, flexible solution for technical analysts. Users can instantly monitor one or several assets across multiple timeframes without opening separate charts. 
Individual configuration for each symbol, along with the inclusion of key metrics like candlestick type, ATR/TR, and OHLC prices, makes the tool suitable for a wide range of trading styles—from scalping to swing and position trading.
In summary, this screener enables traders to gain a clear, high-level view of various markets in seconds and make quicker, smarter, and lower-risk decisions. It saves time, streamlines analysis, and boosts overall efficiency and confidence in trading strategies.
ADR by Saurabh MaggoADR levels for intraday 
This Pine Script v5 indicator plots Average Daily Range (ADR) levels on a 5-minute NSE chart, ideal for intraday traders. It marks key price levels (L3+, L3-, L2+, L2-, L1+, L1-) at 9:15 AM IST each day, based on the daily open and a customizable ATR period.
Features:
Configurable Levels: Adjust ATR period (default 5) and multipliers (L3=0.5, L2=0.25, L1=0.125) to set price targets.
Today Only Option: Toggle Show Recent to display only the current day’s levels or all historical levels.
Visual Customization: Choose vibrant colors for each level via settings, with a glow effect
 (toggleable, transparency=20) and adjustable circle size (default 2, range 1–5) for enhanced visibility, optimized for dark chart backgrounds.
Clean Design: Single-point plotting at 9:15 AM IST ensures a clutter-free chart, with dynamic points that move with the chart.
Usage: Perfect for NSE intraday trading, this indicator helps identify high-probability price targets. Customize levels, colors, and visuals to suit your strategy.
AP Session Liquidity with EQH/EQL and Previous DayThis indicator plots key intraday session highs and lows, along with essential market structure levels, to help traders identify areas of interest, potential liquidity zones, and high-probability trade setups. It includes the Asia Session High and Low (typically 00:00–08:00 UTC), London Session High and Low (08:00–12:00 UTC), New York AM Session High and Low (12:00–15:00 UTC), and New York Lunch High and Low (15:00–17:00 UTC). Additionally, it displays the Previous Day’s High and Low for context on recent price action, as well as automatically detected Equal Highs and Lows based on configurable proximity settings to highlight potential liquidity pools or engineered price levels. These session levels are widely used by institutional traders and are critical for analyzing market behavior during time-based volatility windows. Traders can use this indicator to anticipate breakouts, fakeouts, and reversals around session boundaries—such as liquidity grabs at Asia highs/lows before the London or New York sessions—or to identify key consolidation and expansion zones. Equal Highs and Lows serve as magnets for price, offering insight into potential stop hunts or inducement zones. This tool is ideal for day traders, scalpers, and smart money concept practitioners, and includes full customization for session timings, color schemes, line styles, and alert conditions. Whether you're trading price action, ICT concepts, or supply and demand, this indicator provides a powerful framework for intraday analysis.
Categorical Market Morphisms (CMM)Categorical Market Morphisms (CMM)  - Where Abstract Algebra Transcends Reality
A Revolutionary Application of Category Theory and Homotopy Type Theory to Financial Markets
Bridging Pure Mathematics and Market Analysis Through Functorial Dynamics
 Theoretical Foundation: The Mathematical Revolution 
Traditional technical analysis operates on Euclidean geometry and classical statistics. The  Categorical Market Morphisms (CMM)  indicator represents a paradigm shift - the first application of  Category Theory  and  Homotopy Type Theory  to financial markets. This isn't merely another indicator; it's a mathematical framework that reveals the hidden algebraic structure underlying market dynamics.
 Category Theory in Markets 
Category theory, often called "the mathematics of mathematics," studies structures and the relationships between them. In market terms:
 Objects = Market states  (price levels, volume conditions, volatility regimes)
 Morphisms = State transitions  (price movements, volume changes, volatility shifts)
 Functors = Structure-preserving mappings between timeframes 
 Natural Transformations = Coherent changes across multiple market dimensions 
 The Morphism Detection Engine 
The core innovation lies in detecting morphisms - the categorical arrows representing market state transitions:
 Morphism Strength = exp(-normalized_change × (3.0 / sensitivity)) 
 Threshold = 0.3 - (sensitivity - 1.0) × 0.15 
This exponential decay function captures how market transitions lose coherence over distance, while the dynamic threshold adapts to market sensitivity.
 Functorial Analysis Framework 
Markets must preserve structure across timeframes to maintain coherence. Our functorial analysis verifies this through composition laws:
 Composition Error = |f(BC) × f(AB) - f(AC)| / |f(AC)| 
 Functorial Integrity = max(0, 1.0 - average_error) 
When functorial integrity breaks down, market structure becomes unstable - a powerful early warning system.
 Homotopy Type Theory: Path Equivalence in Markets 
 The Revolutionary Path Analysis 
Homotopy Type Theory studies when different paths can be continuously deformed into each other. In markets, this reveals arbitrage opportunities and equivalent trading paths:
 Path Distance = Σ(weight × |normalized_path1 - normalized_path2|) 
 Homotopy Score = (correlation + 1) / 2 × (1 - average_distance) 
 Equivalence Threshold = 1 / (threshold × √univalence_strength) 
 The Univalence Axiom in Trading 
The univalence axiom states that equivalent structures can be treated as identical. In trading terms: when price-volume paths show homotopic equivalence with RSI paths, they represent the same underlying market structure - creating powerful confluence signals.
 Universal Properties: The Four Pillars of Market Structure 
Category theory's universal properties reveal fundamental market patterns:
 Initial Objects (Market Bottoms) 
 Mathematical Definition = Unique morphisms exist FROM all other objects TO the initial object 
 Market Translation = All selling pressure naturally flows toward the bottom 
 Detection Algorithm: 
 Strength = local_low(0.3) + oversold(0.2) + volume_surge(0.2) + momentum_reversal(0.2) + morphism_flow(0.1) 
 Signal = strength > 0.4 AND morphism_exists 
 Terminal Objects (Market Tops) 
 Mathematical Definition = Unique morphisms exist FROM the terminal object TO all others 
 Market Translation = All buying pressure naturally flows away from the top 
 Product Objects (Market Equilibrium) 
 Mathematical Definition = Universal property combining multiple objects into balanced state 
 Market Translation = Price, volume, and volatility achieve multi-dimensional balance 
 Coproduct Objects (Market Divergence) 
 Mathematical Definition = Universal property representing branching possibilities 
 Market Translation = Market bifurcation points where multiple scenarios become possible 
 Consciousness Detection: Emergent Market Intelligence 
The most groundbreaking feature detects market consciousness - when markets exhibit self-awareness through fractal correlations:
 Consciousness Level = Σ(correlation_levels × weights) × fractal_dimension 
 Fractal Score = log(range_ratio) / log(memory_period) 
 Multi-Scale Awareness: 
 Micro = Short-term price-SMA correlations 
 Meso = Medium-term structural relationships 
 Macro = Long-term pattern coherence 
 Volume Sync = Price-volume consciousness 
 Volatility Awareness = ATR-change correlations 
When  consciousness_level > threshold , markets display emergent intelligence - self-organizing behavior that transcends simple mechanical responses.
 Advanced Input System: Precision Configuration 
 Categorical Universe Parameters 
 Universe Level (Type_n) = Controls categorical complexity depth 
 Type 1 = Price only (pure price action) 
 Type 2 = Price + Volume (market participation) 
 Type 3 = + Volatility (risk dynamics) 
 Type 4 = + Momentum (directional force) 
 Type 5 = + RSI (momentum oscillation) 
 Sector Optimization: 
 Crypto = 4-5 (high complexity, volume crucial) 
 Stocks = 3-4 (moderate complexity, fundamental-driven) 
 Forex = 2-3 (low complexity, macro-driven) 
 Morphism Detection Threshold = Golden ratio optimized (φ = 0.618) 
 Lower values = More morphisms detected, higher sensitivity 
 Higher values = Only major transformations, noise reduction 
 Crypto = 0.382-0.618 (high volatility accommodation) 
 Stocks = 0.618-1.0 (balanced detection) 
 Forex = 1.0-1.618 (macro-focused) 
 Functoriality Tolerance = φ⁻² = 0.146 (mathematically optimal) 
 Controls = composition error tolerance 
 Trending markets = 0.1-0.2 (strict structure preservation) 
 Ranging markets = 0.2-0.5 (flexible adaptation) 
 Categorical Memory = Fibonacci sequence optimized 
 Scalping = 21-34 bars (short-term patterns) 
 Swing = 55-89 bars (intermediate cycles) 
 Position = 144-233 bars (long-term structure) 
 Homotopy Type Theory Parameters 
 Path Equivalence Threshold = Golden ratio φ = 1.618 
 Volatile markets = 2.0-2.618 (accommodate noise) 
 Normal conditions = 1.618 (balanced) 
 Stable markets = 0.786-1.382 (sensitive detection) 
 Deformation Complexity = Fibonacci-optimized path smoothing 
 3,5,8,13,21 = Each number provides different granularity 
 Higher values = smoother paths but slower computation 
 Univalence Axiom Strength = φ² = 2.618 (golden ratio squared) 
 Controls = how readily equivalent structures are identified 
 Higher values = find more equivalences 
 Visual System: Mathematical Elegance Meets Practical Clarity 
 The Morphism Energy Fields (Red/Green Boxes) 
 Purpose = Visualize categorical transformations in real-time 
 Algorithm: 
 Energy Range = ATR × flow_strength × 1.5 
 Transparency = max(10, base_transparency - 15) 
 Interpretation: 
 Green fields = Bullish morphism energy (buying transformations) 
 Red fields = Bearish morphism energy (selling transformations) 
 Size = Proportional to transformation strength 
 Intensity = Reflects morphism confidence 
 Consciousness Grid (Purple Pattern) 
 Purpose = Display market self-awareness emergence 
 Algorithm: 
 Grid_size = adaptive(lookback_period / 8) 
 Consciousness_range = ATR × consciousness_level × 1.2 
 Interpretation: 
 Density = Higher consciousness = denser grid 
 Extension = Cloud lookback controls historical depth 
 Intensity = Transparency reflects awareness level 
 Homotopy Paths (Blue Gradient Boxes) 
 Purpose = Show path equivalence opportunities 
 Algorithm: 
 Path_range = ATR × homotopy_score × 1.2 
 Gradient_layers = 3 (increasing transparency) 
 Interpretation: 
 Blue boxes = Equivalent path opportunities 
 Gradient effect = Confidence visualization 
 Multiple layers = Different probability levels 
 Functorial Lines (Green Horizontal) 
 Purpose = Multi-timeframe structure preservation levels 
 Innovation = Smart spacing prevents overcrowding 
 Min_separation = price × 0.001 (0.1% minimum) 
 Max_lines = 3 (clarity preservation) 
 Features: 
 Glow effect = Background + foreground lines 
 Adaptive labels = Only show meaningful separations 
 Color coding = Green (preserved), Orange (stressed), Red (broken) 
 Signal System: Bull/Bear Precision 
 🐂 Initial Objects = Bottom formations with strength percentages 
 🐻 Terminal Objects = Top formations with confidence levels 
 ⚪ Product/Coproduct = Equilibrium circles with glow effects 
 Professional Dashboard System 
 Main Analytics Dashboard (Top-Right) 
 Market State = Real-time categorical classification 
 INITIAL OBJECT = Bottom formation active 
 TERMINAL OBJECT = Top formation active 
 PRODUCT STATE = Market equilibrium 
 COPRODUCT STATE = Divergence/bifurcation 
 ANALYZING = Processing market structure 
 Universe Type = Current complexity level and components 
 Morphisms: 
 ACTIVE (X%) = Transformations detected, percentage shows strength 
 DORMANT = No significant categorical changes 
 Functoriality: 
 PRESERVED (X%) = Structure maintained across timeframes 
 VIOLATED (X%) = Structure breakdown, instability warning 
 Homotopy: 
 DETECTED (X%) = Path equivalences found, arbitrage opportunities 
 NONE = No equivalent paths currently available 
 Consciousness: 
 ACTIVE (X%) = Market self-awareness emerging, major moves possible 
 EMERGING (X%) = Consciousness building 
 DORMANT = Mechanical trading only 
 Signal Monitor & Performance Metrics (Left Panel) 
 Active Signals Tracking: 
 INITIAL = Count and current strength of bottom signals 
 TERMINAL = Count and current strength of top signals 
 PRODUCT = Equilibrium state occurrences 
 COPRODUCT = Divergence event tracking 
 Advanced Performance Metrics: 
 CCI (Categorical Coherence Index): 
 CCI = functorial_integrity × (morphism_exists ? 1.0 : 0.5) 
 STRONG (>0.7) = High structural coherence 
 MODERATE (0.4-0.7) = Adequate coherence 
 WEAK (<0.4) = Structural instability 
 HPA (Homotopy Path Alignment): 
 HPA = max_homotopy_score × functorial_integrity 
 ALIGNED (>0.6) = Strong path equivalences 
 PARTIAL (0.3-0.6) = Some equivalences 
 WEAK (<0.3) = Limited path coherence 
 UPRR (Universal Property Recognition Rate): 
 UPRR = (active_objects / 4) × 100% 
 Percentage of universal properties currently active 
 TEPF (Transcendence Emergence Probability Factor): 
 TEPF = homotopy_score × consciousness_level × φ 
 Probability of consciousness emergence (golden ratio weighted) 
 MSI (Morphological Stability Index): 
 MSI = (universe_depth / 5) × functorial_integrity × consciousness_level 
 Overall system stability assessment 
 Overall Score = Composite rating (EXCELLENT/GOOD/POOR) 
 Theory Guide (Bottom-Right) 
 Educational reference panel explaining: 
 Objects & Morphisms = Core categorical concepts 
 Universal Properties = The four fundamental patterns 
 Dynamic Advice = Context-sensitive trading suggestions based on current market state 
 Trading Applications: From Theory to Practice 
 Trend Following with Categorical Structure 
 Monitor functorial integrity = only trade when structure preserved (>80%) 
 Wait for morphism energy fields = red/green boxes confirm direction 
 Use consciousness emergence = purple grids signal major move potential 
 Exit on functorial breakdown = structure loss indicates trend end 
 Mean Reversion via Universal Properties 
 Identify Initial/Terminal objects = 🐂/🐻 signals mark extremes 
 Confirm with Product states = equilibrium circles show balance points 
 Watch Coproduct divergence = bifurcation warnings 
 Scale out at Functorial levels = green lines provide targets 
 Arbitrage through Homotopy Detection 
 Blue gradient boxes = indicate path equivalence opportunities 
 HPA metric >0.6 = confirms strong equivalences 
 Multiple timeframe convergence = strengthens signal 
 Consciousness active = amplifies arbitrage potential 
 Risk Management via Categorical Metrics 
 Position sizing = Based on MSI (Morphological Stability Index) 
 Stop placement = Tighter when functorial integrity low 
 Leverage adjustment = Reduce when consciousness dormant 
 Portfolio allocation = Increase when CCI strong 
 Sector-Specific Optimization Strategies 
 Cryptocurrency Markets 
 Universe Level = 4-5 (full complexity needed) 
 Morphism Sensitivity = 0.382-0.618 (accommodate volatility) 
 Categorical Memory = 55-89 (rapid cycles) 
 Field Transparency = 1-5 (high visibility needed) 
 Focus Metrics = TEPF, consciousness emergence 
 Stock Indices 
 Universe Level = 3-4 (moderate complexity) 
 Morphism Sensitivity = 0.618-1.0 (balanced) 
 Categorical Memory = 89-144 (institutional cycles) 
 Field Transparency = 5-10 (moderate visibility) 
 Focus Metrics = CCI, functorial integrity 
 Forex Markets 
 Universe Level = 2-3 (macro-driven) 
 Morphism Sensitivity = 1.0-1.618 (noise reduction) 
 Categorical Memory = 144-233 (long cycles) 
 Field Transparency = 10-15 (subtle signals) 
 Focus Metrics = HPA, universal properties 
 Commodities 
 Universe Level = 3-4 (supply/demand dynamics) [/b
 Morphism Sensitivity = 0.618-1.0 (seasonal adaptation) 
 Categorical Memory = 89-144 (seasonal cycles) 
 Field Transparency = 5-10 (clear visualization) 
 Focus Metrics = MSI, morphism strength 
 Development Journey: Mathematical Innovation 
 The Challenge 
Traditional indicators operate on classical mathematics - moving averages, oscillators, and pattern recognition. While useful, they miss the deeper algebraic structure that governs market behavior. Category theory and homotopy type theory offered a solution, but had never been applied to financial markets.
 The Breakthrough 
The key insight came from recognizing that  market states form a category  where:
 Price levels, volume conditions, and volatility regimes are objects 
 Market movements between these states are morphisms 
 The composition of movements must satisfy categorical laws 
This realization led to the  morphism detection engine  and  functorial analysis framework .
 Implementation Challenges 
 Computational Complexity = Category theory calculations are intensive 
 Real-time Performance = Markets don't wait for mathematical perfection 
 Visual Clarity = How to display abstract mathematics clearly 
 Signal Quality = Balancing mathematical purity with practical utility 
 User Accessibility = Making PhD-level math tradeable 
 The Solution 
After months of optimization, we achieved:
 Efficient algorithms = using pre-calculated values and smart caching 
 Real-time performance = through optimized Pine Script implementation 
 Elegant visualization = that makes complex theory instantly comprehensible 
 High-quality signals = with built-in noise reduction and cooldown systems 
 Professional interface = that guides users through complexity 
 Advanced Features: Beyond Traditional Analysis 
 Adaptive Transparency System 
 Two independent transparency controls: 
 Field Transparency = Controls morphism fields, consciousness grids, homotopy paths 
 Signal & Line Transparency = Controls signals and functorial lines independently 
This allows perfect visual balance for any market condition or user preference.
 Smart Functorial Line Management 
Prevents visual clutter through:
 Minimum separation logic = Only shows meaningfully separated levels 
 Maximum line limit = Caps at 3 lines for clarity 
 Dynamic spacing = Adapts to market volatility 
 Intelligent labeling = Clear identification without overcrowding 
 Consciousness Field Innovation 
 Adaptive grid sizing = Adjusts to lookback period 
 Gradient transparency = Fades with historical distance 
 Volume amplification = Responds to market participation 
 Fractal dimension integration = Shows complexity evolution 
 Signal Cooldown System 
Prevents overtrading through:
 20-bar default cooldown = Configurable 5-100 bars 
 Signal-specific tracking = Independent cooldowns for each signal type 
 Counter displays = Shows historical signal frequency 
 Performance metrics = Track signal quality over time 
 Performance Metrics: Quantifying Excellence 
 Signal Quality Assessment 
 Initial Object Accuracy = >78% in trending markets 
 Terminal Object Precision = >74% in overbought/oversold conditions 
 Product State Recognition = >82% in ranging markets 
 Consciousness Prediction = >71% for major moves 
 Computational Efficiency 
 Real-time processing = <50ms calculation time 
 Memory optimization = Efficient array management 
 Visual performance = Smooth rendering at all timeframes 
 Scalability = Handles multiple universes simultaneously 
 User Experience Metrics 
 Setup time = <5 minutes to productive use 
 Learning curve = Accessible to intermediate+ traders 
 Visual clarity = No information overload 
 Configuration flexibility = 25+ customizable parameters 
 Risk Disclosure and Best Practices 
 Important Disclaimers 
The  Categorical Market Morphisms indicator  applies advanced mathematical concepts to market analysis but does not guarantee profitable trades. Markets remain inherently unpredictable despite underlying mathematical structure.
 Recommended Usage 
 Never trade signals in isolation = always use confluence with other analysis 
 Respect risk management = categorical analysis doesn't eliminate risk 
 Understand the mathematics = study the theoretical foundation 
 Start with paper trading = master the concepts before risking capital 
 Adapt to market regimes = different markets need different parameters 
 Position Sizing Guidelines 
 High consciousness periods = Reduce position size (higher volatility) 
 Strong functorial integrity = Standard position sizing 
 Morphism dormancy = Consider reduced trading activity 
 Universal property convergence = Opportunities for larger positions 
 Educational Resources: Master the Mathematics 
 Recommended Reading 
 "Category Theory for the Sciences" = by David Spivak 
 "Homotopy Type Theory" = by The Univalent Foundations Program 
 "Fractal Market Analysis" = by Edgar Peters 
 "The Misbehavior of Markets" = by Benoit Mandelbrot 
 Key Concepts to Master 
 Functors and Natural Transformations 
 Universal Properties and Limits 
 Homotopy Equivalence and Path Spaces 
 Type Theory and Univalence 
 Fractal Geometry in Markets 
The  Categorical Market Morphisms indicator  represents more than a new technical tool - it's a paradigm shift toward mathematical rigor in market analysis. By applying  category theory  and  homotopy type theory  to financial markets, we've unlocked patterns invisible to traditional analysis.
This isn't just about better signals or prettier charts. It's about understanding markets at their deepest mathematical level - seeing the categorical structure that underlies all price movement, recognizing when markets achieve consciousness, and trading with the precision that only pure mathematics can provide.
 Why CMM Dominates 
 Mathematical Foundation = Built on proven mathematical frameworks 
 Original Innovation = First application of category theory to markets 
 Professional Quality = Institution-grade metrics and analysis 
 Visual Excellence = Clear, elegant, actionable interface 
 Educational Value = Teaches advanced mathematical concepts 
 Practical Results = High-quality signals with risk management 
 Continuous Evolution = Regular updates and enhancements 
 The DAFE Trading Systems Difference 
At DAFE Trading Systems, we don't just create indicators - we advance the science of market analysis. Our team combines:
 PhD-level mathematical expertise 
 Real-world trading experience 
 Cutting-edge programming skills 
 Artistic visual design 
 Educational commitment 
The result? Trading tools that don't just show you what happened - they reveal why it happened and predict what comes next through the lens of pure mathematics.
"In mathematics you don't understand things. You just get used to them." - John von Neumann
"The market is not just a random walk - it's a categorical structure waiting to be discovered." - DAFE Trading Systems
Trade with Mathematical Precision. Trade with Categorical Market Morphisms.
Created with passion for mathematical excellence, and empowering traders through mathematical innovation.
— Dskyz, Trade with insight. Trade with anticipation.
Adjustable Vertical LinesThe script provides an indicator which will plot lines - 15 min, 30 min and 60 min. You can customize the time intervals and go to as low as one minute, but I found the 15-minute and 30-minute intervals works best for me when trying to find setups, and the lower time-frame intervals, is just pointless to use if you're not scalping on the seconds timeframe.
You can customize inputs for the line style. Line thickness, colour, etc.   
I've seen this work using the OBR theory and applying it to the one-minute candle then looking for other confluences like order blocks, or breakers, FVGs, BOS/CHoC for further confirmation for scalping. It's important to backtest though and see for yourself.
Thanks for the boost.
Momentum Fusion v1Momentum Fusion v1  
Overview
Momentum Fusion v1 (MFusion) is a multi-oscillator indicator that combines several components to analyze market momentum and trend strength. It incorporates modified versions of classic indicators such as PVI (Positive Volume Index), NVI (Negative Volume Index), MFI (Money Flow Index), RSI, Stochastic, and Bollinger Bands Oscillator. The indicator displays a histogram that changes color based on momentum strength and includes "FUSION🔥" signal labels when extreme values are reached.
Indicator Settings
Parameters:
EMA Length – Smoothing period for the moving average (default: 255).
Smoothing Period – Internal calculation smoothing parameter (default: 15).
BB Multiplier – Standard deviation multiplier for Bollinger Bands (default: 2.0).
Show verde / marron / media lines – Toggles the display of auxiliary lines.
Show FUSION🔥 label – Enables/disables signal labels.
Indicator Components
1. PVI (Positive Volume Index)
Formula:
pvi := volume > volume  ? nz(pvi ) + (close - close ) / close  * sval : nz(pvi )
Description:
PVI increases when volume rises compared to the previous bar and accounts for price percentage change. The stronger the price movement with increasing volume, the higher the PVI value.
2. NVI (Negative Volume Index)
Formula:
nvi := volume < volume  ? nz(nvi ) + (close - close ) / close  * sval : nz(nvi )
Description:
NVI tracks price movements during declining volume. If the price rises on low volume, it may indicate a "stealth" trend.
3. Money Flow Index (MFI)
Formula:
100 - 100 / (1 + up / dn)
Description:
An oscillator measuring money flow strength. Values above 80 suggest overbought conditions, while values below 20 indicate oversold conditions.
4. Stochastic Oscillator
Formula:
k = 100 * (close - lowest(low, length)) / (highest(high, length) - lowest(low, length))
Description:
A classic stochastic oscillator showing price position relative to the selected period's range.
5. Bollinger Bands Oscillator
Formula:
(tprice - BB midline) / (upper BB - lower BB) * 100
Description:
Indicates the price position relative to Bollinger Bands in percentage terms.
Key Lines & Histogram
1. Verde (Green Line)
Calculation:
verde = marron + oscp (normalized PVI)
Interpretation:
Higher values indicate stronger bullish momentum. A FUSION🔥 signal appears when the value reaches 750+.
2. Marron (Brown Line)
Calculation:
marron = (RSI + MFI + Bollinger Osc + Stochastic / 3) / 2
Interpretation:
A composite oscillator combining multiple indicators. Higher values suggest overbought conditions.
3. Media (Red Line)
Calculation:
media = EMA of marron with smoothing period
Interpretation:
Acts as a signal line for trend confirmation.
4. Histogram
Calculation:
histo = verde - marron
Colors:
Bright green (>100) – Strong bullish momentum.
Light green (>0) – Moderate bullish momentum.
Orange (<0) – Bearish momentum.
Red (<-100) – Strong bearish momentum.
Signals & Alerts
1. FUSION🔥 (Strong Momentum)
Condition:
verde >= 750
Visualization:
A "FUSION🔥" label appears below the chart.
Alert:
Can be set to trigger notifications when the condition is met.
2. Background Aura
Condition:
verde > 850
Visualization:
The chart background turns teal, indicating extreme momentum.
Usage Recommendations
FUSION🔥 Signal – Can be used as a long entry point when confirmed by other indicators.
Histogram:
1. Green bars – Potential long entry.
2. Red/orange bars – Potential short entry.
3. Media & Marron Crossover – Can serve as an additional trend filter.
4. Suitable for a 5-15 minute time frame
Conclusion
Momentum Fusion v1 is a powerful tool for momentum analysis, combining multiple indicators into a unified system. It is suitable for:
Trend traders (catching strong movements).
Scalpers (identifying short-term impulses).
Swing traders (filtering entry points).
The indicator features customizable settings and visual signals, making it adaptable to various trading styles.
MirPapa_Library_ICTLibrary   "MirPapa_Library_ICT" 
 GetHTFoffsetToLTFoffset(_offset, _chartTf, _htfTf) 
  GetHTFoffsetToLTFoffset
@description Adjust an HTF offset to an LTF offset by calculating the ratio of timeframes.
  Parameters:
     _offset (int) : int         The HTF bar offset (0 means current HTF bar).
     _chartTf (string) : string     The current chart’s timeframe (e.g., "5", "15", "1D").
     _htfTf (string) : string       The High Time Frame string (e.g., "60", "1D").
@return int                The corresponding LTF bar index. Returns 0 if the result is negative.
 IsConditionState(_type, _isBull, _level, _open, _close, _open1, _close1, _low1, _low2, _low3, _low4, _high1, _high2, _high3, _high4) 
  IsConditionState
@description Evaluate a condition state based on type for COB, FVG, or FOB.
Overloaded: first signature handles COB, second handles FVG/FOB.
  Parameters:
     _type (string) : string        Condition type ("cob", "fvg", "fob").
     _isBull (bool) : bool        Direction flag: true for bullish, false for bearish.
     _level (int) : int          Swing level (only used for COB).
     _open (float) : float         Current bar open price (only for COB).
     _close (float) : float        Current bar close price (only for COB).
     _open1 (float) : float        Previous bar open price (only for COB).
     _close1 (float) : float       Previous bar close price (only for COB).
     _low1 (float) : float         Low 1 bar ago (only for COB).
     _low2 (float) : float         Low 2 bars ago (only for COB).
     _low3 (float) : float         Low 3 bars ago (only for COB).
     _low4 (float) : float         Low 4 bars ago (only for COB).
     _high1 (float) : float        High 1 bar ago (only for COB).
     _high2 (float) : float        High 2 bars ago (only for COB).
     _high3 (float) : float        High 3 bars ago (only for COB).
     _high4 (float) : float        High 4 bars ago (only for COB).
@return bool               True if the specified condition is met, false otherwise.
 IsConditionState(_type, _isBull, _pricePrev, _priceNow) 
  IsConditionState
@description Evaluate FVG or FOB condition based on price movement.
  Parameters:
     _type (string) : string        Condition type ("fvg", "fob").
     _isBull (bool) : bool        Direction flag: true for bullish, false for bearish.
     _pricePrev (float) : float    Previous price (for FVG/FOB).
     _priceNow (float) : float     Current price (for FVG/FOB).
@return bool               True if the specified condition is met, false otherwise.
 IsSwingHighLow(_isBull, _level, _open, _close, _open1, _close1, _low1, _low2, _low3, _low4, _high1, _high2, _high3, _high4) 
  IsSwingHighLow
@description Public wrapper for isSwingHighLow.
  Parameters:
     _isBull (bool) : bool       Direction flag: true for bullish, false for bearish.
     _level (int) : int         Swing level (1 or 2).
     _open (float) : float        Current bar open price.
     _close (float) : float       Current bar close price.
     _open1 (float) : float       Previous bar open price.
     _close1 (float) : float      Previous bar close price.
     _low1 (float) : float        Low 1 bar ago.
     _low2 (float) : float        Low 2 bars ago.
     _low3 (float) : float        Low 3 bars ago.
     _low4 (float) : float        Low 4 bars ago.
     _high1 (float) : float       High 1 bar ago.
     _high2 (float) : float       High 2 bars ago.
     _high3 (float) : float       High 3 bars ago.
     _high4 (float) : float       High 4 bars ago.
@return bool              True if swing condition is met, false otherwise.
 AddBox(_left, _right, _top, _bot, _xloc, _colorBG, _colorBD) 
  AddBox
@description Draw a rectangular box on the chart with specified coordinates and colors.
  Parameters:
     _left (int) : int         Left bar index for the box.
     _right (int) : int        Right bar index for the box.
     _top (float) : float        Top price coordinate for the box.
     _bot (float) : float        Bottom price coordinate for the box.
     _xloc (string) : string      X-axis location type (e.g., xloc.bar_index).
     _colorBG (color) : color    Background color for the box.
     _colorBD (color) : color    Border color for the box.
@return box              Returns the created box object.
 Addline(_x, _y, _xloc, _color, _width) 
  Addline
@description Draw a vertical or horizontal line at specified coordinates.
  Parameters:
     _x (int) : int           X-coordinate for start (bar index).
     _y (int) : float         Y-coordinate for start (price).
     _xloc (string) : string     X-axis location type (e.g., xloc.bar_index).
     _color (color) : color     Line color.
     _width (int) : int       Line width.
@return line            Returns the created line object.
 Addline(_x, _y, _xloc, _color, _width) 
  Parameters:
     _x (int) 
     _y (float) 
     _xloc (string) 
     _color (color) 
     _width (int) 
 Addline(_x1, _y1, _x2, _y2, _xloc, _color, _width) 
  Parameters:
     _x1 (int) 
     _y1 (int) 
     _x2 (int) 
     _y2 (int) 
     _xloc (string) 
     _color (color) 
     _width (int) 
 Addline(_x1, _y1, _x2, _y2, _xloc, _color, _width) 
  Parameters:
     _x1 (int) 
     _y1 (int) 
     _x2 (int) 
     _y2 (float) 
     _xloc (string) 
     _color (color) 
     _width (int) 
 Addline(_x1, _y1, _x2, _y2, _xloc, _color, _width) 
  Parameters:
     _x1 (int) 
     _y1 (float) 
     _x2 (int) 
     _y2 (int) 
     _xloc (string) 
     _color (color) 
     _width (int) 
 Addline(_x1, _y1, _x2, _y2, _xloc, _color, _width) 
  Parameters:
     _x1 (int) 
     _y1 (float) 
     _x2 (int) 
     _y2 (float) 
     _xloc (string) 
     _color (color) 
     _width (int) 
 AddlineMid(_type, _left, _right, _top, _bot, _xloc, _color, _width) 
  AddlineMid
@description Draw a midline between top and bottom for FVG or FOB types.
  Parameters:
     _type (string) : string      Type identifier: "fvg" or "fob".
     _left (int) : int         Left bar index for midline start.
     _right (int) : int        Right bar index for midline end.
     _top (float) : float        Top price of the region.
     _bot (float) : float        Bottom price of the region.
     _xloc (string) : string      X-axis location type (e.g., xloc.bar_index).
     _color (color) : color      Line color.
     _width (int) : int        Line width.
@return line or na       Returns the created line or na if type is not recognized.
 GetHtfFromLabel(_label) 
  GetHtfFromLabel
@description Convert a Korean HTF label into a Pine Script timeframe string via handler library.
  Parameters:
     _label (string) : string    The Korean label (e.g., "5분", "1시간").
@return string          Returns the corresponding Pine Script timeframe (e.g., "5", "60").
 IsChartTFcomparisonHTF(_chartTf, _htfTf) 
  IsChartTFcomparisonHTF
@description Determine whether a given HTF is greater than or equal to the current chart timeframe.
  Parameters:
     _chartTf (string) : string  Current chart timeframe (e.g., "5", "15", "1D").
     _htfTf (string) : string    HTF timeframe (e.g., "60", "1D").
@return bool            True if HTF ≥ chartTF, false otherwise.
 CreateBoxData(_type, _isBull, _useLine, _top, _bot, _xloc, _colorBG, _colorBD, _offset, _htfTf, htfBarIdx, _basePoint) 
  CreateBoxData
@description Create and draw a box and optional midline for given type and parameters. Returns success flag and BoxData.
  Parameters:
     _type (string) : string       Type identifier: "fvg", "fob", "cob", or "sweep".
     _isBull (bool) : bool       Direction flag: true for bullish, false for bearish.
     _useLine (bool) : bool      Whether to draw a midline inside the box.
     _top (float) : float         Top price of the box region.
     _bot (float) : float         Bottom price of the box region.
     _xloc (string) : string       X-axis location type (e.g., xloc.bar_index).
     _colorBG (color) : color     Background color for the box.
     _colorBD (color) : color     Border color for the box.
     _offset (int) : int        HTF bar offset (0 means current HTF bar).
     _htfTf (string) : string      HTF timeframe string (e.g., "60", "1D").
     htfBarIdx (int) : int      HTF bar_index (passed from HTF request).
     _basePoint (float) : float   Base point for breakout checks.
@return tuple(bool, BoxData)  Returns a boolean indicating success and the created BoxData struct.
 ProcessBoxDatas(_datas, _useMidLine, _closeCount, _colorClose) 
  ProcessBoxDatas
@description Process an array of BoxData structs: extend, record volume, update stage, and finalize boxes.
  Parameters:
     _datas (array) : array  Array of BoxData objects to process.
     _useMidLine (bool) : bool       Whether to update the midline endpoint.
     _closeCount (int) : int        Number of touches required to close the box.
     _colorClose (color) : color      Color to apply when a box closes.
@return void                  No return value; updates are in-place.
 BoxData 
  Fields:
     _isActive (series bool) 
     _isBull (series bool) 
     _box (series box) 
     _line (series line) 
     _basePoint (series float) 
     _boxTop (series float) 
     _boxBot (series float) 
     _stage (series int) 
     _isStay (series bool) 
     _volBuy (series float) 
     _volSell (series float) 
     _result (series string) 
 LineData 
  Fields:
     _isActive (series bool) 
     _isBull (series bool) 
     _line (series line) 
     _basePoint (series float) 
     _stage (series int) 
     _isStay (series bool) 
     _result (series string)
MirPapa_Handler_HTFLibrary   "MirPapa_Handler_HTF" 
High Time Frame Handler Library:
Provides utilities for working with High Time Frame (HTF) and chart (LTF) conversions and data retrieval.
 IsChartTFcomparisonHTF(_chartTf, _htfTf) 
  IsChartTFcomparisonHTF
@description
Determine whether the given High Time Frame (HTF) is greater than or equal to the current chart timeframe.
  Parameters:
     _chartTf (string) : The current chart’s timeframe string (examples: "5", "15", "1D").
     _htfTf (string) : The High Time Frame string to compare (examples: "60", "1D").
@return
Returns true if HTF minutes ≥ chart minutes, false otherwise or na if conversion fails.
 GetHTFrevised(_tf, _case) 
  GetHTFrevised
@description
Retrieve a specific bar value from a Higher Time Frame (HTF) series.
Supports current and historical OHLC values, based on a case identifier.
  Parameters:
     _tf (string) : The target HTF string (examples: "60", "1D").
     _case (string) : A case string determining which OHLC value and bar offset to request:
"b"   → HTF bar_index
"o"   → HTF open
"h"   → HTF high
"l"   → HTF low
"c"   → HTF close
"o1"  → HTF open one bar ago
"h1"  → HTF high one bar ago
"l1"  → HTF low one bar ago
"c1"  → HTF close one bar ago
… up to "o5", "h5", "l5", "c5" for five bars ago.
@return
Returns the requested HTF value or na if _case does not match any condition.
 GetHTFfromLabel(_label) 
  GetHTFfromLabel
@description
Convert a Korean HTF label into a Pine Script-recognizable timeframe string.
Examples:
"5분"  → "5"
"1시간" → "60"
"일봉"  → "1D"
"주봉"  → "1W"
"월봉"  → "1M"
"연봉"  → "12M"
  Parameters:
     _label (string) : The Korean HTF label string (examples: "5분", "1시간", "일봉").
@return
Returns the Pine Script timeframe string corresponding to the label, or "1W" if no match is found.
 GetHTFoffsetToLTFoffset(_offset, _chartTf, _htfTf) 
  GetHTFoffsetToLTFoffset
@description
Adjust an HTF bar index and offset so that it aligns with the current chart’s bar index.
Useful for retrieving historical HTF data on an LTF chart.
  Parameters:
     _offset (int) : The HTF bar offset (0 means current HTF bar, 1 means one bar ago, etc.).
     _chartTf (string) : The current chart’s timeframe string (examples: "5", "15", "1D").
     _htfTf (string) : The High Time Frame string to align (examples: "60", "1D").
@return
Returns the corresponding LTF bar index after applying HTF offset. If result is negative, returns 0.
NY Opening Range Breakout - MA StopCore Concept
This strategy trades breakouts from the New York opening range (9:30-9:45 AM NY time) on intraday timeframes, designed for scalping and day trading.
Setup Requirements
Timeframe: Works on any timeframe under 15 minutes (1m, 2m, 3m, 5m, 10m)
Session: New York market hours
Range Period: 9:30-9:45 AM NY time (15-minute opening range)
Entry Rules
Long Entries:
Wait for a candle to close above the opening range high
Enter long on the next candle (before 12:00 PM NY time)
Must be above moving average if using MA-based take profit
Short Entries:
Wait for a candle to close below the opening range low
Enter short on the next candle (before 12:00 PM NY time)
Must be below moving average if using MA-based take profit
Risk Management
Stop Loss:
Long trades: Opening range low
Short trades: Opening range high
Take Profit Options:
Fixed Risk Reward: 1.5x the range size (customizable ratio)
Moving Average: Exit when price crosses back through MA
Both: Whichever comes first
Key Features
Trade Direction Options:
Long Only
Short Only
Both directions
Moving Average Filter:
Prevents entries that would immediately hit stop loss
Uses EMA/SMA/WMA/VWMA with customizable length
Acts as dynamic support/resistance
Time Restrictions:
No entries after 12:00 PM NY time (customizable cutoff)
One trade per direction per day
Daily reset of all variables
Visual Elements
Red/green lines showing opening range
Purple line for moving average
Entry and breakout signals with shapes
Take profit and stop loss levels plotted
Information table with current status
Strategy Logic Flow
Morning: Capture 9:30-9:45 range high/low
Wait: Monitor for breakout (previous candle close outside range)
Filter: Check MA condition if using MA-based exits
Enter: Trade on next candle after breakout
Manage: Exit at fixed TP, MA cross, or stop loss
Reset: Start fresh next trading day
This is a momentum-based breakout strategy that capitalizes on early market volatility while using the opening range as natural support/resistance levels.
Consolidation Range [BigBeluga]A hybrid volatility-volume indicator that isolates periods of price equilibrium and reveals the directional force behind each range buildup. 
 Consolidation Range   is a powerful tool designed to detect compression phases in the market using volatility thresholds while visualizing volume imbalance within those phases. By combining low-volatility detection with directional volume delta, it highlights where accumulation or distribution is occurring—giving traders the confidence to act when breakouts follow. This indicator is particularly valuable in choppy or sideways markets where range identification and sentiment context are key.
 🔵 CONCEPTS 
 
   Volatility Compression:  Uses ADX (Average Directional Index) to detect periods of low trend strength—specifically when ADX drops below a configurable threshold.
   Range Structure:  Upon a low-volatility trigger, the script dynamically anchors horizontal upper and lower bounds based on local highs and lows.
   Directional Volume Delta:  Inside each active range, it calculates the net difference between buy and sell volume, showing who controlled the range.
   Sentiment Bias:  A label appears in the center of the zone on breakout, showing the accumulated delta and bias direction (▲ for positive, ▼ for negative).
   Range Validity Filter:  Only ranges with more than 15 bars are considered valid—short-lived consolidations are auto-filtered.
 
 🔵 KEY FEATURES   
 
  Detects  low volatility market phases  using ADX logic (crosses under "Volatility Threshold Input").  
  Automatically plots  adaptive consolidation zones  with upper and lower boundary lines.  
  Includes  dynamic midline  to visualize the price average inside the range.  
  Visual range is filled with a  progressive gradient  to reflect distance between highs and lows.  
  
  When the range is active, the indicator accumulates  volume delta (Buy - Sell volume) .  
  Upon breakout, the total volume delta is displayed  at the midpoint , providing insight into market sentiment during the consolidation phase.  
  
  Filters out weak or short-lived consolidations under 15 bars.  
 
 🔵 HOW TO USE   
 
  Spot  ranging or compression zones  with minimal effort.  
  Use  breakouts with volume delta bias  to assess the strength or weakness of moves.  
  
  Combine with trend-following tools or volume-based confirmation for stronger setups.  
  Apply to higher timeframes for  macro consolidation tracking .  
 
 🔵 CONCLUSION 
Consolidation Range   now brings together volatility filtering and directional volume delta into one smart module. This hybrid logic allows traders to not only identify balance zones but also understand  who was in control  during the buildup—offering a sharper edge for breakout and trend continuation strategies.
Anchored VWAP by Time (Math by Thomas)📄 Description
This tool lets you plot an Anchored Volume Weighted Average Price (VWAP) starting from any specific date and time you choose. Unlike standard VWAPs that reset daily or weekly, this version gives you full control to track institutional pricing zones from precise anchor points—such as key swing highs/lows, market open, or news-driven candles.
It’s especially useful for price action and Smart Money Concepts (SMC) traders who track liquidity, fair value gaps (FVGs), and institutional zones.
🇮🇳 For NSE India Traders
You can anchor VWAP to Indian market open (e.g., 9:15 AM IST) or major events like RBI policy, earnings, or breakout candles.
The time input uses UTC by default, so for Indian Standard Time (IST), remember:
9:15 AM IST = 3:45 AM UTC
3:30 PM IST = 10:00 AM UTC
⚙️ How to Use
Add the indicator to your chart.
Open the settings panel.
Under “Anchor Start Time”, choose the date & time to begin the VWAP.
Use UTC format (adjust from IST if needed).
Customize the line color and thickness to suit your chart style.
The VWAP will begin plotting from that time forward.
🔎 Best Use Cases
Track VWAP from intraday range breakouts
Anchor from swing highs/lows to identify mean reversion zones
Combine with your FVGs, Order Blocks, or CHoCHs
Monitor VWAP reactions during key macro events or expiry days
🔧 Clean Design
No labels are used, keeping your chart clean.
Works on all timeframes (1min to Daily).
Designed for serious intraday & positional traders.
Ultimate Scalping Tool[BullByte]Overview 
The  Ultimate Scalping Tool  is an open-source TradingView indicator built for scalpers and short-term traders released under the Mozilla Public License 2.0. It uses a custom  Quantum Flux Candle (QFC)  oscillator to combine multiple market forces into one visual signal. In plain terms, the script reads  momentum, trend strength, volatility, and volume  together and plots a special  “candlestick”  each bar (the QFC) that reflects the overall market bias. This unified view makes it easier to spot entries and exits: the tool labels signals as  Strong Buy/Sell, Pullback (a brief retracement in a trend), Early Entry, or Exit Warning . It also provides color-coded alerts and a small dashboard of metrics. In practice, traders see green/red oscillator bars and symbols on the chart when conditions align, helping them scalp or trend-follow without reading multiple separate indicators.
 Core Components 
 Quantum Flux Candle (QFC) Construction 
The QFC is the heart of the indicator. Rather than using raw price, it creates a candlestick-like bar from the underlying oscillator values.  Each QFC bar has an “open,” “high/low,” and “close” derived from calculated momentum and volatility inputs for that period . In effect, this turns the oscillator into intuitive candle patterns so traders can recognize momentum shifts visually. (For comparison, note that Heikin-Ashi candles “have a smoother look because   take an average of the movement”. The QFC instead represents exact oscillator readings, so it reflects true momentum changes without hiding price action.) Colors of QFC bars change dynamically (e.g. green for bullish momentum, red for bearish) to highlight shifts.  This is the first open-source QFC oscillator that dynamically weights four non-correlated indicators with moving thresholds, which makes it a unique indicator on its own. 
 Oscillator Normalization & Adaptive Weights 
The script normalizes its oscillator to a fixed scale (for example, a 0–100 range much like the RSI) so that various inputs can be compared fairly. It then applies adaptive weighting: the relative influence of trend, momentum, volatility or volume signals is automatically adjusted based on current market conditions. For instance, in very volatile markets the script might weight volatility more heavily, or in a strong trend it might give extra weight to trend direction.  Normalizing data and adjusting weights helps keep the QFC sensitive but stable (normalization ensures all inputs fit a common scale). 
 Trend/Momentum/Volume/Volatility Fusion 
Unlike a typical single-factor oscillator, the QFC oscillator fuses four aspects at once. It may compute, for example,  a trend indicator (such as an ADX or moving average slope), a momentum measure (like RSI or Rate-of-Change), a volume-based pressure (similar to MFI/OBV), and a volatility measure (like ATR) . These different values are combined into one composite oscillator. This “multi-dimensional” approach follows best practices of using non-correlated indicators (trend, momentum, volume, volatility) for confirmation. By encoding all these signals in one line, a high QFC reading means that trend, momentum, and volume are all aligned, whereas a neutral reading might mean mixed conditions. This gives traders a comprehensive picture of market strength.
 Signal Classification 
The script interprets the QFC oscillator to label trades. For example:
• Strong Buy/Sell : Triggered when the oscillator crosses a high-confidence threshold (e.g. breaks clearly above zero with strong slope), indicating a well-confirmed move. This is like seeing a big green/red QFC candle aligned with the trend.
• Pullbacks : Identified when the trend is up but momentum dips briefly. A Pullback Buy appears if the overall trend is bullish but the oscillator has a short retracement – a typical buying opportunity in an uptrend. (A pullback is “a brief decline or pause in a generally upward price trend”.)
• Early Buy/Sell : Marks an initial swing in the oscillator suggesting a possible new trend, before it is fully confirmed. It’s a hint of momentum building (an early-warning signal), not as strong as the confirmed “Strong” signal.
• Exit Warnings : Issued when momentum peaks or reverses. For instance, if the QFC bars reach a high and start turning red/green opposite, the indicator warns that the move may be ending. In other words, a Momentum Peak is the point of maximum strength after which weakness may follow.
These categories correspond to typical trading concepts: Pullback (temporary reversal in an uptrend), Early Buy (an initial bullish cross), Strong Buy (confirmed bullish momentum), and Momentum Peak (peak oscillator value suggesting exhaustion).
 Filters (DI Reversal, Dynamic Thresholds, HTF EMA/ADX) 
Extra filters help avoid bad trades.  A DI Reversal filter uses the +DI/–DI lines (from the ADX system) to require that the trend direction confirms the signal . For example, it might ignore a buy signal if the +DI is still below –DI. Dynamic Thresholds adjust signal levels on-the-fly: rather than fixed “overbought” lines, they move with volatility so signals happen under appropriate market stress. An optional High-Timeframe EMA or ADX filter adds a check against a larger timeframe trend: for instance, only taking a trade if price is above the weekly EMA or if weekly ADX shows a strong trend. (Notably, the ADX is “a technical indicator used by traders to determine the strength of a price trend”, so requiring a high-timeframe ADX avoids trading against the bigger trend.)
 Dashboard Metrics & Color Logic 
 
The  Dashboard  in the  Ultimate Scalping Tool (UST)  serves as a centralized information hub, providing traders with real-time insights into market conditions, trend strength, momentum, volume pressure, and trade signals. It is highly customizable, allowing users to adjust its appearance and content based on their preferences.  
 1. Dashboard Layout & Customization   
 Short vs. Extended Mode : Users can toggle between a  compact view  (9 rows) and an  extended view  (13 rows) via the `Short Dashboard` input.  
 Text Size Options : The dashboard supports three text sizes— Tiny, Small, and Normal —adjustable via the `Dashboard Text Size` input.  
 Positioning : The dashboard is positioned in the  top-right corner  by default but can be moved if modified in the script.  
 2. Key Metrics Displayed   
The dashboard presents critical trading metrics in a structured table format:  
 Trend (TF) : Indicates the current trend direction (Strong Bullish, Moderate Bullish, Sideways, Moderate Bearish, Strong Bearish) based on  normalized trend strength (normTrend) .  
 Momentum (TF) : Displays momentum status (Strong Bullish/Bearish or Neutral) derived from the  oscillator's position relative to dynamic thresholds.   
 Volume (CMF) : Shows buying/selling pressure levels (Very High Buying, High Selling, Neutral, etc.) based on the  Chaikin Money Flow (CMF) indicator.   
 Basic & Advanced Signals:   
 Basic Signal : Provides simple trade signals (Strong Buy, Strong Sell, Pullback Buy, Pullback Sell, No Trade).  
 Advanced Signal : Offers nuanced signals (Early Buy/Sell, Momentum Peak, Weakening Momentum, etc.) with color-coded alerts.  
 RSI : Displays the Relative Strength Index (RSI) value, colored based on overbought (>70), oversold (<30), or neutral conditions.  
 HTF Filter : Indicates the  higher timeframe trend status  (Bullish, Bearish, Neutral) when using the Leading HTF Filter.  
 VWAP : Shows the V olume-Weighted Average Price  and whether the current price is above (bullish) or below (bearish) it.  
 ADX : Displays the  Average Directional Index (ADX)  value, with color highlighting whether it is rising (green) or falling (red).  
 Market Mode : Shows the selected  market type (Crypto, Stocks, Options, Forex, Custom).   
 Regime : Indicates volatility conditions (High, Low, Moderate) based on the **ATR ratio**.  
 3. Filters Status Panel 
A secondary panel displays the  status of active filters,  helping traders quickly assess which conditions are influencing signals:  
-  DI Reversal Filter:  On/Off (confirms reversals before generating signals).  
-  Dynamic Thresholds:  On/Off (adjusts buy/sell thresholds based on volatility).  
-  Adaptive Weighting:  On/Off (auto-adjusts oscillator weights for trend/momentum/volatility).  
-  Early Signal:  On/Off (enables early momentum-based signals).  
-  Leading HTF Filter:  On/Off (applies higher timeframe trend confirmation).  
 4. Visual Enhancements   
 Color-Coded Cells : Each metric is color-coded (green for bullish, red for bearish, gray for neutral) for quick interpretation.  
 Dynamic Background : The dashboard background adapts to market conditions (bullish/bearish/neutral) based on ADX and DI trends.  
 Customizable Reference Lines : Users can enable/disable fixed reference lines for the oscillator.  
 How It(QFC) Differs from Traditional Indicators 
 Quantum Flux Candle (QFC) Versus Heikin-Ashi 
Heikin-Ashi candles smooth price by averaging (HA’s open/close use averages) so they show trend clearly but hide true price (the current HA bar’s close is not the real price).  QFC candles are different: they are oscillator values, not price averages . A Heikin-Ashi chart “has a smoother look because it is essentially taking an average of the movement”, which can cause lag. The QFC instead shows the raw combined momentum each bar, allowing faster recognition of shifts. In short, HA is a smoothed price chart; QFC is a momentum-based chart.
 Versus Standard Oscillators 
Common oscillators like RSI or MACD use fixed formulas on price (or price+volume). For example, RSI “compares gains and losses and normalizes this value on a scale from 0 to 100”, reflecting pure price momentum. MFI is similar but adds volume. These indicators each show one dimension: momentum or volume. The Ultimate Scalping Tool’s QFC goes further by integrating trend strength and volatility too. In practice, this means a move that looks strong on RSI might be downplayed by low volume or weak trend in QFC. As one source notes, using multiple non-correlated indicators (trend, momentum, volume, volatility) provides a more complete market picture.  The QFC’s multi-factor fusion is unique – it is effectively a multi-dimensional oscillator rather than a traditional single-input one. 
 Signal Style 
Traditional oscillators often use crossovers (RSI crossing 50) or fixed zones (MACD above zero) for signals. The Ultimate Scalping Tool’s signals are custom-classified: it explicitly labels pullbacks, early entries, and strong moves. These terms go beyond a typical indicator’s generic “buy”/“sell.” In other words, it packages a strategy around the oscillator, which traders can backtest or observe without reading code.
 Key Term Definitions 
• Pullback : A short-term dip or consolidation in an uptrend. In this script, a Pullback Buy appears when price is generally rising but shows a brief retracement. (As defined by Investopedia, a pullback is “a brief decline or pause in a generally upward price trend”.)
• Early Buy/Sell : An initial or tentative entry signal. It means the oscillator first starts turning positive (or negative) before a full trend has developed. It’s an early indication that a trend might be starting.
• Strong Buy/Sell : A confident entry signal when multiple conditions align. This label is used when momentum is already strong and confirmed by trend/volume filters, offering a higher-probability trade.
• Momentum Peak : The point where bullish (or bearish) momentum reaches its maximum before weakening. When the oscillator value stops rising (or falling) and begins to reverse, the script flags it as a peak – signaling that the current move could be overextended.
 What is the Flux MA? 
 The Flux MA (Moving Average) is an Exponential Moving Average (EMA) applied to a normalized oscillator, referred to as FM . Its purpose is to smooth out the fluctuations of the oscillator, providing a clearer picture of the underlying trend direction and strength. Think of it as a dynamic baseline that the oscillator moves above or below, helping you determine whether the market is trending bullish or bearish.
 How it’s calculated (Flux MA): 
1.The oscillator is normalized (scaled to a range, typically between 0 and 1, using a default scale factor of 100.0).
2.An EMA is applied to this normalized value (FM) over a user-defined period (default is 10 periods).
3.The result is rescaled back to the oscillator’s original range for plotting.
 Why it matters : The Flux MA acts like a support or resistance level for the oscillator, making it easier to spot trend shifts.
 Color of the Flux Candle 
The Quantum Flux Candle visualizes the normalized oscillator (FM) as candlesticks, with colors that indicate specific market conditions based on the relationship between the FM and the Flux MA. Here’s what each color means:
• Green : The FM is above the Flux MA, signaling bullish momentum. This suggests the market is trending upward.
• Red : The FM is below the Flux MA, signaling bearish momentum. This suggests the market is trending downward.
• Yellow : Indicates strong buy conditions (e.g., a "Strong Buy" signal combined with a positive trend). This is a high-confidence signal to go long.
• Purple : Indicates strong sell conditions (e.g., a "Strong Sell" signal combined with a negative trend). This is a high-confidence signal to go short.
The candle mode shows the oscillator’s open, high, low, and close values for each period, similar to price candlesticks, but it’s the color that provides the quick visual cue for trading decisions.
 How to Trade the Flux MA with Respect to the Candle 
Trading with the Flux MA and Quantum Flux Candle involves using the MA as a trend indicator and the candle colors as entry and exit signals. Here’s a step-by-step guide:
1.  Identify the Trend Direction 
• Bullish Trend : The Flux Candle is green and positioned above the Flux MA. This indicates upward momentum.
• Bearish Trend : The Flux Candle is red and positioned below the Flux MA. This indicates downward momentum.
The Flux MA serves as the reference line—candles above it suggest buying pressure, while candles below it suggest selling pressure.
2.  Interpret Candle Colors for Trade Signals 
• Green Candle : General bullish momentum. Consider entering or holding a long position.
• Red Candle : General bearish momentum. Consider entering or holding a short position.
• Yellow Candle : A strong buy signal. This is an ideal time to enter a long trade.
• Purple Candle : A strong sell signal. This is an ideal time to enter a short trade.
3.  Enter Trades Based on Crossovers and Colors 
• Long Entry : Enter a buy position when the Flux Candle turns green and crosses above the Flux MA. If it turns yellow, this is an even stronger signal to go long.
• Short Entry : Enter a sell position when the Flux Candle turns red and crosses below the Flux MA. If it turns purple, this is an even stronger signal to go short.
4. Exit Trades 
• Exit Long : Close your buy position when the Flux Candle turns red or crosses below the Flux MA, indicating the bullish trend may be reversing.
• Exit Short : Close your sell position when the Flux Candle turns green or crosses above the Flux MA, indicating the bearish trend may be reversing.
•You might also exit a long trade if the candle changes from yellow to green (weakening strong buy signal) or a short trade from purple to red (weakening strong sell signal).
5.  Use Additional Confirmation 
To avoid false signals, combine the Flux MA and candle signals with other indicators or dashboard metrics (e.g., trend strength, momentum, or volume pressure). For example:
•A yellow candle with a " Strong Bullish " trend and high buying volume is a robust long signal.
•A red candle with a " Moderate Bearish " trend and neutral momentum might need more confirmation before shorting.
 Practical Example 
Imagine you’re scalping a cryptocurrency:
• Long Trade : The Flux Candle turns yellow and is above the Flux MA, with the dashboard showing "Strong Buy" and high buying volume. You enter a long position. You exit when the candle turns red and dips below the Flux MA.
• Short Trade : The Flux Candle turns purple and crosses below the Flux MA, with a "Strong Sell" signal on the dashboard. You enter a short position. You exit when the candle turns green and crosses above the Flux MA.
 Market Presets and Adaptation 
This indicator is designed to work on any market with candlestick price data (stocks, crypto, forex, indices, etc.). To handle different behavior, it provides presets for major asset classes.  Selecting a “Stocks,” “Crypto,” “Forex,” or “Options” preset automatically loads a set of parameter values optimized for that market . For example, a crypto preset might use a shorter lookback or higher sensitivity to account for crypto’s high volatility, while a stocks preset might use slightly longer smoothing since stocks often trend more slowly. In practice, this means the same core QFC logic applies across markets, but the thresholds and smoothing adjust so signals remain relevant for each asset type.
 Usage Guidelines 
• Recommended Timeframes : Optimized for 1 minute to 15 minute intraday charts. Can also be used on higher timeframes for short term swings.
• Market Types : Select “Crypto,” “Stocks,” “Forex,” or “Options” to auto tune periods, thresholds and weights. Use “Custom” to manually adjust all inputs.
• Interpreting Signals : Always confirm a signal by checking that trend, volume, and VWAP agree on the dashboard. A green “Strong Buy” arrow with green trend, green volume, and price > VWAP is highest probability.
• Adjusting Sensitivity : To reduce false signals in fast markets, enable DI Reversal Confirmation and Dynamic Thresholds. For more frequent entries in trending environments, enable Early Entry Trigger.
• Risk Management : This tool does not plot stop loss or take profit levels. Users should define their own risk parameters based on support/resistance or volatility bands.
 Background Shading 
To give you an at-a-glance sense of market regime without reading numbers, the indicator automatically tints the chart background in three modes—neutral, bullish and bearish—with two levels of intensity (light vs. dark):
 Neutral (Gray) 
When ADX is below 20 the market is considered “no trend” or too weak to trade. The background fills with a light gray (high transparency) so you know to sit on your hands.
 Bullish (Green) 
As soon as ADX rises above 20 and +DI exceeds –DI, the background turns a semi-transparent green, signaling an emerging uptrend. When ADX climbs above 30 (strong trend), the green becomes more opaque—reminding you that trend-following signals (Strong Buy, Pullback) carry extra weight.
 Bearish (Red) 
Similarly, if –DI exceeds +DI with ADX >20, you get a light red tint for a developing downtrend, and a darker, more solid red once ADX surpasses 30.
By dynamically varying both hue (green vs. red vs. gray) and opacity (light vs. dark), the background instantly communicates trend strength and direction—so you always know whether to favor breakout-style entries (in a strong trend) or stay flat during choppy, low-ADX conditions.
 The setup shown in the above chart snapshot is BTCUSD 15 min chart : Binance for reference. 
 Disclaimer 
No indicator guarantees profits. Backtest or paper trade this tool to understand its behavior in your market. Always use proper position sizing and stop loss orders.
Good luck!
- BullByte 
Candle % High/Low Bar + HL Order + MA by Barty&PitPapcioWhat does the indicator show? 
The "Candle % High/Low Bar + HL Order + MA by Barty&PitPapcio" indicator displays the percentage deviation of each candle’s high and low relative to its open price. The zero line represents the candle’s open — bars above zero show upward movement from the open (to high), bars below zero show downward movement (to low).
Additionally, the indicator plots a dot above or below each bar indicating which came first during the candle — the high or the low — based on data from a lower timeframe two steps below the current chart (for example, on a 1-hour chart it uses 15-minute data).
Finally, the indicator calculates and plots a user-selectable moving average (EMA, SMA, or WMA) of these "first high or low" signals, helping identify trends whether the first move is more often upwards or downwards.
 Where do the data come from? 
Percentage values are calculated directly from the current chart’s candles:
 
 highPerc=(High−Open)/Open×100%,
 lowPerc=(Low−Open)/Open×100%
 
The timing of the first high or low for each candle is retrieved from a lower timeframe, stepping down two levels from the current timeframe (e.g. from 1H to 15 min), providing better precision in detecting the order of highs and lows that may be blurred on higher timeframes.
 Additional features: 
 
     Full customization of colors for bars, dots, zero line, grid, and thicknesses.
     Background grid with adjustable scale and style.
     Safety checks for missing lower timeframe data.
     A moving average smoothing the sequence of first high/low signals to reveal directional tendencies.
 
 Suggested strategy for technical analysis support 
 
     Identify dominant candle direction: If the dot often appears above the bar (first high), it indicates buying pressure; if below (first low), selling pressure dominates.
     Use percentage deviations: Large percent bars indicate heightened volatility and potential reversal points.
     Moving average on order signals: The EMA of high/low first signals smooths the noise, showing the dominant trend in the sequence of price moves, useful for filtering other signals.
     Combine with other tools: This indicator can act as a directional filter on multiple timeframes, synergizing well with momentum indicators, RSI, or support/resistance levels to confirm move strength.
 
Lots of love, Bartosz
Why EMA Isn't What You Think It IsMany new traders adopt the Exponential Moving Average (EMA) believing it's simply a "better Simple Moving Average (SMA)". This common misconception leads to fundamental misunderstandings about how EMA works and when to use it.
EMA and SMA differ at their core. SMA use a window of finite number of data points, giving equal weight to each data point in the calculation period. This makes SMA a Finite Impulse Response (FIR) filter in signal processing terms. Remember that FIR means that "all that we need is the 'period' number of data points" to calculate the filter value. Anything beyond the given period is not relevant to FIR filters – much like how a security camera with 14-day storage automatically overwrites older footage, making last month's activity completely invisible regardless of how important it might have been.
EMA, however, is an Infinite Impulse Response (IIR) filter. It uses ALL historical data, with each past price having a diminishing - but never zero - influence on the calculated value. This creates an EMA response that extends infinitely into the past—not just for the last N periods. IIR filters cannot be precise if we give them only a 'period' number of data to work on - they will be off-target significantly due to lack of context, like trying to understand Game of Thrones by watching only the final season and wondering why everyone's so upset about that dragon lady going full pyromaniac.
If we only consider a number of data points equal to the EMA's period, we are capturing no more than  86.5%  of the total weight of the EMA calculation. Relying on he period window alone (the warm-up period) will provide only 1 - (1 / e^2) weights, which is approximately 1−0.1353 = 0.8647 = 86.5%. That's like claiming you've read a book when you've skipped the first few chapters – technically, you got most of it, but you probably miss some crucial early context.
▶️  What is period in EMA used for? 
What does a period parameter really mean for EMA? When we select a 15-period EMA, we're not selecting a window of 15 data points as with an SMA. Instead, we are using that number to calculate a decay factor (α) that determines how quickly older data loses influence in EMA result. Every trader knows EMA calculation: α = 1 / (1+period) – or at least every trader claims to know this while secretly checking the formula when they need it.
Thinking in terms of "period" seriously restricts EMA. The α parameter can be - should be! - any value between 0.0 and 1.0, offering infinite tuning possibilities of the indicator. When we limit ourselves to whole-number periods that we use in FIR indicators, we can only access a small subset of possible IIR calculations – it's like having access to the entire RGB color spectrum with 16.7 million possible colors but stubbornly sticking to the 8 basic crayons in a child's first art set because the coloring book only mentioned those by name.
For example:
 
  Period 10 → alpha = 0.1818
  Period 11 → alpha = 0.1667
 
What about wanting an alpha of 0.17, which might yield superior returns in your strategy that uses EMA? No whole-number period can provide this! Direct α parameterization offers more precision, much like how an analog tuner lets you find the perfect radio frequency while digital presets force you to choose only from predetermined stations, potentially missing the clearest signal sitting right between channels.
 Sidenote: the choice of α = 1 / (1+period) is just a convention from 1970s, probably started by J. Welles Wilder, who popularized the use of the 14-day EMA. It was designed to create an approximate equivalence between EMA and SMA over the same number of periods, even thought SMA needs a period window (as it is FIR filter) and EMA doesn't. In reality, the decay factor α in EMA should be allowed any valye between 0.0 and 1.0, not just some discrete values derived from an integer-based period! Algorithmic systems should find the best α decay for EMA directly, allowing the system to fine-tune at will and not through conversion of integer period to float α decay – though this might put a few traditionalist traders into early retirement. Well, to prevent that, most traditionalist implementations of EMA only use period and no alpha at all. Heaven forbid we disturb people who print their charts on paper, draw trendlines with rulers, and insist the market "feels different" since computers do algotrading! 
▶️  Calculating EMAs Efficiently 
The standard textbook formula for EMA is:
 
EMA = CurrentPrice × alpha + PreviousEMA × (1 - alpha)
 
But did you know that a more efficient version exists, once you apply a tiny bit of high school algebra:
 
EMA = alpha × (CurrentPrice - PreviousEMA) + PreviousEMA
 
The first one requires three operations: 2 multiplications + 1 addition. The second one also requires three ops: 1 multiplication + 1 addition + 1 subtraction.
That's pathetic, you say? Not worth implementing? In most computational models, multiplications cost much more than additions/subtractions – much like how ordering dessert costs more than asking for a water refill at restaurants.
 Relative CPU cost of float operations :
 
  Addition/Subtraction: ~1 cycle
  Multiplication: ~5 cycles (depending on precision and architecture)
 
Now you see the difference? 2 * 5 + 1 = 11 against 5 + 1 + 1 = 7. That is ≈ 36.36% efficiency gain just by swapping formulas around! And making your high school math teacher proud enough to finally put your test on the refrigerator.
▶️  The Warmup Problem: how to start the EMA sequence right 
How do we calculate the first EMA value when there's no previous EMA available? Let's see some possible options used throughout the history:
 
   Start with zero : EMA(0) = 0. This creates stupidly large distortion until enough bars pass for the horrible effect to diminish – like starting a trading account with zero balance but backdating a year of missed trades, then watching your balance struggle to climb out of a phantom debt for months.
   Start with first price : EMA(0) = first price. This is better than starting with zero, but still causes initial distortion that will be extra-bad if the first price is an outlier – like forming your entire opinion of a stock based solely on its IPO day price, then wondering why your model is tanking for weeks afterward.
   Use SMA for warmup : This is the tradition from the pencil-and-paper era of technical analysis – when calculators were luxury items and "algorithmic trading" meant your broker had neat handwriting. We first calculate an SMA over the initial period, then kickstart the EMA with this average value. It's widely used due to tradition, not merit, creating a mathematical Frankenstein that uses an FIR filter (SMA) during the initial period before abruptly switching to an IIR filter (EMA). This methodology is so aesthetically offensive (abrupt kink on the transition from SMA to EMA) that charting platforms hide these early values entirely, pretending EMA simply doesn't exist until the warmup period passes – the technical analysis equivalent of sweeping dust under the rug.
   Use WMA for warmup : This one was never popular because it is harder to calculate with a pencil - compared to using simple SMA for warmup. Weighted Moving Average provides a much better approximation of a starting value as its linear descending profile is much closer to the EMA's decay profile.
 
These methods all share one problem: they produce inaccurate initial values that traders often hide or discard, much like how hedge funds conveniently report awesome performance "since strategy inception" only after their disastrous first quarter has been surgically removed from the track record.
▶️  A Better Way to start EMA: Decaying compensation 
Think of it this way: An ideal EMA uses an infinite history of prices, but we only have data starting from a specific point. This creates a problem - our EMA starts with an incorrect assumption that all previous prices were all zero, all close, or all average – like trying to write someone's biography but only having information about their life since last Tuesday.
But there is a better way. It requires more than high school math comprehension and is more computationally intensive, but is mathematically correct and numerically stable. This approach involves compensating calculated EMA values for the "phantom data" that would have existed before our first price point.
Here's how phantom data compensation works:
 
  We start our normal EMA calculation:
 
EMA_today = EMA_yesterday + α × (Price_today - EMA_yesterday)
 
  But we add a correction factor that adjusts for the missing history:
 
Correction = 1 at the start
Correction = Correction × (1-α) after each calculation
 
  We then apply this correction:
 
True_EMA = Raw_EMA / (1-Correction)
 
 
This correction factor starts at 1 (full compensation effect) and gets exponentially smaller with each new price bar. After enough data points, the correction becomes so small (i.e., below 0.0000000001) that we can stop applying it as it is no longer relevant.
Let's see how this works in practice:
 
  For the first price bar:
Raw_EMA = 0
Correction = 1
True_EMA = Price (since 0 ÷ (1-1) is undefined, we use the first price)
  For the second price bar:
Raw_EMA = α × (Price_2 - 0) + 0 = α × Price_2
Correction = 1 × (1-α) = (1-α)
True_EMA = α × Price_2 ÷ (1-(1-α)) = Price_2
  For the third price bar:
Raw_EMA updates using the standard formula
Correction = (1-α) × (1-α) = (1-α)²
True_EMA = Raw_EMA ÷ (1-(1-α)²)
 
With each new price, the correction factor shrinks exponentially. After about -log₁₀(1e-10)/log₁₀(1-α) bars, the correction becomes negligible, and our EMA calculation matches what we would get if we had infinite historical data.
This approach provides accurate EMA values from the very first calculation. There's no need to use SMA for warmup or discard early values before output converges - EMA is mathematically correct from first value, ready to party without the awkward warmup phase.
Here is Pine Script 6 implementation of EMA that can take alpha parameter directly (or period if desired), returns valid values from the start, is resilient to dirty input values, uses decaying compensator instead of SMA, and uses the least amount of computational cycles possible.
 
// Enhanced EMA function with proper initialization and efficient calculation
ema(series float source, simple int period=0, simple float alpha=0)=>
// Input validation - one of alpha or period must be provided
if alpha<=0 and period<=0
runtime.error("Alpha or period must be provided")
// Calculate alpha from period if alpha not directly specified
float a = alpha > 0 ? alpha : 2.0 / math.max(period, 1)
// Initialize variables for EMA calculation
var float ema = na      // Stores raw EMA value
var float result = na   // Stores final corrected EMA
var float e = 1.0       // Decay compensation factor
var bool warmup = true  // Flag for warmup phase
if not na(source)
    if na(ema)
        // First value case - initialize EMA to zero
        // (we'll correct this immediately with the compensation)
        ema := 0
        result := source
    else
        // Standard EMA calculation (optimized formula)
        ema := a * (source - ema) + ema
        
        if warmup
            // During warmup phase, apply decay compensation
            e *= (1-a)                  // Update decay factor
            float c = 1.0 / (1.0 - e)   // Calculate correction multiplier
            result := c * ema           // Apply correction
            
            // Stop warmup phase when correction becomes negligible
            if e <= 1e-10
                warmup := false
        else
            // After warmup, EMA operates without correction
            result := ema
result  // Return the properly compensated EMA value
 
▶️  CONCLUSION 
EMA isn't just a "better SMA"—it is a fundamentally different tool, like how a submarine differs from a sailboat – both float, but the similarities end there. EMA responds to inputs differently, weighs historical data differently, and requires different initialization techniques.
By understanding these differences, traders can make more informed decisions about when and how to use EMA in trading strategies. And as EMA is embedded in so many other complex and compound indicators and strategies, if system uses tainted and inferior EMA calculatiomn, it is doing a disservice to all derivative indicators too – like building a skyscraper on a foundation of Jell-O.
The next time you add an EMA to your chart, remember: you're not just looking at a "faster moving average." You're using an INFINITE IMPULSE RESPONSE filter that carries the echo of all previous price actions, properly weighted to help make better trading decisions.
EMA done right might significantly improve the quality of all signals, strategies, and trades that rely on EMA somewhere deep in its algorithmic bowels – proving once again that math skills are indeed useful after high school, no matter what your guidance counselor told you.






















