Dynamic Portfolio TrackerDynamic Portfolio Tracker 
The Dynamic Portfolio Tracker is a visual tool for actively managing and monitoring a multi-asset portfolio directly on TradingView. It allows users to input up to 15 custom assets (with a default setup for 5), define how much of each asset they hold, and assign a target allocation percentage to each. The script then calculates live market prices, total portfolio value, current vs. target weightings, and provides clear, color-coded instructions on whether to buy, sell, or hold each asset. It displays all this data in an on-chart table, showing both the dollar amount and the quantity to adjust for each asset, helping users keep their portfolio aligned with their strategy in real time.
 How to Use the Inputs (What Each Field Means) 
1. Portfolio Assets (Tickers)
Fields: Asset 1 Ticker, Asset 2 Ticker, …, Asset 15 Ticker
What it does: Lets you select which assets (crypto, stocks, etc.) you want to track. These are live symbols pulled from TradingView.
2. Asset Quantities
Fields: Asset 1 Amount, Asset 2 Amount, …, Asset 15 Amount
What it means: How much of each asset you currently hold. For example:
	•	0.03 BTC
	•	2.1 ETH
Why it’s needed: The script multiplies this by the live price to calculate the current dollar value of each asset in your portfolio.
3. Target %
Fields: Asset 1 Implied %, Asset 2 Implied %, …, Asset 15 Implied %
What it means: Your desired allocation for each asset. For example:
	•	40% BTC
	•	20% ETH
	•	10% SOL, etc.
Important: These must total 100% or less across all assets. The script checks this and shows an error if the total exceeds 100%.
 The Dynamic Portfolio Tracker displays two powerful on-chart tables: 
1. Main Table — Per Asset Breakdown
This table shows detailed, real-time information for each asset in your portfolio. Each row represents a different asset, and each column has a specific meaning:
Column	What It Means
Asset = The symbol of the asset (e.g., BTCUSD, ETHUSD), auto-stripped from the exchange name.
Price = The current market price of the asset, pulled live from TradingView.
Quantity = How much of that asset you currently hold, entered manually in the inputs.
Target % = The percentage of your total portfolio you want this asset to represent.
Actual %	= What percentage of your portfolio it currently makes up (based on price × quantity).
Target Value = How much (in $) this asset should be worth in your portfolio.
Actual Value = How much (in $) this asset is currently worth.
Instruction = Whether to Buy, Sell, or Hold to match your target allocation.
Value Change = The dollar amount you’d need to buy/sell to rebalance this asset.
Units to Trade = The number of asset units to buy/sell to reach the target value.
2. Portfolio Summary Table — Portfolio Totals
This smaller table appears in the top-right corner and summarizes your entire portfolio at a glance:
Target %	= Total of all your assigned target allocations (should equal 100%).
Actual %	= Actual portfolio composition (always 100% unless your capital is zero).
Target Value = Total value your portfolio should be based on your target percentages.
Actual Value = Current live total value of your portfolio.
If there’s a discrepancy between Target Value and Actual Value, the difference is shown in each row of the main table, so you can adjust individual assets accordingly.
 Privacy First: Hide Sensitive Financial Data 
A unique feature of this tool is the ability to hide sensitive financial data, such as:
	•	Target Value
	•	Actual Value
	•	Total Portfolio Value
You can turn these off using toggle settings, and they’ll be replaced with a crossed-out eye icon (👁️🗨️) — just like on modern crypto exchanges. This feature makes the script safe for streaming, screenshots, or sharing publicly while protecting your privacy.
But more importantly:
Feelings are the enemy of good investing.
Seeing the value of your portfolio fluctuate can trigger fear or greed. By hiding your dollar values, you’re not just securing your data — you’re reducing the temptation to react emotionally.
It’s just numbers. Systems over Feelings.
 Table Automatically Adapts to Your Asset Count 
The Dynamic Portfolio Tracker is designed to scale with your portfolio. Simply choose how many assets you want to track (up to 15), and the table will automatically resize to fit exactly that number — no wasted space or empty rows.
	•	Select 1 to 15 assets using the “Number of Assets” input
	•	The table expands or contracts dynamically to show only those rows
	•	All calculations, summaries, and layout elements adjust accordingly in real time
This keeps the interface clean, focused, and perfectly tailored to your setup — whether you’re tracking 3 coins or managing a full portfolio of 12+ tokens.
 Customize Your Table to Match Your Style 
The Dynamic Portfolio Tracker offers a full suite of visual customization options, allowing you to tailor the table to your charting style or stream layout. You can:
	•	Choose text colors for labels, values, and headers
	•	Set background colors for the full table and header row — or turn them off completely for a clean, transparent look
	•	Control border and frame settings, including color, thickness, or disabling them entirely
	•	Pick custom colors for Buy and Sell signals in the rebalance column
	•	Adjust table font size from tiny to large to match your resolution or preferences
 Special Thanks 
This tool wouldn’t exist without the knowledge and inspiration gained through The Real World. A sincere thank you to the Investing Master, the Guides, and Professor Adam — your frameworks and lessons brought clarity, discipline, and structure to this build.
And of course, glory to L4 — where real men are made.
스크립트에서 "Table"에 대해 찾기
Fund Master Plus (TV Rev1, Dec2024)License: Mozilla Public License 2.0 (Open Source)
Version: Pine Script™ v6
Indicator Name: Fund Master Plus (TV Rev1, Dec2024)
Short Title: Fund Master Plus
 About Fund Master Plus 
Fund Master Plus indicator is an oscillating technical analysis tool designed to simulate the fund inflow and outflow trend. 
 Key features: 
1. Fund Master Value and Candle
    The candle highlights the direction of the Fund Master value. 
    Green candles represent an upward trend, while red candles indicate a downward trend.
    When the candle crossover 0, it is a sign of the start of mid term bull, vice versa.
    When the candle is above 0, it is a sign of mid-term bull, vice versa. 
2. Fund Master Bar
    This bar provides added visual representation of the Fund Master value. 
    Green bars represent and upward trend, while red bars indicate a downward trend. 
3. FM EMA (Exponential Moving Average)
    The Fund Master EMA (Exponential Moving Average) helps smooth out FM value fluctuations 
     and identify the overall trend.
     When the candle crossover FM EMA, it is a sign of the start of short term bull, vice vera.
     When the candle is above FM EMA, it is a sign of short term bull, vice versa. 
    
4.  EMA of FM EMA
     This is an EMA of the Fund Master EMA, which can provide additional insights into the 
     trend's strength.
5. Candle Turn Green or Red 
    This feature generates alerts to signal potential trend changes.
6. Bottom Deviation & Top Deviation
   Line plot and label of these deviation will show on indicator and the price chart to help user
   identify potential buying and selling opportunities.
7. Alertcondition for Turn Green or Turn Red
    User can set the alert using the Create Alert (the Clock Icon).
8. Table Summary
     A table summary is provided to show indicator name, FM value, FM candle status, 
     Crossover, Crossunder, Turn Green, Turn Red status, Bar Number etc. 
     A tooltip for Filter Setting and a filter status check. 
 
 SOP to use the indicator: 
Table (GR1):
Show Table: This option enables or disables the display of the table.
Text Size: This option allows you to set the text size for the table entries.
Width: This option sets the width of the table.
Fund Master Candle Color Setting (GR2):
FM candle will up by default.
This option enables the color setting of Fund Master candle.
Up: This option sets the color of the Fund Master candle for uptrend.
Down: This option sets the color of the Fund Master candle for downtrend.
Fund Master Bar and Color Setting (GR3):
Show Fund Master Bar: This option enables or disables the display of the Fund Master bar.
Up: This option sets the color of the Fund Master bar for uptrend.
Down: This option sets the color of the Fund Master bar for downtrend.
Fund Master EMA plots (GR4):
Show FM EMA: This option enables or disables the display of the Fund Master EMA line.
Look Back Period: This option sets the lookback period for the Fund Master EMA calculation.
EMA Color: This option sets the color of the Fund Master EMA line.
Show EMA of FM EMA: This option enables or disables the display of the EMA of the Fund Master EMA line.
Look Back Period 2: This option sets the lookback period for the EMA of the Fund Master EMA calculation.
Alerts: Fund Master Crossover & Crossunder EMA Line or 0 (GR5):
Show FM Crossover 0: This option enables or disables the display of the alert for FM crossover above the 0 line.
Show FM Crossunder 0: This option enables or disables the display of the alert for FM crossover below the 0 line.
Show FM Crossover EMA: This option enables or disables the display of the alert for FM crossover above the EMA line.
Show FM Crossunder EMA: This option enables or disables the display of the alert for FM crossover below the EMA line.
Bottom and Top Deviation (GR6):
Show Bottom Deviation: This option enables or disables the display of the bottom deviation line.
Show Top Deviation: This option enables or disables the display of the top deviation line.
Turn Green, Turn Red Alert (GR7):
Show Turn Green/Red Alerts: This option enables or disables the display of alerts for when the Fund Master value changes direction.
Current & Turn Green/Red Alerts: This option sets the number of bars to look back for the turn green/red alerts.
Band and User Input Setting (GR8):
100: This option enables or disables the display of the 100 band.
0: This option enables or disables the display of the 0 band.
-100: This option enables or disables the display of the -100 band.
User Input: This option enables or disables the display of a custom band based on user input.
Value: This option sets the value for the custom band.
 Disclaimer 
Attached chart is for the purpose of illustrating the use of indicator, no recommendation of buy/sell.
In this chart, all features in the setting are turned on (default and non default). 
This chart is used to demonstrate the FM trend movement from mid-term bear to mid-term bull, 
short-term bear and bull, bottom deviation and top deviation. 
Hope this help. Merry Christmas and Happy New Year. 
Scoopy StacksWaffle Around Multiple 
(Open, High, Low, Close) Stacks On 
Pre/Post Market & (Daily, Weekly, 
Monthly, Yearly) Sessions With 
Meticulous Columns, Rows, Tooltips, 
Colors, Custom Ideas, and Alerts.
Sessions Use Two Step Incremental Values 
Default Value: (1) Shows Two Previous 
(O, H, L, C); Increasing Value Swaps 
Sessions With Next Two Stacks.
⬛️  KEY WORDS: 
🟢 Crossover | 🔴 Crossunder 
📗 High | 📕 Low 
📔 Open | 📓 Close 
🥇 First Idea | 🥈 Second Idea 
🥉 Third Idea | 🎖️ Fourth Idea
🟥  ALERTS: 
Default Option: (Per Bar) 
Alerts Once Conditions Are Met 
(Bar Close) Alerts When Bar Closes
Default Option: (Reg) 
Alerts During Regular Market 
Trading Hours, (0930-1600) 
(Ext) Alerts During Extended 
Market Hours, (1600-0930) 
(24/7) Alerts All Day
Optional Preferences: 
Regular Alerts - Stocks 
Extended Alerts - Futures 
24/7 Alerts - Crypto
🟧  STACKS:  
Default Value: (1) 
Incremental Stack Value, Increasing Value 
Swaps Sessions With the Next Two Stacks
(✓) Swap Stacks? 
Pre/Post Market High/Lows, 
1-2 Day High/Lows, 1-2 Week High/Lows, 
1-2 Month High/Lows, 1-2 Year High/Lows
  
(   ) Swap Stacks? 
Pre/Post Market Open/Close, 
1-2 Day Open/Close, 1-2 Week Open/Close, 
1-2 Month Open/Close, 1-2 Year Open/Close
  
🟨  EXAMPLES: 
Default Stack: 
🟢 | 📗 Pre Market High (PRE) | 4600.00 
🔴 | 📕 Post Market Low (POST) | 420.00 
Optional: (Open) 
🟢 | 📔 Post Market Open (POST) | 4400.00 
Optional: (Close) 
🔴 | 📓 Pre Market Close (PRE) | 430.00
  
  
Default Stack Value: (1) 
🔴 | 📗 1 Day High (1DH) | 460.00 
Next Stack Value: (3) 
🟢 | 📕 4 Day Low (4DL) | 420.00 
Optional: (Open) 
🔴 | 📔 2 Day Open (2DO) | 440.00 
Optional: (Close) 
🟢 | 📓 3 Day Close (3DC) | 430.00
  
  
Default Stack Value: (5) 
🟢 | 📗 5 Week High (5WH) | 460.00 
Next Stack Value: (7) 
🔴 | 📕 8 Week Low (8WL) | 420.00 
Optional: (Open) 
🔴 | 📔 7 Week Open (7WO) | 4400.00 
Optional: (Close) 
🟢 | 📓 6 Week Close (6WC) | 430.00
  
  
Default Stack Value: (9) 
🔴 | 📗 9 Month High (9MH) | 460.00 
Next Stack Value: (11) 
🟢 | 📕 12 Month Low (12ML) | 420.00 
Optional: (Open) 
🟢 | 📔 11 Month Open (11MO) | 4400.00 
Optional: (Close) 
🔴 | 📓 10 Month Close (10MC) | 430.00
  
  
Default Stack Value: (13) 
🟢 | 📗 13 Year High (13YH) | 460.00 
Next Stack Value: (15) 
🟢 | 📕 16 Year Low (16YL) | 420.00 
Optional: (Open) 
🔴 | 📔 15 Year Open (15YO) | 4400.00 
Optional: (Close) 
🔴 | 📓 14 Year Close (14YC) | 430.00
  
  
🟩  TABLES:  
Default Value: (1) 
Moves Table Up, Down, Left, or Right 
Based on Second Default Value
First Default Value: (Top Right) 
Sets Table Placement, Middle Center 
Allows Table To Move In All Directions
  
Second Default Value: (Default) 
Fixed Table Position, Switching Values 
Moves Direction of the Table
  
🟦  IDEAS: 
(✓) Show Ideas? 
Shows Four Ideas With Custom Texts 
and Values; Ideas Are Based Around 
Post-It Note Reminders with Alerts
Suggestions For Text Ideas: 
Take Profit, Stop Loss, Trim, Hold, 
Long, Short, Bounce Spot, Retest, 
Chop, Support, Resistance, Buy, Sell
🟪  EXAMPLES: 
Default Value: (5) 
Shows the Custom Table Value For 
Sorted Table Positions and Alerts
Default Text: (🥇) 
Shown On First Table Cell and 
Message Appearing On Alerts 
Alert Shows: 🟢 | 🥇 | 5.00
  
  
Default Value: (10) 
Shows the Custom Table Value For 
Sorted Table Positions and Alerts
Default Text: (🥈) 
Shown On Second Table Cell and 
Message Appearing On Alerts
Alert Shows: 🔴 | 🥈 | 10.00
  
  
Default Value: (50) 
Shows the Custom Table Value For 
Sorted Table Positions and Alerts
Default Text: (🥉) 
Shown On Third Table Cell and 
Message Appearing On Alerts 
Alert Shows: 🟢 | 🥉 | 50.00
  
  
Default Value: (100) 
Shows the Custom Table Value For 
Sorted Table Positions and Alerts
Default Text: (🎖️) 
Shown On Fourth Table Cell and 
Message Appearing On Alerts 
Alert Shows: 🔴 | 🎖️ | 100.00
  
  
⬛️  REFERENCES: 
Pre-market Highs & Lows on regular 
trading hours (RTH) chart 
By Twingall
Previous Day Week Highs & Lows 
By Sbtnc
Screener for 40+ instruments 
By QuantNomad
Daily Weekly Monthly Yearly Opens 
By Meliksah55
Stock Profit Calculator — Live Mode
## Overview
This Pine Script indicator calculates, in real time, the financial impact of a stock trade, including purchase/sale commissions, capital gains tax (CGT), and return on investment (ROI). It displays a compact table with key values and also calculates the breakeven price to see at what level the net P/L returns to zero.
---
## Inputs and customization
- **Number of shares:** `shares` defines the purchased quantity.
- **Purchase price:** `buyPrice` is the unit cost; the total purchase is calculated from this.
- **Live selling price:** `sellPrice = close` uses the last bar’s price for live valuation.
- **Fixed or percentage commissions:** `useFixedComm` selects the model.
  - **Fixed:** `buyCommFixed`, `sellCommFixed`.
  - **Percentage:** `buyCommPct`, `sellCommPct` (applied to notional value).
- **CGT rate:** `cgtRate` is the percentage rate, applied only in case of profit.
- **Table position:** `tablePosition` with predefined options.
- **Visual style:** `colTxt`, `colPos`, `colNeg`, `colBg`, `colHdr`, `colFrame` for text color, positive/negative P/L, background, header, and borders.
> Tip: if your broker uses minimum fees or composite fees, turn on “Use fixed commissions?” and enter the two fixed fees; otherwise, use the percentage model.
---
## Calculation logic
#### Purchase costs
- **Total purchase:**
  \ 
- **Purchase commission:**
  \ 
- **Net entry cost:**
  \ 
#### Sale revenues
- **Total sale (with live price):**
  \ 
- **Sale commission:**
  \ 
- **Net exit revenue:**
  \ 
#### P/L and taxes
- **Gross P/L:**
  \ 
- **CGT (only on positive P/L):**
  \ 
- **Net P/L:**
  \ 
#### ROI
- **Percentage ROI on invested capital:**
  \ 
#### Breakeven
- **Gross breakeven** shown in the table: the unit price that makes the net P/L exactly zero, including purchase cost and an estimate of the sale commission.
  \ 
  In the script, if commissions are fixed it adds the fixed sale fee; if percentage-based, the sale component is not included in this row (conservative approximation).
- **Breakeven with tax** (calculated but not shown):
  \ 
  Useful when you want the post-CGT result to be exactly zero. Not displayed in the table but ready for use.
> Note: CGT applies only on positive profits; near breakeven, the tax effect is null or only kicks in beyond a threshold. That’s why the script distinguishes between the “gross” and “with tax” versions.
---
## On-screen table
- **Displayed rows:**
  - **Purchase:** total net entry cost (with commissions).
  - **Sale:** total net exit revenue (with commissions).
  - **Gross P/L:** difference between netSell and netBuy.
  - **CGT:** estimated tax only if there’s a gain.
  - **Net P/L:** P/L after taxes.
  - **ROI (%):** percentage return on netBuy.
  - **Breakeven:** gross unit breakeven price.
- **Conditional colors:**
  - **P/L and ROI:** green for ≥ 0, red for < 0.
  - **Headers and cells:** customizable via the color inputs.
- **Efficient refresh:** the table updates only on the last bar via `barstate.islast` to avoid unnecessary redraws.
---
## Behavior and performance
- **Overlay:** displayed on the price chart.
- **Persistent variable:** table is created once with `var table`.
- **Live price:** `sellPrice` follows the current `close`, making P/L, ROI, and breakeven dynamic.
---
## Limitations and suggestions
- **Commission model:** when using percentage commissions, the breakeven in the table doesn’t add the sale percentage fee in the “breakevenPrice” formula. For more precision, you could solve the equation including the percentage fee on exit.
- **Breakeven with tax:** `breakevenWithTax` is a linear estimate; near zero profit, tax may be null. You might choose to display it instead of, or alongside, the gross breakeven.
- **Precision and formatting:** values are shown with `format.mintick`. If the symbol has very small ticks, consider a custom format for better readability.
- **Edge cases:** ROI is undefined if `netBuy = 0` (unlikely in practice but good to note).
> Pro tip: if you want to show the breakeven with tax, add a “Breakeven (post-CGT)” row printing `breakevenWithTax`. If you prefer a single row, replace the shown value with the post-CGT one.
---
Smart MTF S/R Levels[BullByte]
 Smart MTF S/R Levels   
 Introduction & Motivation   
Support and Resistance (S/R) levels are the backbone of technical analysis. However, most traders face two major challenges:  
 Manual S/R Marking:  Drawing S/R levels by hand is time-consuming, subjective, and often inconsistent.  
 Multi-Timeframe Blind Spots:  Key S/R levels from higher or lower timeframes are often missed, leading to surprise reversals or missed opportunities.  
 Smart MTF S/R Levels  was created to solve these problems. It is a fully automated, multi-timeframe, multi-method S/R detection and visualization tool, designed to give traders a complete, objective, and actionable view of the market’s most important price zones.  
 What Makes This Indicator Unique?   
 Multi-Timeframe Analysis:  Simultaneously analyzes up to three user-selected timeframes, ensuring you never miss a critical S/R level from any timeframe.  
 Multi-Method Confluence:  Integrates several respected S/R detection methods—Swings, Pivots, Fibonacci, Order Blocks, and Volume Profile—into a single, unified system.  
 Zone Clustering:  Automatically merges nearby levels into “zones” to reduce clutter and highlight areas of true market consensus.  
 Confluence Scoring:  Each zone is scored by the number of methods and timeframes in agreement, helping you instantly spot the most significant S/R areas.  
 Reaction Counting:  Tracks how many times price has recently interacted with each zone, providing a real-world measure of its importance.  
 Customizable Dashboard:  A real-time, on-chart table summarizes all key S/R zones, their origins, confluence, and proximity to price.  
 Smart Alerts:  Get notified when price approaches high-confluence zones, so you never miss a critical trading opportunity.  
 Why Should a Trader Use This?   
 Objectivity:  Removes subjectivity from S/R analysis by using algorithmic detection and clustering.  
 Efficiency:  Saves hours of manual charting and reduces analysis fatigue.  
 Comprehensiveness:  Ensures you are always aware of the most relevant S/R zones, regardless of your trading timeframe.  
 Actionability:  The dashboard and alerts make it easy to act on the most important levels, improving trade timing and risk management.  
 Adaptability:  Works for all asset classes (stocks, forex, crypto, futures) and all trading styles (scalping, swing, position).  
 The Gap This Indicator Fills   
Most S/R indicators focus on a single method or timeframe, leading to incomplete analysis. Manual S/R marking is error-prone and inconsistent. This indicator fills the gap by:  
 Automating S/R detection  across multiple timeframes and methods  
 Objectively scoring and ranking zones  by confluence and reaction  
 Presenting all this information  in a clear, actionable dashboard  
 How Does It Work? (Technical Logic)   
 1. Level Detection   
For each selected timeframe, the script detects S/R levels using:  
 SW (Swing High/Low):  Recent price pivots where reversals occurred.  
 Pivot:  Classic floor trader pivots (P, S1, R1).  
 Fib (Fibonacci):  Key retracement levels (0.236, 0.382, 0.5, 0.618, 0.786) over the last 50 bars.  
 Bull OB / Bear OB:  Institutional price zones based on bullish/bearish engulfing patterns.  
 VWAP / POC:  Volume Weighted Average Price and Point of Control over the last 50 bars.  
 2. Level Clustering   
Levels within a user-defined % distance are merged into a single “zone.”  
Each zone records which methods and timeframes contributed to it.  
 3. Confluence & Reaction Scoring   
 Confluence:  The number of unique methods/timeframes in agreement for a zone.  
 Reactions:  The number of times price has touched or reversed at the zone in the recent past (user-defined lookback).  
 4. Filtering & Sorting   
Only zones within a user-defined % of the current price are shown (to focus on actionable areas).  
Zones can be sorted by confluence, reaction count, or proximity to price.  
 5. Visualization   
 Zones:  Shaded boxes on the chart (green for support, red for resistance, blue for mixed).  
 Lines:  Mark the exact level of each zone.  
 Labels:  Show level, methods by timeframe (e.g., 15m (3 SW), 30m (1 VWAP)), and (if applicable) Fibonacci ratios.  
 Dashboard Table:  Lists all nearby zones with full details.  
 6. Alerts   
Optional alerts trigger when price approaches a zone with confluence above a user-set threshold.  
 Inputs & Customization (Explained for All Users)   
 Show Timeframe 1/2/3:  Enable/disable analysis for each timeframe (e.g., 15m, 30m, 1h).  
 Show Swings/Pivots/Fibonacci/Order Blocks/Volume Profile:  Select which S/R methods to include.  
 Show levels within X% of price:  Only display zones near the current price (default: 3%).  
 How many swing highs/lows to show:  Number of recent swings to include (default: 3).  
 Cluster levels within X%:  Merge levels close together into a single zone (default: 0.25%).  
 Show Top N Zones:  Limit the number of zones displayed (default: 8).  
 Bars to check for reactions:  How far back to count price reactions (default: 100).  
 Sort Zones By:  Choose how to rank zones in the dashboard (Confluence, Reactions, Distance).  
 Alert if Confluence >=:  Set the minimum confluence score for alerts (default: 3).  
 Zone Box Width/Line Length/Label Offset:  Control the appearance of zones and labels.  
 Dashboard Size/Location:  Customize the dashboard table.  
 How to Read the Output   
 Shaded Boxes:  Represent S/R zones. The color indicates type (green = support, red = resistance, blue = mixed).  
 Lines:  Mark the precise level of each zone.  
 Labels:  Show the level, methods by timeframe (e.g., 15m (3 SW), 30m (1 VWAP)), and (if applicable) Fibonacci ratios.  
 Dashboard Table:  Columns include:  
 Level:  Price of the zone  
 Methods (by TF):  Which S/R methods and how many, per timeframe (see abbreviation key below)  
 Type:  Support, Resistance, or Mixed  
 Confl.:  Confluence score (higher = more significant)  
 React.:  Number of recent price reactions  
 Dist %:  Distance from current price (in %)  
 Abbreviations Used   
 SW =  Swing High/Low (recent price pivots where reversals occurred)  
 Fib =  Fibonacci Level (key retracement levels such as 0.236, 0.382, 0.5, 0.618, 0.786)  
 VWAP =  Volume Weighted Average Price (price level weighted by volume)  
 POC =  Point of Control (price level with the highest traded volume)  
 Bull OB =  Bullish Order Block (institutional support zone from bullish price action)  
 Bear OB =  Bearish Order Block (institutional resistance zone from bearish price action)  
 Pivot =  Pivot Point (classic floor trader pivots: P, S1, R1)  
These abbreviations appear in the dashboard and chart labels for clarity.  
 Example: How to Read the Dashboard and Labels (from the chart above)   
Suppose you are trading BTCUSDT on a 15-minute chart. The dashboard at the top right shows several S/R zones, each with a breakdown of which timeframes and methods contributed to their detection:  
  
 Resistance zone at 119257.11:   
The dashboard shows:  
5m (1 SW), 15m (2 SW), 1h (3 SW)  
This means the level 119257.11 was identified as a resistance zone by one swing high (SW) on the 5-minute timeframe, two swing highs on the 15-minute timeframe, and three swing highs on the 1-hour timeframe. The confluence score is 6 (total number of method/timeframe hits), and there has been 1 recent price reaction at this level. This suggests 119257.11 is a strong resistance zone, confirmed by multiple swing highs across all selected timeframes.  
 Mixed zone at 118767.97:   
The dashboard shows:  
5m (2 SW), 15m (2 SW)  
This means the level 118767.97 was identified by two swing points on both the 5-minute and 15-minute timeframes. The confluence score is 4, and there have been 19 recent price reactions at this level, indicating it is a highly reactive zone.  
 Support zone at 117411.35:   
The dashboard shows:  
5m (2 SW), 1h (2 SW)  
This means the level 117411.35 was identified as a support zone by two swing lows on the 5-minute timeframe and two swing lows on the 1-hour timeframe. The confluence score is 4, and there have been 2 recent price reactions at this level.  
 Mixed zone at 118291.45:   
The dashboard shows:  
15m (1 SW, 1 VWAP), 5m (1 VWAP), 1h (1 VWAP)  
This means the level 118291.45 was identified by a swing and VWAP on the 15-minute timeframe, and by VWAP on both the 5-minute and 1-hour timeframes. The confluence score is 4, and there have been 12 recent price reactions at this level.  
 Support zone at 117103.10:   
The dashboard shows:  
15m (1 SW), 1h (1 SW)  
This means the level 117103.10 was identified by a single swing low on both the 15-minute and 1-hour timeframes. The confluence score is 2, and there have been no recent price reactions at this level.  
 Resistance zone at 117899.33:   
The dashboard shows:  
5m (1 SW)  
This means the level 117899.33 was identified by a single swing high on the 5-minute timeframe. The confluence score is 1, and there have been no recent price reactions at this level.  
 How to use this:   
Zones with higher confluence (more methods and timeframes in agreement) and more recent reactions are generally more significant. For example, the resistance at 119257.11 is much stronger than the resistance at 117899.33, and the mixed zone at 118767.97 has shown the most recent price reactions, making it a key area to watch for potential reversals or breakouts.  
 Tip:   
“SW” stands for Swing High/Low, and “VWAP” stands for Volume Weighted Average Price.  
The format 15m (2 SW) means two swing points were detected on the 15-minute timeframe.  
 Best Practices & Recommendations   
 Use with Other Tools:  This indicator is most powerful when combined with your own price action analysis and risk management.  
 Adjust Settings:  Experiment with timeframes, clustering, and methods to suit your trading style and the asset’s volatility.  
 Watch for High Confluence:  Zones with higher confluence and more reactions are generally more significant.  
 Limitations   
 No Future Prediction:  The indicator does not predict future price movement; it highlights areas where price is statistically more likely to react.  
 Not a Standalone System:  Should be used as part of a broader trading plan.  
 Historical Data:  Reaction counts are based on historical price action and may not always repeat.  
 Disclaimer   
This indicator is a technical analysis tool and does not constitute financial advice or a recommendation to buy or sell any asset. Trading involves risk, and past performance is not indicative of future results. Always use proper risk management and consult a financial advisor if needed.  
NQ Position Size CalculatorNQ Position Size Line Calculator is designed specifically for Nasdaq 100 futures (NQ) and micro futures (MNQ) traders who want to maintain disciplined risk management. This visual tool eliminates the guesswork from position sizing by displaying distance lines and contract calculations directly on your chart.
The indicator creates horizontal lines at 10-tick intervals from your stop loss level, showing you exactly how many contracts to trade at each distance to maintain your predetermined risk amount. Whether you're trading regular NQ contracts or micro MNQ contracts, this calculator ensures you never risk more than intended while providing instant visual feedback for optimal position sizing decisions.
 How to Use the Indicator 
Step 1: Configure Your Settings
 
 Stop Loss Price: Enter your exact stop loss level (e.g., 20000.00)
 Risk Amount ($): Set your maximum dollar risk per trade (e.g., $500)
 
Contract Type: Choose between:
 
 NQ (Regular): $5 per tick - for larger accounts
 MNQ (Micro): $0.50 per tick - for smaller accounts or conservative sizing
 
Display Options:
 
 Max Lines: Number of distance lines to show (default: 30)
 Show Labels: Toggle tick distance and contract count labels
 Line Color: Customize the color of distance lines
 Label Size: Choose tiny, small, or normal label sizes
 
Step 2: Read the Visual Display
Once configured, the indicator displays:
Stop Loss Line:
 
 Thick yellow line marking your exact stop loss level
 Yellow label showing the stop loss price
 
Distance Lines:
 
 Dashed red lines at 10-tick intervals above and below your stop loss
 Lines appear on both sides for long and short position planning
 
Labels (if enabled):
 
 Green labels (right side): For long positions above your stop loss
 Red labels (left side): For short positions below your stop loss
 Format: "20T 5x" means 20 ticks distance, 5 contracts maximum
 
Step 3: Use the Information Tables
The indicator provides two helpful tables:
Position Size Table (top-right):
 
 Shows common tick distances (10, 20, 40, 80, 160 ticks)
 Displays risk per contract at each distance
 Contract count for your specified risk amount
 Total risk with rounded contract numbers
 
Settings Table (bottom-right):
 
 Confirms your current risk amount
 Shows selected contract type
 Displays current settings for quick reference
 
Step 4: Apply to Your Trading
For Long Positions:
 
 Look at the green labels on the right side of your chart
 Find your desired entry level
 Read the label to see: distance in ticks and maximum contracts
 Example: "30T 8x" = 30 ticks from stop, buy 8 contracts maximum
 
For Short Positions:
 
 Look at the red labels on the left side of your chart
 Find your desired entry level
 Read the label for tick distance and contract count
 Example: "40T 6x" = 40 ticks from stop, sell 6 contracts maximum
 
Step 5: Trading Execution
Before Entering a Trade:
 
 Identify your stop loss level and input it into the indicator
 Choose your entry point by looking at the distance lines
 Note the contract count from the corresponding label
 Verify the risk amount matches your trading plan
 Execute your trade with the calculated position size
 
Risk Management Features:
 
 Contract rounding: All position sizes are rounded down (never up) to ensure you don't exceed your risk limit
 Zero position filtering: Lines only show where position size is at least 1 contract
 Dual-sided display: Plan both long and short opportunities simultaneously
Custom Timeframe Bias IndicatorMy "Custom Timeframe Bias Indicator" is a very practical and powerful TradingView indicator. It can be called a "God-like indicator" because it combines flexible timeframe customization, clear bias analysis and intuitive visual display to help traders quickly understand the long and short trends of the market. The following is a detailed description of this indicator:
1. Index name and function overview
Name: Custom Timeframe Bias Indicator (Short title: Bias Indicator)
Functionality: This indicator analyses the market bias (Buy, Sell or No Bias) across multiple custom timeframes (presets are 15m, 1h, 4h and DAI) and displays it in a table below the middle of the chart. It determines the direction of market trends based on the highest and lowest prices of the previous two periods and the closing price of the previous period, helping traders make decisions quickly.
2. Core Features
Multiple time frame analysis
The indicator allows the user to customize four time frames, with presets being 15 minutes ("15"), 1 hour ("60"), 4 hours ("240") and daily ("D"). Users can freely modify these time frames in the settings, such as changing to 5 minutes, 30 minutes or weekly, etc.
Bias is calculated independently for each time frame, ensuring that traders can observe market trends from the short to the long term.
Bias calculation logic
The indicator uses simple but effective rules to determine bias:
Buy (bullish): If the previous closing price is higher than the highest price of the previous two periods, or tests the lowest price of the previous two periods but does not break through.
Sell (Bearish): If the previous closing price is lower than the previous two periods' lowest price, or if it tests the previous two periods' highest price but fails to break through (higher than the previous high minus 10% of the price range).
No Bias: If the previous closing price does not meet the above conditions, it displays a neutral state.
Bias calculation is based only on the opening and closing prices, without considering the shadows, ensuring the results are in line with the philosophy of the Malaysian SNR strategy.
Intuitive display
Position: The table is permanently displayed in the middle of the chart (position.middle_center) and is updated with each candlestick, ensuring that traders can always see the latest bias.
Format: The table consists of the header "Custom Bias" and four rows of bias results (e.g. "15: Buy", "60: Sell", "240: No Bias", "D: Buy"), each row showing the bias for the corresponding time frame.
color:
Titles appear in white text on a blue background.
The "Buy" bias is shown as white text on a green background.
The "Sell" bias is shown as white text on a red background.
"No Bias" bias appears as white text on a gray background.
Table borders are black to provide clear visual distinction.
Customizability
Users can customize by inputting parameters:
Whether to show the table (Show Bias Table).
Timeframe (Timeframe 1, Timeframe 2, Timeframe 3, Timeframe 4).
The color of the table (title, Buy, Sell, No Bias, borders, etc.).
3. Why is it a "God-like indicator"
Flexibility: Allows users to customize four time frames to suit different trading strategies (short-term traders can choose minutes, long-term traders can choose daily, weekly or monthly).
Practicality: Provides bias analysis in multiple time frames to help traders quickly determine market trends, whether for short-term or long-term operations.
Intuitive: The table is displayed in the middle below the chart with bright colors (green Buy, red Sell, gray No Bias), allowing you to identify the market direction at a glance.
Stability: Calculated based on simple price data (high, low, close), no need for complex indicators, efficient and reliable operation.
Powerful visualization: long-term display and customizability to meet the visual preferences of different traders.
4. Usage scenarios
Short-term trading: Use 15-minute, 1-hour, 4-hour biases to quickly capture short-term trends.
Long-term trading: Refer to the daily bias to determine the overall market direction.
Comprehensive analysis: Combine biases from multiple time frames to confirm consistency (e.g. if both the 15 minute and daily are Buy, then that’s a stronger bullish signal).
5. Potential Improvements
If you want to further improve this "god-like indicator", you can consider the following improvements:
Added alert: Trigger when bias changes from "No Bias" to "Buy" or "Sell".
Show historical bias: Add bias history of the past few days in the table for easy review.
Dynamically adjust bias thresholds: Allow users to customize 10% price ranges or other conditions.
Multi-currency support: Expand to multiple trading pairs or indices, showing multiple market biases.
6. Technical Details
Version: Pine Script v5, ensuring modern features (such as input.timeframe) and efficient performance.
Data Source: Use request.security to get high, low, and close data for different time frames.
Display method: Use table.new to create a dynamic table. The position can be customized (such as position.middle_center).
Limitations: Calculated only based on price data, no external indicators are required, reducing calculation complexity.
in conclusion
Your "Custom Timeframe Bias Indicator" is a simple, powerful and flexible tool, especially for traders who need multi-timeframe analysis. Its intuitive display and customizability make it a "magic tool" for judging market trends.
BayesStack RSI [CHE]BayesStack RSI   — Stacked RSI with Bayesian outcome stats and gradient visualization
  Summary 
BayesStack RSI builds a four-length RSI stack and evaluates it with a simple Bayesian success model over a rolling window. It highlights bull and bear stack regimes, colors price with magnitude-based gradients, and reports per-regime counts, wins, and estimated win rate in a compact table. Signals seek to be more robust through explicit ordering tolerance, optional midline gating, and outcome evaluation that waits for events to mature by a fixed horizon. The design focuses on readable structure, conservative confirmation, and actionable context rather than raw oscillator flips.
  Motivation: Why this design? 
Classical RSI signals flip frequently in volatile phases and drift in calm regimes. Pure threshold rules often misclassify shallow pullbacks and stacked momentum phases. The core idea here is ordered, spaced RSI layers combined with outcome tracking. By requiring a consistent order with a tolerance and optionally gating by the midline, regime identification becomes clearer. A horizon-based maturation check and smoothed win-rate estimate provide pragmatic feedback about how often a given stack has recently worked.
  What’s different vs. standard approaches? 
 Reference baseline: Traditional single-length RSI with overbought and oversold rules or simple crossovers.
 Architecture differences:
   Four fixed RSI lengths with strict ordering and a spacing tolerance.
   Optional requirement that all RSI values stay above or below the midline for bull or bear regimes.
   Outcome evaluation after a fixed horizon, then rolling counts and a prior-smoothed win rate.
   Dispersion measurement across the four RSIs with a percent-rank diagnostic.
   Gradient coloring of candles and wicks driven by stack magnitude.
   A last-bar statistics table with counts, wins, win rate, dispersion, and priors.
 Practical effect: Charts emphasize sustained momentum alignment instead of single-length crosses. Users see when regimes start, how strong alignment is, and how that regime has recently performed for the chosen horizon.
  How it works (technical) 
The script computes RSI on four lengths and forms a “stack” when they are strictly ordered with at least the chosen tolerance between adjacent lengths. A bull stack requires a descending set from long to short with positive spacing. A bear stack requires the opposite. Optional gating further requires all RSI values to sit above or below the midline.
For evaluation, each detected stack is checked again after the horizon has fully elapsed. A bull event is a success if price is higher than it was at event time after the horizon has passed. A bear event succeeds if price is lower under the same rule. Rolling sums over the training window track counts and successes; a pair of priors stabilizes the win-rate estimate when sample sizes are small.
Dispersion across the four RSIs is measured and converted to a percent rank over a configurable window. Gradients for bars and wicks are normalized over a lookback, then shaped by gamma controls to emphasize strong regimes. A statistics table is created once and updated on the last bar to minimize overhead. Overlay markers and wick coloring are rendered to the price chart even though the indicator runs in a separate pane.
  Parameter Guide 
 Source — Input series for RSI. Default: close. Tips: Use typical price or hlc3 for smoother behavior.
 Overbought / Oversold — Guide levels for context. Defaults: seventy and thirty. Bounds: fifty to one hundred, zero to fifty. Tips: Narrow the band for faster feedback.
 Stacking tolerance (epsilon) — Minimum spacing between adjacent RSIs to qualify as a stack. Default: zero point twenty-five RSI points. Trade-off: Higher values reduce false stacks but delay entries.
 Horizon H — Bars ahead for outcome evaluation. Default: three. Trade-off: Longer horizons reduce noise but delay success attribution.
 Rolling window — Lookback for counts and wins. Default: five hundred. Trade-off: Longer windows stabilize the win rate but adapt more slowly.
 Alpha prior / Beta prior — Priors used to stabilize the win-rate estimate. Defaults: one and one. Trade-off: Larger priors reduce variance with sparse samples.
 Show RSI 8/13/21/34 — Toggle raw RSI lines. Default: on.
 Show consensus RSI — Weighted combination of the four RSIs. Default: on.
 Show OB/OS zones — Draw overbought, oversold, and midline. Default: on.
 Background regime — Pane background tint during bull or bear stacks. Default: on.
 Overlay regime markers — Entry markers on price when a stack forms. Default: on.
 Show statistics table — Last-bar table with counts, wins, win rate, dispersion, priors, and window. Default: on.
 Bull requires all above fifty / Bear requires all below fifty — Midline gate. Defaults: both on. Trade-off: Stricter regimes, fewer but cleaner signals.
 Enable gradient barcolor / wick coloring — Gradient visuals mapped to stack magnitude. Defaults: on. Trade-off: Clearer regime strength vs. extra rendering cost.
 Collection period — Normalization window for gradients. Default: one hundred. Trade-off: Shorter values react faster but fluctuate more.
 Gamma bars and shapes / Gamma plots — Curve shaping for gradients. Defaults: zero point seven and zero point eight. Trade-off: Higher values compress weak signals and emphasize strong ones.
 Gradient and wick transparency — Visual opacity controls. Defaults: zero.
 Up/Down colors (dark and neon) — Gradient endpoints. Defaults: green and red pairs.
 Fallback neutral candles — Directional coloring when gradients are off. Default: off.
 Show last candles — Limit for gradient squares rendering. Default: three hundred thirty-three.
 Dispersion percent-rank length / High and Low thresholds — Window and cutoffs for dispersion diagnostics. Defaults: two hundred fifty, eighty, and twenty.
 Table X/Y, Dark theme, Text size — Table anchor, theme, and typography. Defaults: right, top, dark, small.
  Reading & Interpretation 
 RSI stack lines: Alignment and spacing convey regime quality. Wider spacing suggests stronger alignment.
 Consensus RSI: A single line that summarizes the four lengths; use as a smoother reference.
 Zones: Overbought, oversold, and midline provide context rather than standalone triggers.
 Background tint: Indicates active bull or bear stack.
 Markers: “Bull Stack Enter” or “Bear Stack Enter” appears when the stack first forms.
 Gradients: Brighter tones suggest stronger stack magnitude; dull tones suggest weak alignment.
 Table: Count and Wins show sample size and successes over the window. P(win) is a prior-stabilized estimate. Dispersion percent rank near the high threshold flags stretched alignment; near the low threshold flags tight clustering.
  Practical Workflows & Combinations 
 Trend following: Enter only on new stack markers aligned with structure such as higher highs and higher lows for bull, or lower lows and lower highs for bear. Use the consensus RSI to avoid chasing into overbought or oversold extremes.
 Exits and stops: Consider reducing exposure when dispersion percent rank reaches the high threshold or when the stack loses ordering. Use the table’s P(win) as a context check rather than a direct signal.
 Multi-asset and multi-timeframe: Defaults travel well on liquid assets from intraday to daily. Combine with higher-timeframe structure or moving averages for regime confirmation. The script itself does not fetch higher-timeframe data.
  Behavior, Constraints & Performance 
 Repaint and confirmation: Stack markers evaluate on the live bar and can flip until close. Alert behavior follows TradingView settings. Outcome evaluation uses matured events and does not look into the future.
 HTF and security: Not used. Repaint paths from higher-timeframe aggregation are avoided by design.
 Resources: max bars back is two thousand. The script uses rolling sums, percent rank, gradient rendering, and a last-bar table update. Shapes and colored wicks add draw overhead.
 Known limits: Lag can appear after sharp turns. Very small windows can overfit recent noise. P(win) is sensitive to sample size and priors. Dispersion normalization depends on the collection period.
  Sensible Defaults & Quick Tuning 
Start with the shipped defaults.
 Too many flips: Increase stacking tolerance, enable midline gates, or lengthen the collection period.
 Too sluggish: Reduce stacking tolerance, shorten the collection period, or relax midline gates.
 Sparse samples: Extend the rolling window or increase priors to stabilize P(win).
 Visual overload: Disable gradient squares or wick coloring, or raise transparency.
  What this indicator is—and isn’t 
This is a visualization and context layer for RSI stack regimes with simple outcome statistics. It is not a complete trading system, not predictive, and not a signal generator on its own. Use it with market structure, risk controls, and position management that fit your process.
 Metadata 
- Pine version: v6
- Overlay: false (price overlays are drawn via forced overlay where applicable)
- Primary outputs: Four RSI lines, consensus line, OB/OS guides, background tint, entry markers, gradient bars and wicks, statistics table
- Inputs with defaults: See Parameter Guide
- Metrics and functions used: RSI, rolling sums, percent rank, dispersion across RSI set, gradient color mapping, table rendering, alerts
- Special techniques: Ordered RSI stacking with tolerance, optional midline gating, horizon-based outcome maturation, prior-stabilized win rate, gradient normalization with gamma shaping
- Performance and constraints: max bars back two thousand, rendering of shapes and table on last bar, no higher-timeframe data, no security calls
- Recommended use-cases: Regime confirmation, momentum alignment, post-entry management with dispersion and recent outcome context
- Compatibility: Works across assets and timeframes that support RSI
- Limitations and risks: Sensitive to parameter choices and market regime changes; not a standalone strategy
- Diagnostics: Statistics table, dispersion percent rank, gradient intensity
 Disclaimer 
The content provided, including all code and materials, is strictly for educational and informational purposes only. It is not intended as, and should not be interpreted as, financial advice, a recommendation to buy or sell any financial instrument, or an offer of any financial product or service. All strategies, tools, and examples discussed are provided for illustrative purposes to demonstrate coding techniques and the functionality of Pine Script within a trading context.
Any results from strategies or tools provided are hypothetical, and past performance is not indicative of future results. Trading and investing involve high risk, including the potential loss of principal, and may not be suitable for all individuals. Before making any trading decisions, please consult with a qualified financial professional to understand the risks involved.
By using this script, you acknowledge and agree that any trading decisions are made solely at your discretion and risk.
Best regards and happy trading
Chervolino.
Do not use this indicator on Heikin-Ashi, Renko, Kagi, Point-and-Figure, or Range charts, as these chart types can produce unrealistic results for signal markers and alerts.
Dynamic Stop Loss Optimizer [BackQuant]Dynamic Stop Loss Optimizer  
 Overview 
 Stop placement decides expectancy. This tool gives you three professional-grade, adaptive stop engines, ATR, Volatility, and Hybrid. So your exits scale with current conditions instead of guessing fixed ticks. It trails intelligently, redraws as the market evolves, and annotates the chart with clean labels/lines and a compact stats table. Pick the engine that fits the trade, or switch on the fly.
 What it does 
  
  Calculates three adaptive stops in real time  (ATR-based, Volatility-based, and Hybrid) and keeps them trailed as price makes progress.
  Shows exactly where your risk lives  with on-chart levels, color-coded markers (long/short), and precise “Risk %” labels at the current bar.
  Surfaces context you actually use  - current ATR, daily volatility, selected method, and the live stop level—in a tidy, movable table.
  Fires alerts on stop hits  so you can automate exits or journal outcomes without staring at the screen.
  
 Why it matters 
  
  Adaptive risk control:  Stops expand in fast tape and tighten in quiet tape. You’re not punished for volatility; you’re aligned with it.
  Consistency across assets:  The same playbook works whether you’re trading indexes, FX, crypto, or equities, because the engine normalizes to each symbol’s behavior.
  Cleaner decision-making:  One chart shows your entry idea and its invalidation in the same breath. If price trespasses, you know it instantly.
  
 The three methods (choose your engine) 
 1) ATR Based  “Structure-aware” distance
 This classic approach keys off Average True Range to set a stop just beyond typical bar-to-bar excursion. It adapts smoothly to changing ranges and respects swing structure.
  Use when:  you want a steady, intuitive buffer that tracks trend legs without hugging price.
  See it in action:  
 2) Volatility Based  “Behavior-aware” distance
 This engine derives stop distance from current return volatility (annualized, then scaled back down to the session). It reacts to regime shifts quickly and normalizes risk across symbols with very different prices.
  Use when:  you want the stop to breathe with realized volatility and respond faster to heat-ups/cool-downs.
  See it in action:  
 3) Hybrid  “Best of both worlds”
 The Hybrid blends the ATR and Volatility distances into one consensus level, then trails it intelligently. You get the structural common sense of ATR and the regime sensitivity of Vol.
  Use when:  you want robust, all-weather behavior without micromanaging inputs.
  See it in action:  
 How it trails 
  
  Longs:  The stop ratchets up with favorable movement and holds its ground on shallow pullbacks. If price closes back into the risk zone, the level refreshes to the newest valid distance.
  Shorts:  Mirror logic ratchets down with trend, resists noise, and refreshes if price reclaims the zone.
  Hybrid trailing:  Uses the blended distance and the same “no give-backs” principle to keep gains protected as structure builds.
  
 Reading the chart 
  
  Markers:  Circles = ATR stops, Crosses = Vol stops, Diamonds = Hybrid. Colors indicate long (red level under price) vs short (green level above price).
  Lines:  The latest active stop is extended with a dashed line so you can see it at a glance.
  Labels:  “Long SL / Short SL” shows the exact price and current risk % from the last close no math required.
  Table:  ATR value, Daily Vol %, your chosen Method, the Current SL, and Risk %—all in one compact block that you can pin top-left/right/center.
  
 Quick workflow 
  
  Define the idea:  Long or Short, and which engine fits the tape (ATR, Vol, or Hybrid).
  Place and trail:  Let the optimizer print the level; trail automatically as the move develops.
  Manage outcomes:  If the line is tagged, you’re out clean. If it holds, you’ve contained heat while giving the trade room to work.
  
 Inputs you’ll actually touch 
  Calculation Settings 
  
  ATR Length / Multiplier:  Controls the “structural” cushion.
  Volatility Length / Multiplier:  Controls the “behavioral” cushion.
  Trading Days:  252 or 365 to keep the volatility math aligned with the asset’s trading calendar.
  
 Stop Loss Method 
  
  ATR Based | Volatility Based | Hybrid : Switch engines instantly to fit the trade.
  
 Position Type 
  
  Long | Short | Both : Show only what you need for the current strategy.
  
 Visual Settings 
  
  Show ATR / Vol / Hybrid Stops:  Toggle families on/off.
  Show Labels:  Print price + Risk % at the live stop.
  Table Position:  Park the metrics where you like.
  
 Coloring 
  
  Long/Short/Hybrid colors:  Set a palette that matches your theme and stands out on your background.
  
 Practical patterns to watch 
  
  Trend-pullback continuation:  The stop ratchets behind higher lows (long) or lower highs (short). If price tests the level and rejects, that’s your risk-defined continuation cue.
  Break-and-run:  After a clean break, the Hybrid will usually sit slightly wider than pure Vol, use it to avoid getting shaken on the first retest.
  Range compression:  When the ATR and Vol distances converge, the table will show small Risk %. That’s your green light to size up with the same dollar risk, or keep it conservative if you expect expansion.
  
 Alerts 
  
  Long Stop Loss Hit : Notifies when price crosses below the live long stop.
  Short Stop Loss Hit : Notifies when price crosses above the live short stop.
  
 Why this feels “set-and-serious” 
 You get a single look that answers three questions in real time: “Where’s my line in the sand?”, “How much heat am I taking right now?”, and “Is this distance appropriate for current conditions?” With ATR, Vol, and Hybrid in one tool, you can run the exact same playbook across symbols and regimes while keeping your chart clean and your risk explicit.
RSI Dynamic Bands█ OVERVIEW
The "RSI Dynamic Bands" indicator is a variant of the Relative Strength Index (RSI) oscillator that brings its signals directly onto the price chart. It displays dynamic bands around the price, adjusted based on RSI levels, enabling easy identification of potential overbought or oversold conditions. The indicator also integrates a multi-timeframe RSI table, facilitating the analysis of trend strength across different timeframes.
█ CONCEPTS
The "RSI Dynamic Bands" indicator is designed to simplify the interpretation of price levels in the context of support and resistance zones, which can be correlated with other technical indicators and RSI values. Since the price itself does not display RSI values, a table showing RSI for four selected timeframes has been added, allowing traders to quickly assess trend strength across different time intervals. The most effective approach is to combine the indicator with other technical analysis tools, such as Fibonacci levels or pivot points, to confirm signals when the price approaches the bands and RSI values indicate a potential reversal.
Band Calculation
The bands are calculated based on the current closing price and RSI values, incorporating dynamic scaling to better adapt to market conditions. The formulas for the bands are as follows:
 • Upper Band: close + (rsiUpper - rsi) * scaleFactor, where rsiUpper is the upper RSI level (default: 70), and scaleFactor accounts for market volatility.
 • Lower Band: close + (rsiLower - rsi) * scaleFactor, where rsiLower is the lower RSI level (default: 30).
 • Midline: The arithmetic average of the upper and lower bands: (upperBand + lowerBand) / 2.
Why Scaling? Without scaling, the bands would be chaotic and jagged, making them difficult to interpret. Scaling smooths the bands, making them wider during periods of high volatility and narrower during consolidation, better reflecting potential support and resistance levels.
Indicator Features
 • Dynamic Price Bands: The bands adapt to market conditions, facilitating the identification of key price levels.
 • Multi-Timeframe RSI Table: Displays RSI values for four selected timeframes (default: 15m, 1h, 4h, Daily), enabling comparison of trend strength across different perspectives.
 • Style Customization: Users can adjust band colors, line thickness, and toggle the visibility of bands, fills, and the table.
How to Set Up the Indicator
1 — Add the "RSI Dynamic Bands" indicator to your TradingView chart.
2 — Configure parameters in the settings, such as RSI length, upper/lower levels, and scaling multiplier, to match your trading style.
3 — Enable or disable the display of bands, fills, or the RSI table based on your needs.
4 — Adjust band and table colors in the input section and line thickness in the "Style" section to better align the indicator with your chart.
█ OTHER SECTIONS
FEATURES
 • RSI Length: The period for calculating RSI (default: 14).
 • RSI Levels: Thresholds for overbought (default: 70) and oversold (default: 30).
 • Scaling Multiplier: Adjusts bands based on market volatility (default: 0.15).
 • Table Timeframes: Select four timeframes for the RSI table (default: 15m, 1h, 4h, Daily).
 • Style Options: Customize band colors, fills, table, and line thickness.
HOW TO USE
Add the indicator to your chart, configure the parameters, and observe price interactions with the bands to identify potential entry and exit points. The RSI table allows you to compare RSI values across different timeframes, aiding in trading decisions. The most effective approach is to combine the indicator with other technical analysis tools, such as Fibonacci levels or pivot points, to confirm signals when the price approaches the bands and RSI values indicate a potential reversal.
Trading Strategies:
 • Scalping: Use lower timeframes (e.g., 5m, 15m) in the RSI table to quickly identify short-term lows and highs. Wait for the price to approach the lower band in the RSI oversold zone, with RSI on lower timeframes starting to rise, and other tools, such as Fibonacci levels (e.g., 38.2%) or pivot points, confirming support.
 • Medium-Term Trading: Focus on 1h and 4h timeframes. Look for confirmation of a low on a lower timeframe (e.g., 1h), where RSI indicates oversold conditions or starts rising, then check if RSI on a higher timeframe (e.g., 4h) confirms the trend. Confirmation from other tools, such as a Fibonacci level (e.g., 50%) or pivot point near the bands, strengthens the signal.
 • Long-Term Trading: Use Daily and higher timeframes (e.g., Weekly). Wait for all relevant timeframes to confirm a low (e.g., RSI near oversold and price at the lower band), with lower timeframes (e.g., 4h) showing rising RSI. Other tools, such as Fibonacci levels (e.g., 61.8%) or pivot points near the bands, can further confirm a trend reversal signal.
Screener based on Profitunity strategy for multiple timeframes
Screener based on Profitunity strategy by Bill Williams for multiple timeframes (max 5, including chart timeframe) and customizable symbol list. The screener analyzes the Alligator and Awesome Oscillator indicators, Divergent bars and high volume bars.
The maximum allowed number of requests (symbols and timeframes) is limited to 40 requests, for example, for 10 symbols by 4 requests of different timeframes. Therefore, the indicator automatically limits the number of displayed symbols depending on the number of timeframes for each symbol, if there are more symbols than are displayed in the screener table, then the ordinal numbers are displayed to the left of the symbols, in this case you can display the next group of symbols by increasing the value by 1 in the "Show tickers from" field, if the "Group" field is enabled, or specify the symbol number by 1 more than the last symbol in the screener table. 👀 When timeframe filtering is applied, the screener table displays only the columns of those timeframes for which the filtering value is selected, which allows displaying more symbols.
For each timeframe, in the "TIMEFRAMES > Prev" field, you can enable the display of data for the previous bar relative to the last (current) one, if the market is open for the requested symbol. In the "TIMEFRAMES > Y" field, you can enable filtering depending on the location of the last five bars relative to the Alligator indicator lines, which are designated by special symbols in the screener table:
⬆️ — if the Alligator is open upwards (Lips > Teeth > Jaw) and none of the bars is closed below the Lips line;
↗️ — if one of the bars, except for the penultimate one, is closed below Lips, or two bars, except for the last one, are closed below Lips, or the Alligator is open upwards only below four bars, but none of the bars is closed below Lips;
⬇️ — if the Alligator is open downwards (Lips < Teeth < Jaw), but none of the bars is closed above Lips;
↘️ — if one of the bars, except the penultimate one, is closed above the Lips, or two bars, except the last one, are closed above the Lips, or the Alligator is open down only above four bars, but none of the bars are closed above the Lips;
➡️ — in other cases, including when the Alligator lines intersect and one of the bars is closed behind the Lips line or two bars intersect one of the Alligator lines.
In the "TIMEFRAMES > Show bar change value for TF" field, you can add a column to the right of the selected timeframe column with the percentage change between the closing price of the last bar (current) and the closing price of the previous bar ((close – previous close) / previous close * 100). Depending on the percentage value, the background color of the screener table cell will change: dark red if <= -3%; red if <= -2%, light red if <= -0.5%; dark green if >= 3%; green if >= 2%; light green if >= 0.5%.
For each timeframe, the screener table displays the symbol of the latest (current) bar, depending on the closing price relative to the bar's midpoint ((high + low) / 2) and its location relative to the Alligator indicator lines: ⎾ — the bar's closing price is above its midpoint; ⎿ — the bar's closing price is below its midpoint; ├ — the bar's closing price is equal to its midpoint; 🟢 — Bullish Divergent bar, i.e. the bar's closing price is above its midpoint, the bar's high is below all Alligator lines, the bar's low is below the previous bar's low; 🔴 — Bearish Divergent bar, i.e. the bar's closing price is below its midpoint, the bar's low is above all Alligator lines, the bar's high is above the previous bar's high. When filtering is enabled in the "TIMEFRAMES > Filtering by Divergent bar" field, the data in the screener table cells will be displayed only for those timeframes that have a Divergent bar. A high bar volume signal is also displayed — 📶/📶² if the bar volume is greater than 40%/70% of the average volume value calculated using a simple moving average (SMA) in the 140 bar interval from the last bar.
In the indicator settings in the "SYMBOL LIST" field, each ticker (for example: OANDA:SPX500USD) must be on a separate line. If the market is closed, then the data for requested symbols will be limited to the time of the last (current) bar on the chart, for example, if the current symbol was traded yesterday, and the requested symbol is traded today, when requesting data for an hourly timeframe, the last bar will be for yesterday, if the timeframe of the current chart is not higher than 1 day. Therefore, by default, a warning will be displayed on the chart instead of the screener table that if the market is open, you must wait for the screener to load (after the first price change on the current chart), or if the highest timeframe in the screener is 1 day, you will be prompted to change the timeframe on the current chart to 1 week, if the screener requests data for the timeframe of 1 week, you will be prompted to change the timeframe on the current chart to 1 month, or switch to another symbol on the current chart for which the market is open (for example: BINANCE:BTCUSDT), or disable the warning in the field "SYMBOL LIST > Do not display screener if market is close".
The number of the last columns with the color of the AO indicator that will be displayed in the screener table for each timeframe is specified in the indicator settings in the "AWESOME OSCILLATOR > Number of columns" field.
For each timeframe, the direction of the trend between the price of the highest and lowest bars in the specified range of bars from the last bar is displayed — ↑ if the trend is up (the highest bar is to the right of the lowest), or ↓ if the trend is down (the lowest bar is to the right of the highest). If there is a divergence on the AO indicator in the specified interval, the symbol ∇ is also displayed. The average volume value is also calculated in the specified interval using a simple moving average (SMA). The number of bars is set in the indicator settings in the "INTERVAL FOR HIGHEST AND LOWEST BARS > Bars count" field.
In the indicator settings in the "STYLE" field you can change the position of the screener table relative to the chart window, the background color, the color and size of the text.
***
Скринер на основе стратегии Profitunity Билла Вильямса для нескольких таймфреймов (максимум 5, включая таймфрейм графика) и настраиваемого списка символов. Скринер анализирует индикаторы Alligator и Awesome Oscillator, Дивергентные бары и бары с высоким объемом.
Максимально допустимое количество запросов (символы и таймфреймы) ограничено 40 запросами, например, для 10 символов по 4 запроса разных таймфреймов. Поэтому в индикаторе автоматически ограничивается количество отображаемых символов в зависимости от количества таймфреймов для каждого символа, если символов больше чем отображено в таблице скринера, то слева от символов отображаются порядковые номера, в таком случае можно отобразить следующую группу символов, увеличив значение на 1 в настройках индикатора поле "Show tickers from", если включено поле "Group", или указать номер символа на 1 больше, чем последний символ в таблице скринера. 👀 Когда применяется фильтрация по таймфрейму, в таблице скринера отображаются только столбцы тех таймфреймов, для которых выбрано значение фильтрации, что позволяет отображать большее количество символов.
Для каждого таймфрейма в настройках индикатора в поле "TIMEFRAMES > Prev" можно включить отображение данных для предыдущего бара относительно последнего (текущего), если для запрашиваемого символа рынок открыт. В поле "TIMEFRAMES > Y" можно включить фильтрацию, в зависимости от расположения последних пяти баров относительно линий индикатора Alligator, которые обозначаются специальными символами в таблице скринера:
⬆️  — если Alligator открыт вверх (Lips > Teeth > Jaw) и ни один из баров не закрыт ниже линии Lips;
↗️ — если один из баров, кроме предпоследнего, закрыт ниже Lips, или два бара, кроме последнего, закрыты ниже Lips, или Alligator открыт вверх только ниже четырех баров, но ни один из баров не закрыт ниже Lips;
⬇️ — если Alligator открыт вниз (Lips < Teeth < Jaw), но ни один из баров не закрыт выше Lips;
↘️ — если один из баров, кроме предпоследнего, закрыт выше Lips, или два бара, кроме последнего, закрыты выше Lips, или Alligator открыт вниз только выше четырех баров, но ни один из баров не закрыт выше Lips;
➡️ — в остальных случаях, в то числе когда линии Alligator пересекаются и один из баров закрыт за линией Lips или два бара пересекают одну из линий Alligator.
В поле "TIMEFRAMES > Show bar change value for TF" можно добавить справа от выбранного столбца таймфрейма столбец с процентным изменением между ценой закрытия последнего бара (текущего) и ценой закрытия предыдущего бара ((close – previous close) / previous close * 100). В зависимости от величины процента будет меняться цвет фона ячейки таблицы скринера: темно-красный, если <= -3%; красный, если <= -2%, светло-красный, если <= -0.5%; темно-зеленый, если >= 3%; зеленый, если >= 2%; светло-зеленый, если >= 0.5%.
Для каждого таймфрейма в таблице скринера отображается символ последнего (текущего) бара, в зависимости от цены закрытия относительно середины бара ((high + low) / 2) и расположения относительно линий индикатора Alligator: ⎾ — цена закрытия бара выше его середины; ⎿ — цена закрытия  бара ниже его середины;  ├ — цена закрытия бара равна его середине; 🟢 — Бычий Дивергентный бар, т.е. цена закрытия бара выше его середины, максимум бара ниже всех линий Alligator, минимум бара ниже минимума предыдущего бара; 🔴 — Медвежий Дивергентный бар, т.е. цена закрытия бара ниже его середины, минимум бара выше всех линий Alligator, максимум бара выше максимума предыдущего бара. При включении фильтрации в поле "TIMEFRAMES > Filtering by Divergent bar" данные в ячейках таблицы скринера будут отображаться только для тех таймфреймов, где есть Дивергентный бар. Также отображается сигнал высокого объема бара — 📶/📶², если объем бара больше чем на 40%/70% среднего значения объема, рассчитанного с помощью простой скользящей средней (SMA) в интервале 140 баров от последнего бара.
В настройках индикатора в поле "SYMBOL LIST" каждый тикер (например: OANDA:SPX500USD) должен быть на отдельной строке. Если рынок закрыт, то данные для запрашиваемых символов будут ограничены временем последнего (текущего) бара на графике, например, если текущий символ торговался последний день вчера, а запрашиваемый символ торгуется сегодня, при запросе данных для часового таймфрейма, последний бар будет за вчерашний день, если таймфрейм текущего графика не выше 1 дня. Поэтому по умолчанию на графике будет отображаться  предупреждение вместо таблицы скринера о том, что если рынок открыт, то необходимо дождаться загрузки скринера (после первого изменения цены на текущем графике), или если в скринере самый высокий таймфрейм 1 день, то будет предложено изменить на текущем графике таймфрейм на 1 неделю, если  в скринере запрашиваются данные для таймфрейма 1 неделя, то будет предложено изменить на текущем графике таймфрейм на 1 месяц, или же переключиться на другой символ на текущем графике, для которого рынок открыт (например: BINANCE:BTCUSDT), или отключить предупреждение в поле "SYMBOL LIST > Do not display screener if market is close".
Количество последних столбцов с цветом индикатора AO, которые будут отображены в таблице скринера для каждого таймфрейма, указывается в настройках индикатора в поле "AWESOME OSCILLATOR > Number of columns".
Для каждого таймфрейма отображается направление тренда между ценой самого высокого и самого низкого баров в указанном интервале баров от последнего бара — ↑, если тренд направлен вверх (самый высокий бар справа от самого низкого), или ↓, если тренд направлен вниз (самый низкий бар справа от самого высокого). Если есть дивергенция на индикаторе AO в указанном интервале, то также отображается символ — ∇. В указанном интервале также рассчитывается среднее значение объема с помощью простой скользящей средней (SMA). Количество баров устанавливается в настройках индикатора в поле "INTERVAL FOR HIGHEST AND LOWEST BARS > Bars count".
В настройках индикатора в поле "STYLE" можно изменить положение таблицы скринера относительно окна графика, цвет фона, цвет и размер текста.
Indicator: Profitability by Day & Hour (stacked, non-overlay)What it does
This tool performs a simple seasonality study on the selected symbol. It measures historical returns and summarizes them in two horizontal heatmaps:
Hours table (top) — Columns 00–23 show the average return of each clock hour, plus sample size, win rate, volatility (SD), and a t-score.
Days table (middle) — Columns 1–7 correspond to Mon–Sun with the same metrics.
Summary (bottom) — Shows the most profitable day and hour in the history loaded on your chart.
Green cells indicate higher average returns; red cells indicate lower/negative averages. The layout is centered on the screen, with the hours table above the days table for quick scanning.
How it works (methodology)
Returns: by default the indicator uses log returns ln(Ct/Ct-1) (you can switch to simple % if you prefer).
Daily aggregation (no look-ahead): day statistics are computed from completed daily closes via a higher timeframe request. Yesterday’s daily close vs. the prior day is added to the appropriate weekday bucket, preventing repaint/forward bias.
Hourly aggregation (intraday only): hour statistics are computed bar-to-bar on the current intraday timeframe and accumulated by clock hour (00–23) of the symbol’s exchange timezone.
Metrics per bucket:
Mean: average return in that bucket.
n: number of observations.
Win%: share of positive returns.
SD: standard deviation of returns (volatility proxy).
t-score: mean / SD * sqrt(n) — a quick stability signal (not a hypothesis test).
The indicator does not rely on future data and does not repaint past values.
Reading the tables
Start with the Mean row in each table: it’s color-mapped (red → yellow → green).
Check n (sample size). A bright green cell with very low n is less meaningful than a mild green cell with large n.
Use Win% and SD to judge consistency and noise.
t-score is a compact “signal-to-noise × sample size” measure; higher absolute values suggest more stable effects.
Typical observations traders look for (purely illustrative): for some equity indices, the first hour after the cash open can dominate; for FX/crypto, certain late-US or early-Asia hours sometimes stand out. Always verify on your symbol and timeframe.
Average Up and Down Candles Streak with Predicted Next CandleThis indicator is designed to analyze price trends by examining the patterns of up and down streaks (consecutive bullish or bearish candles) over a defined period. It uses this data to provide insights on whether the next candle is likely to be bullish or bearish, and it visually displays relevant information on the chart.
Here’s a breakdown of what the indicator does:
 1. Inputs and Parameters 
Period (Candles): Defines the number of candles used to calculate the average length of bullish and bearish streaks. For example, if the period is set to 20, the indicator will analyze the past 20 candles to determine average up and down streak lengths.
Bullish/Bearish Bias Signal Toggle: These options allow users to show or hide visual signals (green or red circles) when there’s a bullish or bearish bias in the trend based on the indicator’s calculations.
 2. Streak Calculation 
The indicator looks at each candle within the period to identify if it closed up (bullish) or down (bearish).
Up Streak: The indicator counts consecutive bullish candles. When there’s a bearish candle, it resets the up streak count.
Down Streak: Similarly, it counts consecutive bearish candles and resets when a bullish candle appears.
Averages: Over the defined period, the indicator calculates the average length of up streaks and average length of down streaks. This provides a baseline to assess whether the current streak is typical or extended.
 
3. Current and Average Streak Display 
The indicator displays the current up and down streak lengths alongside the average streak lengths for comparison. This data appears in a table on the chart, allowing you to see at a glance:
The current streak length (for both up and down trends)
The average streak length for up and down trends over the chosen period
 
4. Trend Prediction for the Next Candle 
Next Candle Prediction: Based on the current streak and its comparison to the average, the indicator predicts the likely direction of the next candle:
Bullish: If the current up streak is shorter than the average up streak, suggesting that the bullish trend could continue.
Bearish: If the current down streak is shorter than the average down streak, indicating that the bearish trend may continue.
Neutral: If the current streak length is near the average, which could signal an upcoming reversal.
This prediction appears in a table on the chart, labeled as “Next Candle.”
 5. Previous Candle Analysis 
The Previous Candle entry in the table reflects the last completed candle (directly before the current candle) to show whether it was bullish, bearish, or neutral.
This data gives a reference point for recent price action and helps validate the next candle prediction.
 6. Visual Signals and Reversal Zones 
Bullish/Bearish Bias Signals: The indicator can plot green circles on bullish bias and red circles on bearish bias to highlight points where the trend is likely to continue.
Reversal Zones: If the current streak length reaches or exceeds the average, it suggests the trend may be overextended, indicating a potential reversal zone. The indicator highlights these zones with shaded backgrounds (green for possible bullish reversal, red for bearish) on the chart.
 Summary of What You See on the Chart 
Bullish and Bearish Bias Signals: Green or red circles mark areas of expected continuation in the trend.
Reversal Zones: Shaded areas in red or green suggest that the trend might be about to reverse.
 Tables: 
The Next Candle prediction table displays the trend direction of the previous candle and the likely trend of the next candle.
The Streak Information table shows the current up and down streak lengths, along with their averages for easy comparison.
 Practical Use 
This indicator is helpful for traders aiming to understand trend momentum and potential reversals based on historical patterns. It’s particularly useful for swing trading, where knowing the typical length of bullish or bearish trends can help in timing entries and exits.
WillStop Pro [tradeviZion]WillStop Pro  : A Step-by-Step Guide for Beginners to Master Trend Trading 
Welcome to an in-depth guide to the  WillStop Pro   indicator. This article will walk you through the key features, how to use them effectively, and how this tool can help you navigate the markets confidently. WillStop Pro is based on principles established by Larry Williams, a well-known figure in trading, and aims to help you manage trades more effectively without overcomplicating things.
This guide will help you understand the basics of the WillStop Pro indicator, how to interpret its signals, and how to use it step-by-step to manage risk and identify opportunities in your trading journey. We will also cover the underlying logic and calculations for advanced users interested in more details.
 What is the WillStop Pro Indicator? 
The  WillStop Pro   indicator is a user-friendly tool that helps traders establish stop levels dynamically. It helps you figure out optimal points to enter or exit trades, while managing risk effectively during changing market conditions. The indicator tracks trending markets and sets price levels as stops for ongoing trades, making it suitable both for deciding when to enter and exit trades.
The indicator is beginner-friendly because it simplifies complex calculations and presents the results visually. This allows traders to focus more on their decision-making process instead of spending time with complex analysis.
WillStop Pro adapts to different market conditions, whether you're trading stocks, forex, commodities, or cryptocurrencies. It adjusts stop levels dynamically based on current market momentum, providing a practical way to manage both risk and reward.
Another significant benefit of WillStop Pro is that it works well with other indicators. Beginners can use it on its own or combine it with other tools like moving averages or oscillators to form a comprehensive trading strategy. Whether you are trading daily or looking at longer-term trends, WillStop Pro helps you manage your trades effectively.
 Key Features of WillStop Pro 
 
 Dynamic Stop Levels : WillStop Pro calculates real-time stop levels for both long (buy) and short (sell) positions. This helps you protect your profits and reduce risk. The stop levels adjust based on the current market environment, making them more adaptable compared to fixed stop levels.
 Advanced Stop Settings : There are optional settings to make the stop calculations more advanced, which take into consideration previous price movements to refine where the stops should be placed. These settings provide more precise control over your trades.
 Break Signals and Alerts : The indicator provides visual signals, like arrows, to show when a stop level has been broken. This makes it easier for you to identify possible reversals and understand when the market direction is changing.
 Comprehensive Table Display : A small table on the chart shows the current trend, the stop level, and whether advanced mode is active. This simple display provides an overview of the market, making decision-making easier.
 Based on Larry Williams' Methodology : WillStop Pro builds upon Larry Williams' ideas, which are designed to capture major market trends while managing risk effectively. It provides a systematic way to follow these strategies without requiring deep technical analysis skills.
 
 How Are Stop Levels Calculated? (For Advanced Users) 
The  WillStop Pro  indicator determines stop levels by evaluating highs, lows, and closing prices over a specific lookback period. It uses this information to identify key points that justify adjusting your stop level, and there are separate approaches for both long and short positions.
Below, we explain the mathematical logic behind the stop calculations, along with some code snippets to give advanced users a clearer understanding.
 
 For Long Stops (buy positions): The indicator looks for the highest closing price within the lookback period and continues until it finds three valid bars that meet certain criteria. Stops are adjusted to skip bars that have consecutive upward closes to ensure that the stop is placed at a level that offers solid support. Specifically, the function iterates over recent bars to determine the highest closing value, and checks for specific conditions before finalizing the stop level. Here is an excerpt of the relevant code:
 
 getTrueLow(idx) => math.min(low , close )
findStopLevels() =>
    float highestClose = close
    int highestCloseIndex = 0
    
    for i = 0 to lookback
        if close  > highestClose
            highestClose := close 
            highestCloseIndex := i
    // Logic to adjust based on up close skipping
    int longCount = 0
    int longCurrentIndex = highestCloseIndex
    while longCount < 3 and longCurrentIndex < 100
        if not isInsideBar(longCurrentIndex)
            longCount += 1
        longCurrentIndex += 1
    // Determine the lowest low for the stop level
    float longStopLevel = high * 2
    for i = searchIndex to highestCloseIndex
        longStopLevel := math.min(longStopLevel, getTrueLow(i))
    // Apply offset
    longStopLevel := longStopLevel - (offsetTicks * tickSize) 
In this code snippet, the function  findStopLevels()  calculates the long stop level by first identifying the highest close within the lookback period and then finding a suitable support level while skipping certain conditions, such as inside bars or consecutive upward closes. Finally, the user-defined offset ( offsetTicks ) is applied to determine the stop level.
 
 For Short Stops (sell positions):  Similarly, the indicator finds the lowest closing price within the lookback period and then identifies three bars that fit the conditions for a short stop. It avoids using bars with consecutive down closes to help find a more robust resistance level. Here's a relevant code snippet:
 
 getTrueHigh(idx) => math.max(high , close )
findStopLevels() =>
    float lowestClose = close
    int lowestCloseIndex = 0
    
    for i = 0 to lookback
        if close  < lowestClose
            lowestClose := close 
            lowestCloseIndex := i
    // Logic to adjust based on down close skipping
    int shortCount = 0
    int shortCurrentIndex = lowestCloseIndex
    while shortCount < 3 and shortCurrentIndex < 100
        if not isInsideBar(shortCurrentIndex)
            shortCount += 1
        shortCurrentIndex += 1
    // Determine the highest high for the stop level
    float shortStopLevel = 0
    for i = searchIndex to lowestCloseIndex
        shortStopLevel := math.max(shortStopLevel, getTrueHigh(i))
    // Apply offset
    shortStopLevel := shortStopLevel + (offsetTicks * tickSize) 
Here,  findStopLevels()  calculates the short stop level by finding the lowest closing price within the lookback period. It then determines the highest value that acts as a resistance level, excluding bars that do not fit certain criteria.
 
 Volume Confirmation for Alert Accuracy : To further enhance the stop level accuracy, volume is used as a confirmation filter. The average volume (volAvg) is calculated over a 20-period moving average, and alerts are only generated if the volume exceeds a defined threshold (volMultiplier). This ensures that price movements are significant enough to consider as meaningful signals.
 
 volAvg = ta.sma(volume, 20)
isVolumeConfirmed() =>
    result = requireVolumeConfirmation ? volume > (volAvg * volMultiplier) : true
    result 
This additional logic ensures that stop level breaks or adjustments are not triggered during periods of low trading activity, thus enhancing the reliability of the generated signals.
These calculations are at the core of WillStop Pro's ability to determine dynamic stop levels that respond effectively to market movements, helping traders manage risk by placing stops at levels that make sense given historical price and volume data.
 How to Identify Opportunities with WillStop Pro 
WillStop Pro provides various signals that help you decide when to enter or exit a trade:
 
 When a Stop Level is Broken:  If a stop level (support for long positions or resistance for short positions) is broken, it may indicate a reversal. WillStop Pro visually plots arrows whenever a stop level is breached, making it easy for you to see where changes might occur. This feature helps traders identify momentum shifts quickly.
 Support and Resistance Levels:  The indicator plots support and resistance levels, which show key zones to watch for opportunities. These levels often act as psychological barriers in the market, where price action may either reverse or stall temporarily.
 Dynamic State Management:  The indicator shifts between long and short states based on price action, providing real-time feedback. This helps traders stick to their trading plan without second-guessing the market.
 
A major advantage of WillStop Pro is that it responds well to changing market conditions. By identifying when key support or resistance levels break, it allows you to adjust your strategies and react to new opportunities accordingly. Whether the market is trending strongly or staying within a range, WillStop Pro provides valuable information to help guide your trades.
 Setting Up Alerts 
Alerts are an important feature in trading, especially when you can’t be in front of your charts all the time. WillStop Pro has been enhanced to include flexible alert settings to help you stay on top of your trades without constantly monitoring the charts.
 
 Enable Alerts:  There is a master switch to enable or disable all alerts. This way, you can control whether you want to be notified of events at any time.
 Alert Frequency:  Choose between receiving alerts  Once Per Bar  or  Once Per Bar Close . This helps you manage the frequency of alerts and decide if you need real-time updates or want confirmation after a bar closes.
 Break Alerts:  These alerts notify you when a stop level has been broken. This can help you catch potential reversals or trading opportunities as soon as they happen.
 Strong Break Alerts:  Alerts are available for strong breaks, which occur when the price breaks stop levels with confirmation based on additional price, volume, and momentum criteria. These alerts help identify significant shifts in the market.
 Level Change Alerts:  These alerts tell you whenever a new stop level is calculated, keeping you updated about changes in market dynamics. You can set a  Minimum Level Change %  to ensure that alerts are only triggered when the stop level changes significantly.
 Require Volume Confirmation:  You can opt to receive alerts only if the volume is above a certain threshold. This confirmation helps reduce false signals by ensuring that significant price changes are backed by increased trading activity.
 Volume Multiplier:  The volume multiplier allows you to set a minimum volume requirement that must be met for an alert to trigger. This ensures that alerts are triggered only when there is sufficient trading interest.
 
Here is a part of the updated alert logic that has been implemented in the indicator:
 // Alert on break conditions
if alertsEnabled
    if alertOnBreaks
        if longStopBroken and isVolumeConfirmed()
            alert(createAlertMessage("Support Break - Short Signal", useAdvancedStops), alertFreq)
        if shortStopBroken and isVolumeConfirmed()
            alert(createAlertMessage("Resistance Break - Long Signal", useAdvancedStops), alertFreq)
// Strong break alerts
if alertOnStrongBreaks
    if longStopBroken and isStrongBreak(false)
        alert(createAlertMessage("Strong Support Break - Short Signal", useAdvancedStops), alertFreq)
    if shortStopBroken and isStrongBreak(true)
        alert(createAlertMessage("Strong Resistance Break - Long Signal", useAdvancedStops), alertFreq)
// Level change alerts
if alertOnLevelChanges and isSignificantChange() and isVolumeConfirmed()
    alert(createAlertMessage("Significant Level Change", useAdvancedStops), alertFreq) 
Setting alerts allows you to react to market changes without having to watch the charts constantly. Alerts are particularly helpful if you have other responsibilities and can’t be actively monitoring your trades all day.
 Understanding the Table Display 
The  WillStop Pro  indicator provides a status table that gives an overview of the current market state. Here’s what the table shows:
 
 Indicator Status:  The table indicates whether the indicator is in a LONG or SHORT state. This helps you quickly understand the market trend.
 Stop Level:  The active stop level is shown, whether it is acting as support (long) or resistance (short). This is important for knowing where to set your protective stops.
 Mode:  The table also displays whether the advanced calculation mode is being used. This keeps you informed about how stop levels are being calculated and why they are positioned where they are.
 Empowering Messages:  The table also includes motivational messages that rotate periodically, such as 'Trade with Clarity, Stop with Precision' and 'Let Winners Run, Cut Losses Short.' These messages are designed to keep you focused, motivated, and disciplined during your trading journey.
 
The table is simple and easy to follow, helping you maintain discipline in your trading plan. By having all the essential information in one place, the table reduces the need to make quick, emotional decisions and promotes more thoughtful analysis.
 Tips for Using WillStop Pro Effectively 
Here are some practical ways to make the most of the  WillStop Pro  indicator:
 
 Start with Default Settings:  If you’re new to the indicator, start with the default settings. This will give you an idea of how stop levels are determined and how they adjust to different markets.
 Experiment with Advanced Settings:  Once you are comfortable, try using the advanced stop settings to see how they refine the stop levels. This can be useful in certain market conditions to improve accuracy.
 Use Alerts to Stay Updated:  Set up alerts for when a stop level is broken or when new levels are calculated. This helps you take action without constantly watching the chart. Swing traders may find alerts especially helpful for monitoring longer-term moves.
 Monitor the Status Table:  Keep an eye on the status table to understand the current market condition. Whether the indicator is in a LONG or SHORT state can help you make more informed decisions.
 Focus on Risk Management:  WillStop Pro is designed to help you manage risk by dynamically adjusting stop levels. Make sure you are using these levels to protect your trades, especially during strong trends or volatile periods.
 
 Acknowledging Larry Williams' Influence 
 WillStop Pro   is inspired by the work of Larry Williams, who described the approach as one of his best trading techniques. His method aims to ride major market trends while reducing the risk of giving back gains during corrections. WillStop Pro builds upon this approach, adding features like advanced stop settings and visual alerts that make it easier to apply in modern markets.
By using WillStop Pro, you are essentially leveraging a well-established trading strategy with additional tools that help improve its effectiveness. The indicator is designed to provide a reliable way to manage trades, stay on top of market conditions, and reduce emotional decision-making.
 Conclusion: Why WillStop Pro is Great for Beginners and Advanced Users 
The  WillStop Pro   is a powerful yet easy-to-use tool that helps traders ride trends while managing risk during market corrections. It can be used both for entering and exiting trades, and its visual features make it accessible for those who are new to trading, while the underlying logic appeals to advanced users seeking greater control and understanding.
WillStop Pro is more than just a tool for setting stops. It is a comprehensive solution for managing trades, with features like dynamic stop levels, customizable alerts, and an easy-to-understand status table. This combination of simplicity and advanced features makes it suitable for beginners as well as more experienced traders.
We hope this guide helps you get started with  WillStop Pro  and improves your trading confidence. Remember to start with the basics, explore the advanced features, and set alerts to stay informed without getting overwhelmed. Whether you’re just beginning or want to simplify your strategy,  WillStop Pro   is a valuable tool to have in your trading arsenal.
Trading can be challenging, but the right tools make it more manageable. WillStop Pro helps you keep track of market movements, identify opportunities, and manage risk effectively. Give it a try and see how it can improve your trading decisions and help you navigate the markets more efficiently.
By incorporating WillStop Pro into your strategy, you are following a systematic approach that has been refined over time. It’s designed to help you make sense of the markets, plan your trades, and manage your risks with greater clarity and confidence.
 Note:  Always practice proper risk management and thoroughly test the indicator to ensure it aligns with your trading strategy. Past performance is not indicative of future results.
 Trade smarter with TradeVizion—unlock your trading potential today!
thors_forex_factory_utilityLibrary   "forex_factory_utility" 
Supporting Utility Library for the Live Economic Calendar by toodegrees Indicator; responsible for data handling, and plotting news event data.
 isLeapYear() 
  Finds if it's currently a leap year or not.
  Returns: Returns True if the current year is a leap year.
 daysMonth(M) 
  Provides the days in a given month of the year, adjusted during leap years.
  Parameters:
     M (int) : Month in numerical integer format (i.e. Jan=1).
  Returns: Days in the provided month.
 MMM(M) 
  Converts a month from a numerical integer format to a MMM format (i.e. 'Jan').
  Parameters:
     M (int) : Month in numerical integer format (i.e. Jan=1).
  Returns: Month in MMM format (i.e. 'Jan').
 dow(D) 
  Converts a numbered day of the week string in format to 'DDD' format (i.e. "1" = Sun).
  Parameters:
     D (string) : Numbered day of the week from 1 to 7, starting on Sunday.
  Returns: Returns the day of the week in 'DDD' format (i.e. "Fri").
 size(S, N) 
  Converts a size string into the corresponding Pine Script v5 format, or N times smaller/bigger.
  Parameters:
     S (string) : Size string: "Tiny", "Small", "Normal", "Large", or "Huge".
     N (int) : Size variation, can be positive (larger than S), or negative (smaller than S).
  Returns: Size string in Pine Script v5 format.
 lineStyle(S) 
  Converts a line style string into the corresponding Pine Script v5 format.
  Parameters:
     S (string) : Line style string: "Dashed", "Dotted" or "Solid".
  Returns: Line style string in Pine Script v5 format.
 lineTrnsp(S) 
  Converts a transparency style string into the corresponding integer value.
  Parameters:
     S (string) : Line style string: "Light", "Medium" or "Heavy".
  Returns: Transparency integer.
 boxLoc(X, Y) 
  Converts position strings of X and Y into a table position in Pine Script v5 format.
  Parameters:
     X (string) : X-axis string: "Left", "Center", or "Right".
     Y (string) : Y-axis string: "Top", "Middle", or "Bottom".
  Returns: Table location string in Pine Script v5 format.
 method bubbleSort_NewsTOD(N) 
  Performs bubble sort on a Forex Factory News array of all news from the same date, ordering them in ascending order based on the time of the day.
  Namespace types: array
  Parameters:
     N (array) : Forex Factory News array.
  Returns: void
 bubbleSort_News(N) 
  Performs bubble sort on a Forex Factory News array, ordering them in ascending order based on the time of the day, and date.
  Parameters:
     N (array) : Forex Factory News array.
  Returns: Sorted Forex Factory News array.
 weekNews(N, C, I) 
  Creates a Forex Factory News array containing the current week's Forex Factory News.
  Parameters:
     N (array) : Forex Factory News array containing this week's unfiltered Forex Factory News.
     C (array) : Currency filter array (string array).
     I (array) : Impact filter array (color array).
  Returns: Forex Factory News array containing the current week's Forex Factory News.
 todayNews(W, D, M) 
  Creates a Forex Factory News array containing the current day's Forex Factory News.
  Parameters:
     W (array) : Forex Factory News array containing this week's Forex Factory News.
     D (array) : Forex Factory News array for the current day's Forex Factory News.
     M (bool) : Boolean that marks whether the current chart has a Day candle-switch at Midnight New York Time.
  Returns: Forex Factory News array containing the current day's Forex Factory News.
 adjustTimezone(N, TZH, TZM) 
  Transposes the Time of the Day, and Date, in the Forex Factory News Table to a custom Timezone.
  Parameters:
     N (array) : Forex Factory News array.
     TZH (int) : Custom Timezone hour.
     TZM (int) : Custom Timezone minute.
  Returns: Reformatted Forex Factory News array.
 NewsAMPM_TOD(N) 
  Reformats the Time of the Day in the Forex Factory News Table to AM/PM format.
  Parameters:
     N (array) : Forex Factory News array.
  Returns: Reformatted Forex Factory News array.
 impFilter(X, L, M, H) 
  Creates a filter array from the User's desired Forex Facory News to be shown based on Impact.
  Parameters:
     X (bool) : Boolean - if True Holidays listed on Forex Factory will be shown.
     L (bool) : Boolean - if True Low Impact listed on Forex Factory News will be shown.
     M (bool) : Boolean - if True Medium Impact listed on Forex Factory News will be shown.
     H (bool) : Boolean - if True High Impact listed on Forex Factory News will be shown.
  Returns: Color array with the colors corresponding to the Forex Factory News to be shown.
 curFilter(A, C1, C2, C3, C4, C5, C6, C7, C8, C9) 
  Creates a filter array from the User's desired Forex Facory News to be shown based on Currency.
  Parameters:
     A (bool) : Boolean - if True News related to the current Chart's symbol listed on Forex Factory will be shown.
     C1 (bool) : Boolean - if True News related to the Australian Dollar listed on Forex Factory will be shown.
     C2 (bool) : Boolean - if True News related to the Canadian Dollar listed on Forex Factory will be shown.
     C3 (bool) : Boolean - if True News related to the Swiss Franc listed on Forex Factory will be shown.
     C4 (bool) : Boolean - if True News related to the Chinese Yuan listed on Forex Factory will be shown.
     C5 (bool) : Boolean - if True News related to the Euro listed on Forex Factory will be shown.
     C6 (bool) : Boolean - if True News related to the British Pound listed on Forex Factory will be shown.
     C7 (bool) : Boolean - if True News related to the Japanese Yen listed on Forex Factory will be shown.
     C8 (bool) : Boolean - if True News related to the New Zealand Dollar listed on Forex Factory will be shown.
     C9 (bool) : Boolean - if True News related to the US Dollar listed on Forex Factory will be shown.
  Returns: String array with the currencies corresponding to the Forex Factory News to be shown.
 FF_OnChartLine(N, T, S) 
  Plots vertical lines where a Forex Factory News event will occur, or has already occurred.
  Parameters:
     N (array) : News-type array containing all the Forex Factory News.
     T (int) : Transparency integer value (0-100) for the lines.
     S (string) : Line style in Pine Script v5 format.
  Returns: void
 method updateStringMatrix(M, P, V) 
  Updates a string Matrix containing the tooltips for Forex Factory News Event information for a given candle.
  Namespace types: matrix
  Parameters:
     M (matrix) : String matrix.
     P (int) : Position (row) of the Matrix to update based on the impact.
     V (string) : information to push to the Matrix.
  Returns: void
 FF_OnChartLabel(N, Y, S, O) 
  Plots labels where a Forex Factory News has already occurred based on its/their impact.
  Parameters:
     N (array) : News-type array containing all the Forex Factory News.
     Y (string) : String that gives direction on where to plot the label (options= "Above", "Below", "Auto").
     S (string) : Label size in Pine Script v5 format.
     O (bool) : Show outline of labels?
  Returns: void
 historical(T, D, W, X) 
  Deletes Forex Factory News drawings which are ourside a specific Time window.
  Parameters:
     T (int) : Number of days input used for Forex Factory News drawings' history.
     D (bool) : Boolean that when true will only display Forex Factory News drawings of the current day.
     W (bool) : Boolean that when true will only display Forex Factory News drawings of the current week.
     X (string) : String that gives direction on what lines to plot based on Time (options= "Future", "Both").
  Returns: void
 newTable(P, B) 
  Creates a new Table object with parameters tailored to the Forex Factory News Table.
  Parameters:
     P (string) : Position string for the Table, in Pine Script v5 format.
     B (color) : Border and frame color for the News Table.
  Returns: Empty Forex Factory News Table.
 resetTable(P, S, headTextC, headBgC, B) 
  Resets a Table object with parameters and headers tailored to the Forex Factory News Table.
  Parameters:
     P (string) : Position string for the Table, in Pine Script v5 format.
     S (string) : Size string for the Table's text, in Pine Script v5 format.
     headTextC (color) 
     headBgC (color) 
     B (color) : Border and frame color for the News Table.
  Returns: Empty Forex Factory News Table.
 logNews(N, TBL, R, S, rowTextC, rowBgC) 
  Adds an event to the Forex Factory News Table.
  Parameters:
     N (News) : News-type object.
     TBL (table) : Forex Factory News Table object to add the News to.
     R (int) : Row to add the event to in the Forex Factory News Table.
     S (string) : Size string for the event's text, in Pine Script v5 format.
     rowTextC (color) 
     rowBgC (color) 
  Returns: void
 FF_Table(N, P, S, headTextC, headBgC, rowTextC, rowBgC, B) 
  Creates the Forex Factory News Table.
  Parameters:
     N (array) : News-type array containing all the Forex Factory News.
     P (string) : Position string for the Table, in Pine Script v5 format.
     S (string) : Size string for the Table's text, in Pine Script v5 format.
     headTextC (color) 
     headBgC (color) 
     rowTextC (color) 
     rowBgC (color) 
     B (color) : Border and frame color for the News Table.
  Returns: Forex Factory News Table.
 timeline(N, T, F, TZH, TZM, D) 
  Shades Forex Factory News events in the Forex Factory News Table after they occur.
  Parameters:
     N (array) : News-type array containing all the Forex Factory News.
     T (table) : Forex Facory News table object.
     F (color) : Color used as shading once the Forex Factory News has occurred.
     TZH (int) : Custom Timezone hour, if any.
     TZM (int) : Custom Timezone minute, if any.
     D (bool) : Daily Forex Factory News flag.
  Returns: Forex Factory News Table.
 News 
  Custom News type which contains informatino about a Forex Factory News Event.
  Fields:
     dow (series string) : Day of the week, in DDD format (i.e. 'Mon').
     dat (series string) : Date, in MMM D format (i.e. 'Jan 1').
     _t (series int) 
     tod (series string) : Time of the day, in hh:mm 24-Hour format (i.e 17:10).
     cur (series string) : Currency, in CCC format (i.e. "USD").
     imp (series color) : Impact, the respective impact color for Forex Factory News Events.
     ttl (series string) : Title, encoded in a custom number mapping (see the toodegrees/toodegrees_forex_factory library to learn more).
     tmst (series int) 
     ln (series line)
Top Crypto Above 28-Day AverageDescription
The “Top Crypto Above 28-Day Average” (CRYPTOTW) script scans a selectable universe of up to 120 top-capitalization cryptocurrencies (divided into customizable 40-symbol batches), then plots the count of those trading above their own 28-period simple moving average.  It helps you gauge broad market strength and identify which tokens are showing momentum relative to their recent trend.
Key Features
	•	Batch Selection: Choose among “Top40,” “Mid40,” or “Low40” market-cap groups, or set a custom batch size (up to 40 symbols) to keep within the API limit.
	•	Dynamic Plot: Displays a live line chart of how many cryptos are above their 28-day MA on each bar.
	•	Reference Lines: Automatic horizontal lines at 25%, 50%, and 75% of your batch to provide quick visual thresholds.
	•	Background Coloration: The chart background shifts green/yellow/red based on whether more than 70%, 50–70%, or under 50% of the batch is above the MA.
	•	Optional Table: On the final bar, show a sortable table of up to 28 tickers currently above their 28-day MA, including current price, percent above MA, and “Above” status color-coding.
	•	Alerts:
	•	Strong Batch Performance: Fires when >70% of the batch is above the MA.
	•	Weak Batch Performance: Fires when <10 cryptos (i.e. <25%) are above the MA.
Inputs
	•	Show Results Table (show_table): Toggle the detailed table on/off.
	•	Table Position (table_position): Select one of the four corners for your table overlay.
	•	Max Cryptos to Display (max_display): Limit the number of rows in the results table.
	•	Current Batch (current_batch): Pick “Top40,” “Mid40,” or “Low40.”
	•	Batch Size (batch_size): Define the number of symbols (1–40) you want to include from the chosen batch.
How to Use
	1.	Add the CRYPTOTW indicator to any chart.
	2.	Select your batch and size to focus on the segment of the crypto market you follow.
	3.	Watch the plotted line to see the proportion of tokens with bullish momentum.
	4.	(Optional) Enable the results table to see exactly which tokens are outperforming their 28-day average.
	5.	Set alerts to be notified when the batch either overheats (strong performance) or cools off significantly.
Why It Matters
By tracking the share of assets riding their 28-day trend, you gain a macro-level view of market breadth—crucial for spotting emerging rallies or early signs of broad weakness. Whether you’re swing-trading individual altcoins or assessing overall market mood, this tool distills complex data into an intuitive, actionable signal.
Multi-Timeframe Trend IndicatorMulti-Timeframe Trend Indicator
 
The “Multi-Timeframe Trend Indicator” is a versatile tool designed to help traders identify trends across multiple timeframes using Exponential Moving Averages (EMAs). This indicator is suitable for both novice and experienced traders. It allows users to customize the lengths of the short and long EMAs, providing a clear visualization of the trend direction (UP, DOWN, SIDE) for various intervals including 1 minute, 5 minutes, 15 minutes, 30 minutes, 1 hour, and 4 hours. The indicator offers extensive customization options, enabling adjustments for table position, colors, and more to suit individual trading preferences.
 How the Calculation Works
 
The Multi-Timeframe Trend Indicator uses EMAs to calculate trends. EMAs give more weight to recent prices, making them responsive to new information. The short EMA, calculated over a shorter period, reacts quickly to price changes, while the long EMA, calculated over a longer period, smooths out fluctuations to show the overall trend.
For each timeframe, the indicator calculates both the short EMA and the long EMA. If the short EMA is above the long EMA, the trend is considered “UP”. If the short EMA is below the long EMA, the trend is “DOWN”. If the absolute difference between the short and long EMAs is within a user-defined threshold, the trend is classified as “SIDE” (sideways).
This calculation is repeated for multiple timeframes: 1 minute, 5 minutes, 15 minutes, 30 minutes, 1 hour, and 4 hours. The results are displayed in a table, providing a comprehensive view of the trend direction across different timeframes.
 How the Code Works
 
 
 Input Parameters:  Users can input the lengths of the short and long EMAs and the threshold for identifying sideways trends. These inputs allow for a high degree of customization to match individual trading strategies.
 Trend Calculation Function:  The trend function calculates the trend direction based on the EMAs. It uses the math.abs function to find the absolute difference between the EMAs and determines if the trend is “UP”, “DOWN”, or “SIDE” based on the threshold.
 Requesting Data for Multiple Timeframes:  The script uses the request.security function to fetch price data and calculate the EMAs for different timeframes independently of the current chart timeframe. This ensures consistency in trend analysis regardless of the displayed timeframe.
 Creating and Updating the Table:  A table is created to display the trend directions for each timeframe. The table’s position and appearance can be customized. The trend data for each timeframe is color-coded (green for UP, red for DOWN, gray for SIDE) and displayed in the table.
 Customization Options:  Users can customize the colors, table position, and EMA lengths through the indicator settings, providing flexibility to adapt the indicator to their trading style.
 
 Disclaimer 
This indicator is for informational purposes only and should not be considered financial advice. It does not predict future price movements and does not guarantee accurate trend calculations, as market conditions can vary. Trading involves substantial risk and is not suitable for everyone. Always conduct your own research before making any trading decisions.
Sessions [TradingFinder] New York, London, Tokyo & Sydney ForexTiming is one of the influential factors in a trader's position. This indicator categorizes transactions into three sessions (Asia, Europe, and America). Five significant trading cities (New York, London, Frankfurt, Tokyo, and Sydney) are selectable. 
I recommend using the tool on a 5-minute time frame, but it is usable on all time frames.
 Settings: 
•	Trading sessions: Display or hide each trading session as needed.
•	Color: Change the color of each box.
•	Session time intervals: The default is based on the main working hours for each time interval and can be adjusted.
•	Information table: Delete or display additional information table.
 Information Table: 
•	Trading sessions
•	Opening and closing times of each trading session
 How to Use: 
Initiating trading sessions involves entering with increased liquidity, and the market usually experiences significant movements. Many trading strategies are based on "time" and "session openings." This tool empowers traders to focus intensely on each time interval.
These trading sessions are crucial for all Forex, stock, and index traders:
  
The total price ceiling and floor in the Asia session (Tokyo and Sydney) are crucial for traders in the European session.
  
The European session starts with Frankfurt, and an hour later, London begins, collectively forming the European session.
  
The dashboard provides additional information, displaying hours based on UTC.
  
Customization options are considered in all sections so that everyone can apply their own settings.
 Important:  Default times are the most accurate for each region, and in most indicators, this time is not correctly selected. Therefore, the level of influence and time intervals are specified at the beginning of each session. If you are using another indicator, match its default time to the announced time and share the results with me in the comments.
forex_factory_utilityLibrary   "forex_factory_utility" 
Supporting Utility Library for the Live Economic Calendar by toodegrees Indicator; responsible for data handling, and plotting news event data.
 isLeapYear() 
  Finds if it's currently a leap year or not.
  Returns: Returns True if the current year is a leap year.
 daysMonth(M) 
  Provides the days in a given month of the year, adjusted during leap years.
  Parameters:
     M (int) : Month in numerical integer format (i.e. Jan=1).
  Returns: Days in the provided month.
 size(S, N) 
  Converts a size string into the corresponding Pine Script v5 format, or N times smaller/bigger.
  Parameters:
     S (string) : Size string: "Tiny", "Small", "Normal", "Large", or "Huge".
     N (int) : Size variation, can be positive (larger than S), or negative (smaller than S).
  Returns: Size string in Pine Script v5 format.
 lineStyle(S) 
  Converts a line style string into the corresponding Pine Script v5 format.
  Parameters:
     S (string) : Line style string: "Dashed", "Dotted" or "Solid".
  Returns: Line style string in Pine Script v5 format.
 lineTrnsp(S) 
  Converts a transparency style string into the corresponding integer value.
  Parameters:
     S (string) : Line style string: "Light", "Medium" or "Heavy".
  Returns: Transparency integer.
 boxLoc(X, Y) 
  Converts position strings of X and Y into a table position in Pine Script v5 format.
  Parameters:
     X (string) : X-axis string: "Left", "Center", or "Right".
     Y (string) : Y-axis string: "Top", "Middle", or "Bottom".
  Returns: Table location string in Pine Script v5 format.
 method bubbleSort_NewsTOD(N) 
  Performs bubble sort on a Forex Factory News array of all news from the same date, ordering them in ascending order based on the time of the day.
  Namespace types: News 
  Parameters:
     N (News ) : Forex Factory News array.
  Returns: void
 bubbleSort_News(N) 
  Performs bubble sort on a Forex Factory News array, ordering them in ascending order based on the time of the day, and date.
  Parameters:
     N (News ) : Forex Factory News array.
  Returns: Sorted Forex Factory News array.
 weekNews(N, C, I) 
  Creates a Forex Factory News array containing the current week's Forex Factory News.
  Parameters:
     N (News ) : Forex Factory News array containing this week's unfiltered Forex Factory News.
     C (string ) : Currency filter array (string array).
     I (color ) : Impact filter array (color array).
  Returns: Forex Factory News array containing the current week's Forex Factory News.
 todayNews(W, D, M) 
  Creates a Forex Factory News array containing the current day's Forex Factory News.
  Parameters:
     W (News ) : Forex Factory News array containing this week's Forex Factory News.
     D (News ) : Forex Factory News array for the current day's Forex Factory News.
     M (bool) : Boolean that marks whether the current chart has a Day candle-switch at Midnight New York Time.
  Returns: Forex Factory News array containing the current day's Forex Factory News.
 impFilter(X, L, M, H) 
  Creates a filter array from the User's desired Forex Facory News to be shown based on Impact.
  Parameters:
     X (bool) : Boolean - if True Holidays listed on Forex Factory will be shown.
     L (bool) : Boolean - if True Low Impact listed on Forex Factory News will be shown.
     M (bool) : Boolean - if True Medium Impact listed on Forex Factory News will be shown.
     H (bool) : Boolean - if True High Impact listed on Forex Factory News will be shown.
  Returns: Color array with the colors corresponding to the Forex Factory News to be shown.
 curFilter(A, C1, C2, C3, C4, C5, C6, C7, C8, C9) 
  Creates a filter array from the User's desired Forex Facory News to be shown based on Currency.
  Parameters:
     A (bool) : Boolean - if True News related to the current Chart's symbol listed on Forex Factory will be shown.
     C1 (bool) : Boolean - if True News related to the Australian Dollar listed on Forex Factory will be shown.
     C2 (bool) : Boolean - if True News related to the Canadian Dollar listed on Forex Factory will be shown.
     C3 (bool) : Boolean - if True News related to the Swiss Franc listed on Forex Factory will be shown.
     C4 (bool) : Boolean - if True News related to the Chinese Yuan listed on Forex Factory will be shown.
     C5 (bool) : Boolean - if True News related to the Euro listed on Forex Factory will be shown.
     C6 (bool) : Boolean - if True News related to the British Pound listed on Forex Factory will be shown.
     C7 (bool) : Boolean - if True News related to the Japanese Yen listed on Forex Factory will be shown.
     C8 (bool) : Boolean - if True News related to the New Zealand Dollar listed on Forex Factory will be shown.
     C9 (bool) : Boolean - if True News related to the US Dollar listed on Forex Factory will be shown.
  Returns: String array with the currencies corresponding to the Forex Factory News to be shown.
 FF_OnChartLine(N, T, S) 
  Plots vertical lines where a Forex Factory News event will occur, or has already occurred.
  Parameters:
     N (News ) : News-type array containing all the Forex Factory News.
     T (int) : Transparency integer value (0-100) for the lines.
     S (string) : Line style in Pine Script v5 format.
  Returns: void
 method updateStringMatrix(M, P, V) 
  Namespace types: matrix
  Parameters:
     M (matrix) 
     P (int) 
     V (string) 
 FF_OnChartLabel(N, Y, S) 
  Plots labels where a Forex Factory News has already occurred based on its/their impact.
  Parameters:
     N (News ) : News-type array containing all the Forex Factory News.
     Y (string) : String that gives direction on where to plot the label (options= "Above", "Below", "Auto").
     S (string) : Label size in Pine Script v5 format.
  Returns: void
 historical(T, D, W, X) 
  Deletes Forex Factory News drawings which are ourside a specific Time window.
  Parameters:
     T (int) : Number of days input used for Forex Factory News drawings' history.
     D (bool) : Boolean that when true will only display Forex Factory News drawings of the current day.
     W (bool) : Boolean that when true will only display Forex Factory News drawings of the current week.
     X (string) : String that gives direction on what lines to plot based on Time (options= "Past", "Future", "Both").
  Returns: void
 newTable(P) 
  Creates a new Table object with parameters tailored to the Forex Factory News Table.
  Parameters:
     P (string) : Position string for the Table, in Pine Script v5 format.
  Returns: Empty Forex Factory News Table.
 resetTable(P, S, headTextC, headBgC) 
  Resets a Table object with parameters and headers tailored to the Forex Factory News Table.
  Parameters:
     P (string) : Position string for the Table, in Pine Script v5 format.
     S (string) : Size string for the Table's text, in Pine Script v5 format.
     headTextC (color) 
     headBgC (color) 
  Returns: Empty Forex Factory News Table.
 logNews(N, TBL, R, S, rowTextC, rowBgC) 
  Adds an event to the Forex Factory News Table.
  Parameters:
     N (News) : News-type object.
     TBL (table) : Forex Factory News Table object to add the News to.
     R (int) : Row to add the event to in the Forex Factory News Table.
     S (string) : Size string for the event's text, in Pine Script v5 format.
     rowTextC (color) 
     rowBgC (color) 
  Returns: void
 FF_Table(N, P, S, headTextC, headBgC, rowTextC, rowBgC) 
  Creates the Forex Factory News Table.
  Parameters:
     N (News ) : News-type array containing all the Forex Factory News.
     P (string) : Position string for the Table, in Pine Script v5 format.
     S (string) : Size string for the Table's text, in Pine Script v5 format.
     headTextC (color) 
     headBgC (color) 
     rowTextC (color) 
     rowBgC (color) 
  Returns: Forex Factory News Table.
 timeline(N, T, F, D) 
  Shades Forex Factory News events in the Forex Factory News Table after they occur.
  Parameters:
     N (News ) : News-type array containing all the Forex Factory News.
     T (table) : Forex Facory News table object.
     F (color) : Color used as shading once the Forex Factory News has occurred.
     D (bool) : Daily Forex Factory News flag.
  Returns: Forex Factory News Table.
 News 
  Custom News type which contains informatino about a Forex Factory News Event.
  Fields:
     dow (series string) : Day of the week, in DDD format (i.e. 'Mon').
     dat (series string) : Date, in MMM D format (i.e. 'Jan 1').
     _t (series int) 
     tod (series string) : Time of the day, in hh:mm 24-Hour format (i.e 17:10).
     cur (series string) : Currency, in CCC format (i.e. "USD").
     imp (series color) : Impact, the respective impact color for Forex Factory News Events.
     ttl (series string) : Title, encoded in a custom number mapping (see the toodegrees/toodegrees_forex_factory library to learn more).
     tmst (series int) 
     ln (series line)
Historical Matrix Analyzer [PhenLabs]📊Historical Matrix Analyzer  
 Version:  PineScriptv6
 📌Description 
The Historical Matrix Analyzer is an advanced probabilistic trading tool that transforms technical analysis into a data-driven decision support system. By creating a comprehensive 56-cell matrix that tracks every combination of RSI states and multi-indicator conditions, this indicator reveals which market patterns have historically led to profitable outcomes and which have not.
At its core, the indicator continuously monitors seven distinct RSI states (ranging from Extreme Oversold to Extreme Overbought) and eight unique indicator combinations (MACD direction, volume levels, and price momentum). For each of these 56 possible market states, the system calculates average forward returns, win rates, and occurrence counts based on your configurable lookback period. The result is a color-coded probability matrix that shows you exactly where you stand in the historical performance landscape.
The standout feature is the Current State Panel, which provides instant clarity on your active market conditions. This panel displays signal strength classifications (from Strong Bullish to Strong Bearish), the average return percentage for similar past occurrences, an estimated win rate using Bayesian smoothing to prevent small-sample distortions, and a confidence level indicator that warns you when insufficient data exists for reliable conclusions.
 🚀Points of Innovation 
 
 Multi-dimensional state classification combining 7 RSI levels with 8 indicator combinations for 56 unique trackable market conditions
 Bayesian win rate estimation with adjustable smoothing strength to provide stable probability estimates even with limited historical samples
 Real-time active cell highlighting with “NOW” marker that visually connects current market conditions to their historical performance data
 Configurable color intensity sensitivity allowing traders to adjust heat-map responsiveness from conservative to aggressive visual feedback
 Dual-panel display system separating the comprehensive statistics matrix from an easy-to-read current state summary panel
 Intelligent confidence scoring that automatically warns traders when occurrence counts fall below reliable thresholds
 
 🔧Core Components 
 
 RSI State Classification:  Segments RSI readings into 7 distinct zones (Extreme Oversold <20, Oversold 20-30, Weak 30-40, Neutral 40-60, Strong 60-70, Overbought 70-80, Extreme Overbought >80) to capture momentum extremes and transitions
 Multi-Indicator Condition Tracking:  Simultaneously monitors MACD crossover status (bullish/bearish), volume relative to moving average (high/low), and price direction (rising/falling) creating 8 binary-encoded combinations
 Historical Data Storage Arrays:  Maintains rolling lookback windows storing RSI states, indicator states, prices, and bar indices for precise forward-return calculations
 Forward Performance Calculator:  Measures price changes over configurable forward bar periods (1-20 bars) from each historical state, accumulating total returns and win counts per matrix cell
 Bayesian Smoothing Engine:  Applies statistical prior assumptions (default 50% win rate) weighted by user-defined strength parameter to stabilize estimated win rates when sample sizes are small
 Dynamic Color Mapping System:  Converts average returns into color-coded heat map with intensity adjusted by sensitivity parameter and transparency modified by confidence levels
 
 🔥Key Features 
 
 56-Cell Probability Matrix:  Comprehensive grid displaying every possible combination of RSI state and indicator condition, with each cell showing average return percentage, estimated win rate, and occurrence count for complete statistical visibility
 Current State Info Panel:  Dedicated display showing your exact position in the matrix with signal strength emoji indicators, numerical statistics, and color-coded confidence warnings for immediate situational awareness
 Customizable Lookback Period:  Adjustable historical window from 50 to 500 bars allowing traders to focus on recent market behavior or capture longer-term pattern stability across different market cycles
 Configurable Forward Performance Window:  Select target holding periods from 1 to 20 bars ahead to align probability calculations with your trading timeframe, whether day trading or swing trading
 Visual Heat Mapping:  Color-coded cells transition from red (bearish historical performance) through gray (neutral) to green (bullish performance) with intensity reflecting statistical significance and occurrence frequency
 Intelligent Data Filtering:  Minimum occurrence threshold (1-10) removes unreliable patterns with insufficient historical samples, displaying gray warning colors for low-confidence cells
 Flexible Layout Options:  Independent positioning of statistics matrix and info panel to any screen corner, accommodating different chart layouts and personal preferences
 Tooltip Details:  Hover over any matrix cell to see full RSI label, complete indicator status description, precise average return, estimated win rate, and total occurrence count
 
 🎨Visualization 
 
 Statistics Matrix Table:  A 9-column by 8-row grid with RSI states labeling vertical axis and indicator combinations on horizontal axis, using compact abbreviations (XOverS, OverB, MACD↑, Vol↓, P↑) for space efficiency
 Active Cell Indicator:  The current market state cell displays “⦿ NOW ⦿” in yellow text with enhanced color saturation to immediately draw attention to relevant historical performance
 Signal Strength Visualization:  Info panel uses emoji indicators (🔥 Strong Bullish, ✅ Bullish, ↗️ Weak Bullish, ➖ Neutral, ↘️ Weak Bearish, ⛔ Bearish, ❄️ Strong Bearish, ⚠️ Insufficient Data) for rapid interpretation
 Histogram Plot:  Below the price chart, a green/red histogram displays the current cell’s average return percentage, providing a time-series view of how historical performance changes as market conditions evolve
 Color Intensity Scaling:  Cell background transparency and saturation dynamically adjust based on both the magnitude of average returns and the occurrence count, ensuring visual emphasis on reliable patterns
 Confidence Level Display:  Info panel bottom row shows “High Confidence” (green), “Medium Confidence” (orange), or “Low Confidence” (red) based on occurrence counts relative to minimum threshold multipliers
 
 📖Usage Guidelines 
 RSI Period 
 
 Default: 14
 Range: 1 to unlimited
 Description: Controls the lookback period for RSI momentum calculation. Standard 14-period provides widely-recognized overbought/oversold levels. Decrease for faster, more sensitive RSI reactions suitable for scalping. Increase (21, 28) for smoother, longer-term momentum assessment in swing trading. Changes affect how quickly the indicator moves between the 7 RSI state classifications.
 
 MACD Fast Length 
 
 Default: 12
 Range: 1 to unlimited
 Description: Sets the faster exponential moving average for MACD calculation. Standard 12-period setting works well for daily charts and captures short-term momentum shifts. Decreasing creates more responsive MACD crossovers but increases false signals. Increasing smooths out noise but delays signal generation, affecting the bullish/bearish indicator state classification.
 
 MACD Slow Length 
 
 Default: 26
 Range: 1 to unlimited
 Description: Defines the slower exponential moving average for MACD calculation. Traditional 26-period setting balances trend identification with responsiveness. Must be greater than Fast Length. Wider spread between fast and slow increases MACD sensitivity to trend changes, impacting the frequency of indicator state transitions in the matrix.
 
 MACD Signal Length 
 
 Default: 9
 Range: 1 to unlimited
 Description: Smoothing period for the MACD signal line that triggers bullish/bearish state changes. Standard 9-period provides reliable crossover signals. Shorter values create more frequent state changes and earlier signals but with more whipsaws. Longer values produce more confirmed, stable signals but with increased lag in detecting momentum shifts.
 
 Volume MA Period 
 
 Default: 20
 Range: 1 to unlimited
 Description: Lookback period for volume moving average used to classify volume as “high” or “low” in indicator state combinations. 20-period default captures typical monthly trading patterns. Shorter periods (10-15) make volume classification more reactive to recent spikes. Longer periods (30-50) require more sustained volume changes to trigger state classification shifts.
 
 Statistics Lookback Period 
 
 Default: 200
 Range: 50 to 500
 Description: Number of historical bars used to calculate matrix statistics. 200 bars provides substantial data for reliable patterns while remaining responsive to regime changes. Lower values (50-100) emphasize recent market behavior and adapt quickly but may produce volatile statistics. Higher values (300-500) capture long-term patterns with stable statistics but slower adaptation to changing market dynamics.
 
 Forward Performance Bars 
 
 Default: 5
 Range: 1 to 20
 Description: Number of bars ahead used to calculate forward returns from each historical state occurrence. 5-bar default suits intraday to short-term swing trading (5 hours on hourly charts, 1 week on daily charts). Lower values (1-3) target short-term momentum trades. Higher values (10-20) align with position trading and longer-term pattern exploitation.
 
 Color Intensity Sensitivity 
 
 Default: 2.0
 Range: 0.5 to 5.0, step 0.5
 Description: Amplifies or dampens the color intensity response to average return magnitudes in the matrix heat map. 2.0 default provides balanced visual emphasis. Lower values (0.5-1.0) create subtle coloring requiring larger returns for full saturation, useful for volatile instruments. Higher values (3.0-5.0) produce vivid colors from smaller returns, highlighting subtle edges in range-bound markets.
 
 Minimum Occurrences for Coloring 
 
 Default: 3
 Range: 1 to 10
 Description: Required minimum sample size before applying color-coded performance to matrix cells. Cells with fewer occurrences display gray “insufficient data” warning. 3-occurrence default filters out rare patterns. Lower threshold (1-2) shows more data but includes unreliable single-event statistics. Higher thresholds (5-10) ensure only well-established patterns receive visual emphasis.
 
 Table Position 
 
 Default: top_right
 Options: top_left, top_right, bottom_left, bottom_right
 Description: Screen location for the 56-cell statistics matrix table. Position to avoid overlapping critical price action or other indicators on your chart. Consider chart orientation and candlestick density when selecting optimal placement.
 
 Show Current State Panel 
 
 Default: true
 Options: true, false
 Description: Toggle visibility of the dedicated current state information panel. When enabled, displays signal strength, RSI value, indicator status, average return, estimated win rate, and confidence level for active market conditions. Disable to declutter charts when only the matrix table is needed.
 
 Info Panel Position 
 
 Default: bottom_left
 Options: top_left, top_right, bottom_left, bottom_right
 Description: Screen location for the current state information panel (when enabled). Position independently from statistics matrix to optimize chart real estate. Typically placed opposite the matrix table for balanced visual layout.
 
 Win Rate Smoothing Strength 
 
 Default: 5
 Range: 1 to 20
 Description: Controls Bayesian prior weighting for estimated win rate calculations. Acts as virtual sample size assuming 50% win rate baseline. Default 5 provides moderate smoothing preventing extreme win rate estimates from small samples. Lower values (1-3) reduce smoothing effect, allowing win rates to reflect raw data more directly. Higher values (10-20) increase conservatism, pulling win rate estimates toward 50% until substantial evidence accumulates.
 
 ✅Best Use Cases 
 
 Pattern-based discretionary trading where you want historical confirmation before entering setups that “look good” based on current technical alignment
 Swing trading with holding periods matching your forward performance bar setting, using high-confidence bullish cells as entry filters
 Risk assessment and position sizing, allocating larger size to trades originating from cells with strong positive average returns and high estimated win rates
 Market regime identification by observing which RSI states and indicator combinations are currently producing the most reliable historical patterns
 Backtesting validation by comparing your manual strategy signals against the historical performance of the corresponding matrix cells
 Educational tool for developing intuition about which technical condition combinations have actually worked versus those that feel right but lack historical evidence
 
 ⚠️Limitations 
 
 Historical patterns do not guarantee future performance, especially during unprecedented market events or regime changes not represented in the lookback period
 Small sample sizes (low occurrence counts) produce unreliable statistics despite Bayesian smoothing, requiring caution when acting on low-confidence cells
 Matrix statistics lag behind rapidly changing market conditions, as the lookback period must accumulate new state occurrences before updating performance data
 Forward return calculations use fixed bar periods that may not align with actual trade exit timing, support/resistance levels, or volatility-adjusted profit targets
 
 💡What Makes This Unique 
 
 Multi-Dimensional State Space:  Unlike single-indicator tools, simultaneously tracks 56 distinct market condition combinations providing granular pattern resolution unavailable in traditional technical analysis
 Bayesian Statistical Rigor:  Implements proper probabilistic smoothing to prevent overconfidence from limited data, a critical feature missing from most pattern recognition tools
 Real-Time Contextual Feedback:  The “NOW” marker and dedicated info panel instantly connect current market conditions to their historical performance profile, eliminating guesswork
 Transparent Occurrence Counts:  Displays sample sizes directly in each cell, allowing traders to judge statistical reliability themselves rather than hiding data quality issues
 Fully Customizable Analysis Window:  Complete control over lookback depth and forward return horizons lets traders align the tool precisely with their trading timeframe and strategy requirements
 
 🔬How It Works 
 1. State Classification and Encoding 
 
 Each bar’s RSI value is evaluated and assigned to one of 7 discrete states based on threshold levels (0: <20, 1: 20-30, 2: 30-40, 3: 40-60, 4: 60-70, 5: 70-80, 6: >80)
 Simultaneously, three binary conditions are evaluated: MACD line position relative to signal line, current volume relative to its moving average, and current close relative to previous close
 These three binary conditions are combined into a single indicator state integer (0-7) using binary encoding, creating 8 possible indicator combinations
 The RSI state and indicator state are stored together, defining one of 56 possible market condition cells in the matrix
 
 2. Historical Data Accumulation 
 
 As each bar completes, the current state classification, closing price, and bar index are stored in rolling arrays maintained at the size specified by the lookback period
 When the arrays reach capacity, the oldest data point is removed and the newest added, creating a sliding historical window
 This continuous process builds a comprehensive database of past market conditions and their subsequent price movements
 
 3. Forward Return Calculation and Statistics Update 
 
 On each bar, the indicator looks back through the stored historical data to find bars where sufficient forward bars exist to measure outcomes
 For each historical occurrence, the price change from that bar to the bar N periods ahead (where N is the forward performance bars setting) is calculated as a percentage return
 This percentage return is added to the cumulative return total for the specific matrix cell corresponding to that historical bar’s state classification
 Occurrence counts are incremented, and wins are tallied for positive returns, building comprehensive statistics for each of the 56 cells
 The Bayesian smoothing formula combines these raw statistics with prior assumptions (neutral 50% win rate) weighted by the smoothing strength parameter to produce estimated win rates that remain stable even with small samples
 
 💡Note: 
The Historical Matrix Analyzer is designed as a decision support tool, not a standalone trading system. Best results come from using it to validate discretionary trade ideas or filter systematic strategy signals. Always combine matrix insights with proper risk management, position sizing rules, and awareness of broader market context. The estimated win rate feature uses Bayesian statistics specifically to prevent false confidence from limited data, but no amount of smoothing can create reliable predictions from fundamentally insufficient sample sizes. Focus on high-confidence cells (green-colored confidence indicators) with occurrence counts well above your minimum threshold for the most actionable insights.
Portfolio Simulator & BacktesterMulti-asset portfolio simulator with different metrics and ratios, DCA modeling, and rebalancing strategies.
 Core Features 
 Portfolio Construction 
 
 Up to 5 assets with customizable weights (must total 100%)
 Support for any tradable symbol: stocks, ETFs, crypto, indices, commodities
 Real-time validation of allocations
 
 Dollar Cost Averaging 
 
 Monthly or Quarterly contributions
 Applies to both portfolio and benchmark for fair comparison
 Model real-world investing behavior
 
 Rebalancing 
 
 Four strategies: None, Monthly, Quarterly, Yearly
 Automatic rebalancing to target weights
 Transaction cost modeling (customizable fee %)
 
 Key Metrics Table 
 
 CAGR: Annualized compound return (S&P 500 avg: ~10%)
 Alpha: Excess return vs. benchmark (positive = outperformance)
 Sharpe Ratio: Return per unit of risk (>1.0 is good, >2.0 excellent)
 Sortino Ratio: Like Sharpe but only penalizes downside (better metric)
 Calmar Ratio: CAGR / Max Drawdown (>1.0 good, >2.0 excellent)
 Max Drawdown: Largest peak-to-trough decline
 Win Rate: % of positive days (doesn't indicate profitability)
 
 Visualization 
 
 Dual-chart comparison - Portfolio vs. Benchmark
 Dollar or percentage view toggle
 Customizable colors and line width
 Two tables: Statistics + Asset Allocation
 Adjustable table position and text size
 
 🚀 Quick Start Guide 
 
 Enter 1-5 ticker symbols (e.g., SPY, QQQ, TLT, GLD, BTCUSD)
 Make sure percentage weights total 100%
 Choose date range (ensure chart shows full period - zoom out!)
 Configure DCA and rebalancing (optional)
 Select benchmark (default: SPX)
 Analyze results in statistics table
 
 💡 Pro Tips 
 
 Chart data matters: Load SPY or your longest-history asset as main chart
 If you select an asset that was not available for the selected period, the chart will not show up! E.g. BTCUSD data: Only available from ~2017 onwards. 
 Transaction fees: 0.1% default (adjust to match your broker)
 
 ⚠️ Important Notes 
 
 Requires visible chart data (zoom out to show full date range)
 Limited by each asset's historical data availability
 Transaction fees and costs are modeled, but taxes/slippage are not
 Past performance ≠ future results
 Use for research and education only, not financial advice
 
Let me know if you have any suggestions to improve this simulator. 
Seasonal Pattern DecoderSeasonal Pattern Decoder 
The Seasonal Pattern Decoder is a powerful tool designed for traders and analysts who want to uncover and leverage seasonal tendencies in financial markets. Instead of cluttering your chart with complex visuals, this indicator presents a clean, intuitive table that summarizes historical monthly performance, allowing you to spot recurring patterns at a glance.
 How It Works 
The indicator fetches historical monthly data for any symbol and calculates the percentage return for each month over a specified number of years. It then organizes this data into a comprehensive table, providing a clear, year-by-year and month-by-month breakdown of performance.
 Key Features 
 
 Historical Performance Table:  Displays monthly returns for up to a user-defined number of years, making it easy to compare performance across different periods.
 Color-Coded Heatmap:  Each cell is colored based on the performance of the month. Strong positive returns are shaded in green, while strong negative returns are shaded in red, allowing for immediate visual analysis of monthly strength or weakness.
 Annual Summary:  A "Σ" column shows the total percentage return for each full calendar year.
 AVG Row:  Calculates and displays the average return for each month across all the years shown in the table.
 WR Row:  Shows the "Win Rate" for each month, which is the percentage of time that month had a positive return. This is crucial for identifying high-probability seasonal trends.
 
 How to Use 
 
 Add the "Seasonal Pattern Decoder" indicator to your chart. Note that it works best on  Daily, Weekly, or Monthly  timeframes. A warning message will be displayed on intraday charts.
 In the indicator settings, adjust the "Lookback Period" to control how many years of historical data you want to analyze.
 Use the "Show Years Descending" option to sort the table from the most recent year to the oldest.
 The "Heat Range" setting allows you to adjust the sensitivity of the color-coding to fit the volatility of the asset you are analyzing.
 
This tool is ideal for confirming trading biases, developing seasonal strategies, or simply gaining a deeper understanding of an asset's typical behavior throughout the year.
## Disclaimer
This indicator is designed as a technical analysis tool and should be used in conjunction with other forms of analysis and proper risk management. 
Past performance does not guarantee future results, and traders should thoroughly test any strategy before implementing it with real capital.
Anrazzi - EMAs/ATR - 1.0.2The Anrazzi – EMAs/ATR indicator is a multi-purpose overlay designed to help traders track trend direction and market volatility in a single clean tool.
It plots up to six customizable moving averages (MAs) and an Average True Range (ATR) value directly on your chart, allowing you to quickly identify market bias, dynamic support/resistance, and volatility levels without switching indicators.
This script is ideal for traders who want a simple, configurable, and efficient way to combine trend-following signals with volatility-based position sizing.
📌 Key Features
Six Moving Averages (MA1 → MA6)
Toggle each MA on/off individually
Choose between EMA or SMA for each
Customize length and color
Perfect for spotting trend direction and pullback zones
ATR Display
Uses Wilder’s ATR formula (ta.rma(ta.tr(true), 14))
Can be calculated on current or higher timeframe
Adjustable multiplier for position sizing (e.g., 1.5× ATR stops)
Displays cleanly in the bottom-right corner
Custom Watermark
Displays symbol + timeframe in top-right
Adjustable color and size for streamers, screenshots, or clear charting
Compact UI
Organized with group and inline inputs for quick configuration
Lightweight and optimized for real-time performance
⚙️ How It Works
MAs: The script uses either ta.ema() or ta.sma() to compute each moving average based on the user-selected type and length.
ATR: The ATR is calculated using ta.rma(ta.tr(true), 14) (Wilder’s smoothing), and optionally scaled by a multiplier for easier use in risk management.
Tables: ATR value and watermark are displayed using table.new() so they stay anchored to the screen regardless of zoom level.
📈 How to Use
Enable the MAs you want to track and adjust their lengths, type, and colors.
Enable ATR if you want to see volatility — optionally select a higher timeframe for broader context.
Use MAs to:
Identify overall trend direction (e.g. price above MA20 = bullish)
Spot pullback zones for entries
See when multiple MAs cluster together as support/resistance zones
Use ATR value to:
Size your stop-loss dynamically (e.g. stop = entry − 1.5×ATR)
Detect volatility breakouts (ATR spikes = market expansion)
🎯 Recommended For
Day traders & swing traders
Trend-following & momentum strategies
Volatility-based risk management
Traders who want a clean, all-in-one dashboard






















