QQQ and SPY Price Levels [MW]Introduction:  
Don’t let SPY and QQQ resistance levels hurt your futures trading anymore. The QQQ and SPY Price Levels   indicator automagically provides easily accessible QQQ price levels for NASDAQ-related charts such as QQQ,  /NQ and /MNQ futures, and leveraged ETFs such as TQQQ and SQQQ as well as for SPY price levels for S&P 500-related charts such as SPY,  /ES and /MES futures, SPX, and leveraged ETFs such as UPRO and SPXU. If you’ve ever traded futures, or anything QQQ- or SPY-related and wanted to know at what price would the corresponding asset reach a key whole number level of QQQ or SPY, like 400, 440, 445, or even 447.50, this tool is for you. Key 10x, 5x, and even 2.5x multiples of QQQ and SPY can act as support or resistance for other related-assets. Until now, there hasn’t been an indicator that can serve as an easy visual cue to know exactly when that is about to happen across assets. 
This indicator is a fork of the original SPY Price Levels   indicator, which only considered SPY-related assets.
 Settings:  
 
   QQQ/SPY 2.5x:  Show closest levels above and below that are multiples of 2.5 on QQQ
   QQQ/SPY 5x:  Show closest levels above and below that are multiples of 5 on QQQ
   QQQ/SPY 10x:  Show closest levels above and below that are multiples of 10 on QQQ
   Show QQQ/SPY Price Label:  Show the current QQQ/SPY price
   Extend lines to the left:  Extend label lines for each price level to the beginning of the chart
 
 Calculations:  
This indicator defines the ratio between the price of QQQ/SPY and another NASDAQ/S&P-related asset and uses that multiplier once the user-defined price increments are defined. For example, if /MNQ is at 19000 and QQQ is at 465, then the ratio would be 40.8. 
The incremental QQQ levels that are above and below the QQQ price are calculated using the following equations:
 qqqLevelUp = _multiplier * math.ceil(_qqqClose / _multiplier)
qqqLevelDown = _multiplier * math.floor(_qqqClose / _multiplier) 
The conversion ratio is then multiplied by that amount to get the final estimated corresponding price using the calculation:
 levelUp := _conversion * qqqLevelUp
levelDown := _conversion * qqqLevelDown 
For leveraged assets, the conversion must be used on the difference between the current QQQ price and the incremental upper and lower levels.
For example, the calculation for the next level up looks like the following: 
 levelUpDelta := math.abs(_qqqClose - qqqLevelUp)
levelUp := close + _conversion * (levelUpDelta * _leverage) 
This logic is identical for SPY-related assets.
 How to Use:  
The QQQ and SPY Price Levels   indicator aims to be as unobtrusive as possible. The default view shows 3 labels and 2 lines that are all aligned to the right of the main chart, so that it interferes as little as possible with any other indicators. It can be added to any /NQ or /MNQ futures chart, SQQQ, TQQQ, and, of course, QQQ as well as any /ES /MES futures chart, SPXU, UPRO, SPX, and of course SPY. The most immediate price levels for each multiplier appears above and below the current price along with the price of QQQ/SPY.
For example, MNQU2024 is currently at 19594. By looking at the indicator the next QQQ increment below is at 475, or 19556 on the MNQU2024 chart. This potential support is marked with a green label that shows both prices. The next increment above is at QQQ 477.50, or 19659 on the MESU2024 chart. And the QQQ price itself, is also shown (and can be removed) at 475.92.
QQQ and SPY price increments of 2.5, 5, and 10 tend to consistently act at the very least as emotional support and resistance levels. Weak, or weakening volume and/or momentum when these levels are hit can trigger a strong rejection, and can sometimes precipitate lengthy consolidation periods at those levels. Watching an NASDAQ- and S&P 500-related asset come to a halt, fall off a cliff, or react in some other unintuitive way could very well be the result of a QQQ/SPY level being reached.  Even though many of us know that this relationship exists, it’s easy to forget. So, this indicator helps to ensure that its users keep that relationship front and center.
By extending the lines into the past on QQQ/SPY and their related assets, you can see what reactions happened at these key levels.
 Other Usage Notes and Limitations:  
The calculations used only provide an estimated relationship or a close approximation, and are not exact. 
It's important for traders to be aware of the limitations of any indicator and to use them as part of a broader, well-rounded trading strategy that includes risk management, fundamental analysis, and other tools that can help with reducing false signals, determining trend direction, and providing additional confirmation for a trade decision. Diversifying strategies and not relying solely on one type of indicator or analysis can help mitigate some of these risks.
חפש סקריפטים עבור "标准普尔500指数"
whookLibrary   "whook" 
This library provides functions for generating trading alerts for `whook`
check this -> github.com
Currently supported exchanges:
Kucoin futures
Bitget futures
Coinex futures
Bingx
OKX futures ( also its demo mode )
Bybit futures ( also Bybit testnet )
Binance futures ( also Binance futures testnet )
Phemex futures ( also Phemex testnet )
Kraken futures ( also Kraken futures testnet )
# --- Test Cases ---
Note: These test cases are for demonstration purposes only and may not cover all scenarios.
// buy(string account, float amount,  string unit = "units", float leverage = 1)
buy("MyAccount", 100, "units", 1)
buy("MyAccount", 1000, "USDT", 5)
buy("MyAccount", 50, "percent", 2)
// sell(string account, float amount,  string unit = "units", float leverage = 1)
sell("MyAccount", 50, "units", 1)
sell("MyAccount", 500, "USDT", 3)
sell("MyAccount", 25, "percent", 2)
// set_position(string account, float amount, string unit = "units", float leverage = 1)
set_position("MyAccount", 100, "units", 1)
set_position("MyAccount", 1000, "USDT", 5)
set_position("MyAccount", 50, "percent", 2)
// limit_buy(string account, float amount, float price, string unit = "units", float leverage = 1, string id = "")
limit_buy("MyAccount", 100, 10000, "units", 1, "MyBuyOrder")
limit_buy("MyAccount", 1000, 10500, "USDT", 5)
limit_buy("MyAccount", 50, 11000, "percent", 2)
// limit_sell(string account, float amount, float price, string unit = "units", float leverage = 1, string id = "")
limit_sell("MyAccount", 50, 10000, "units", 1, "MySellOrder")
limit_sell("MyAccount", 500, 9500, "USDT", 3)
limit_sell("MyAccount", 25, 9000, "percent", 2)
// close_percent(string account, float pct = 100)
close_percent("MyAccount", 100)
close_percent("MyAccount", 50)
 buy(account, amount, unit, leverage) 
  Sends a trading alert to execute a market buy order.
  Parameters:
     account (string) : The account ID.
     amount (float) : The amount to buy (can be in USD, units, or percentage).
     unit (string) : The unit of the amount (optional, defaults to "units").
     leverage (float) : The leverage to use (optional, defaults to 1x).
 sell(account, amount, unit, leverage) 
  Sends a trading alert to execute a market sell order.
  Parameters:
     account (string) : The account ID.
     amount (float) : The amount to sell (can be in USD, units, or percentage).
     unit (string) : The unit of the amount (optional, defaults to "units").
     leverage (float) : The leverage to use (optional, defaults to 1x).
 set_position(account, amount, unit, leverage) 
  Sends a trading alert to set a position.
  Parameters:
     account (string) : The account ID.
     amount (float) : The amount to set the position to (can be in USD, units, or percentage).
     unit (string) : The unit of the amount (optional, defaults to "units").
     leverage (float) : The leverage to use (optional, defaults to 1x).
 limit_buy(account, amount, price, unit, leverage, id) 
  Sends a trading alert to place a limit buy order.
  Parameters:
     account (string) : The account ID.
     amount (float) : The amount to buy (can be in USD, units, or percentage).
     price (float) : The limit price.
     unit (string) : The unit of the amount (optional, defaults to "units").
     leverage (float) : The leverage to use (optional, defaults to 1x).
     id (string) : An optional custom ID for the limit order.
 limit_sell(account, amount, price, unit, leverage, id) 
  Sends a trading alert to place a limit sell order.
  Parameters:
     account (string) : The account ID.
     amount (float) : The amount to sell (can be in USD, units, or percentage).
     price (float) : The limit price.
     unit (string) : The unit of the amount (optional, defaults to "units").
     leverage (float) : The leverage to use (optional, defaults to 1x).
     id (string) : An optional custom ID for the limit order.
 close_percent(account, pct) 
  Sends an alert to close a position on Phemex.
  Parameters:
     account (string) : The account ID.
     pct (float) : The percentage of the position to close (optional, defaults to 100%).
Higher Time Frame(HTF)The Higher Time Frame (HTF) will be displayed in a box. You can choose HTF periods from: 15min, 30min, 1hour, 2hour, 3hour, 4hour, 6hour, 8hour, 12hour, 1day, 1week, 2week, 4week, 1month, 2month, 3month, 4month, 6month, and 1year.
An error will occur if you set a period longer than the current candlestick period being displayed. The HTF Box can display a maximum of 500 boxes. There is no guarantee that all combinations of periods will work correctly.
----
上位足(Higher Time Frame, HTF) をボックスで表示します。
上位足の期間は、15分 30分 1時間 2時間 3時間 4時間 6時間 8時間 12時間 1日 1週 2週 4週 1月 2月 3月 4月 6月 1年から選べます。
表示しているローソク足の期間より長い期間を設定しないとエラーとなります。
上位足ボックスは最大500個表示することができます。
全ての期間の組み合わせで正しく動くことを保証するものではありません。
S&P Short-Range Oscillator**SHOULD BE USED ON THE S&P 500 ONLY**
The S&P Short-Range Oscillator (SRO), inspired by the principles of Jim Cramer's oscillator, is a technical analysis tool designed to help traders identify potential buy and sell signals in the stock market, specifically for the S&P 500 index. The SRO combines several market indicators to provide a normalized measure of market sentiment, assisting traders in making informed decisions.
The SRO utilizes two simple moving averages (SMAs) of different lengths: a 5-day SMA and a 10-day SMA. It also incorporates the daily price change and market breadth (the net change of closing prices). The 5-day and 10-day SMAs are calculated based on the closing prices. The daily price change is determined by subtracting the opening price from the closing price. Market breadth is calculated as the difference between the current closing price and the previous closing price.
The raw value of the oscillator, referred to as SRO Raw, is the sum of the daily price change, the 5-day SMA, the 10-day SMA, and the market breadth. This raw value is then normalized using its mean and standard deviation over a 20-day period, ensuring that the oscillator is centered and maintains a consistent scale. Finally, the normalized value is scaled to fit within the range of -15 to 15.
When interpreting the SRO, a value below -5 indicates that the market is potentially oversold, suggesting it might be a good time to start buying stocks as the market could be poised for a rebound. Conversely, a value above 5 suggests that the market is potentially overbought. In this situation, it may be prudent to hold on to existing positions or consider selling if you have substantial gains.
The SRO is visually represented as a blue line on a chart, making it easy to track its movements. Red and green horizontal lines mark the overbought (5) and oversold (-5) levels, respectively. Additionally, the background color changes to light red when the oscillator is overbought and light green when it is oversold, providing a clear visual cue.
By incorporating the S&P Short-Range Oscillator into your trading strategy, you can gain valuable insights into market conditions and make more informed decisions about when to buy, sell, or hold your stocks. However, always consider other market factors and perform your own analysis before making any trading decisions.
The S&P Short-Range Oscillator is a powerful tool for traders looking to gain insights into market sentiment. It provides clear buy and sell signals through its combination of multiple indicators and normalization process. However, traders should be aware of its lagging nature and potential complexity, and use it in conjunction with other analysis methods for the best results.
Disclaimer
The S&P Short-Range Oscillator is for informational purposes only and should not be considered financial advice. Trading involves risk, and you should conduct your own research or consult a financial advisor before making investment decisions. The author is not responsible for any losses incurred from using this indicator. Use at your own risk.
TASC 2024.08 Volume Confirmation For A Trend System█ OVERVIEW
This script demonstrates the use of volume data to validate price movements based on the techniques Buff Pelz Dormeier discusses in his "Volume Confirmation For A Trend System" article from the  August 2024 edition of TASC's Traders' Tips . It presents a trend-following system implementation that utilizes a combination of three indicators: the Average Directional Index (ADX), the Trend Thrust Indicator (TTI), and the Volume Price Confirmation Indicator (VPCI). 
█ CONCEPTS
In his article, Buff Pelz Dormeier recounts his search for an optimal trend-following strategy enhanced with volume data, starting with a simple system combining the  ADX ,  MACD , and  OBV  indicators. Even in these early tests, the author observed that the volume confirmation from OBV notably improved trading performance. Subsequently, the author replaced OBV with his VPCI, which considers the proportional weights of volume and price, to enhance the validation of trend momentum. Lastly, the author explored the inclusion of his TTI, a modified MACD that features volume-based enhancements, as a strategy component for improved trend-following performance. 
According to the author's research, the ADX+TTI+VPCI system outperformed similar strategies he tested in the article, yielding significantly higher returns and enhanced perceived reliability. Because the system's design revolves around catching pronounced trends, it performs best with a portfolio of individual stocks. The author applies the system in the article by allocating 5% of the equity to long positions in S&P 500 components that meet the ADX+TTI+VPCI entry criteria (see the Calculations section below for details). He uses the proceeds from closing positions to enter new positions in other stocks meeting the screening criteria, holding any excess proceeds in cash.
█ CALCULATIONS
The  TTI  is similar to the MACD. Its calculation entails the following steps:
 
 Calculate fast (short-term) and slow (long-term) volume-weighted moving averages (VWMAs).
 Compute the volume multiple (VM) as the square of the ratio of the fast VWMA to the slow VWMA.
 Adjust these averages by multiplying the fast VWMA by the VM and dividing the slow VWMA by the VM. 
 Calculate the difference between the adjusted VWMAs to determine the TTI value, and take the average of that series to determine the signal line value. 
The  VPCI  utilizes differences and ratios between VWMAs and corresponding simple moving averages (SMAs) to provide an alternative volume-price confirmation tool. Its calculation is as follows:
 
 Subtract the slow SMA from the VWMA of the same length to calculate the volume-price confirmation/contradiction (VPC) value. 
 Divide the fast VWMA by the corresponding fast SMA to determine the volume-price ratio (VPR).
 Divide the short-term VWMA by the long-term VWMA to calculate the VM. 
 Compute the VPCI as the product of the VPC, VPR, and VM values. 
The  long entry criteria  of the ADX+TTI+VPCI system are as follows:
 
 The ADX is above 30.
 The TTI crosses above its signal line.
 The VPCI is above 0, confirming the trend. 
Signals to close positions occur when the VPCI is below 0, indicating a  contradiction .
NOTE: Unlike in the article, this script applies the ADX+TTI+VPCI system to  one stock at a time , not a portfolio of S&P 500 constituents. 
█ DISCLAIMER
This strategy script educates users on the trading system outlined by the TASC article. By default, it uses 10% of equity as the order size and a slippage amount of 5 ticks. Traders should adjust these settings and the commission amount when using this script.
Trend Forecasting - The Quant Science🌏 Trend Forecasting | ENG 🌏 
This plug-in acts as a statistical filter, adding new information to your chart that will allow you to quickly verify the direction of a trend and the probability with which the price will be above or below the average in the future, helping you to uncover probable market inefficiencies. 
🧠  Model calculation 
The model calculates the arithmetic mean in relation to positive and negative events within the available sample for the selected time series. Where a positive event is defined as a closing price greater than the average, and a negative event as a closing price less than the average. Once all events have been calculated, the probabilities are extrapolated by relating each event. 
 Example 
 
 Positive event A: 70
 Negative event B: 30 
 Total events: 100
 Probabilities A: (100 / 70) x 100 = 70%
  Probabilities B: (100 / 30) x 100 = 30%
 
 Event A  has a 70% probability of occurring compared to  Event B  which has a 30% probability.
🔍 Information Filter 
The data on the graph show the future probabilities of prices being above average (default in green) and the probabilities of prices being below average (default in red). 
The information that can be quickly retrieved from this indicator is:
 1. Trend:  Above-average prices together with a constant of data in green greater than 50% + 1 indicate that the observed historical series shows a bullish trend. The probability is correlated proportionally to the value of the data; the higher and increasing the expected value, the greater the observed bullish trend. On the other hand, a below-average price together with a red-coloured data constant show quantitative data regarding the presence of a bearish trend.
 2. Future Probability:  By analysing the data, it is possible to find the probability with which the price will be above or below the average in the future. In green are classified the probabilities that the price will be higher than the average, in red are classified the probabilities that the price will be lower than the average.
🔫  Operational Filter .
The indicator can be used operationally in the search for investment or trading opportunities given its ability to identify an inefficiency within the observed data sample. 
⬆  Bullish forecast 
For bullish trades, the inefficiency will appear as a historical series with a bullish trend, with high probability of a bullish trend in the future that is currently below the average. 
  
⬇  Bearish forecast 
For short trades, the inefficiency will appear as a historical series with a bearish trend, with a high probability of a bearish trend in the future that is currently above the average.
  
📚 Settings 
 
 Input:  via the Input user interface, it is possible to adjust the periods (1 to 500) with which the average is to be calculated. By default the periods are set to 200, which means that the average is calculated by taking the last 200 periods. 
 Style:  via the Style user interface it is possible to adjust the colour and switch a specific output on or off. 
 
 🇮🇹Previsione Della Tendenza Futura | ITA 🇮🇹 
Questo plug-in funge da filtro statistico, aggiungendo nuove informazioni al tuo grafico che ti permetteranno di verificare rapidamente tendenza di un trend, probabilità con la quale il prezzo si troverà sopra o sotto la media in futuro aiutandoti a scovare probabili inefficienze di mercato. 
🧠  Calcolo del modello 
Il modello calcola la media aritmetica in relazione con gli eventi positivi e negativi all'intero del campione disponibile per la serie storica selezionata. Dove per evento positivo si intende un prezzo alla chiusura maggiore della media, mentre per evento negativo si intende un prezzo alla chiusura minore della media. Calcolata la totalità degli eventi le probabilità vengono estrapolate rapportando ciascun evento. 
 Esempio 
 
 Evento positivo A: 70
 Evento negativo B: 30 
 Totale eventi : 100
 Formula A: (100 / 70) x 100 = 70%
 Formula B: (100 / 30) x 100 = 30%
 
 Evento A  ha una probabilità del 70% di realizzarsi rispetto all'  Evento B  che ha una probabilità pari al 30%.
🔍 Filtro informativo 
I dati sul grafico mostrano le probabilità future che i prezzi siano sopra la media (di default in verde) e le probabilità che i prezzi siano sotto la media (di default in rosso). 
Le informazioni che si possono rapidamente reperire da questo indicatore sono:
 1. Trend:  I prezzi sopra la media insieme ad una costante di dati in verde maggiori al 50% + 1 indicano che la serie storica osservata presenta un trend rialzista. La probabilità è correlata proporzionalmente al valore del dato; tanto più sarà alto e crescente il valore atteso e maggiore sarà la tendenza rialzista osservata. Viceversa, un prezzo sotto la media insieme ad una costante di dati classificati in colore rosso mostrano dati quantitativi riguardo la presenza di una tendenza ribassista.
 2. Probabilità future:  analizzando i dati è possibile reperire la probabilità con cui il prezzo si troverà sopra o sotto la media in futuro. In verde vengono classificate le probabilità che il prezzo sarà maggiore alla media, in rosso vengono classificate le probabilità che il prezzo sarà minore della media.
🔫  Filtro operativo 
L' indicatore può essere utilizzato a livello operativo nella ricerca di opportunità di investimento o di trading vista la capacità di identificare un inefficienza all'interno del campione di dati osservato. 
⬆  Previsione rialzista 
Per operatività di tipo rialzista l'inefficienza apparirà come una serie storica a tendenza rialzista, con alte probabilità di tendenza rialzista in futuro che attualmente si trova al di sotto della media. 
  
⬇  Previsione ribassista 
Per operatività di tipo short l'inefficienza apparirà come una serie storica a tendenza ribassista, con alte probabilità di tendenza ribassista in futuro che si trova attualmente sopra la media.
  
📚 Impostazioni 
 
 Input:  tramite l'interfaccia utente Input è possibile regolare i periodi (da 1 a 500) con cui calcolare la media. Di default i periodi sono impostati sul valore di 200, questo significa che la media viene calcolata prendendo gli ultimi 200 periodi. 
 Style:  tramite l'interfaccia utente Style è possibile regolare il colore e attivare o disattivare un specifico output. 
 
CNN Fear and Greed IndexThe “CNN Fear and Greed Index” indicator in this context is designed to gauge market sentiment based on a combination of several fundamental indicators. Here’s a breakdown of how this indicator works and what it represents:
Components of the Indicator:
	1.	Stock Price Momentum:
	•	Calculates the momentum of the S&P 500 index relative to its 125-day moving average. Momentum is essentially the rate of acceleration or deceleration of price movements over time.
	2.	Stock Price Strength:
	•	Measures the breadth of the market by comparing the number of stocks hitting 52-week highs versus lows. This provides insights into the overall strength or weakness of the market trend.
	3.	Stock Price Breadth:
	•	Evaluates the volume of shares trading on the rise versus the falling volume. Higher volume on rising days suggests positive market breadth, while higher volume on declining days indicates negative breadth.
	4.	Put and Call Options Ratio (Put/Call Ratio):
	•	This ratio indicates the sentiment of investors in the options market. A higher put/call ratio typically signals increased bearish sentiment (more puts relative to calls) and vice versa.
	5.	Market Volatility (VIX):
	•	Also known as the “fear gauge,” the VIX measures the expected volatility in the market over the next 30 days. Higher VIX values indicate higher expected volatility and often correlate with increased fear or uncertainty in the market.
	6.	Safe Haven Demand:
	•	Compares the returns of stocks (represented by S&P 500) versus safer investments like 10-year Treasury bonds. Higher returns on bonds relative to stocks suggest a flight to safety or risk aversion.
	7.	Junk Bond Demand:
	•	Measures the spread between yields on high-yield (junk) bonds and investment-grade bonds. Widening spreads may indicate increasing risk aversion as investors demand higher yields for riskier bonds.
Normalization and Weighting:
	•	Normalization: Each component is normalized to a scale of 0 to 100 using a function that adjusts the range based on historical highs and lows of the respective indicator.
	•	Weighting: The user can adjust the relative importance (weight) of each component using input parameters. This customization allows for different interpretations of market sentiment based on which factors are considered more influential.
Fear and Greed Index Calculation:
	•	The Fear and Greed Index is calculated as a weighted average of all normalized components. This index provides a single numerical value that summarizes the overall sentiment of the market based on the selected indicators.
Usage:
	•	Visualization: The indicator plots the Fear and Greed Index and its components on the chart. This allows traders and analysts to visually assess the sentiment trends over time.
	•	Analysis: Changes in the Fear and Greed Index can signal shifts in market sentiment. For example, a rising index may indicate increasing greed and potential overbought conditions, while a falling index may suggest increasing fear and potential oversold conditions.
	•	Customization: Traders can customize the indicator by adjusting the weights assigned to each component based on their trading strategies and market insights.
By integrating multiple fundamental indicators into a single index, the “CNN Fear and Greed Index” provides a comprehensive snapshot of market sentiment, helping traders make informed decisions about market entry, exit, and risk management strategies.
Volume Positive & Negative Levels [ChartPrime]Volume Positive & Negative Levels  
 Overview: 
The Volume Positive & Negative Levels indicator by ChartPrime is designed to provide traders with a clear visualization of volume activity across different price levels. By plotting volume levels as histograms, this tool helps identify significant areas of buying (positive volume) and selling (negative volume) pressure, enhancing the ability to spot potential support and resistance zones.
 Key Features: 
⯁  Lookback Period: 
 
    - The `lookbackPeriod` parameter, set to 500 bars, determines the range over which the volume analysis is conducted, ensuring a comprehensive view of the market’s volume activity. The maximum lookback period is 500 bars or the bars currently visible on the chart, whichever is smaller.
 
  
⯁  Dynamic Volume Calculation: 
 
    - Volume is calculated dynamically based on the price action, with positive volume indicating buying pressure (close > open) and negative volume indicating selling pressure (close < open).
 
⯁  Color Coding for Clarity: 
 
    - Positive Volume: Represented with a distinct color (`#ad9a2c`), making it easy to identify areas of buying interest.
    - Negative Volume: Highlighted with another color (`#ad2cad`), simplifying the detection of selling pressure.
 
  
 Volume Threshold and Bins: 
 
    - The indicator allows users to set a volume threshold (`volume_level`) to highlight significant volume levels, with the default set at 70.
    - The number of bins (`numBins`) defines the granularity of the volume profile, with a higher number providing more detail.
 
  
⯁  Volume Profile Visualization: 
 
    - The volume profile is plotted as a histogram, with the height of each bar proportional to the volume at that price level. This visualization helps in quickly assessing the strength of volume at various price points.
 
  
⯁  Interactive Labels and Threshold Indicators: 
 
    - Labels: The indicator uses labels to mark significant volume levels, providing quick reference points for traders.
    - Threshold Lines: Lines are drawn at specified volume thresholds, with colors and widths dynamically adjusted based on the volume levels.
 
⯁  User Inputs: 
 
 - Volume Threshold (`volume_level`): Sets the minimum volume required to highlight significant levels.
 - Number of Bins (`numBins`): Determines the resolution of the volume profile.
 - Line Width (`line_withd`): Specifies the width of the lines used in the visualization.
 
The Volume Positive & Negative Levels indicator is a powerful tool for traders looking to gain deeper insights into market dynamics. By providing a clear visual representation of volume activity across different price levels, it helps traders identify key support and resistance zones, spot trends, and make more informed trading decisions. Whether you are a day trader or a swing trader, this indicator enhances your ability to analyze volume data effectively, improving your overall trading strategy.
Comprehensive Correlation Meter with Multiple MarketsThe Comprehensive Correlation Meter is designed to provide traders and investors with insights into the relationships between multiple financial instruments. This script expands upon an existing idea on TradingView about correlation by introducing the ability to analyze the correlation between three markets, offering deeper insights into market relationships. It helps users understand how these markets move in relation to each other, aiding in risk management and portfolio diversification.
Key Features:
Multiple Market Analysis: This script allows you to analyze the correlation between your primary market and two other selected markets.
Customizable Inputs: Users can select any symbols for the reference and third markets, and these selections must be confirmed before use.
Correlation Coefficients: Calculates and plots the correlation coefficients for:
Current Market vs. Reference Market
Third Market vs. Reference Market
Current Market vs. Third Market
An average correlation of all three markets combined.
Visual Aids: Plots reference lines at +1, 0, and -1 to indicate maximum positive correlation, no correlation, and maximum negative correlation.
How It Works:
Input Symbols: Select the symbols for the reference and third markets. The current market is based on the chart you are viewing.
Data Collection: The script collects the closing prices of the selected markets and calculates the percentage changes.
Correlation Calculation: Using the collected data, the script computes the covariance and standard deviations to determine the correlation coefficients.
Visualization: The correlation coefficients and covariances are plotted for visual analysis.
How to Use:
Select Symbols:
Use the input fields to specify the reference and third market symbols. Confirm your selections to proceed.
Customize Display:
Choose whether to display the covariance, reference market, current market, and third market.
Select which correlation coefficients to display.
Interpret Results:
A correlation coefficient close to +1 indicates a strong positive correlation.
A coefficient close to -1 indicates a strong negative correlation.
A coefficient around 0 indicates little to no correlation.
Use these insights to manage risk and diversify your portfolio effectively.
Example Use Case:
Suppose you are trading the S&P 500 and want to understand its correlation with the NASDAQ 100 and a particular stock, such as Apple. By setting the S&P 500 as the reference market, the NASDAQ 100 as the third market, and observing the current market (Apple), you can see how these instruments move in relation to each other. This can help you decide on hedging strategies or identify opportunities for diversification. However this is Not a Financial advise
[EVI]Enhanced Volume IndicatorEnglish Version
Enhanced Volume Indicator (EVI)
The Enhanced Volume Indicator (EVI) is an advanced yet user-friendly tool designed to measure and visualize the strength of market volume using the statistical power of standard deviation. By offering a clear and dynamic representation of volume fluctuations, the EVI enables traders to effortlessly identify significant market movements and potential trading opportunities.
Key Features:
Sophisticated Volume Strength Assessment: The EVI leverages the standard deviation of historical candle volumes to evaluate and categorize the current volume intensity. This sophisticated methodology allows for the precise detection of when current volume levels significantly deviate from their historical norms.
Intuitive Visual Cues: Volume bars are color-coded to represent varying levels of volume intensity, ranging from very weak to very strong. This intuitive visual differentiation aids traders in quickly grasping the market's underlying volume dynamics at a glance.
Proactive Threshold Alerts: Stay ahead of the market with the EVI’s built-in alert functionality. Receive real-time notifications of critical volume changes, ensuring that you remain informed of significant market developments even while away from your trading desk.
How It Works:
The EVI calculates the Simple Moving Average (SMA) and Standard Deviation (STDEV) of volume over a user-defined period (default set to 500 candles). Utilizing these statistical measures, the indicator establishes various volume thresholds by applying predefined multipliers for extreme, high, medium, and low volume levels. The volume bars are then color-coded based on these thresholds, providing traders with a clear visual representation of volume intensity. Additionally, horizontal lines indicating these thresholds are plotted on the chart for easy reference, further enhancing the indicator’s usability.
This version of the EVI is particularly suited for traders who prefer simplicity and efficiency over complexity, making it an excellent alternative to the more intricate Volume Delta Divergence (VDD) indicator. The EVI delivers powerful volume insights in a straightforward and accessible manner, ensuring that even those who favor less complexity can benefit from robust volume analysis.
Ideal for traders seeking to capture major market moves or pinpoint potential reversals, the Enhanced Volume Indicator (EVI) is a must-have tool. Elevate your trading strategy with the EVI and ensure you never miss out on significant volume breakouts again.
Korean Version
Enhanced Volume Indicator (EVI)
Enhanced Volume Indicator (EVI)는 시장 볼륨의 강도를 표준편차의 통계적 힘을 사용하여 측정하고 시각화하는 고급적이면서도 사용하기 쉬운 도구입니다. EVI는 볼륨 변동의 명확하고 동적인 표현을 제공하여 트레이더가 중요한 시장 움직임과 잠재적인 거래 기회를 쉽게 식별할 수 있도록 합니다.
주요 기능:
정교한 볼륨 강도 평가: EVI는 이전 캔들의 볼륨 표준편차를 활용하여 현재 볼륨 강도를 평가하고 분류합니다. 이 정교한 방법론은 현재 볼륨 수준이 과거 평균에서 크게 벗어날 때를 정확하게 감지할 수 있도록 합니다.
직관적인 시각적 신호: 볼륨 바는 매우 약한 것부터 매우 강한 것까지 다양한 볼륨 강도를 나타내는 색상으로 코딩됩니다. 이 직관적인 시각적 차별화는 트레이더가 시장의 기본적인 볼륨 동향을 한눈에 쉽게 파악할 수 있도록 돕습니다.
선제적 임계값 알림: EVI의 내장 알림 기능으로 시장을 앞서가십시오. 중요한 볼륨 변화에 대한 실시간 알림을 받아 거래 데스크를 떠나 있는 동안에도 중요한 시장 발전에 대해 계속 정보를 얻을 수 있습니다.
작동 원리:
EVI는 사용자가 정의한 기간(기본값은 500 캔들)의 볼륨에 대한 단순 이동평균(SMA)과 표준편차(STDEV)를 계산합니다. 이러한 통계적 측정을 활용하여, 인디케이터는 극단적, 높은, 중간 및 낮은 볼륨 수준에 대한 사전 정의된 배수를 적용하여 다양한 볼륨 임계값을 설정합니다. 그런 다음, 볼륨 바는 이러한 임계값을 기반으로 색상 코딩되어 트레이더에게 볼륨 강도의 명확한 시각적 표현을 제공합니다. 또한, 이러한 임계값을 나타내는 수평선이 차트에 참조용으로 표시되어 인디케이터의 사용성을 더욱 향상시킵니다.
이 버전의 EVI는 복잡함보다는 단순함과 효율성을 선호하는 트레이더에게 특히 적합하여, 더 복잡한 Volume Delta Divergence (VDD) 인디케이터에 대한 훌륭한 대안이 됩니다. EVI는 강력한 볼륨 정보를 간단하고 접근 가능한 방식으로 제공하여, 복잡함을 싫어하는 사용자도 강력한 볼륨 분석의 혜택을 누릴 수 있도록 합니다.
주요 시장 움직임을 포착하거나 잠재적인 반전을 식별하려는 트레이더에게 이상적인 Enhanced Volume Indicator (EVI)는 반드시 갖추어야 할 도구입니다. EVI로 트레이딩 전략을 강화하고 중요한 볼륨 돌파를 절대 놓치지 마세요.
The Next Pivot (With History) [Mxwll]Introducing "The Next Pivot (With History)"!
With permission from the author @KioseffTrading 
The script "The Next Pivot" has been restructured to show historical projections!
 Features 
 
 Find the most similar price sequence per time frame change.
 Forecast almost  any  public indicator! Not just price!
 Forecast any session i.e. 4Hr, 1Hr, 15m, 1D, 1W
 Forecast ZigZag for any session
 Spearmen
 Pearson
 Absolute Difference
 Cosine Similarity
 Mean Squared Error
 Kendall
 Forecasted linear regression channel
 
  
The image above shows/explains some of the indicator's capabilities!
Additionally, you can project almost any indicator!
  
Should load times permit it, the script can search all bar history for a correlating sequence. This won't always be possible, contingent on the forecast length, correlation length, and the number of bars on the chart. 
  
 If a load time error occurs, simple reduce the "Bars Back To Search" parameter! 
 The script can only draw 500 bars into the future. For whatever time frame you are on and the session you wish to project, ensure it will not exceeded a 500-bar forecast! 
 Reasonable Assessment 
The script uses various similarity measures to find the "most similar" price sequence to what's currently happening. Once found, the subsequent price move (to the most similar sequence) is recorded and projected forward.
So,
1: Script finds most similar price sequence
2: Script takes what happened after and projects forward
While this may be useful, the projection is simply the reaction to a possible one-off "similarity" to what's currently happening. Random fluctuations are likely and, if occurring, similarities between the current price sequence and the "most similar" sequence are plausibly coincidental.
Thanks!
VIX and SKEW RSI Moving AveragesSKEW and VIX are both indicators of market volatility and risk, but they represent different aspects.
 VIX (CBOE Volatility Index) :.
The VIX is a well-known indicator for predicting future market volatility. It is calculated primarily based on S&P 500 options premiums and indicates the degree of market instability and risk.
Typically, when the VIX is high, market participants view the future as highly uncertain and expect sharp volatility in stock prices. It is generally considered an indicator of market fear.
 SKEW Index :.
The SKEW is a measure of how much market participants estimate the risk of future declines in stock prices, calculated by the CBOE (Chicago Board Options Exchange) and derived from the premium on S&P 500 options.
If the SKEW is high, market participants consider the risk of future declines in stock prices to be high. This generally indicates a "fat tail at the base" of the market and suggests that the market perceives it as very risky.
These indicators are used by market participants to indicate their concerns and expectations about future stock price volatility. In general, when the VIX is high and the SKEW is high, the market is considered volatile and risky. Conversely, when the VIX is low and the SKEW is low, the market is considered relatively stable and low risk.
 Inverse Relationship between SKEW and VIX 
It is often observed that there is an inverse correlation between SKEW and VIX. In general, the relationship is as follows
High VIX and low SKEW: When the VIX is high and the SKEW is low, the market is considered volatile while the risk of future stock price declines is low. This indicates that the market is exposed to sharp volatility, but market participants do not expect a major decline.
Low VIX and High SKEW: A low VIX and high SKEW indicates that the market is relatively stable, while the risk of future declines in stock prices is considered high. This indicates that the market is calm, but market participants are wary of a sharp future decline.
This inverse correlation is believed to be the result of market participants' psychology and expectations affecting the movements of the VIX and SKEW. For example, when the VIX is high, it is evident that the market is volatile, and under such circumstances, people tend to view the risk of a sharp decline in stock prices as low. Conversely, when the VIX is low, the market is considered relatively stable and the risk of future declines is likely to be higher.
 SKEWVIX RSIMACROSS 
In order to compare the trends of the SKEW and VIX, the 50-period moving average of the Relative Strength Index (RSI) was used for verification. the RSI is an indicator of market overheating or overcooling, and the 50-period moving average can be used to determine the medium- to long-term trend. This analysis reveals how the inverse correlation between the SKEW and the VIX relates to the long-term moving average of the RSI.
 how to use 
 Moving Average Direction 
Rising blue for VIXRSI indicates increased uncertainty in the market
Rising red for SKEWRSI indicates optimism and beyond
 RSI moving average crossing 
When the SKEW is dominant, market participants are considered less concerned about a black swan event (significant unexpected price volatility). This suggests that the market is stable and willing to take risks. On the other hand, when the VIX is dominant, it indicates increased market volatility. Investors are more concerned about market uncertainty and tend to take more conservative positions to avoid risk. The direction of the moving averages and the crossing of the moving averages of the two indicators can give an indication of the state of the market.
SKEW>VIX Optimistic/Goldilocks
VIX>SKEW Uncertainty/turbulence
The market can be judged as follows.
BestRegards
Buffett IndicatorThis is an open-source version of the Buffett indicator. The old version was code-protected and broken, so I created another version.
It's computed simply as the entire SPX 500 capitalization divided by the US GDP. Since TradingView does not have data for the SPX 500 capitalization, I used quarterly values of SPX devisors as a proxy.  
I tried to create another version of the Buffett indicator for other countries/indexes, but I can't find the data. If you can help me find data for index divisors, I can add more choices to this indicator. 
It's interesting to see how this indicator's behavior has changed in the last few years. Levels that looked crazy are not so crazy anymore. 
 Disclaimer 
Please remember that past performance may not be indicative of future results.
Due to various factors, including changing market conditions, the strategy may no longer perform as well as in historical backtesting.
This post and the script don’t provide any financial advice.
ATR Bands (Keltner Channel), Wick and SRSI Signals [MW]Introduction 
This indicator uses a novel combination of ATR Bands, candle wicks crossing the ATR upper and lower bands, and baseline, and combines them with the Stochastic SRSI oscillator to provide early BUY and SELL signals in uptrends, downtrends, and in ranging price conditions.
 How it’s unique 
People generally understand Bollinger Bands and Keltner Channels. Buy at the bottom band, sell at the top band. However, because the bands themselves are not static, impulsive moves can render them useless. People also generally understand wicks. Candles with large wicks can represent a change in pattern, or volatile price movement. Combining those two to determine if price is reaching a pivot point is relatively novel. When Stochastic RSI (SRSI) filtering is also added, it becomes a genuinely unique combination that can be used to determine trade entries and exits.
 What’s the benefit 
The benefit of the indicator is that it can help potentially identify pivots WHEN THEY HAPPEN, and with potentially minimal retracement, depending on the trader’s time window.  Many indicators wait for a trend to be established, or wait for a breakout to occur, or have to wait for some form of confirmation. In the interpretation used by this indicator, bands, wicks, and SRSI cycles provide both the signal and confirmation.
It takes into account 3 elements:
 
 Price approaching the upper or lower band or the baseline - MEANING: Price is becoming extended based on calculations that use the candle trading range.
 A candle wick of a defined proportion (e.g. wick is 1/2 the size of a full candle OR candle body) crosses a band or baseline, but the body does not cross the band or baseline - MEANING: Buyers and sellers are both very active.
 The Stochastic RSI reading is above 80 for SELL signals and below 20 for BUY signals - MEANING: Additional confirmation that price is becoming extended based on the current cyclic price pattern.
 
 How to Use 
SIGNALS
Buy Signals - Green(ish):
 B Signal  - Potential pivot up from the lower band when using the preferred multiplier
 B1 Signal  - Potential pivot up from the lower band when using phi * multiplier
 B2 Signal  - Potential pivot up from the lower band when using 1/2 * multiplier
 B3 Signal  - Potential pivot up from baseline
Sell Signals - Red(ish):
 S Signal  - Potential pivot down from the upper band when using the preferred multiplier
 S1 Signal  - Potential pivot down from the upper band when using
 S2 Signal  - Potential pivot down from the upper band when using 1/2 * multiplier
 S3 Signal  - Potential pivot down from the baseline
DISCUSSION
During an uptrend or downtrend, signals from the baseline can help traders identify areas where they may enter the trending move with the least amount of drawdown. In both cases, entry points can occur with baseline signals in the direction of the trend. 
For example, in an uptrend (when the price is forming higher highs and higher lows, or when the baseline is rising), price tends to oscillate between the upper band and baseline. In this case, the baseline BUY signal (B3) can show an entry point.
In a downtrend (when the price is forming lower highs and lower lows, or when the baseline is falling), price tends to oscillate between the baseline and the lower band. In this case, the baseline SELL signal (S3) can show an entry point.
During consolidation, when price is ranging, price tends to oscillate between the upper and lower bands, while crossing through the baseline unperturbed. Here, entry points can occur at the upper and lower bands. 
When all conditions are met at the lower band during consolidation, a BUY signal (B), can occur. This signal may also occur prior to a break out of consolidation to the upside.
When all conditions are met at the upper band during consolidation, a SELL signal (S), can occur. This signal may also occur prior to a break out of consolidation to the downside.
Additional B1, B2, and S1, and S2 signals can be displayed that use the bands based on a multiplier that is half that of the primary one, and phi (0.618) times the primary multiplier as a way to quickly check for signals occurring along different, but related, bands.
 Calculations 
ATR Bands, or Keltner Channels, are a technical analysis tool that are used to measure market volatility and identify overbought or oversold conditions in the trading of financial instruments, such as stocks, bonds, commodities, and currencies.  ATR Bands consist of three lines plotted on a price chart:
Middle Band, Basis, or Baseline: This is typically a simple moving average (SMA) of the closing prices over a certain period. It represents the intermediate-term trend of the asset's price.
Upper Band: This is calculated by adding a certain number of ATRs to the middle band (SMA). The upper band adjusts itself with the increase in volatility.
Lower Band: This is calculated by subtracting the same number of ATRs from the middle band (SMA). Like the upper band, the lower band adjusts to changes in volatility.
The candle wick signals occur if the wick is at the specified ratio compared to either the entire candle or the candle body. The upper band, lower band, and baseline signals happen if the wick is the specified ratio of the total candle size. For the major signals for upper and lower bands, these occur when the wick extends outside of the bands while closing a candle inside of the bands. For the baseline signals, they occur if a wick crosses a baseline but closes on the other side.
 Settings 
CHANNEL SETTINGS
 
 Baseline EMA Period (Default: 21): Period length of the moving average basis line.
 ATR Period (Default: 21): The number of periods over which the Average True Range (ATR) is calculated.
 Basis MA Type (Default: SMA): The moving average type for the basis line.
 Multiplier (Default: 2.5: The deviation multiplier used to calculate the band distance from the basis line.
 
ADDITIONAL CHANNELS
 
 Half of Multiplier Offset (Default: True): Toggles the display of the ATR bands that are set a distance of half of the ATR multiplier.
 Quarter of Multiplier Offset (Default: false): Toggles the display of the ATR bands that are set a distance of one quarter of the ATR multiplier.
 Phi (Φ) Offset (Default: false): Toggles the display of the ATR bands that are set a distance of phi (Φ) times the ATR multiplier.
 
WICK SETTINGS FOR CANDLE FILTERS
 
 Wick Ratio for Bands (Default: 0.4): The ratio of wick size to total candle size for use at upper and lower bands.
 Wick Ratio for Baseline (Default: 0.4): The ratio of wick size to total candle size for use at baseline.
 Use Candle Body (rather than full candle size) (Default: false): Determines whether wick calculations use the candle body or the entire candle size.
 
VISUAL PREFERENCES - SIGNALS
 
 Show Signals (Default: true): Allows signal labels to be shown.
 Show Signals from 1/2 Band Offset (Default: false): Toggle signals originating from 1/2 offset upper and lower bands.
 Show Signals from Phi (Φ) Band Offset (Default: false): Toggle signals originating from phi (Φ) offset upper and lower bands.
 Show Baseline Signals (Default: false): Toggle Baseline signals.
 
VISUAL PREFERENCES - BANDS
 
 Show ATR (Keltner) Bands (Default: true): Use a background color inside the Bollinger Bands.
 Fill Bands (Default: true): Use a background color inside the Bollinger Bands.
 
STOCHASTIC SETTINGS 
 
 Use Stochastic RSI Filtering (Default: False): This will only trigger some SELL signals when the stochastic RSI is above 80, and BUY signals when below 20.
 K (Default: 3): The smoothing level for the Stochastic RSI.
 RSI Length (Default: 14): The period length for the RSI calculation.
 Stochastic Length (Default: 8): The period length over which the stochastic calculation is performed.
 
 Other Usage Notes and Limitations 
To understand future price movement, this indicator assumes that 3 things must be known:
 
 Evidence of a change of market structure. This can be demonstrated by increased volatility, consolidation, volume spikes (which can be tracked with the MW Volume Impulse Indicator) or, in the case of this indicator, candle wicks. 
 The potential cause of the change. It could be a VWAP line (which can be tracked with the Multi VWAP  , and Multi VWAP from Gaps   indicators), an event, an important support or resistance level, a key moving average, or many other things. This indicator assumes the ATR bands can be a cause.
 The current position in the price cycle. Oscillators like the RSI, and MACD, are typical measures of price oscillation (other oscillators like the Price and Volume Stochastic Divergence   indicator can also be useful). This indicator uses the Stochastic RSI oscillator to determine overbought and oversold conditions.
 
When evidence of the change appears, and the potential cause of the change is identified, and the price oscillation is at a favorable position for the desired trading direction, this indicator will generate a signal.
ATR Bands (or Keltner Channels) are used to determine when price might “revert to the mean”. Crossing, or being near the upper or lower band, can indicate an overbought or oversold condition, which could lead to a price reversal. By tracking the behavior of candle wicks during these events, we can see how active the battle is between buyers and sellers. 
If the top of a wick is large, it may indicate that sellers are aggressively attempting to bring the price down. Conversely, if the bottom wick is large, it can indicate that buyers are actively trying to counter the price action caused by selling pressure.
When this wicking action occurs at times when price is not near the upper band, lower band, or baseline, it could indicate the presence of an important level. That could mean a nearby VWAP line, a supply or demand zone, a round price number, or a number of other factors. In any case, this wick may be the first indication of a price reversal.
Shorter baseline periods may be better for short period trading like scalping or day trading, while longer period baselines can show signals that are better suited to swing trading, or longer term investing. 
It's important for traders to be aware of the limitations of any indicator and to use them as part of a broader, well-rounded trading strategy that includes risk management, fundamental analysis, and other tools that can help with reducing false signals, determining trend direction, and providing additional confirmation for a trade decision. Diversifying strategies and not relying solely on one type of indicator or analysis can help mitigate some of these risks.
The TradingView platform allows a maximum of 500 labels per chart. This means that if your settings allow for a lot of signals, labels for earlier ones may not appear if the total number of labels exceeds 500 for the chart.
Bollinger Band Wick and SRSI Signals [MW]Introduction 
This indicator uses a novel combination of Bollinger Bands, candle wicks crossing the upper and lower Bollinger Bands and baseline, and combines them with the Stochastic SRSI oscillator to provide early BUY and SELL signals in uptrends, downtrends, and in ranging price conditions.
 How it’s unique 
People generally understand Bollinger Bands and Keltner Channels. Buy at the bottom band, sell at the top band. However, because the bands themselves are not static, impulsive moves can render them useless. People also generally understand wicks. Candles with large wicks can represent a change in pattern, or volatile price movement. Combining those two to determine if price is reaching a pivot point is relatively novel. When Stochastic RSI (SRSI) filtering is also added, it becomes a genuinely unique combination that can be used to determine trade entries and exits.
 What’s the benefit 
The benefit of the indicator is that it can help potentially identify pivots WHEN THEY HAPPEN, and with potentially minimal retracement, depending on the trader’s time window.  Many indicators wait for a trend to be established, or wait for a breakout to occur, or have to wait for some form of confirmation. In the interpretation used by this indicator, bands, wicks, and SRSI cycles provide both the signal and confirmation.
It takes into account 3 elements:
 
 Price approaching the upper or lower band or the baseline - MEANING: Price is becoming extended based on calculations that use the candle trading range.
 A candle wick of a defined proportion (e.g. wick is 1/2 the size of a full candle OR candle body) crosses a band or baseline, but the body does not cross the band or baseline - MEANING: Buyers and sellers are both very active.
 The Stochastic RSI reading is above 80 for SELL signals and below 20 for BUY signals - MEANING: Additional confirmation that price is becoming extended based on the current cyclic price pattern.
 
 How to Use 
SIGNALS
Buy Signals - Green(ish):
 B Signal  - Potential pivot up from the lower band when using the preferred multiplier
 B1 Signal  - Potential pivot up from baseline
Sell Signals - Red(ish):
 S Signal  - Potential pivot down from the upper band when using the preferred multiplier
 S1 Signal  - Potential pivot down from the baseline
DISCUSSION
During an uptrend or downtrend, signals from the baseline can help traders identify areas where they may enter the trending move with the least amount of drawdown. In both cases, entry points can occur with baseline signals in the direction of the trend. 
For example, in an uptrend (when the price is forming higher highs and higher lows, or when the baseline is rising), price tends to oscillate between the upper band and baseline. In this case, the baseline BUY signal (B3) can show an entry point.
In a downtrend (when the price is forming lower highs and lower lows, or when the baseline is falling), price tends to oscillate between the baseline and the lower band. In this case, the baseline SELL signal (S3) can show an entry point.
During consolidation, when price is ranging, price tends to oscillate between the upper and lower bands, while crossing through the baseline unperturbed. Here, entry points can occur at the upper and lower bands. 
When all conditions are met at the lower band during consolidation, a BUY signal (B), can occur. This signal may also occur prior to a break out of consolidation to the upside.
When all conditions are met at the upper band during consolidation, a SELL signal (S), can occur. This signal may also occur prior to a break out of consolidation to the downside.
Additional, B1 and S1 signals can be displayed that use the baseline as the pivot level.
 Settings 
SIGNALS
 
 Show Bollinger Band Signals (Default: True): Allows signal labels to be shown.
 Hide Baseline Signals (Default: False): Baseline signals are on by default. This will turn them off.
 Show Wick Signals (Defau
 lt: True): Displays signals when wicking occurs.
BOLLINGER BAND SETTINGS
 
 Period length for Bollinger Band Basis (Default: 21): Length of the Bollinger Band (BB) moving average basis line.
 Basis MA Type (Default: SMA): The moving average type for the BB Basis line.
 Source (Default: “close”): The source of time series data.
 Standard Deviation Multiplier (Default: 2.5: The deviation multiplier used to calculate the band distance from the basis line.
 
WICK SETTINGS FOR BOLLINGER BANDS
 
 Wick Ratio for Bands (Default: 0.3): The ratio of wick size to total candle size for use at upper and lower bands.
 Wick Ratio for Baseline (Default: 0.3): The ratio of wick size to total candle size for use at baseline.
 
WICK SETTINGS FOR CANDLE SIGNALS
 
 Upper Wick Threshold (Default: 50): The percent of upper wick compared to the full candle size or candle body size.
 Lower Wick Threshold (Default: 50): The percent of lower wick compared to the full candle size or candle body size.
 Use Candle Body (Default: false): Toggles the use of the full candle size versus the candle body size when calculating the wick signal.
 
VISUAL PREFERENCES
 
 Fill Bands (Default: true): Use a background color inside the Bollinger Bands.
 Show Signals (Default: true): Toggle the Bollinger Band upper band, lower band, and baseline signals.
 Show Bollinger Bands (Default: true): Show the Bollinger Bands.
 
STOCHASTIC SETTINGS
 
 Use Stochastic RSI Filtering (Default: False): This will only trigger some SELL signals when the stochastic RSI is above 80, and BUY signals when below 20.
 K (Default: 3): The smoothing level for the Stochastic RSI.
 RSI Length (Default: 14): The period length for the RSI calculation.
 Stochastic Length (Default: 8): The period length over which the stochastic calculation is performed.
 
 Calculations 
Bollinger Bands are a technical analysis tool that are used to measure market volatility and identify overbought or oversold conditions in the trading of financial instruments, such as stocks, bonds, commodities, and currencies.  Bollinger Bands consist of three lines plotted on a price chart:
Middle Band, Basis, or Baseline: This is typically a simple moving average (SMA) of the closing prices over a certain period. It represents the intermediate-term trend of the asset's price.
Upper Band: This is calculated by adding a certain number of standard deviations to the middle band (SMA). The upper band adjusts itself with the increase in volatility.
Lower Band: This is calculated by subtracting the same number of standard deviations from the middle band (SMA). Like the upper band, the lower band adjusts to changes in volatility.
The candle wick signals occur if the wick is at the specified ratio compared to either the entire candle or the candle body. The upper band, lower band, and baseline signals happen if the wick is the specified ratio of the total candle size. For the major signals for upper and lower bands, these occur when the wick extends outside of the bands while closing a candle inside of the bands. For the baseline signals, they occur if a wick crosses a baseline but closes on the other side.
 Other Usage Notes and Limitations 
To understand future price movement, this indicator assumes that 3 things must be known:
 
 Evidence of a change of market structure. This can be demonstrated by increased volatility, consolidation, volume spikes (which can be tracked with the MW Volume Impulse Indicator) or, in the case of this indicator, candle wicks. 
 The potential cause of the change. It could be a VWAP line (which can be tracked with the Multi VWAP  , and Multi VWAP from Gaps   indicators), an event, an important support or resistance level, a key moving average, or many other things. This indicator assumes the ATR bands can be a cause.
 The current position in the price cycle. Oscillators like the RSI, and MACD, are typical measures of price oscillation (other oscillators like the Price and Volume Stochastic Divergence   indicator can also be useful). This indicator uses the Stochastic RSI oscillator to determine overbought and oversold conditions.
 
When evidence of the change appears, and the potential cause of the change is identified, and the price oscillation is at a favorable position for the desired trading direction, this indicator will generate a signal.
ATR Bands (or Keltner Channels) are used to determine when price might “revert to the mean”. Crossing, or being near the upper or lower band, can indicate an overbought or oversold condition, which could lead to a price reversal. By tracking the behavior of candle wicks during these events, we can see how active the battle is between buyers and sellers. 
If the top of a wick is large, it may indicate that sellers are aggressively attempting to bring the price down. Conversely, if the bottom wick is large, it can indicate that buyers are actively trying to counter the price action caused by selling pressure.
When this wicking action occurs at times when price is not near the upper band, lower band, or baseline, it could indicate the presence of an important level. That could mean a nearby VWAP line, a supply or demand zone, a round price number, or a number of other factors. In any case, this wick may be the first indication of a price reversal.
Shorter baseline periods may be better for short period trading like scalping or day trading, while longer period baselines can show signals that are better suited to swing trading, or longer term investing. 
It's important for traders to be aware of the limitations of any indicator and to use them as part of a broader, well-rounded trading strategy that includes risk management, fundamental analysis, and other tools that can help with reducing false signals, determining trend direction, and providing additional confirmation for a trade decision. Diversifying strategies and not relying solely on one type of indicator or analysis can help mitigate some of these risks.
The TradingView platform allows a maximum of 500 labels per chart. This means that if your settings allow for a lot of signals, labels for earlier ones may not appear if the total number of labels exceeds 500 for the chart.
Market Internals & InfoThis script provides various information on Market Internals and other related info. It was a part of the Daily Levels script but that script was getting very large so I decided to separate this piece of it into its own indicator. I plan on adding some additional features in the near future so stay tuned for those!
The script provides customizability to show certain market internals, tickers, and even Market Profile TPO periods. 
Here is a summary of each setting:
 NASDAQ and NYSE Breadth Ratio 
- Ratio between Up Volume and Down Volume for NASDAQ and NYSE markets. This can help inform about the type of volume flowing in and out of these exchanges.
 Advance/Decline Line (ADL) 
The ADL focuses specifically on the number of advancing and declining stocks within an index, without considering their trading volume.
Here's how the ADL works:
It tracks the daily difference between the number of stocks that are up in price (advancing) and the number of stocks that are down in price (declining) within a particular index.
The ADL is a cumulative measure, meaning each day's difference is added to the previous day's total.
If there are more advancing stocks, the ADL goes up.
If there are more declining stocks, the ADL goes down.
By analyzing the ADL, investors can get a sense of how many stocks are participating in a market move.
Here's what the ADL can tell you:
Confirmation of Trends: When the ADL moves in the same direction as the underlying index (e.g., ADL rising with a rising index), it suggests broad participation in the trend and potentially stronger momentum.
Divergence: If the ADL diverges from the index (e.g., ADL falling while the index is rising), it can be a warning sign. This suggests that fewer stocks are participating in the rally, which could indicate a weakening trend.
Keep in mind:
The ADL is a backward-looking indicator, reflecting past market activity.
It's often used in conjunction with other technical indicators for a more complete picture.
 TRIN Arms Index 
The TRIN index, also called the Arms Index or Short-Term Trading Index, is a technical analysis tool used in the stock market to gauge  market breadth and sentiment. It essentially compares the number of advancing stocks (gaining in price) to declining stocks (losing price) along with their trading volume.
Here's how to interpret the TRIN:
High TRIN (above 1.0): This indicates a weak market where declining stocks and their volume are dominating the market. It can be a sign of a potential downward trend.
Low TRIN (below 1.0): This suggests a strong market where advancing stocks and their volume are in control. It can be a sign of a potential upward trend.
TRIN around 1.0: This represents a more balanced market, where it's difficult to say which direction the market might be headed.
Important points to remember about TRIN:
It's a short-term indicator, primarily used for intraday trading decisions.
It should be used in conjunction with other technical indicators for a more comprehensive market analysis. High or low TRIN readings don't guarantee future price movements.
 VIX/VXN 
VIX and VXN are both indexes created by the Chicago Board Options Exchange (CBOE) to measure market volatility. They  differ based on the underlying index they track:
VIX (Cboe Volatility Index): This is the more well-known index and is considered the "fear gauge" of the stock market. It reflects the market's expectation of volatility in the S&P 500 index over the next 30 days.
VXN (Cboe Nasdaq Volatility Index): This is a counterpart to the VIX, but instead gauges volatility expectations for the Nasdaq 100 index over the coming 30 days. The tech-heavy Nasdaq can sometimes diverge from the broader market represented by the S&P 500, hence the need for a separate volatility measure.
Both VIX and VXN are calculated based on the implied volatilities of options contracts listed on their respective indexes. Here's a general interpretation:
High VIX/VXN: Indicates a high level of fear or uncertainty in the market, suggesting investors expect significant price fluctuations in the near future.
Low VIX/VXN: Suggests a more complacent market with lower expectations of volatility.
Important points to remember about VIX and VXN:
They are forward-looking indicators, reflecting market sentiment about future volatility, not necessarily current market conditions.
High VIX/VXN readings don't guarantee a market crash, and low readings don't guarantee smooth sailing.
These indexes are often used by investors to make decisions about portfolio allocation and hedging strategies.
 Inside/Outside Day 
This provides a quick indication of it we are still trading inside or outside of yesterdays range and will show "Inside Day" or "Outside Day" based upon todays range vs. yesterday's range.
 Custom Ticker Choices 
Ability to add up to 5 other tickers that can be tracked within the table
 Show Market Profile TPO 
This only shows on timeframes less than 30m. It will show both the current TPO period and the remaining time within that period.
 Table Customization 
Provided drop downs to change the text size and also the location of the table.
Material Design ColorsThis library provides a standard set of colors defined in Material Design 2.0.
🔵 API
Step 1: Import this library.
 
import algotraderdev/material/1
// remember to check the latest version of this library and replace the 1 above.
 
Step 2: Get the color you like. Check the source code or the screenshot above to see all the supported colors.
 
material.red()
 
Each color function (except for `black()` and `white()`) accepts an optional `variant` parameter. You can choose any of 50, 100, 200, 300, 400, 500, 600, 700, 800, and 900. By default, 500 is chosen if this parameter is not provided.
Normalized Market IndicatorsExplanation of the Code: 
 Data Retrieval:  The script retrieves the closing prices of the S&P 500 (sp500) and VIX (vix).
 Normalization:  The script normalizes these values using a simple z-score normalization (subtracting the 50-period simple moving average and dividing by the 50-period standard deviation). This makes the scales of the two datasets more comparable.
 Plotting with Secondary Axis:   The normalized values of the S&P 500 and VIX are plotted on the same chart. They will share the same y-axis scale as the main chart (e.g. Netflix, GOLD, Forex).
Points to Note:
 Normalization Method:  The method of normalization (z-score in this case) is a choice and can be adjusted based on your needs. The idea is to bring the data to a comparable scale.
Timeframe and Symbol Codes: Ensure the timeframe and symbol codes are appropriate for your data source and trading strategy.
 Overlaying on Price Chart:  Since these values are normalized and plotted on a seperate chart, they won't directly correspond to the price levels of the main chart (e.g. Netflix, GOLD, Forex).
ottlibLibrary   "ottlib" 
█  OVERVIEW 
This library contains functions for the calculation of the OTT (Optimized Trend Tracker) and its variants, originally created by  Anıl Özekşi  (Anil_Ozeksi). Special thanks to him for the concept and to  Kıvanç Özbilgiç  (KivancOzbilgic) and  dg_factor  (dg_factor) for adapting them to Pine Script.
█  WHAT IS "OTT" 
The OTT (Optimized Trend Tracker) is a highly customizable and very effective trend-following indicator that relies on moving averages and a trailing stop at its core. Moving averages help reduce noise by smoothing out sudden price movements in the markets, while trailing stops assist in detecting trend reversals with precision. Initially developed as a noise-free trailing stop, the current variants of OTT range from rapid trend reversal detection to long-term trend confirmation, thanks to its extensive customizability.
It's well-known variants are:
 
  OTT (Optimized Trend Tracker).
  TOTT (Twin OTT).
  OTT Channels.
  RISOTTO (RSI OTT).
  SOTT (Stochastic OTT).
  HOTT & LOTT (Highest & Lowest OTT)
  ROTT (Relative OTT)
  FT (Original name is Fırsatçı Trend in Turkish which translates to Opportunist Trend)
 
█  LIBRARY FEATURES 
This library has been prepared in accordance with the style, coding, and annotation standards of Pine Script version 5. As a result, explanations and examples will appear when users hover over functions or enter function parameters in the editor.
█  USAGE 
Usage of this library is very simple. Just import it to your script with the code below and use its functions.
 
import ismailcarlik/ottlib/1 as ottlib
 
█  FUNCTIONS 
•  f_vidya(source, length, cmoLength) 
   Short Definition:  Chande's Variable Index Dynamic Average (VIDYA).
   Details:  This function computes Chande's Variable Index Dynamic Average (VIDYA), which serves as the original moving average for OTT. The 'length' parameter determines the number of bars used to calculate the average of the given source. Lower values result in less smoothing of prices, while higher values lead to greater smoothing. While primarily used internally in this library, it has been made available for users who wish to utilize it as a moving average or use in custom OTT implementations.
  Parameters:
     source (float) : (series float) Series of values to process.
     length (simple int) : (simple int) Number of bars to lookback.
     cmoLength (simple int) : (simple int) Number of bars to lookback for calculating CMO. Default value is `9`.
  Returns: (float) Calculated average of `source` for `length` bars back.
  Example:
 
vidyaValue = ottlib.f_vidya(source = close, length = 20)
plot(vidyaValue, color = color.blue)
 
  
•  f_mostTrail(source, multiplier) 
   Short Definition:  Calculates trailing stop value.
   Details:  This function calculates the trailing stop value for a given source and the percentage. The 'multiplier' parameter defines the percentage of the trailing stop. Lower values are beneficial for catching short-term reversals, while higher values aid in identifying long-term trends. Although only used once internally in this library, it has been made available for users who wish to utilize it as a traditional trailing stop or use in custom OTT implementations.
  Parameters:
     source (float) : (series int/float) Series of values to process.
     multiplier (simple float) : (simple float) Percent of trailing stop.
  Returns: (float) Calculated value of trailing stop.
  Example:
 
emaValue = ta.ema(source = close, length = 14)
mostValue = ottlib.f_mostTrail(source = emaValue, multiplier = 2.0)
plot(mostValue, color = emaValue >= mostValue ? color.green : color.red)
 
  
•  f_ottTrail(source, multiplier) 
   Short Definition:  Calculates OTT-specific trailing stop value.
   Details:  This function calculates the trailing stop value for a given source in the manner used in OTT. Unlike a traditional trailing stop, this function modifies the traditional trailing stop value from two bars prior by adjusting it further with half the specified percentage. The 'multiplier' parameter defines the percentage of the trailing stop. Lower values are beneficial for catching short-term reversals, while higher values aid in identifying long-term trends. Although primarily used internally in this library, it has been made available for users who wish to utilize it as a trailing stop or use in custom OTT implementations.
  Parameters:
     source (float) : (series int/float) Series of values to process.
     multiplier (simple float) : (simple float) Percent of trailing stop.
  Returns: (float) Calculated value of OTT-specific trailing stop.
  Example:
 
vidyaValue = ottlib.f_vidya(source = close, length = 20)
ottValue = ottlib.f_ottTrail(source = vidyaValue, multiplier = 1.5)
plot(ottValue, color = vidyaValue >= ottValue ? color.green : color.red)
 
  
•  ott(source, length, multiplier) 
   Short Definition:  Calculates OTT (Optimized Trend Tracker).
   Details:  The OTT consists of two lines. The first, known as the "Support Line", is the VIDYA of the given source. The second, called the "OTT Line", is the trailing stop based on the Support Line. The market is considered to be in an uptrend when the Support Line is above the OTT Line, and in a downtrend when it is below.
  Parameters:
     source (float) : (series float) Series of values to process. Default value is `close`.
     length (simple int) : (simple int) Number of bars to lookback. Default value is `2`.
     multiplier (simple float) : (simple float) Percent of trailing stop. Default value is `1.4`.
  Returns: ( [ float, float ]) Tuple of `supportLine` and `ottLine`.
  Example:
 
  = ottlib.ott(source = close, length = 2, multiplier = 1.4)
longCondition = ta.crossover(supportLine, ottLine)
shortCondition = ta.crossunder(supportLine, ottLine)
 
  
•  tott(source, length, multiplier, bandsMultiplier) 
   Short Definition:  Calculates TOTT (Twin OTT).
   Details:  TOTT consists of three lines: the "Support Line," which is the VIDYA of the given source; the "Upper Line," a trailing stop of the Support Line adjusted with an added multiplier; and the "Lower Line," another trailing stop of the Support Line, adjusted with a reduced multiplier. The market is considered in an uptrend if the Support Line is above the Upper Line and in a downtrend if it is below the Lower Line.
  Parameters:
     source (float) : (series float) Series of values to process. Default value is `close`.
     length (simple int) : (simple int) Number of bars to lookback. Default value is `40`.
     multiplier (simple float) : (simple float) Percent of trailing stop. Default value is `0.6`.
     bandsMultiplier (simple float) : Multiplier for bands. Default value is `0.0006`.
  Returns: ( [ float, float, float ]) Tuple of `supportLine`, `upperLine` and `lowerLine`.
  Example:
 
  = ottlib.tott(source = close, length = 40, multiplier = 0.6, bandsMultiplier = 0.0006)
longCondition = ta.crossover(supportLine, upperLine)
shortCondition = ta.crossunder(supportLine, lowerLine)
 
  
•  ott_channel(source, length, multiplier, ulMultiplier, llMultiplier) 
   Short Definition:  Calculates OTT Channels.
   Details:  OTT Channels comprise nine lines. The central line, known as the "Mid Line," is the OTT of the given source's VIDYA. The remaining lines are positioned above and below the Mid Line, shifted by specified multipliers.
  Parameters:
     source (float) : (series float) Series of values to process. Default value is `close`
     length (simple int) : (simple int) Number of bars to lookback. Default value is `2`
     multiplier (simple float) : (simple float) Percent of trailing stop. Default value is `1.4`
     ulMultiplier (simple float) : (simple float) Multiplier for upper line. Default value is `0.01`
     llMultiplier (simple float) : (simple float) Multiplier for lower line. Default value is `0.01`
  Returns: ( [ float, float, float, float, float, float, float, float, float ]) Tuple of `ul4`, `ul3`, `ul2`, `ul1`, `midLine`, `ll1`, `ll2`, `ll3`, `ll4`.
  Example:
 
  = ottlib.ott_channel(source = close, length = 2, multiplier = 1.4, ulMultiplier = 0.01, llMultiplier = 0.01)
 
  
•  risotto(source, length, rsiLength, multiplier) 
   Short Definition:  Calculates RISOTTO (RSI OTT).
   Details:  RISOTTO comprised of two lines: the "Support Line," which is the VIDYA of the given source's RSI value, calculated based on the length parameter, and the "RISOTTO Line," a trailing stop of the Support Line. The market is considered in an uptrend when the Support Line is above the RISOTTO Line, and in a downtrend if it is below.
  Parameters:
     source (float) : (series float) Series of values to process. Default value is `close`.
     length (simple int) : (simple int) Number of bars to lookback. Default value is `50`.
     rsiLength (simple int) : (simple int) Number of bars used for RSI calculation. Default value is `100`.
     multiplier (simple float) : (simple float) Percent of trailing stop. Default value is `0.2`.
  Returns: ( [ float, float ]) Tuple of `supportLine` and `risottoLine`.
  Example:
 
  = ottlib.risotto(source = close, length = 50, rsiLength = 100, multiplier = 0.2)
longCondition = ta.crossover(supportLine, risottoLine)
shortCondition = ta.crossunder(supportLine, risottoLine)
 
  
•  sott(source, kLength, dLength, multiplier) 
   Short Definition:  Calculates SOTT (Stochastic OTT).
   Details:  SOTT is comprised of two lines: the "Support Line," which is the VIDYA of the given source's Stochastic value, based on the %K and %D lengths, and the "SOTT Line," serving as the trailing stop of the Support Line. The market is considered in an uptrend when the Support Line is above the SOTT Line, and in a downtrend when it is below.
  Parameters:
     source (float) : (series float) Series of values to process. Default value is `close`.
     kLength (simple int) : (simple int) Stochastic %K length. Default value is `500`.
     dLength (simple int) : (simple int) Stochastic %D length. Default value is `200`.
     multiplier (simple float) : (simple float) Percent of trailing stop. Default value is `0.5`.
  Returns: ( [ float, float ]) Tuple of `supportLine` and `sottLine`.
  Example:
 
  = ottlib.sott(source = close, kLength = 500, dLength = 200, multiplier = 0.5)
longCondition = ta.crossover(supportLine, sottLine)
shortCondition = ta.crossunder(supportLine, sottLine)
 
  
•  hottlott(length, multiplier) 
   Short Definition:  Calculates HOTT & LOTT (Highest & Lowest OTT).
   Details:   HOTT & LOTT are composed of two lines: the "HOTT Line", which is the OTT of the highest price's VIDYA, and the "LOTT Line", the OTT of the lowest price's VIDYA. A high price surpassing the HOTT Line can be considered a long signal, while a low price dropping below the LOTT Line may indicate a short signal.
  Parameters:
     length (simple int) : (simple int) Number of bars to lookback. Default value is `20`.
     multiplier (simple float) : (simple float) Percent of trailing stop. Default value is `0.6`.
  Returns: ( [ float, float ]) Tuple of `hottLine` and `lottLine`.
  Example:
 
  = ottlib.hottlott(length = 20, multiplier = 0.6)
longCondition = ta.crossover(high, hottLine)
shortCondition = ta.crossunder(low, lottLine)
 
  
•  rott(source, length, multiplier) 
   Short Definition:  Calculates ROTT (Relative OTT).
   Details:  ROTT comprises two lines: the "Support Line", which is the VIDYA of the given source, and the "ROTT Line", the OTT of the Support Line's VIDYA. The market is considered in an uptrend if the Support Line is above the ROTT Line, and in a downtrend if it is below. ROTT is similar to OTT, but the key difference is that the ROTT Line is derived from the VIDYA of two bars of Support Line, not directly from it.
  Parameters:
     source (float) : (series float) Series of values to process. Default value is `close`.
     length (simple int) : (simple int) Number of bars to lookback. Default value is `200`.
     multiplier (simple float) : (simple float) Percent of trailing stop. Default value is `0.1`.
  Returns: ( [ float, float ]) Tuple of `supportLine` and `rottLine`.
  Example:
 
  = ottlib.rott(source = close, length = 200, multiplier = 0.1)
isUpTrend = supportLine > rottLine
isDownTrend = supportLine < rottLine
 
  
•  ft(source, length, majorMultiplier, minorMultiplier) 
   Short Definition:  Calculates Fırsatçı Trend (Opportunist Trend).
   Details:   FT is comprised of two lines: the "Support Line", which is the VIDYA of the given source, and the "FT Line", a trailing stop of the Support Line calculated using both minor and major trend values. The market is considered in an uptrend when the Support Line is above the FT Line, and in a downtrend when it is below.
  Parameters:
     source (float) : (series float) Series of values to process. Default value is `close`.
     length (simple int) : (simple int) Number of bars to lookback. Default value is `30`.
     majorMultiplier (simple float) : (simple float) Percent of major trend. Default value is `3.6`.
     minorMultiplier (simple float) : (simple float) Percent of minor trend. Default value is `1.8`.
  Returns: ( [ float, float ]) Tuple of `supportLine` and `ftLine`.
  Example:
 
  = ottlib.ft(source = close, length = 30, majorMultiplier = 3.6, minorMultiplier = 1.8)
longCondition = ta.crossover(supportLine, ftLine)
shortCondition = ta.crossunder(supportLine, ftLine)
 
  
█  CUSTOM OTT CREATION 
Users can create custom OTT implementations using  f_ottTrail  function in this library. The example code which uses EMA of 7 period as moving average and calculates OTT based of it is below.
Source Code:
 
//@version=5
indicator("Custom OTT", shorttitle = "COTT", overlay = true)
import ismailcarlik/ottlib/1 as ottlib
src = input.source(close, title = "Source")
length = input.int(7, title = "Length", minval = 1)
multiplier = input.float(2.0, title = "Multiplier", minval = 0.1)
support = ta.ema(source = src, length = length)
ott = ottlib.f_ottTrail(source = support, multiplier = multiplier)
pSupport = plot(support, title = "Moving Average Line (Support)", color = color.blue)
pOtt = plot(ott, title = "Custom OTT Line", color = color.orange)
fillColor = support >= ott ? color.new(color.green, 60) : color.new(color.red, 60)
fill(pSupport, pOtt, color = fillColor, title = "Direction")
 
Result:
  
█  DISCLAIMER 
Trading is risky and most of the day traders lose money eventually. This library and its functions are only for educational purposes and should not be construed as financial advice. Past performances does not guarantee future results.
forex_factory_events_id_BLibrary   "forex_factory_events_id_B" 
Supporting Utility Library for the Live Economic Calendar by toodegrees Indicator; database with the second 500 Forex Factory News Event types.
 ff_titleB(ID) 
  Converts a number to Forex Factory News title (second 500).
  Parameters:
     ID (string) : Identifier of the Forex Factory News Event. Please see the library for more information.
  Returns: Returns the title of the Forex Factory News Event.
forex_factory_events_id_ALibrary   "forex_factory_events_id_A" 
Supporting Utility Library for the Live Economic Calendar by toodegrees Indicator; database with the first 500 Forex Factory News Event types.
 ff_titleA(ID) 
  Converts a number to Forex Factory News title (first 500).
  Parameters:
     ID (string) : Identifier of the Forex Factory News Event. Please see the library for more information.
  Returns: Returns the title of the Forex Factory News Event.
S&P500 Investment AverageThis script lets you choose the best time to invest in the S&P 500, thanks to a line showing an average growth of 8.32% over 50 years, starting from the price of $86.84 on January 1, 1974.
Thanks to this line indicating the price of the S&P 500 based on the average growth of the index. You'll be able to tell when the index is overvalued or undervalued. 
When the price is below 20% of the line, it's a good time to invest your cash for the crash. And when it's back in the black, it's time to reduce your DCA.
You can also specify a specific date in the settings to watch the percentage whenever you like.
COT MCIThe COT MCI script is a market indicator based on the data from the Commitment of Traders Reports.
Integration of COT Report Data:
The script sources COT data from futures contracts, including:
Treasury Bonds (ZB), Dollar Index (DX), 10-Year Treasury Notes (ZN)
Commodities like Soybeans (ZS), Soy Meal (ZM), Soy Oil (ZL), Corn (ZC), Wheat (ZW), Kansas City Wheat (KE), Pork (HE), Cattle (LE)
Precious Metals such as Gold (GC), Silver (SI), Palladium (PA), Platinum (PL)
Industrial Metals like Copper (HG), Aluminum (AUP), Steel (HRC)
Energy Products like Crude Oil (CL), Heating Oil (HO), Gasoline (RB), Natural Gas (NG), Brent Crude (BB)
Currencies such as AUD (6A), GBP (6B), CAD (6C), EUR (6E), JPY (6J), CHF (6S), NZD (6N), BRL (6L), MXN (6M), RUB (6R), ZAR (6Z)
Others: Sugar (SB), Coffee (KC), Cocoa (CC), Cotton (CT), Ethanol (EH), Rice (ZR), Oats (ZO), Whey (DC), Orange Juice (OJ), Lumber (LBS), Livestock (GF), E-mini S&P 500 (ES), E-mini Russell 2000 (RTY), E-mini Dow Jones (YM), E-mini NASDAQ-100 (NQ), VIX Futures (VX), S&P 500 (SP), DJIA (DJIA)
Cryptocurrencies such as Bitcoin (BTC) and Ethereum (ETH)
Functions and Logic of the Script:
COT Calculation: Determines the net positions for commercial actors and large speculators. Also Available are short and long positions of commercials or large speculators.
Position Change Analysis: Analyzes the percentage changes in net positions and open interest data over a period of 6 weeks (Weekly Chart).
Average Value Calculation: Determines short-term and long-term trend averages.
Trend Analysis: Buy and sell signals (represented in colors) are based on linear regressions and average calculations.
Usage and Application Examples:
Ideal for traders looking for a detailed analysis of market dynamics and position changes in the futures market. Suitable for decision-making in transaction timing and assessing market sentiment.
Usage Notes:
Users should be familiar with the interpretation of COT data and basic concepts of futures trading. Particularly suitable for medium to long-term trading strategies.






















