Fortuna/4.20FC. Индикатор для поиска ценовых уровней. Он ищет 2 ценовых уровня.
Красный уровень это уровень максимального количества совпадений цены(качаний)
Синий уровень это второй(2) по количеству совпадений!
Indikator dan strategi
Simplified Buy/Sell StrategyThis Pine Script implements a Simplified Buy/Sell Strategy based on the Moving Average Crossover technique. Here's a breakdown of the functionality:
Description:
Purpose:
The script generates Buy and Sell signals on the chart to help traders identify potential entry and exit points based on short-term and long-term price trends.
Indicators Used:
Short Moving Average (Short MA): Calculates the average closing price over a shorter period (default: 5).
Long Moving Average (Long MA): Calculates the average closing price over a longer period (default: 10).
Buy Signal:
A buy signal is generated when the Short MA crosses above the Long MA. This suggests a potential upward trend in price.
Sell Signal:
A sell signal is generated when the Short MA crosses below the Long MA. This indicates a possible downward trend.
Visualization:
Buy signals are shown as green arrows below the price bars with the label "BUY."
Sell signals are displayed as red arrows above the price bars with the label "SELL."
The Short and Long MAs are plotted on the chart for visual confirmation of trends (blue for Short MA, orange for Long MA).
Customization:
Traders can adjust the lengths of the moving averages to fit different timeframes or assets using the input fields.
Trend Analysis: DJ 09Bullish trends when the short-term MA crosses above the long-term MA and RSI is rising.
Bearish trends when the short-term MA crosses below the long-term MA and RSI is falling.
Composite Indicator (Donchian + OBV)Composite Indicator (Donchian + OBV)
The Composite Indicator (Donchian + OBV) is a powerful tool designed to evaluate the strength of market breakouts and momentum trends , offering traders a comprehensive perspective on price action. This indicator combines the Donchian Channel with On-Balance Volume (OBV) to create a dynamic and easy-to-interpret metric scaled between -1 and 1 .
Key Features
Breakout Strength Analysis:
- The indicator assesses the strength of price breakouts relative to the upper and lower bounds of the Donchian Channel.
- Positive values close to 1 indicate a strong bullish breakout.
- Negative values close to -1 indicate a strong bearish breakout.
Momentum Detection with OBV:
- On-Balance Volume (OBV) tracks the cumulative buying and selling volume to gauge market momentum.
- The smoothed OBV trend ensures the momentum component aligns with price action, reducing noise.
Integrated Composite Value:
- Combines breakout strength and OBV momentum into a single metric for enhanced clarity.
- The final composite value highlights whether the market is bullish, bearish, or neutral.
Divergence Detection:
- Spot bullish divergences when the indicator rises while price falls, suggesting a potential upward reversal.
- Identify bearish divergences when the indicator falls while price rises, hinting at a potential downward reversal.
How It Works
Donchian Channel Analysis:
- Calculates the highest high and lowest low over a user-defined period to establish the upper and lower channels .
- Breakouts beyond these channels contribute to the breakout strength component.
OBV Momentum:
- Measures cumulative volume trends to validate price movements.
- Momentum is derived from the rate of change in smoothed OBV values.
Composite Calculation:
- Combines breakout strength and OBV momentum, normalized and scaled to -1 to 1 for clarity.
How to Use
Bullish Breakout:
- When the indicator value approaches 1 , it signals a strong upward breakout supported by positive OBV momentum.
- Example Action: Consider a Buy if price breaks the upper Donchian Channel with increasing OBV.
Bearish Breakout:
- When the indicator value approaches -1 , it indicates a strong downward breakout supported by negative OBV momentum.
- Example Action: Consider a Sell if price breaks the lower Donchian Channel with decreasing OBV.
Neutral Market:
- When the value is near 0 , the market is likely balanced with no significant breakout or momentum detected.
Divergence Opportunities:
- Bullish Divergence: Price makes lower lows, but the indicator trends upward → Potential upward reversal.
- Bearish Divergence: Price makes higher highs, but the indicator trends downward → Potential downward reversal.
Customization Options
Donchian Channel Length: Adjust the period for the upper and lower bounds.
OBV Smoothing Length: Modify the smoothing period for OBV to fine-tune momentum detection.
Scaling Adjustments: The composite value is automatically normalized for consistency across timeframes.
Ideal Use Cases
Breakout Trading: Identify and confirm strong breakouts in volatile markets.
Momentum Confirmation: Validate price movements with volume-based momentum.
Reversal Detection: Leverage divergences to spot potential market reversals.
Example Applications
Strong Bullish Signal:
- Price breaks the upper channel , and OBV shows increasing volume → Composite value near 1 .
- Action: Enter a Buy position and set a Stop Loss below the upper channel.
Strong Bearish Signal:
- Price breaks the lower channel , and OBV shows decreasing volume → Composite value near -1 .
- Action: Enter a Sell position and set a Stop Loss above the lower channel.
Neutral Market:
- Composite value near 0 suggests indecision or consolidation. Wait for a breakout.
Limitations
Best used alongside additional tools like RSI or MACD for filtering noise and improving decision-making.
Requires careful parameter tuning based on the asset and timeframe.
Final Thoughts
The Composite Indicator (Donchian + OBV) offers traders a versatile tool to navigate complex markets. By blending breakout analysis with volume-based momentum, this indicator provides an actionable edge for identifying high-probability opportunities and potential reversals.
Pivot Range DetectionRange detection based on Pivot points with table showing max pivot point and min pivot point
Custom RSI with Pullback LevelsThis is an Custom RSI that has pull back horizontal lines marked at 40 and 60.
Codi's Perp-Spot Basis# Perp-Spot Basis Indicator
This indicator calculates the percentage basis between perpetual futures and spot prices for crypto assets. It is inspired by the original concept from **Krugermacro**, with the added improvement of **automatic detection of the asset pairs** based on the current chart symbol. This enhancement makes it faster and easier to apply across different assets without manual configuration.
## How It Works
The indicator compares the perpetual futures price (e.g., `BTCUSDT.P`) to the spot price (e.g., `BTCUSDT`) on Binance. The difference is expressed as a percentage: (Perp - Spot) / Spot * 100
The results are displayed in a color-coded graph:
- **Blue (Positive Basis):** Perpetual futures are trading at a premium, indicating **bullish sentiment** among derivatives traders.
- **Red (Negative Basis):** Perpetual futures are trading at a discount, indicating **bearish sentiment** among derivatives traders.
This percentage basis is a core component in understanding funding rates and derivatives market dynamics. It serves as a faster proxy for funding rates, which typically lag behind real-time price movements.
---
## How to Use It
### General Concept
- **Red (Negative Basis):** Ideal to execute **longs** when derivatives traders are overly bearish.
- **Blue (Positive Basis):** Ideal to execute **shorts** when derivatives traders are overly bullish.
### Pullback Sniping
1. During an **uptrend**:
- If the basis turns **red** temporarily, it can signal an opportunity to **buy the dip**.
2. During a **downtrend**:
- If the basis turns **blue** temporarily, it can signal an opportunity to **sell the rip**.
3. Wait for the basis to **pop back** (higher in uptrend, lower in downtrend) to time entries more effectively—this often coincides with **stop runs** or **liquidations**.
### Intraday Execution
- **When price is falling**:
- If the basis is **red**, the move is derivatives-led (**normal**).
- If the basis is **blue**, spot traders are leading, and perps are offside—wait for **price dumps** before longing.
- **When price is rising**:
- If the basis is **blue**, the move is derivatives-led (**normal**).
- If the basis is **red**, spot traders are leading, and perps are offside—wait for **price pops** before shorting.
### Larger Time Frames
- **Consistently Blue Basis:** Indicates a **bull market** as derivatives traders are bullish over the long term.
- **Consistently Red Basis:** Indicates a **bear market** as derivatives traders are bearish over the long term.
---
## Improvements Over the Original
This version of the Perp-Spot Basis indicator **automatically detects the Binance perpetual futures and spot pairs** based on the current chart symbol. For example:
- If you are viewing `ETHUSDT`, it automatically references `ETHUSDT.P` for the perpetual futures pair and `ETHUSDT` for the spot pair in BINANCE.
Gold Breakout Strategy//@version=5
indicator("Gold Breakout Strategy", overlay=true)
// Parameters
emaShort = input(20, "Short EMA")
emaLong = input(50, "Long EMA")
atrLength = input(14, "ATR Length")
// Calculations
ema20 = ta.ema(close, emaShort)
ema50 = ta.ema(close, emaLong)
atr = ta.atr(atrLength)
// Trend
bullishTrend = ema20 > ema50
bearishTrend = ema20 < ema50
// Entry Signals
longSignal = bullishTrend and close > ta.highest(close, 20)
shortSignal = bearishTrend and close < ta.lowest(close, 20)
// Plotting EMAs
plot(ema20, color=color.blue, title="EMA 20")
plot(ema50, color=color.red, title="EMA 50")
// Plotting Signals
plotshape(series=longSignal ? close : na, color=color.green, style=shape.labelup, title="Buy Signal", location=location.belowbar)
plotshape(series=shortSignal ? close : na, color=color.red, style=shape.labeldown, title="Sell Signal", location=location.abovebar)
Roc & Atr & MAROC - ATR and comparison of 3 moving averages.
Buy signal if 3 Moving Averages cross ATR band.
Downward Sell signal.
And comparison to each other.
Volatility - ATR and Averages.
Чистые объемы 1H -> 4H -> 12H (LONG и SHORT)Этот скрипт предназначен для анализа объемов на таймфреймах 1H, 4H и 12H с целью поиска сигналов на вход в LONG и SHORT.
Он синхронизирует объемы между тремя таймфреймами, где 1H подчиняется 4H, а 4H подчиняется 12H.
Основная задача скрипта – находить точки входа, подтвержденные ростом или снижением объемов на всех уровнях.
Таймфрейм 1H используется для точного определения момента входа.
Таймфрейм 4H анализирует объемы для подтверждения движений на 1H.
Таймфрейм 12H проверяет глобальный тренд объемов, синхронизированный с 4H.
Скрипт рассчитывает средние значения объемов (SMA) на каждом таймфрейме.
Условия для LONG включают рост объемов на 1H и 4H, подтвержденный 12H.
Условия для SHORT включают снижение объемов на 1H и 4H, подтвержденное 12H.
VWAP используется как дополнительный фильтр тренда.
LONG возможен только при цене выше VWAP.
SHORT возможен только при цене ниже VWAP.
Скрипт визуально отображает сигналы в виде треугольников на графике.
Зеленый треугольник с меткой "LONG" указывает на сигнал для входа в покупку.
Красный треугольник с меткой "SHORT" указывает на сигнал для входа в продажу.
Объемы на 1H анализируются для выявления локальных изменений.
Объемы на 4H проверяют среднесрочные тенденции.
Объемы на 12H служат для анализа глобальных трендов.
Увеличение объемов подтверждается, если объем больше SMA и больше предыдущего значения.
Уменьшение объемов подтверждается, если объем ниже SMA и меньше предыдущего значения.
Скрипт учитывает динамику объемов на всех уровнях.
Он помогает избежать ложных сигналов в периоды низкой ликвидности.
Скрипт автоматически запрашивает данные с таймфреймов 4H и 12H.
Пользователю достаточно установить скрипт на график с таймфреймом 1H.
VWAP визуализируется на графике в виде линии.
Объемы для 1H, 4H и 12H также отображаются в виде линий.
Скрипт можно адаптировать для других таймфреймов, изменив настройки.
Все сигналы строятся на основе согласованности объемов.
LONG сигнал подтверждается синхронным ростом объемов на всех уровнях.
SHORT сигнал подтверждается синхронным снижением объемов на всех уровнях.
Условия сигнала LONG усиливаются фильтром VWAP.
Условия сигнала SHORT также зависят от фильтра VWAP.
Скрипт рассчитан на использование трейдерами, которые анализируют объемы.
Это идеальный инструмент для работы в трендовых и боковых рынках.
Он помогает улучшить точность входа в сделки.
Скрипт снижает вероятность ложных входов.
Таймфрейм 12H используется для глобальной проверки тренда объемов.
Таймфрейм 4H служит мостом между глобальным и локальным анализом.
VWAP помогает определить справедливую цену актива.
Сигналы становятся более точными за счет многоуровневой проверки.
Скрипт подходит для торговли на криптовалютных и фондовых рынках.
Он легко интегрируется с другими инструментами анализа.
Динамика объемов визуально отображается для удобства пользователя.
VWAP может быть использован как самостоятельный индикатор тренда.
Пользователь может модифицировать настройки SMA для объемов.
Скрипт облегчает принятие решений в реальном времени.
Он особенно полезен в периоды высокой волатильности.
Ekranın Her Yerine Gökkuşağı EfektiEkranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti Ekranın Her Yerine Gökkuşağı Efekti
Thin Liquidity Zones [PhenLabs]Thin Liquidity Zones with Volume Delta
Our advanced volume analysis tool identifies and visualizes significant liquidity zones using real-time volume delta analysis. This indicator helps traders pinpoint and monitor critical price levels where substantial trading activity occurs, providing precise volume flow measurement through lower timeframe analysis.
The tool works by leveraging the fact that hedge funds, institutions, and other large market participants strategically fill their orders in areas of thin liquidity to minimize slippage and market impact. By detecting these zones, traders gain valuable insights into potential areas of accumulation, distribution, and liquidity traps, allowing for more informed trading decisions.
🔍 Key Features
Real-time volume delta calculation using lower timeframe data
Dynamic zone creation based on volume spikes
Automatic timeframe optimization
Size-filtered zones to avoid noise
Custom delta timeframe scanning
Flexible analysis period selection
📊 Visual Demonstration
💡 How It Works
The indicator continuously scans for high-volume areas where trading activity exceeds the specified threshold (default 6.0x average volume). When detected, it creates zones that display the net volume delta, showing whether buying or selling pressure dominated that price level.
Key zone characteristics:
Size filtering prevents noise from large price swings
Volume delta shows actual buying/selling pressure
Zones automatically expire based on lookback period
Real-time updates as new volume data arrives
⚙️ Settings
Time Settings
Analysis Timeframe: 15M to 1W options
Custom Period: User-defined bar count
Delta Timeframe: Automatic or manual selection
Volume Analysis
Volume Threshold: Minimum spike multiple
Volume MA Length: Averaging period
Maximum Zone Size: Size filter percentage
Display Options
Zone Color: Customizable with transparency
Delta Display: On/Off toggle
Text Position: Left/Center/Right alignment
📌 Tips for Best Results
Adjust volume threshold based on instrument volatility
Monitor zone clusters for potential support/resistance
Consider reducing max zone size in volatile markets
Use in conjunction with price action and other indicators
⚠️ Important Notes
Requires volume data from your data provider
Lower timeframe scanning may impact performance
Maximum 500 zones maintained for optimization
Zone creation is filtered by both volume and size
🔧 Volume Delta Calculation
The indicator uses TradingView’s advanced volume delta calculation, which:
Scans lower timeframe data for precision
Measures actual buying vs selling pressure
Updates in real-time with new data
Provides clear positive/negative flow indication
This tool is ideal for traders focusing on volume analysis and order flow. It helps identify key levels where significant trading activity has occurred and provides insight into the nature of that activity through volume delta analysis.
Note: Performance may vary based on your chart’s timeframe. Adjust settings according to your trading style and the instrument’s characteristics. Past performance is not indicative of future results, DYOR.
Buy Sell Indicator by KCMLong when Price is above Blue Line and White Lines has a Bullish crossover, Short when Price is below Blue Line and White Lines has a Bearish crossover.
Warrior Trading Momentum Strategy Momentum based trades looking for stocks with 5x RV and a float of below 7M.
Adaptive Weight Price Oscillator -Aynet# Adaptive Weight Price Oscillator (AWPO) - Aynet
## Core Components
### 1. Input Parameters
- `fastLength`: Period for the fast EMA calculation (default: 10)
- `slowLength`: Period for the slow EMA calculation (default: 21)
- `adaptiveLength`: Period for calculating volatility-based adaptation (default: 34)
- `smoothing`: Smoothing factor for the adaptive weight (default: 2)
### 2. Price and Weight Calculations
#### Median Price
The indicator uses median price as its base calculation:
```pine
medianPrice = (high + low) / 2
```
#### Volatility-Based Weight
The `getVolatilityRatio` function calculates a volatility ratio:
```pine
getVolatilityRatio(length) =>
std = ta.stdev(medianPrice, length)
ratio = std != 0 ? ta.ema(math.abs(ta.change(medianPrice)), length) / std : 0
math.max(math.min(ratio, 1), 0)
```
This function:
1. Calculates standard deviation of median price
2. Computes the ratio of EMA of price changes to standard deviation
3. Constrains the result between 0 and 1
### 3. AWPO Calculation
The main AWPO value is calculated as:
```pine
awpo = (fastMA - slowMA) * adaptiveWeight
```
Where:
- `fastMA`: EMA of median price using fast length
- `slowMA`: EMA of median price using slow length
- `adaptiveWeight`: Smoothed volatility ratio
## Signal Generation
### 1. Signal Line
- Calculated as an EMA of the AWPO with default length of 9
- Used for generating trading signals
### 2. Trading Signals
The indicator generates several types of signals:
#### Crossover Signals
- Buy signal: When AWPO crosses above the signal line
- Sell signal: When AWPO crosses below the signal line
#### Divergence Signals
- Bearish Divergence: Price makes higher high while AWPO makes lower high
- Bullish Divergence: Price makes lower low while AWPO makes higher low
## Visual Components
### 1. Main Plots
- AWPO line (green/red based on direction)
- Signal line (yellow)
- Zero line (gray, dotted)
- Overbought/Oversold levels (dotted lines)
### 2. Color Fills
- AWPO to Signal line fill (green/red)
- AWPO to Zero line fill (green/red)
- Overbought/Oversold zone fills
### 3. Trade Signals
- Triangle up/down shapes for buy/sell signals
- Diamond shapes for divergence signals
## Anti-Repainting Measures
The code includes measures to prevent repainting:
```pine
var float safe_awpo = na
if barstate.isconfirmed
safe_awpo := awpo
```
This ensures signals only appear on confirmed bars.
## Alert Conditions
The indicator includes two alert conditions:
1. AWPO crossing above signal line (buy)
2. AWPO crossing below signal line (sell)
NY Session (MST)Highlights the New York session in MST. Highlights from 730am to 200pm to get a quick visual of previous sessions or overnight data.
Candlestick and Line Chart Patterns AnalyseDas Skript generiert Kaufen und Verkaufen Signale anhand der Analyse auf die gängistetn Kerzenmuster und der gängisten Chartlinienmuster
Indicador de Força de VelaForça de vela = ((close-low)-(high-close))*volume
Mostra a força de compra e venda durante o desenvolvimento da vela. Pode ser usado para definir quando entrar , através da força do momento da vela.
Moving average test scriptshowing buys and sells using the moving average. Looks for the areas and then shows an alert on the screen
Strategy test short - long Pour longer (flèche verte ▲) : Entrer quand l'EMA20 croise à la hausse l'EMA50, avec trois targets à +23.6%, +38.2%, et +61.8% calculés depuis le prix d'entrée.
Pour shorter (flèche rouge ▼) : Entrer quand l'EMA20 croise à la baisse l'EMA50, avec trois targets à -23.6%, -38.2%, et -61.8% calculés depuis le prix d'entrée.
DP Strategy by Shailesh Desai DP Strategy by Shailesh Desai
The DP Strategy is a comprehensive pivot point-based trading indicator designed to enhance decision-making by identifying key support and resistance levels on various timeframes. This indicator allows traders to select different pivot point calculation methods, including Traditional, Woodie, Classic, DM, and Camarilla, offering flexibility and adaptability to different market conditions.
Key Features:
1. Multiple Timeframes:
o The indicator supports a range of timeframes, from intraday (daily) to long-term (yearly) intervals, including custom periods like bi-yearly, tri-yearly, and decennial.
o Users can set the pivot calculation timeframe to "Auto" or choose a specific timeframe, allowing dynamic adjustment based on the current chart period.
2. Pivot Point Calculation:
o The Traditional method, which is default, calculates pivot points using the median of the high, low, and close prices. It also computes multiple levels of support (S1, S2, S3, S4, S5) and resistance (R1, R2, R3, R4, R5) for comprehensive market analysis.
o Fibonacci-based pivots are also included, offering additional levels (P1/Q1, P2/Q2, P3/Q3) that help identify potential reversal zones and continuation levels based on Fibonacci retracement values.
3. Customization Options:
o Users can customize the number of pivot points displayed, the line width, and the colors for various pivot levels.
o The indicator includes options to display labels for each pivot level on the left or right of the chart, enhancing visual clarity and ease of interpretation.
4. Dynamic Adjustment:
o The script includes logic to dynamically adjust pivot calculations based on market changes, ensuring that the levels remain relevant and up-to-date.
o It considers gap adjustments for a more accurate reflection of market behavior, especially in intraday trading.
5. Visual Aids:
o The indicator plots lines and labels directly on the chart for each pivot point, making it easier for traders to spot key levels without switching to a different screen or reference.
o It uses a clean and color-coded system to differentiate between various pivot levels, improving the overall user experience.
Practical Application:
The DP Strategy by Shailesh Desai is suitable for traders looking to incorporate pivot points into their trading strategy for identifying potential entry and exit points. It is particularly useful for detecting market trends and reversals, making it a valuable tool for both short-term and long-term traders.
By integrating traditional pivot calculations with customizable timeframes and Fibonacci retracement levels, this strategy provides a robust framework for navigating the complexities of financial markets.
How the Indicator Works:
1. Pivot Point Calculation: Depending on the selected method (Traditional or Fibonacci), the indicator calculates the pivot point, resistance (R1, R2, R3, etc.), and support levels (S1, S2, S3, etc.) based on historical price data.
2. Dynamic Updates: The indicator updates these levels as new price data becomes available, ensuring that traders have the most recent levels to work with.
3. Visual Representation: The calculated levels are displayed on the chart with customizable lines and labels, helping traders visualize potential support and resistance zones.
How Users can make Profit:
1. Identifying Entry and Exit Points: By observing how the price interacts with the calculated pivot points, traders can make informed decisions on entry and exit points. For instance, a bounce from a support level (S1) might signal a buying opportunity, while a reversal at a resistance level (R1) could suggest a selling point.
2. Risk Management: The multiple levels of support and resistance allow traders to set stop-loss and take-profit orders at strategic points, reducing risk and locking in profits.
3. Trend Confirmation: Pivot points can also help confirm trends. If the price breaks through a resistance level, it might indicate a bullish trend, while a break below a support level could signal a bearish trend.
Mail for contact: ibullsindia@gmail.com
Volume Weighted Average Price_kumaran//@version=6
indicator(title="Volume Weighted Average Price", shorttitle="VWAP", overlay=true, timeframe="", timeframe_gaps=true)
hideonDWM = input(false, title="Hide VWAP on 1D or Above", group="VWAP Settings", display = display.data_window)
var anchor = input.string(defval = "Session", title="Anchor Period",
options= , group="VWAP Settings")
src = input(title = "Source", defval = hlc3, group="VWAP Settings", display = display.data_window)
offset = input.int(0, title="Offset", group="VWAP Settings", minval=0, display = display.data_window)
BANDS_GROUP = "Bands Settings"
CALC_MODE_TOOLTIP = "Determines the units used to calculate the distance of the bands. When 'Percentage' is selected, a multiplier of 1 means 1%."
calcModeInput = input.string("Standard Deviation", "Bands Calculation Mode", options = , group = BANDS_GROUP, tooltip = CALC_MODE_TOOLTIP, display = display.data_window)
showBand_1 = input(true, title = "", group = BANDS_GROUP, inline = "band_1", display = display.data_window)
bandMult_1 = input.float(1.0, title = "Bands Multiplier #1", group = BANDS_GROUP, inline = "band_1", step = 0.5, minval=0, display = display.data_window)
showBand_2 = input(false, title = "", group = BANDS_GROUP, inline = "band_2", display = display.data_window)
bandMult_2 = input.float(2.0, title = "Bands Multiplier #2", group = BANDS_GROUP, inline = "band_2", step = 0.5, minval=0, display = display.data_window)
showBand_3 = input(false, title = "", group = BANDS_GROUP, inline = "band_3", display = display.data_window)
bandMult_3 = input.float(3.0, title = "Bands Multiplier #3", group = BANDS_GROUP, inline = "band_3", step = 0.5, minval=0, display = display.data_window)
cumVolume = ta.cum(volume)
if barstate.islast and cumVolume == 0
runtime.error("No volume is provided by the data vendor.")
new_earnings = request.earnings(syminfo.tickerid, earnings.actual, barmerge.gaps_on, barmerge.lookahead_on, ignore_invalid_symbol=true)
new_dividends = request.dividends(syminfo.tickerid, dividends.gross, barmerge.gaps_on, barmerge.lookahead_on, ignore_invalid_symbol=true)
new_split = request.splits(syminfo.tickerid, splits.denominator, barmerge.gaps_on, barmerge.lookahead_on, ignore_invalid_symbol=true)
isNewPeriod = switch anchor
"Earnings" => not na(new_earnings)
"Dividends" => not na(new_dividends)
"Splits" => not na(new_split)
"Session" => timeframe.change("D")
"Week" => timeframe.change("W")
"Month" => timeframe.change("M")
"Quarter" => timeframe.change("3M")
"Year" => timeframe.change("12M")
"Decade" => timeframe.change("12M") and year % 10 == 0
"Century" => timeframe.change("12M") and year % 100 == 0
=> false
isEsdAnchor = anchor == "Earnings" or anchor == "Dividends" or anchor == "Splits"
if na(src ) and not isEsdAnchor
isNewPeriod := true
float vwapValue = na
float upperBandValue1 = na
float lowerBandValue1 = na
float upperBandValue2 = na
float lowerBandValue2 = na
float upperBandValue3 = na
float lowerBandValue3 = na
if not (hideonDWM and timeframe.isdwm)
= ta.vwap(src, isNewPeriod, 1)
vwapValue := _vwap
stdevAbs = _stdevUpper - _vwap
bandBasis = calcModeInput == "Standard Deviation" ? stdevAbs : _vwap * 0.01
upperBandValue1 := _vwap + bandBasis * bandMult_1
lowerBandValue1 := _vwap - bandBasis * bandMult_1
upperBandValue2 := _vwap + bandBasis * bandMult_2
lowerBandValue2 := _vwap - bandBasis * bandMult_2
upperBandValue3 := _vwap + bandBasis * bandMult_3
lowerBandValue3 := _vwap - bandBasis * bandMult_3
plot(vwapValue, title="VWAP", color=#2962FF, offset=offset)
upperBand_1 = plot(upperBandValue1, title="Upper Band #1", color=color.green, offset=offset, display = showBand_1 ? display.all : display.none)
lowerBand_1 = plot(lowerBandValue1, title="Lower Band #1", color=color.green, offset=offset, display = showBand_1 ? display.all : display.none)
fill(upperBand_1, lowerBand_1, title="Bands Fill #1", color= color.new(color.green, 95) , display = showBand_1 ? display.all : display.none)
upperBand_2 = plot(upperBandValue2, title="Upper Band #2", color=color.olive, offset=offset, display = showBand_2 ? display.all : display.none)
lowerBand_2 = plot(lowerBandValue2, title="Lower Band #2", color=color.olive, offset=offset, display = showBand_2 ? display.all : display.none)
fill(upperBand_2, lowerBand_2, title="Bands Fill #2", color= color.new(color.olive, 95) , display = showBand_2 ? display.all : display.none)
upperBand_3 = plot(upperBandValue3, title="Upper Band #3", color=color.teal, offset=offset, display = showBand_3 ? display.all : display.none)
lowerBand_3 = plot(lowerBandValue3, title="Lower Band #3", color=color.teal, offset=offset, display = showBand_3 ? display.all : display.none)
fill(upperBand_3, lowerBand_3, title="Bands Fill #3", color= color.new(color.teal, 95) , display = showBand_3 ? display.all : display.none)