New York Master Range📈 New York Master Range (5-Min Timeframe)
Description:
This custom TradingView indicator captures the opening range based on the body high and low of the first 3 candles after 10:30 AM (BRT – Brasília Time) on the 5-minute timeframe — a technique often used during the New York market session.
🔍 How it works:
At exactly 10:30 AM (BRT), the indicator starts collecting the highs and lows of candle bodies (not wicks) for the next 3 five-minute candles.
Once the 3 candles are processed, the highest close/open (body high) and lowest close/open (body low) are plotted as static green and red lines on the chart.
These levels can act as key intraday support/resistance zones or range breakout triggers.
Tìm kiếm tập lệnh với "30年国债收益率"
ADR TableTrack volatility and session momentum in real-time with customizable precision.
 Key Features:
 Average Daily Range (ADR): Configurable length (default 5 days), based on previous daily high–low ranges.
 
 Session Anchor Options: Choose anchor at 4 am NY, 6 pm NY, 9:30 am NY, 8:30 am NY, Previous Day Close, or Current Bar.
 Session Range & %ADR: Displays the real-time range from the chosen anchor, plus what percentage of ADR has been covered.
 High / Low Target Levels: Calculates ADR targets based on anchor: anchor ± ADR.
 Optional Target Lines: Draw horizontal lines for high and low targets across the session; customize color and width.
 Dynamic Table Display: User-selectable table size and text size (Tiny to Huge) for optimal readability.
 Robust Anchor Logic: Uses the first bar at-or-after anchor time each NY day, ensuring stability even on irregular intraday timeframes.
 
 How to Use
 
 
 Choose your anchor in settings.
 View ADR, session range (with %ADR), and target price levels in the top-right pane.Toggle High/Low lines to overlay targets on the chart.
 Adjust table and text size to match your workspace.
 
 
 Why It Matters
 Quickly assess where price stands relative to typical volatility.
Easily identify intraday price exhaustion or breakout zones.
Anchor flexibility enables use for both futures and equities, aligning with your trading session.
Clean, professional display—no clutter, no guesswork.
ORB Norman (2 Sessions, Auto Timezone)ORB Norman (2 Sessions, Auto Timezone) 
This script plots Opening Range Breakout (ORB) levels for two configurable sessions. It’s designed for intraday traders—especially in futures markets like Gold (GC), Nasdaq (NQ), and S&P (ES)—who trade based on early session breakouts or range rejections. Unlike standard indicators, this tool auto-adjusts for timezones based on the instrument, ensuring precise session alignment.
 Features: 
Automatically adjusts for NQ/ES (Chicago time) and GC (New York time) based on the symbol.
Plots high, low, and optional midpoint lines for each session.
Clean, minimal settings with visual separation for better usability.
Ray extension length is fully customizable.
Works on any intraday chart (recommended: 5–15 minute timeframes).
Includes customizable session times, colors, ray length, and an optional midpoint line.
  Default Sessions: 
Session 1:
‣ 07:00–08:00 EST for GC
‣ 06:00–07:00 CT for NQ/ES
Session 2:
‣ 09:30–09:45 EST for GC
‣ 08:30–08:45 CT for NQ/ES
This tool is ideal for traders who scalp the early morning breakout or look for range rejections based on the opening auction.
This script was developed from scratch based on the author's own intraday trading needs.
Gold Power Hours Strategy📈 Gold Power Hours Trading Strategy 
Trade XAUUSD (Gold) or XAUEUR during the most volatile hours of the New York session, using momentum and trend confirmation, with session-specific risk/reward profiles.
 ✅ Strategy Rules 
🕒 Valid Trading Times ("Power Hours"):
Trades are only taken during high-probability time windows on  Tuesdays, Wednesdays, and Thursdays , corresponding to key New York session activity:
 Morning Session: 
08:00 – 11:00 (NY time)
 Afternoon Session: 
12:30 – 16:00
19:00 – 22:00
These times align with institutional activity and economic news releases.
📊 Technical Indicators Used:
50-period Simple Moving Average (SMA50):
Identifies the dominant market trend.
14-period Relative Strength Index (RSI):
Measures market momentum with session-adjusted thresholds.
 🟩 Buy Signal Criteria: 
Price is above the 50-period SMA (bullish trend)
RSI is greater than:
60 during Morning Session
55 during Afternoon Session
Must be during a valid day (Tue–Thu) and Power Hour session
 🟥 Sell Signal Criteria: 
Price is below the 50-period SMA (bearish trend)
RSI is less than:
40 during Morning Session
45 during Afternoon Session
Must be during a valid day and Power Hour session
 🎯 Trade Management Rules:
Morning Session (08:00–11:00) 
Stop Loss (SL): 50 pips
Take Profit (TP): 150 pips
Risk–Reward Ratio: 1:3
 Afternoon Session (12:30–16:00 & 19:00–22:00) 
Stop Loss (SL): 50 pips
Take Profit (TP): up to 100 pips
Risk–Reward Ratio: up to 1:2
⚠️ TP is slightly reduced in the afternoon due to typically lower volatility compared to the morning session.
 📺 Visuals & Alerts: 
Buy signals: Green triangle plotted below the bar
Sell signals: Red triangle plotted above the bar
SMA50 line: Orange
Valid session background: Light pink
Alerts: Automatic alerts for buy/sell signals
Time Period Highlighter V2This indicator highlights custom time periods on any intraday chart in TradingView, making it easier to visualize your preferred trading sessions.
You can define up to three separate time ranges per day, each with precise start and end times down to the minute (e.g., 08:30 - 12:15, 14:00 - 16:45, and 20:00 - 22:30). The indicator shades the background of your chart during these periods, helping you quickly identify when you're most active or when specific market conditions occur.
Key Features:
Set start and end times (hours and minutes) for up to three trading sessions.
Automatically highlights these periods across any intraday timeframe.
Uses 24-hour time format aligned with your TradingView chart timezone.
Perfect for day traders, scalpers, or anyone needing clear visual cues for their trading windows.
This tool is especially useful for reviewing trading strategies, backtesting, or ensuring you're focusing on high-probability market hours.
Tip: Double-check that your chart timezone matches your desired session times for accurate highlighting.
5 EMA STRATEGY by Power of Stocks(StockYogi)5 EMA STRATEGY by Power of Stocks(StockYogi)
This is a 5 EMA Breakout Strategy inspired by the trading principles taught by Shubhashi Pani, founder of the Power of Stocks (POS) community.
The strategy is designed to:
• Detect breakout setups when price breaks the high/low of a signal candle (based on EMA conditions)
• Enter trades only if the breakout occurs within the next 3 candles
• Allow multiple trades in the same direction without closing the earlier one
• Use independent stop-loss (SL) and take-profit (TP) targets for each trade based on a user-defined risk-reward ratio
• Optionally enter trades only at candle close
• Optionally avoid trades during a custom time window (e.g., 3:00 PM to 3:30 PM IST)
• Optionally close all open positions at a defined time (e.g., 3:30 PM IST)
The goal of this strategy is to provide greater flexibility and realism for intraday or short-term traders following structured breakout systems.
Disclaimer: This script is an implementation of technical ideas for educational purposes only. It is not financial advice. All trading involves risk, and past performance does not guarantee future results.
Strategy Credits:
This strategy is based on publicly known breakout rules taught by Shubhashi Pani (Power of Stocks). This is not an official POS script, and I am not affiliated with the Power of Stocks team. This implementation was developed independently to follow the logic shared for educational use.
Feel free to use, backtest, and modify according to your needs. Constructive feedback is welcome!
Capital Risk OptimizerCapital Risk Optimizer 🛡️ 
 The Capital Risk Optimizer is an educational tool designed to help traders study capital efficiency, risk management, and scaling strategies when using leverage. 
This script calculates and visualizes essential metrics for managing leveraged positions, including:
 Entry Price –  The current market price.
 Stop Loss Level –  Automatically derived using the 30-bar lowest low minus 1 ATR (default: 14-period ATR), an approach designed to create a dynamic, volatility-adjusted stop loss.
 Stop Loss Distance (%) –  The percentage distance between entry and stop.
 Maximum Safe Leverage –  The highest leverage allowable without risking liquidation before your stop is reached.
 Margin Required –  The amount of collateral necessary to support the desired position size at the calculated leverage.
 Position Size –  The configurable notional value of your trade.
These outputs are presented in a clean, customizable table overlay so you can quickly understand how position sizing, volatility, and leverage interact.
By default, the script uses a 14-period ATR combined with the lowest low of the past 30 bars, providing an optimal balance between sensitivity and noise for defining stop placement. This methodology helps traders account for market volatility in a systematic way.
The Capital Risk Optimizer is particularly useful as a portfolio management tool, supporting traders who want to study how to scale into positions using risk-adjusted sizing and capital efficiency principles. It pairs best with backtested strategies, and does not directly produce signals of any kind.
 How to Use: 
Set your desired position size.
Adjust the ATR and lookback settings to fine-tune stop loss placement.
Study the resulting leverage and margin requirements in real time.
Use this information to simulate and visualize potential trade scenarios and capital allocation models.
 Disclaimer:
This script is provided for educational and informational purposes only. It does not constitute financial advice and should not be relied upon for live trading decisions. Always do your own research and consult with a qualified professional before making any trading or investment decisions.
Custom Daily Session Zones by KoenigseggCustom Daily Session Zones 
🟣 Description
This indicator displays customizable trading session time zones as background highlights on your chart, on any timeframe you choose. The inline info tooltip provides the precise start and end times of the three largest market sessions—the US, the EU, and ASIA—for quick reference. It provides flexible control over session times for different days of the week, making it ideal for traders who need to visualize specific market hours or trading sessions.
🟣 Key Features
- Flexible Session Configuration: Set a common session time for all days or customize individual sessions for each day of the week
- Per-Day Control: Enable or disable sessions for specific days (Monday through Sunday)
- Color Customization: Choose unique colors for each day's session zones
- UTC Timezone Standard: All session times are defined in UTC to ensure consistency across charts
- Clean Visual Display: Non-intrusive background highlighting that doesn't interfere with price action
🟣 How to Use
- Common Session Mode: Use the default mode to apply the same session time across all enabled days
- Manual Per-Day Mode: Enable "Manual per-day sessions" to set different session times for each day
- Day Selection: Toggle individual days on/off based on your trading schedule
- Color Coding: Customize colors for each day to easily distinguish between different sessions
🟣 Technical Details
- Uses Pine Script v6 for optimal performance
- Implements proper session time detection using TradingView's built-in time functions
- Operates in UTC timezone for all session calculations
- Lightweight code that doesn't impact chart performance
🟣 Use Cases
- Highlight specific trading sessions (London, New York, Tokyo, etc.)
- Mark important market hours for your trading strategy
- Visualize different session overlaps
- Create custom trading time windows
- Track market activity during specific hours
🟣 Compatibility
- Works on all timeframes
- Compatible with all asset classes (Forex, Stocks, Crypto, Futures, etc.)
- Supports all TradingView chart types
- Responsive design that adapts to different screen sizes
🟣 Image Descriptions
- First Image (main image):  Shows multiple New York Stock Exchange sessions from 1:30 p.m. to 8:00 p.m. (UTC), on the 15-minute timeframe, with each day’s zone colored differently to demonstrate the indicator’s customizable color settings. 
- Second Image:  A zoomed‑in fractal chart view of the same New York session on the 15-minute timeframe, illustrating how the background session zone appears even at higher detail levels. 
  
Third Image:  A close‑up of the New York session (1:30 p.m. to 8:00 p.m.) on the 3-minute timeframe, reaffirming the consistency of zone highlighting across different zoom levels. 
  
🟣 Future Updates (v2)
In the next release, you’ll be able to define multiple session blocks per day—displaying two distinct colored zones within the same trading day. This will help you visualize when one market session ends and another begins without losing chart clarity.
🟣 Conclusion
This indicator is perfect for traders who need precise control over Market Session visualization and want to maintain a clean, professional chart appearance.
🟣 Disclaimer
This script is provided for educational and illustrative purposes only. It is not financial or trading advice, nor a recommendation to buy or sell any asset. Always conduct your own research and consult a professional before making any trading decisions.
NQ Position Size CalculatorNQ Position Size Line Calculator is designed specifically for Nasdaq 100 futures (NQ) and micro futures (MNQ) traders who want to maintain disciplined risk management. This visual tool eliminates the guesswork from position sizing by displaying distance lines and contract calculations directly on your chart.
The indicator creates horizontal lines at 10-tick intervals from your stop loss level, showing you exactly how many contracts to trade at each distance to maintain your predetermined risk amount. Whether you're trading regular NQ contracts or micro MNQ contracts, this calculator ensures you never risk more than intended while providing instant visual feedback for optimal position sizing decisions.
 How to Use the Indicator 
Step 1: Configure Your Settings
 
 Stop Loss Price: Enter your exact stop loss level (e.g., 20000.00)
 Risk Amount ($): Set your maximum dollar risk per trade (e.g., $500)
 
Contract Type: Choose between:
 
 NQ (Regular): $5 per tick - for larger accounts
 MNQ (Micro): $0.50 per tick - for smaller accounts or conservative sizing
 
Display Options:
 
 Max Lines: Number of distance lines to show (default: 30)
 Show Labels: Toggle tick distance and contract count labels
 Line Color: Customize the color of distance lines
 Label Size: Choose tiny, small, or normal label sizes
 
Step 2: Read the Visual Display
Once configured, the indicator displays:
Stop Loss Line:
 
 Thick yellow line marking your exact stop loss level
 Yellow label showing the stop loss price
 
Distance Lines:
 
 Dashed red lines at 10-tick intervals above and below your stop loss
 Lines appear on both sides for long and short position planning
 
Labels (if enabled):
 
 Green labels (right side): For long positions above your stop loss
 Red labels (left side): For short positions below your stop loss
 Format: "20T 5x" means 20 ticks distance, 5 contracts maximum
 
Step 3: Use the Information Tables
The indicator provides two helpful tables:
Position Size Table (top-right):
 
 Shows common tick distances (10, 20, 40, 80, 160 ticks)
 Displays risk per contract at each distance
 Contract count for your specified risk amount
 Total risk with rounded contract numbers
 
Settings Table (bottom-right):
 
 Confirms your current risk amount
 Shows selected contract type
 Displays current settings for quick reference
 
Step 4: Apply to Your Trading
For Long Positions:
 
 Look at the green labels on the right side of your chart
 Find your desired entry level
 Read the label to see: distance in ticks and maximum contracts
 Example: "30T 8x" = 30 ticks from stop, buy 8 contracts maximum
 
For Short Positions:
 
 Look at the red labels on the left side of your chart
 Find your desired entry level
 Read the label for tick distance and contract count
 Example: "40T 6x" = 40 ticks from stop, sell 6 contracts maximum
 
Step 5: Trading Execution
Before Entering a Trade:
 
 Identify your stop loss level and input it into the indicator
 Choose your entry point by looking at the distance lines
 Note the contract count from the corresponding label
 Verify the risk amount matches your trading plan
 Execute your trade with the calculated position size
 
Risk Management Features:
 
 Contract rounding: All position sizes are rounded down (never up) to ensure you don't exceed your risk limit
 Zero position filtering: Lines only show where position size is at least 1 contract
 Dual-sided display: Plan both long and short opportunities simultaneously
Your trading time period background fillThis script allows you to add background highlights to charts during any regional trading session, customize your own trading time, and is precise and customizable yet simple and easy to use, making it more convenient to review transactions.
Support global mainstream time zones: The drop-down list includes 30 commonly used IANA time zones (default is Asia/Shanghai) (such as Asia/Shanghai, America/New_York, Europe/London, etc.), one-click switching, no need to manually calculate the time difference.
Fully localized time input: "Start hour/minute" and "End hour/minute" are filled in with the local time of the selected time zone. The end hour defaults to 23:00 and can be adjusted to 0-23 at will.
Accurate time difference splitting: The script internally splits the time zone offset into whole hours and remainder minutes (supports half-hour zones, such as UTC+5:30), and ensures that all parameters are integers when calling timestamp to avoid errors.
Dynamic background rendering: Each K-line is judged according to the UTC timestamp whether it falls within the set range. If it meets the time period, it will be marked with a semi-transparent green background, and it will return to its original state after crossing the time period, helping you to identify the opening, closing or active period of any market at a glance.
Wide range of scenarios: It can be used for time-sharing highlighting of all-weather varieties of foreign exchange and cryptocurrency, and can also be used in conjunction with backtesting and timing strategies to only send signals during the active period of the target market, greatly improving trading efficiency and strategy accuracy.
Just select the region and set the time, and the script will automatically complete all complex time zone conversions and drawing, allowing you to focus on the transaction itself.
Chaikin Money Flow (CMF) [ParadoxAlgo]OVERVIEW 
This indicator implements the Chaikin Money Flow oscillator as an overlay on the price chart, designed to help traders identify institutional money flow patterns. The Chaikin Money Flow combines price and volume data to measure the flow of money into and out of a security, making it particularly useful for detecting accumulation and distribution phases.
 WHAT IS CHAIKIN MONEY FLOW? 
Chaikin Money Flow was developed by Marc Chaikin and measures the amount of Money Flow Volume over a specific period. The indicator oscillates between +1 and -1, where:
 
 Positive values indicate money flowing into the security (accumulation)
 Negative values indicate money flowing out of the security (distribution)
 Values near zero suggest equilibrium between buying and selling pressure
 
 CALCULATION METHOD 
 
 Money Flow Multiplier = ((Close - Low) - (High - Close)) / (High - Low)
 Money Flow Volume = Money Flow Multiplier × Volume
 CMF = Sum of Money Flow Volume over N periods / Sum of Volume over N periods
 
 KEY FEATURES 
Big Money Detection:
 
 Identifies significant institutional activity when CMF exceeds user-defined thresholds
 Requires volume confirmation (volume above average) to validate signals
 Uses battery icon (🔋) for institutional buying and lightning icon (⚡) for institutional selling
 
Visual Elements:
 
 Background coloring based on money flow direction
 Support and resistance levels calculated using Average True Range
 Real-time dashboard showing current CMF value, volume strength, and signal status
 
Customizable Parameters:
 
 CMF Period: Calculation period for the money flow (default: 20)
 Signal Smoothing: EMA smoothing applied to reduce noise (default: 5)
 Big Money Threshold: CMF level required to trigger institutional signals (default: 0.15)
 Volume Threshold: Volume multiplier required for signal confirmation (default: 1.5x)
 
 INTERPRETATION 
Signal Types:
 
 🔋 (Battery): Indicates strong institutional buying when CMF > threshold with high volume
 ⚡ (Lightning): Indicates strong institutional selling when CMF < -threshold with high volume
 Background color: Green tint for positive money flow, red tint for negative money flow
 
Dashboard Information:
 
 CMF Value: Current Chaikin Money Flow reading
 Volume: Current volume as a multiple of 20-period average
 Big Money: Status of institutional activity (BUYING/SELLING/QUIET)
 Signal: Strength assessment (STRONG/MEDIUM/WEAK)
 
 
 TRADING APPLICATIONS 
 
 Trend Confirmation: Use CMF direction to confirm price trends
 Divergence Analysis: Look for divergences between price and money flow
 Volume Validation: Confirm breakouts with corresponding money flow
 Accumulation/Distribution: Identify phases of institutional activity
 
 PARAMETER RECOMMENDATIONS 
 
 Day Trading: CMF Period 14-21, higher sensitivity settings
 Swing Trading: CMF Period 20-30, moderate sensitivity
 Position Trading: CMF Period 30-50, lower sensitivity for major trends
 
 ALERTS 
Optional alert system notifies users when:
 
 Big money buying is detected (CMF above threshold with volume confirmation)
 Big money selling is detected (CMF below negative threshold with volume confirmation)
 
 LIMITATIONS 
 
 May generate false signals in low-volume conditions
 Best used in conjunction with other technical analysis tools
 Effectiveness varies across different market conditions and timeframes
 
 EDUCATIONAL PURPOSE 
This open-source indicator is provided for educational purposes to help traders understand money flow analysis. It demonstrates the practical application of the Chaikin Money Flow concept with visual enhancements for easier interpretation.
 TECHNICAL SPECIFICATIONS 
Overlay indicator (displays on price chart)
No repainting - all calculations are based on closed bar data
Suitable for all timeframes and asset classes
Minimal resource usage for optimal performance
 DISCLAIMER 
This indicator is for educational and informational purposes only. Past performance does not guarantee future results. Always conduct your own analysis and consider risk management before making trading decisions.
log.info() - 5 Exampleslog.info() is one of the most powerful tools in Pine Script that no one knows about. Whenever you code, you want to be able to debug, or find out why something isn’t working. The log.info() command will help you do that. Without it, creating more complex Pine Scripts becomes exponentially more difficult.
The first thing to note is that log.info() only displays strings. So, if you have a variable that is not a string, you must turn it into a string in order for log.info() to work. The way you do that is with the str.tostring() command. And remember, it's all lower case! You can throw in any numeric value (float, int, timestamp) into str.string() and it should work.
Next, in order to make your output intelligible, you may want to identify whatever value you are logging. For example, if an RSI value is 50, you don’t want a bunch of lines that just say “50”. You may want it to say “RSI = 50”.
To do that, you’ll have to use the concatenation operator. For example, if you have a variable called “rsi”, and its value is 50, then you would use the “+” concatenation symbol.
EXAMPLE 1
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 //@version=6
indicator("log.info()")
rsi = ta.rsi(close,14)
log.info(“RSI= ” + str.tostring(rsi)) 
Example Output => 
RSI= 50
Here, we use double quotes to create a string that contains the name of the variable, in this case “RSI = “, then we concatenate it with a stringified version of the variable, rsi.
Now that you know how to write a log, where do you view them? There isn’t a lot of documentation on it, and the link is not conveniently located. 
Open up the “Pine Editor” tab at the bottom of any chart view, and you’ll see a “3 dot” button at the top right of the pane. Click that, and right above the “Help” menu item you’ll see “Pine logs”. Clicking that will open  that to open a pane on the right of your browser - replacing whatever was in the right pane area before. This is where your log output will show up. 
But, because you’re dealing with time series data, using the log.info() command without some type of condition will give you a fast moving stream of numbers that will be difficult to interpret. So, you may only want the output to show up once per bar, or only under specific conditions. 
To have the output show up only after all computations have completed, you’ll need to use the  barState.islast command. Remember, barState is camelCase, but islast is not!
EXAMPLE 2
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 //@version=6
indicator("log.info()")
rsi = ta.rsi(close,14)
if barState.islast 
  log.info("RSI=" + str.tostring(rsi))
plot(rsi) 
However, this can be less than ideal, because you may want the value of the rsi variable on a particular bar, at a particular time, or under a specific chart condition. Let’s hit these one at a time.
In each of these cases, the built-in bar_index variable will come in handy. When debugging, I typically like to  assign a variable “bix” to represent bar_index, and include it in the output.
So, if I want to see the rsi value when RSI crosses above 0.5, then I would have something like
EXAMPLE 3
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 //@version=6
indicator("log.info()")
rsi = ta.rsi(close,14)
bix = bar_index
rsiCrossedOver = ta.crossover(rsi,0.5)
if rsiCrossedOver
  log.info("bix=" + str.tostring(bix) + " - RSI=" + str.tostring(rsi))
plot(rsi) 
Example Output => 
bix=19964 - RSI=51.8449459867
bix=19972 - RSI=50.0975830828
bix=19983 - RSI=53.3529808079
bix=19985 - RSI=53.1595745146
bix=19999 - RSI=66.6466337654
bix=20001 - RSI=52.2191767466
Here, we see that the output only appears when the condition is met.
A useful thing to know is that if you want to limit the number of decimal places, then you would use the command str.tostring(rsi,”#.##”), which tells the interpreter that the format of the number should only be 2 decimal places. Or you could round the rsi variable with a command like rsi2 = math.round(rsi*100)/100 . In either case you’re output would look like:
bix=19964 - RSI=51.84
bix=19972 - RSI=50.1
bix=19983 - RSI=53.35
bix=19985 - RSI=53.16
bix=19999 - RSI=66.65
bix=20001 - RSI=52.22
This would decrease the amount of memory that’s being used to display your variable’s values, which can become a limitation for the log.info() command. It only allows 4096 characters per line, so when you get to trying to output arrays (which is another cool feature), you’ll have to keep that in mind.
Another thing to note is that log output is always preceded by a timestamp, but for the sake of brevity, I’m not including those in the output examples.
If you wanted to only output a value after the chart was fully loaded, that’s when barState.islast command comes in. Under this condition, only one line of output is created per tick update — AFTER the chart has finished loading. For example, if you only want to see what the the current bar_index and rsi values are, without filling up your log window with everything that happens before, then you could use the following code:
EXAMPLE 4
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 //@version=6
indicator("log.info()")
rsi = ta.rsi(close,14)
bix = bar_index
if barstate.islast
  log.info("bix=" + str.tostring(bix) + " - RSI=" + str.tostring(rsi)) 
Example Output =>
bix=20203 - RSI=53.1103309071
This value would keep updating after every new bar tick.
The log.info() command is a huge help in creating new scripts, however, it does have its limitations. As mentioned earlier, only 4096 characters are allowed per line. So, although you can use log.info() to output arrays, you have to be aware of how many characters that array will use.
The following code DOES NOT WORK! And, the only way you can find out why will be the red exclamation point next to the name of the indicator. That, and nothing will show up on the chart, or in the logs.
 // CODE DOESN’T WORK
//@version=6
indicator("MW - log.info()")
var array rsi_arr = array.new()
rsi = ta.rsi(close,14)
bix = bar_index
rsiCrossedOver = ta.crossover(rsi,50) 
if rsiCrossedOver
    array.push(rsi_arr, rsi)
if barstate.islast
    log.info("rsi_arr:" + str.tostring(rsi_arr))
    log.info("bix=" + str.tostring(bix) + " - RSI=" + str.tostring(rsi))
plot(rsi)
// No code errors, but will not compile because too much is being written to the logs. 
However, after putting some time restrictions in with the i_startTime and i_endTime user input variables, and creating a dateFilter variable to use in the conditions, I can limit the size of the final array. So, the following code does work.
EXAMPLE 5
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 // CODE DOES WORK
//@version=6
indicator("MW - log.info()")
i_startTime         = input.time(title="Start", defval=timestamp("01 Jan 2025 13:30 +0000"))
i_endTime           = input.time(title="End", defval=timestamp("1 Jan 2099 19:30 +0000"))
var array rsi_arr = array.new()
dateFilter = time >= i_startTime and time <= i_endTime 
rsi = ta.rsi(close,14)
bix = bar_index
rsiCrossedOver = ta.crossover(rsi,50) and dateFilter // <== The dateFilter condition keeps the array from getting too big
if rsiCrossedOver
    array.push(rsi_arr, rsi)
if barstate.islast
    log.info("rsi_arr:" + str.tostring(rsi_arr))
    log.info("bix=" + str.tostring(bix) + " - RSI=" + str.tostring(rsi))
plot(rsi) 
Example Output =>
rsi_arr: 
bix=20210 - RSI=56.9030578034
Of course, if you restrict the decimal places by using the rounding the rsi value with something like rsiRounded = math.round(rsi * 100) / 100 , then you can further reduce the size of your array. In this case the output may look something like:
Example Output =>
rsi_arr: 
bix=20210 - RSI=55.6947486019
This will give your code a little breathing room.
In a nutshell, I was coding for over a year trying to debug by pushing output to labels, tables, and using libraries that cluttered up my code. Once I was able to debug with log.info() it was a game changer. I was able to start building much more advanced scripts. Hopefully, this will help you on your journey as well.
RSI-Adaptive T3 + Squeeze Momentum Strategy✅ Strategy Guide: RSI-Adaptive T3 + Squeeze Momentum Strategy 
📌  Overview 
The RSI-Adaptive T3 + Squeeze Momentum Strategy is a dynamic trend-following strategy based on an  RSI-responsive T3 moving average  and  Squeeze Momentum detection .
It adapts in real-time to market volatility to enhance entry precision and optimize risk.
⚠️ This strategy is provided for educational and research purposes only.
Past performance does not guarantee future results.
🎯  Strategy Objectives 
The main objective of this strategy is to catch the early phase of a trend and generate consistent entry signals.
Designed to be intuitive and accessible for traders from beginner to advanced levels.
✨  Key Features 
 
 RSI-Responsive T3: T3 length dynamically adjusts according to RSI values for adaptive trend detection
 Squeeze Momentum: Combines Bollinger Bands and Keltner Channels to identify trend buildup phases
 Visual Triggers: Entry signals are generated from T3 crossovers and momentum strength after squeeze release
 
📊  Trading Rules 
 Long Entry: 
When T3 crosses upward, momentum is positive, and the squeeze has just been released.
 Short Entry: 
When T3 crosses downward, momentum is negative, and the squeeze has just been released.
 Exit (Reversal): 
When the opposite condition to the entry is triggered, the position is reversed.
💰  Risk Management Parameters 
 
 Pair & Timeframe: BTC/USD (30-minute chart)
 Capital (simulated): $30,00
 Order size: `$100` per trade (realistic, low-risk sizing)
 Commission: 0.02%
 Slippage: 2 pips
 Risk per Trade: 5%
 Number of Trades (backtest period): 181
 
 📊 Performance Overview 
 
 Symbol: BTC/USD
 Timeframe: 30-minute chart
 Date Range: January 1, 2024 – July 3, 2025
 Win Rate: 47.8%
 Profit Factor: 2.01
 Net Profit: 173.16 (units not specified)
 Max Drawdown: 5.77% or 24.91 (0.79%)
 
⚙️  Indicator Parameters 
 Indicator Name:  RSI-Adaptive T3 + Squeeze Momentum
 
 RSI Length: 14
 T3 Min Length: 5
 T3 Max Length: 50
 T3 Volume Factor: 0.7
 BB Length: 27 (Multiplier: 2.0)
 KC Length: 20 (Multiplier: 1.5, TrueRange enabled)
 
🖼  Visual Support 
T3 slope direction, squeeze status, and momentum bars are visually plotted on the chart,
providing high clarity for quick trend analysis and execution.
🔧  Strategy Improvements & Uniqueness 
Inspired by the  RSI Adaptive T3 by ChartPrime  and  Squeeze Momentum Indicator by LazyBear ,
this strategy fuses both into a  hybrid trend-reversal and momentum breakout detection system .
Compared to traditional trend-following methods, it excels at  capturing early trend signals with greater sensitivity .
✅  Summary 
The RSI-Adaptive T3 + Squeeze Momentum Strategy combines momentum detection with volatility-responsive risk management.
With a strong balance between visual clarity and practicality, it serves as a powerful tool for traders seeking high repeatability.
⚠️ This strategy is based on historical data and does not guarantee future profits.
Always use appropriate risk management when applying it.
Opening Range Breakout🧭 Overview
The Open Range Breakout (ORB) indicator is designed to capture and display the initial price range of the trading day (typically the first 15 minutes), and help traders identify breakout opportunities beyond this range. This is a popular strategy among intraday and momentum traders.
🔧 Features
📊 ORB High/Low Lines
Plots horizontal lines for the session’s high and low
🟩 Breakout Zones
Background highlights when price breaks above or below the range
🏷️ Breakout Labels
Text labels marking breakout events
🧭 Session Control
Customizable session input (default: 09:15–09:30 IST)
📍 ORB Line Labels
Text labels anchored to the ORB high and low lines (aligned right)
🔔 Alerts
Configurable alerts for breakout events
⚙️ Adjustable Settings
Show/hide background, labels, session window, etc.
⏱️ Session Logic
	•	The ORB range is calculated during a defined session window (default: 09:15–09:30).
	•	During this window, the highest high and lowest low are recorded as ORB High and ORB Low.
📈 Breakout Detection
	•	Breakout Above: Triggered when price crosses above the ORB High.
	•	Breakout Below: Triggered when price crosses below the ORB Low.
	•	Each breakout can trigger:
	•	A background highlight (green/red)
	•	A text label (“Breakout ↑” / “Breakout ↓”)
	•	An optional alert
🔔 Alerts
Two built-in alert conditions:
	1.	Breakout Above ORB High
	•	Message: "🔼 Price broke above ORB High: {{close}}"
	2.	Breakout Below ORB Low
	•	Message: "🔽 Price broke below ORB Low: {{close}}"
You can create alerts in TradingView by selecting these from the Add Alert window.
📌 Best Use Cases
	•	Intraday momentum trading
	•	Breakout and scalping strategies
	•	First 15-minute range traders (NSE, BSE markets)
Intraday Session Levels: Pre-Mkt, 5m, 15m (Replay/Toggle/Labels)Intraday Session Levels: Pre-Mkt, 5m, 15m (Replay/Toggle/Labels) 
 Version v1.0 
Live session levels for every trader!
This indicator automatically tracks and draws the most actionable intraday levels as they develop—live in real-time and fully compatible with TradingView’s bar replay and backtesting.
 How it works: 
 Pre-Market High & Low: 
Levels appear and update live as soon as the pre-market session starts (4:00am ET), then “freeze” at the official open (9:30am ET) and remain visible for the rest of the day.
 
First 5-Minute Candle High/Low: 
Drawn instantly after the first 5-minute candle (9:30–9:35am ET) completes.
 First 15-Minute Candle High/Low: 
Drawn right after the first 15-minute candle (9:30–9:45am ET) completes.
Labels on every line
Each level is clearly labeled on your chart (“PreMkt High”, “5m Low”, “15m High”, etc).
 Perfect for backtesting: 
All levels display exactly as they would have appeared in real time, making this indicator fully bar replay and historical test compatible.
 Flexible ON/OFF toggles: 
Instantly show or hide Pre-Mkt, 5m, and 15m levels via the settings panel.
Why use it?
Identify support/resistance and key reaction zones intraday
Fade or break the opening range with confidence
Backtest your strategies with accurate historical context
Reduce chart clutter with customizable, minimal visuals
Whether you’re a scalper, day trader, or backtest enthusiast, this tool keeps your charts focused and your edge sharp.
Developed by 
Options Strategy V1.3📈 Options Strategy V1.3 — EMA Crossover + RSI + ATR + Opening Range
Overview:
This strategy is designed for short-term directional trades on large-cap stocks or ETFs, especially when trading options. It combines classic trend-following signals with momentum confirmation, volatility-based risk management, and session timing filters to help identify high-probability entries with predefined stop-loss and profit targets.
🔍 Strategy Components:
EMA Crossover (Fast/Slow)
Entry signals are triggered by the crossover of a short EMA above or below a long EMA — a traditional trend-following method to detect shifts in momentum.
RSI Filter
RSI confirms the signal by avoiding entries in overbought/oversold zones unless certain momentum conditions are met.
Long entry requires RSI ≥ Long Threshold
Short entry requires RSI ≤ Short Threshold
ATR-Based SL & TP
Stop-loss is set dynamically as a multiple of ATR below (long) or above (short) the entry price.
Take-profit is placed as a ratio (TP/SL) of the stop distance, ensuring consistent reward/risk structure.
Opening Range Filter (Optional)
If enabled, the strategy only triggers trades after price breaks out of the 09:30–09:45 EST range, ensuring participation in directional moves.
Session Filters
No trades from 04:00 to 09:30 and from 16:00 to 20:00 EST, avoiding low-liquidity periods.
All open trades are closed at 15:55 EST, to avoid overnight risk or expiration issues for options.
⚙️ Built-in Presets:
You can choose one of the built-in ticker-specific presets for optimal conditions:
Ticker	EMAs	RSI (Long/Short)	ATR	SL×ATR	TP/SL
SPY	8/28	56 / 26	14	1.4×	4.0×
TSLA	23/27	56 / 33	13	1.4×	3.6×
AAPL	6/13	61 / 26	23	1.4×	2.1×
MSFT	25/32	54 / 26	14	1.2×	2.2×
META	25/32	53 / 26	17	1.8×	2.3×
AMZN	28/32	55 / 25	16	1.8×	2.3×
You can also choose "Custom" to fully configure all parameters to your own market and strategy preferences.
📌 Best Use Case:
This strategy is especially suited for intraday options trading, where timing and risk control are critical. It works best on liquid tickers with strong trends or clear breakout behavior.
Next Day Key Levels [Auto-Pivot Suite] RobustNext Day Key Levels  
Automatically plot key levels (Floor Pivots) for the next U.S. trading day, with smart session detection.
What does this script do?
Automatically detects the most recent completed U.S. regular trading session (9:30 AM–4:00 PM Eastern) and plots all classic Floor Pivot levels for the next trading day.
Handles Mondays and holidays: Always uses the most recent session’s data, so Friday’s values are shown on Monday, and holidays are skipped seamlessly.
Works in both pre-market and after-hours—levels appear for the next session at the right time.
Levels plotted:
Previous Session High (H)
Previous Session Low (L)
Previous Session Close (C)
Pivot (P)
Resistance 1, 2, 3 (R1, R2, R3)
Support 1, 2, 3 (S1, S2, S3)
How it works
Monitors each bar and tracks session highs/lows/close only during regular market hours.
At the close of each session (4:00 PM ET), saves these values.
In pre-market (before 9:30 AM ET) and after-hours (after 4:00 PM ET), automatically plots levels based on the last completed session—always the correct session, even on Mondays and after holidays.
Why is it better?
No clutter: Only one set of levels per day, drawn cleanly.
Accurate pivots for every next U.S. session.
Zero manual setup: Add to any U.S. ticker, on any intraday timeframe.
Features
Works across all U.S. stocks and ETFs.
Plots and labels all levels with color coding for quick reference.
Designed for intraday and short-term trading strategies.
Handles time zone and market session edge cases automatically.
How to use
Add the indicator to any U.S. equity or ETF chart (15m–1h timeframes recommended).
Levels will appear automatically in pre-market or after the market closes, always for the next session.
Trade with confidence using automatic, accurate pivots and support/resistance levels.
Developed by  .
For questions or feedback, leave a comment below!
Momentum Trail Oscillator [AlgoAlpha]🟠 OVERVIEW 
This script builds a Momentum Trail Oscillator designed to measure directional momentum strength and dynamically track shifts in trend bias using a combination of smoothed price change calculations and adaptive trailing bands. The oscillator aims to help traders visualize when momentum is expanding or contracting and to identify transitions between bullish and bearish conditions.
🟠 CONCEPTS 
The core idea combines two methods. First, the script calculates a normalized momentum measure by smoothing price changes relative to their absolute values, which creates a bounded oscillator that highlights whether moves are directional or choppy. Second, it uses a trailing band mechanism inspired by volatility stops, where bands adapt to the oscillator’s volatility, adjusting the thresholds that define a shift in directional bias. This dual approach seeks to address both the magnitude and persistence of momentum, reducing false signals in ranging markets.
🟠 FEATURES 
The momentum calculation applies Hull Moving Averages and double EMA smoothing to price changes, producing a smooth, responsive oscillator.
  
The trailing bands are derived by offsetting a weighted moving average of the oscillator by a multiple of recent momentum volatility. A directional state variable tracks whether the oscillator is above or below the bands, updating when the momentum crosses these dynamic thresholds. 
  
Overbought and oversold zones are visually marked between fixed levels (+30/+40 and -30/-40), with color fills to highlight when momentum is in extreme areas. The script plots signals on both the oscillator pane and optionally overlays markers on the main price chart for clarity.
  
🟠 USAGE 
To use the indicator, apply it to any symbol and timeframe. The “Oscillator Length” controls how sensitive the momentum line is to recent price changes—lower values react faster, higher values smooth out noise. The “Trail Multiplier” sets how far the adaptive bands sit from the oscillator mid-line, which affects how often trend state changes occur. When the momentum line rises into the upper filled area and then crosses back below +40, it signals potential overbought exhaustion. The opposite applies for the oversold zone below -40. The plotted trailing bands switch visibility depending on the current directional state: when momentum is trending up, the lower band acts as the active trailing stop, and when trending down, the upper band becomes active. Trend changes are marked with circular symbols when the direction variable flips, and optional overlay arrows appear on the price chart to highlight overbought or oversold reversals. Traders can combine these signals with their own price action or volume analysis to confirm entries or exits.
TPO[Fixed Range, Anchored, Bars Back]TPO Bars Back, Fixed Range and Anchored 
 Overview 
The  TPO Profile  (Time Price Opportunity Profile) is a powerful market profile indicator that displays the amount of time price spent at different levels during a specified period. Unlike traditional volume profile indicators that show volume distribution, TPO Profile shows  time distribution , providing insights into where price has spent the most time and identifying key support and resistance levels.
 Key Advantages Over TradingView's Built-in TPO 
 
 Simplified Composite Creation : Automatically creates TPO profiles for any time range without manual split/merge operations
 Instant Value Area Calculation : Immediately shows Value Area, POC, VAH, and VAL for your selected period
 No Manual Assembly Required : TradingView's native TPO requires you to manually split sessions and merge them to create composites - this indicator does it automatically
 Flexible Time Ranges : Create composites for any custom time period (multiple days, weeks, specific events) with a few clicks
 Real-time Composite Updates : Anchor mode creates live composites that update as new data arrives
 Multiple Composite Analysis : Easily compare different time periods without the tedious manual process
 
 Key Features 
 Core Functionality 
 
 Time-Based Analysis : Shows time spent at each price level rather than volume
 Configurable Time Blocks : Use any timeframe for TPO counting (30min, 1H, 4H, etc.)
 Multiple Price Levels : Adjustable from 5 to 200 levels for granular analysis
 Point of Control (POC) : Automatically identifies the price level with highest time activity
 Value Area Calculation : Shows the price range containing 70% (configurable) of time activity
 Automatic Composite Generation : Creates multi-session composites without manual intervention
 
 Three Operating Modes 
 1. Bars Back Mode 
 
 Analyzes the last N bars from the current bar
 Perfect for recent market activity analysis
 Range: 10-500 bars
 Use Case : Intraday analysis, recent session review
 
 2. Fixed Range Mode 
 
 Analyzes a specific time period between start and end times
 Ideal for historical analysis of specific events
 Creates perfect composites for multi-day periods
 Use Case : Earnings periods, news events, specific trading sessions, weekly/monthly composites
 
 3. Anchor Mode   (NEW) 
 
 Starts from a specific time and extends to the current bar
 Dynamically updates as new bars form
 Perfect for building live composites from any starting point
 Use Case : Live session monitoring, event-based analysis from a specific point, growing composites
 
 Visual Elements 
 TPO Bars 
 
 Horizontal bars showing time distribution at each price level
 Longer bars = more time spent at that level
 Color-coded to distinguish Value Area from outlying levels
 
 Point of Control (POC) 
 
 Red line marking the price level with highest time activity
 Most significant support/resistance level
 Configurable line style (Solid/Dashed/Dotted) and width
 
 Value Area High/Low (VAH/VAL) 
 
 Green and Orange lines marking the boundaries of the Value Area
 Shows the price range containing the specified percentage of time activity
 Optional display with customizable line styles
 
 Single Print Detection 
 
 Identifies price levels touched by only one time block
 Display options: Lines or Boxes
 Purple color highlighting these significant levels
 Often act as strong support/resistance in future trading
 
 Customization Options 
 Time Block Configuration 
 
 Block Time : Choose timeframe for TPO counting (30min, 1H, 4H, etc.)
 Allows analysis at different time granularities
 Higher timeframes = broader perspective, Lower timeframes = finer detail
 
 Visual Styling 
 
 Line Styles : Solid, Dashed, or Dotted for all line elements
 Line Widths : 1-5 pixels for POC, VAH, and VAL lines
 Colors : Fully customizable colors for all elements
 Transparency : Adjustable transparency for better chart readability
 
 Label Management 
 
 Show/Hide Labels : Toggle POC, VAH, VAL labels
 Font Sizes : Tiny, Small, Normal, Large, Huge
 Label Positioning : 8 different position options relative to lines
 Offset Controls : Fine-tune label positioning
 
 Line Extension 
 
 Level Offset Right : Controls how far lines extend
 Smart extension logic:
 
 
 Value ≤ 0: Infinite extension (extend.right)
 Value ≥ 1: Extends exactly N bars ahead
 
 Trading Applications 
 Support & Resistance 
 
 POC often acts as strong support/resistance
 Value Area boundaries provide key levels
 Single prints frequently become significant levels
 
 Market Structure Analysis 
 
 Identify areas of price acceptance (thick TPO bars)
 Spot areas of price rejection (thin TPO bars)
 Understand where market participants are comfortable trading
 
 Composite Profile Analysis 
 
 Create multi-day, weekly, or monthly composites instantly
 Compare different composite periods without manual work
 Analyze longer-term price acceptance levels
 Build composites around specific events or announcements
 
 Session Analysis 
 
 Monitor intraday session development in real-time
 Compare different sessions (London, New York, Asia)
 Track how profiles change throughout the trading day
 Build live composites across multiple sessions
 
 Event Analysis 
 
 Use Fixed Range mode for earnings, news events
 Use Anchor mode to track price development from specific events
 Compare pre/post event price acceptance levels
 Create event-based composites automatically
 
 Input Parameters 
 Mode Selection 
 
 Mode : Bars Back | Fixed Range | Anchor
 Bars Back : Number of bars to analyze (10-500)
 Start Time : Beginning time for Fixed Range and Anchor modes
 End Time : Ending time for Fixed Range mode only
 
 Analysis Configuration 
 
 Block Time : Timeframe for TPO blocks (e.g., "30" for 30-minute blocks)
 TPO Levels : Number of price levels (5-200)
 Value Area % : Percentage for Value Area calculation (50-95%)
 
 Display Options 
 
 Show POC : Display Point of Control line
 Show Value Area : Display Value Area box
 Show VAH/VAL Lines : Display Value Area boundary lines
 Show Single Prints : Display single print detection
 Single Print Style : Lines or Boxes
 
 Styling Controls 
 
 Colors : TPO, POC, Value Area, VAH, VAL, Single Print colors
 Line Styles : POC, VAH, VAL line styles
 Line Widths : POC, VAH, VAL line widths
 Labels : Show/hide, font size, position, offset controls
 
 Technical Details 
 Calculation Method 
 
 Divides the price range into equal levels based on TPO Levels setting
 For each time block, determines which price levels it crosses
 Adds +1 count to each crossed level
 Identifies POC as the level with highest count
 Calculates Value Area by expanding from POC until target percentage is reached
 
 Performance Considerations 
 
 Historical data limited to prevent buffer overflow errors
 Smart bounds checking for different timeframes
 Optimized cleanup routines to prevent drawing object accumulation
 
 Pine Script Version 
 
 Built on Pine Script v6
 Uses modern Pine Script best practices
 Efficient array handling and drawing object management
 
 Best Practices 
 Timeframe Selection 
 
 Block Time = Chart Timeframe : Traditional TPO approach
 Block Time > Chart Timeframe : Smoother, broader perspective
 Block Time < Chart Timeframe : More granular, detailed analysis
 
 Level Count Guidelines 
 
 Low levels (10-20) : Better for swing trading, major levels
 High levels (50-100) : Better for scalping, precise entries
 Very high levels (100+) : For very detailed analysis
 
 Mode Selection 
 
 Bars Back : Daily analysis, recent activity
 Fixed Range : Historical events, specific periods, manual composites
 Anchor : Live monitoring, event-based analysis, growing composites
 
 Composite Creation Workflow 
 
 Select Fixed Range or Anchor mode
 Set your desired start time (and end time for Fixed Range)
 Adjust TPO Levels for desired granularity
 Enable VAH/VAL lines to see Value Area boundaries
 The composite profile generates automatically with all key levels
 
 This indicator eliminates the tedious manual process of creating composite TPO profiles in TradingView. Instead of splitting sessions and manually merging them, you get instant composite analysis with automatic Value Area calculation, POC identification, and single print detection. The combination of time-based analysis, multiple operating modes, and extensive customization options makes it a powerful tool for understanding market structure and price acceptance levels across any time period.  
Triple Configurable VWAPTriple Configurable VWAP Indicator
This advanced VWAP (Volume Weighted Average Price) indicator displays three independently configurable VWAP lines on your chart, providing multiple timeframe perspectives for better trading decisions.
Key Features:
• Three Customizable VWAP Periods: Configure each VWAP independently with periods ranging from 1 to 365 days
Default: 10-day (Green), 30-day (Red), 365-day (Blue)
• Dynamic Visual Elements:
Color-coded lines for easy identification
Smart labels at the current price level with matching colors
Contrasting text colors for optimal readability
• Interactive Information Table:
Toggle on/off display
Repositionable to any corner or side of the chart
Shows each VWAP period with corresponding color indicators
Larger, easy-to-read font size
• Professional Calculation Method:
Uses daily timeframe data for accurate VWAP calculations
Anchored VWAP starting from your specified lookback periods
Proper volume weighting for institutional-grade accuracy
Use Cases:
Short-term Trading: 10-day VWAP for recent price action analysis
Medium-term Analysis: 30-day VWAP for monthly trend assessment
Long-term Perspective: 365-day VWAP for yearly institutional levels
Perfect for traders who need multiple VWAP timeframes simultaneously to identify key support/resistance levels, trend direction, and institutional price points across different time horizons.
OBV ATR Strategy (OBV Breakout Channel) bas20230503ผมแก้ไขจาก OBV+SMA อันเดิม ของเดิม ดูที่เส้น SMA สองเส้นตัดกันมั่นห่วยแตกสำหรับที่ผมลองเทรดจริง และหลักการเบรค ได้แรงบันดาลใจ ATR จาก เทพคอย ที่ใช้กับราคา แต่นี้ใช้กับ OBV แทน
และผมใช้เจมินี้ เพื่อแก้ ให้ เป็น strategy   เพื่อเช็คย้อนหลังได้ง่ายกว่าเดิม
หลักการง่ายคือถ้ามันขึ้น มันจะขึ้นเรื่อยๆ 
เขียน แบบสุภาพ (น่าจะอ่านได้ง่ายกว่าผมเขียน)
สคริปต์นี้ได้รับการพัฒนาต่อยอดจากแนวคิด OBV+SMA Crossover แบบดั้งเดิม ซึ่งจากการทดสอบส่วนตัวพบว่าประสิทธิภาพยังไม่น่าพอใจ กลยุทธ์ใหม่นี้จึงเปลี่ยนมาใช้หลักการ "Breakout" ซึ่งได้รับแรงบันดาลใจมาจากการใช้ ATR สร้างกรอบของราคา แต่เราได้นำมาประยุกต์ใช้กับ On-Balance Volume (OBV) แทน นอกจากนี้ สคริปต์ได้ถูกแปลงเป็น Strategy เต็มรูปแบบ (โดยความช่วยเหลือจาก Gemini AI) เพื่อให้สามารถทดสอบย้อนหลัง (Backtest) และประเมินประสิทธิภาพได้อย่างแม่นยำ
หลักการของกลยุทธ์: กลยุทธ์นี้ทำงานบนแนวคิดโมเมนตัมที่ว่า "เมื่อแนวโน้มได้เกิดขึ้นแล้ว มีโอกาสที่มันจะดำเนินต่อไป" โดยจะมองหาการทะลุของพลังซื้อ-ขาย (OBV) ที่แข็งแกร่งเป็นพิเศษเป็นสัญญาณเข้าเทร
----
สคริปต์นี้เป็นกลยุทธ์ (Strategy) ที่ใช้ On-Balance Volume (OBV) ซึ่งเป็นอินดิเคเตอร์ที่วัดแรงซื้อและแรงขายสะสม แทนที่จะใช้การตัดกันของเส้นค่าเฉลี่ย (SMA Crossover) ที่เป็นแบบพื้นฐาน กลยุทธ์นี้จะมองหาการ "ทะลุ" (Breakout) ของพลัง OBV ออกจากกรอบสูงสุด-ต่ำสุดของตัวเองในรอบที่ผ่านมา
สัญญาณกระทิง (Bull Signal): เกิดขึ้นเมื่อพลังการซื้อ (OBV) แข็งแกร่งจนสามารถทะลุจุดสูงสุดของตัวเองในอดีตได้ บ่งบอกถึงโอกาสที่แนวโน้มจะเปลี่ยนเป็นขาขึ้น
สัญญาณหมี (Bear Signal): เกิดขึ้นเมื่อพลังการขาย (OBV) รุนแรงจนสามารถกดดันให้ OBV ทะลุจุดต่ำสุดของตัวเองในอดีตได้ บ่งบอกถึงโอกาสที่แนวโน้มจะเปลี่ยนเป็นขาลง
ส่วนประกอบบนกราฟ (Indicator Components)
เส้น OBV
เส้นหลัก ที่เปลี่ยนเขียวเป็นแดง เป็นทั้งแนวรับและแนวต้าน และ จุด stop loss
เส้นนี้คือหัวใจของอินดิเคเตอร์ ที่แสดงถึงพลังสะสมของ Volume
เมื่อเส้นเป็นสีเขียว (แนวรับ): จะปรากฏขึ้นเมื่อกลยุทธ์เข้าสู่ "โหมดกระทิง" เส้นนี้คือระดับต่ำสุดของ OBV ในอดีต และทำหน้าที่เป็นแนวรับไดนามิก
เมื่อเส้นกลายเป็นสีแดงสีแดง (แนวต้าน): จะปรากฏขึ้นเมื่อกลยุทธ์เข้าสู่ "โหมดหมี" เส้นนี้คือระดับสูงสุดของ OBV ในอดีต และทำหน้าที่เป็นแนวต้านไดนามิก
สัญลักษณ์สัญญาณ (Signal Markers):
Bull 🔼 (สามเหลี่ยมขึ้นสีเขียว): คือสัญญาณ "เข้าซื้อ" (Long) จะปรากฏขึ้น ณ จุดที่ OBV ทะลุขึ้นไปเหนือกรอบด้านบนเป็นครั้งแรก
Bear 🔽 (สามเหลี่ยมลงสีแดง): คือสัญญาณ "เข้าขาย" (Short) จะปรากฏขึ้น ณ จุดที่ OBV ทะลุลงไปต่ำกว่ากรอบด้านล่างเป็นครั้งแรก
วิธีการใช้งาน (How to Use)
เพิ่มสคริปต์นี้ลงบนกราฟราคาที่คุณสนใจ
ไปที่แท็บ "Strategy Tester" ด้านล่างของ TradingView เพื่อดูผลการทดสอบย้อนหลัง (Backtest) ของกลยุทธ์บนสินทรัพย์และไทม์เฟรมต่างๆ
ใช้สัญลักษณ์ "Bull" และ "Bear" เป็นตัวช่วยในการตัดสินใจเข้าเทรด
ข้อควรจำ: ไม่มีกลยุทธ์ใดที่สมบูรณ์แบบ 100% ควรใช้สคริปต์นี้ร่วมกับการวิเคราะห์ปัจจัยอื่นๆ เช่น โครงสร้างราคา, แนวรับ-แนวต้านของราคา และการบริหารความเสี่ยง (Risk Management) ของตัวคุณเองเสมอ
การตั้งค่า (Inputs)
SMA Length 1 / SMA Length 2: ใช้สำหรับพล็อตเส้นค่าเฉลี่ยของ OBV เพื่อดูเป็นภาพอ้างอิง ไม่มีผลต่อตรรกะการเข้า-ออกของ Strategy อันใหม่ แต่มันเป็นของเก่า ถ้าชอบ ก็ใช้ได้ เมื่อ SMA สองเส้นตัดกัน หรือตัดกับเส้น OBV
High/Low Lookback Length: (ค่าพื้นฐาน30/แก้ตรงนี้ให้เหมาะสมกับ coin หรือหุ้น ตามความผันผวน ) คือระยะเวลาที่ใช้ในการคำนวณกรอบสูงสุด-ต่ำสุดของ OBV
ค่าน้อย: ทำให้กรอบแคบลง สัญญาณจะเกิดไวและบ่อยขึ้น แต่อาจมีสัญญาณหลอก (False Signal) เยอะขึ้น
ค่ามาก: ทำให้กรอบกว้างขึ้น สัญญาณจะเกิดช้าลงและน้อยลง แต่มีแนวโน้มที่จะเป็นสัญญาณที่แข็งแกร่งกว่า
แน่นอนครับ นี่คือคำแปลฉบับภาษาอังกฤษที่สรุปใจความสำคัญ กระชับ และสุภาพ เหมาะสำหรับนำไปใช้ในคำอธิบายสคริปต์ (Description) ของ TradingView ครับ
 ---Translate to English---
 
OBV Breakout Channel Strategy
 
This script is an evolution of a traditional OBV+SMA Crossover concept. Through personal testing, the original crossover method was found to have unsatisfactory performance. This new strategy, therefore, uses a "Breakout" principle. The inspiration comes from using ATR to create price channels, but this concept has been adapted and applied to On-Balance Volume (OBV) instead.
Furthermore, the script has been converted into a full Strategy (with assistance from Gemini AI) to enable precise backtesting and performance evaluation.
The strategy's core principle is momentum-based: "once a trend is established, it is likely to continue." It seeks to enter trades on exceptionally strong breakouts of buying or selling pressure as measured by OBV.
Core Concept
This is a Strategy that uses On-Balance Volume (OBV), an indicator that measures cumulative buying and selling pressure. Instead of relying on a basic Simple Moving Average (SMA) Crossover, this strategy identifies a "Breakout" of the OBV from its own highest-high and lowest-low channel over a recent period.
Bull Signal: Occurs when the buying pressure (OBV) is strong enough to break above its own recent highest high, indicating a potential shift to an upward trend.
Bear Signal: Occurs when the selling pressure (OBV) is intense enough to push the OBV below its own recent lowest low, indicating a potential shift to a downward trend.
On-Screen Components
1. OBV Line
This is the main indicator line, representing the cumulative volume. Its color changes to green when OBV is rising and red when it is falling.
2. Dynamic Support & Resistance Line
This is the thick Green or Red line that appears based on the strategy's current "mode." This line serves as a dynamic support/resistance level and can be used as a reference for stop-loss placement.
Green Line (Support): Appears when the strategy enters "Bull Mode." This line represents the lowest low of the OBV in the recent past and acts as dynamic support.
Red Line (Resistance): Appears when the strategy enters "Bear Mode." This line represents the highest high of the OBV in the recent past and acts as dynamic resistance.
3. Signal Markers
Bull 🔼 (Green Up Triangle): This is the "Long Entry" signal. It appears at the moment the OBV first breaks out above its high-low channel.
Bear 🔽 (Red Down Triangle): This is the "Short Entry" signal. It appears at the moment the OBV first breaks down below its high-low channel.
How to Use
Add this script to the price chart of your choice.
Navigate to the "Strategy Tester" panel at the bottom of TradingView to view the backtesting results for the strategy on different assets and timeframes.
Use the "Bull" and "Bear" signals as aids in your trading decisions.
Disclaimer: No strategy is 100% perfect. This script should always be used in conjunction with other forms of analysis, such as price structure, key price-based support/resistance levels, and your own personal risk management rules.
Inputs
SMA Length 1 / SMA Length 2: These are used to plot moving averages on the OBV for visual reference. They are part of the legacy logic and do not affect the new breakout strategy. However, they are kept for traders who may wish to observe their crossovers for additional confirmation.
High/Low Lookback Length: (Most Important Setting) This determines the period used to calculate the highest-high and lowest-low OBV channel. (Default is 30; adjust this to suit the asset's volatility).
A smaller value: Creates a narrower channel, leading to more frequent and faster signals, but potentially more false signals.
A larger value: Creates a wider channel, leading to fewer and slower signals, which are likely to be more significant.
Long/Short/Exit/Risk management Strategy # LongShortExit Strategy Documentation
## Overview
The LongShortExit strategy is a versatile trading system for TradingView that provides complete control over entry, exit, and risk management parameters. It features a sophisticated framework for managing long and short positions with customizable profit targets, stop-loss mechanisms, partial profit-taking, and trailing stops. The strategy can be enhanced with continuous position signals for visual feedback on the current trading state.
## Key Features
### General Settings
- **Trading Direction**: Choose to trade long positions only, short positions only, or both.
- **Max Trades Per Day**: Limit the number of trades per day to prevent overtrading.
- **Bars Between Trades**: Enforce a minimum number of bars between consecutive trades.
### Session Management
- **Session Control**: Restrict trading to specific times of the day.
- **Time Zone**: Specify the time zone for session calculations.
- **Expiration**: Optionally set a date when the strategy should stop executing.
### Contract Settings
- **Contract Type**: Select from common futures contracts (MNQ, MES, NQ, ES) or custom values.
- **Point Value**: Define the dollar value per point movement.
- **Tick Size**: Set the minimum price movement for accurate calculations.
### Visual Signals
- **Continuous Position Signals**: Implement 0 to 1 visual signals to track position states.
- **Signal Plotting**: Customize color and appearance of position signals.
- **Clear Visual Feedback**: Instantly see when entry conditions are triggered.
### Risk Management
#### Stop Loss and Take Profit
- **Risk Type**: Choose between percentage-based, ATR-based, or points-based risk management.
- **Percentage Mode**: Set SL/TP as a percentage of entry price.
- **ATR Mode**: Set SL/TP as a multiple of the Average True Range.
- **Points Mode**: Set SL/TP as a fixed number of points from entry.
#### Advanced Exit Features
- **Break-Even**: Automatically move stop-loss to break-even after reaching specified profit threshold.
- **Trailing Stop**: Implement a trailing stop-loss that follows price movement at a defined distance.
- **Partial Profit Taking**: Take partial profits at predetermined price levels:
  - Set first partial exit point and percentage of position to close
  - Set second partial exit point and percentage of position to close
- **Time-Based Exit**: Automatically exit a position after a specified number of bars.
#### Win/Loss Streak Management
- **Streak Cutoff**: Automatically pause trading after a series of consecutive wins or losses.
- **Daily Reset**: Option to reset streak counters at the start of each day.
### Entry Conditions
- **Source and Value**: Define the exact price source and value that triggers entries.
- **Equals Condition**: Entry signals occur when the source exactly matches the specified value.
### Performance Analytics
- **Real-Time Stats**: Track important performance metrics like win rate, P&L, and largest wins/losses.
- **Visual Feedback**: On-chart markers for entries, exits, and important events.
### External Integration
- **Webhook Support**: Compatible with TradingView's webhook alerts for automated trading.
- **Cross-Platform**: Connect to external trading systems and notification platforms.
- **Custom Order Execution**: Implement advanced order flows through external services.
## How to Use
### Setup Instructions
1. Add the script to your TradingView chart.
2. Configure the general settings based on your trading preferences.
3. Set session trading hours if you only want to trade specific times.
4. Select your contract specifications or customize for your instrument.
5. Configure risk parameters:
   - Choose your preferred risk management approach
   - Set appropriate stop-loss and take-profit levels
   - Enable advanced features like break-even, trailing stops, or partial profit taking as needed
6. Define entry conditions:
   - Select the price source (such as close, open, high, or an indicator)
   - Set the specific value that should trigger entries
### Entry Condition Examples
- **Example 1**: To enter when price closes exactly at a whole number:
  - Long Source: close
  - Long Value: 4200 (for instance, to enter when price closes exactly at 4200)
  
- **Example 2**: To enter when an indicator reaches a specific value:
  - Long Source: ta.rsi(close, 14)
  - Long Value: 30 (triggers when RSI equals exactly 30)
### Best Practices
1. **Always backtest thoroughly** before using in live trading.
2. **Start with conservative risk settings**:
   - Small position sizes
   - Reasonable stop-loss distances
   - Limited trades per day
3. **Monitor and adjust**:
   - Use the performance table to track results
   - Adjust parameters based on how the strategy performs
4. **Consider market volatility**:
   - Use ATR-based stops during volatile periods
   - Use fixed points during stable markets
## Continuous Position Signals Implementation
The LongShortExit strategy can be enhanced with continuous position signals to provide visual feedback about the current position state. These signals can help you track when the strategy is in a long or short position.
### Adding Continuous Position Signals
Add the following code to implement continuous position signals (0 to 1):
```pine
// Continuous position signals (0 to 1)
var float longSignal = 0.0
var float shortSignal = 0.0
// Update position signals based on your indicator's conditions
longSignal := longCondition ? 1.0 : 0.0
shortSignal := shortCondition ? 1.0 : 0.0
// Plot continuous signals
plot(longSignal, title="Long Signal", color=#00FF00, linewidth=2, transp=0, style=plot.style_line)
plot(shortSignal, title="Short Signal", color=#FF0000, linewidth=2, transp=0, style=plot.style_line)
```
### Benefits of Continuous Position Signals
- Provides clear visual feedback of current position state (long/short)
- Signal values stay consistent (0 or 1) until condition changes
- Can be used for additional calculations or alert conditions
- Makes it easier to track when entry conditions are triggered
### Using with Custom Indicators
You can adapt the continuous position signals to work with any custom indicator by replacing the condition with your indicator's logic:
```pine
// Example with moving average crossover
longSignal := fastMA > slowMA ? 1.0 : 0.0
shortSignal := fastMA < slowMA ? 1.0 : 0.0
```
## Webhook Integration
The LongShortExit strategy is fully compatible with TradingView's webhook alerts, allowing you to connect your strategy to external trading platforms, brokers, or custom applications for automated trading execution.
### Setting Up Webhooks
1. Create an alert on your chart with the LongShortExit strategy
2. Enable the "Webhook URL" option in the alert dialog
3. Enter your webhook endpoint URL (from your broker or custom trading system)
4. Customize the alert message with relevant information using TradingView variables
### Webhook Message Format Example
```json
{
  "strategy": "LongShortExit",
  "action": "{{strategy.order.action}}",
  "price": "{{strategy.order.price}}",
  "quantity": "{{strategy.position_size}}",
  "time": "{{time}}",
  "ticker": "{{ticker}}",
  "position_size": "{{strategy.position_size}}",
  "position_value": "{{strategy.position_value}}",
  "order_id": "{{strategy.order.id}}",
  "order_comment": "{{strategy.order.comment}}"
}
```
### TradingView Alert Condition Examples
For effective webhook automation, set up these alert conditions:
#### Entry Alert
```
{{strategy.position_size}} != {{strategy.position_size}} 
```
#### Exit Alert
```
{{strategy.position_size}} < {{strategy.position_size}}  or {{strategy.position_size}} > {{strategy.position_size}} 
```
#### Partial Take Profit Alert
```
strategy.order.comment contains "Partial TP"
```
### Benefits of Webhook Integration
- **Automated Trading**: Execute trades automatically through supported brokers
- **Cross-Platform**: Connect to custom trading bots and applications
- **Real-Time Notifications**: Receive trade signals on external platforms
- **Data Collection**: Log trade data for further analysis
- **Custom Order Management**: Implement advanced order types not available in TradingView
### Compatible External Applications
- Trading bots and algorithmic trading software
- Custom order execution systems
- Discord, Telegram, or Slack notification systems
- Trade journaling applications
- Risk management platforms
### Implementation Recommendations
- Test webhook delivery using a free service like webhook.site before connecting to your actual trading system
- Include authentication tokens or API keys in your webhook URL or payload when required by your external service
- Consider implementing confirmation mechanisms to verify trade execution
- Log all webhook activities for troubleshooting and performance tracking
## Strategy Customization Tips
### For Scalping
- Set smaller profit targets (1-3 points)
- Use tighter stop-losses
- Enable break-even feature after small profit
- Set higher max trades per day
### For Day Trading
- Use moderate profit targets
- Implement partial profit taking
- Enable trailing stops
- Set reasonable session trading hours
### For Swing Trading
- Use longer-term charts
- Set wider stops (ATR-based often works well)
- Use higher profit targets
- Disable daily streak reset
## Common Troubleshooting
### Low Win Rate
- Consider widening stop-losses
- Verify that entry conditions aren't triggering too frequently
- Check if the equals condition is too restrictive; consider small tolerances
### Missing Obvious Trades
- The equals condition is extremely precise. Price must exactly match the specified value.
- Consider using floating-point precision for more reliable triggers
### Frequent Stop-Outs
- Try ATR-based stops instead of fixed points
- Increase the stop-loss distance
- Enable break-even feature to protect profits
## Important Notes
- The exact equals condition is strict and may result in fewer trade signals compared to other conditions.
- For instruments with decimal prices, exact equality might be rare. Consider the precision of your value.
- Break-even and trailing stop calculations are based on points, not percentage.
- Partial take-profit levels are defined in points distance from entry.
- The continuous position signals (0 to 1) provide valuable visual feedback but don't affect the strategy's trading logic directly.
- When implementing continuous signals, ensure they're aligned with the actual entry conditions used by the strategy.
---
*This strategy is for educational and informational purposes only. Always test thoroughly before using with real funds.*
Cycle Composite 3.6 WeightedThe Cycle Composite is a multi-factor market cycle model designed to classify long-term market behavior into distinct phases using normalized and weighted data inputs.
It combines ten key on-chain, dominance, volatility, sentiment, and trend-following metrics into a single composite output. The goal is to provide a clearer understanding of where the market may stand in the broader cycle (e.g., accumulation, early bull, late bull, or euphoria).
This version (3.4) introduces flexible weighting, trend strength markers, and additional context-aware signals such as risk-on confirmations and altseason flags.
Phases Identified:
The model categorizes the market into one of five zones:
Euphoria (> 85)
Late Bull (70 – 85)
Mid Bull (50 – 70)
Early Bull (30 – 50)
Fear (< 30)
Each phase is determined by a smoothed EMA of the weighted composite score.
Data Sources and Metrics Used (10 total):
BTC Dominance (CRYPTOCAP:BTC.D)
Stablecoin Dominance (USDT + USDC average) (inverted for risk-on)
ETH Dominance (CRYPTOCAP:ETH.D)
BBWP (normalized Bollinger Band Width % over 1-year window)
WVF (Williams VIX Fix for volatility spike detection)
NUPL (Net Unrealized Profit/Loss, external source)
CMF (Chaikin Money Flow, smoothed volume accumulation)
CEX Open Interest (custom input from DAO / external source)
Whale Inflows (custom input from whale exchange transfer data)
Google Trends Average (BTC, Crypto, Altcoin terms)
All inputs are normalized over a 200-bar window and combined via weighted averaging, where each weight is user-configurable.
Additional Features:
Phase Labels: Labels are printed only when a new phase is entered.
Bull Continuation Marker: Triangle up when composite makes higher highs and NUPL increases.
Weakening Marker: Triangle down when composite rolls over in Late Bull and NUPL falls.
Risk-On Signal: Green circle appears when CMF and Google Trends are both rising.
Altseason Flag: Orange diamond appears when dominance of "others.d" exceeds BTC.D and ETH.D and composite is above 50.
Background Shading: Each phase is shaded with a semi-transparent background color.
Timeframe-Aware Display: All markers and signals are shown only on weekly timeframe for clarity.
Intended Use:
This script is intended for educational and macro-trend analysis purposes.
It can be used to:
Identify macro cycle position (accumulation, bull phases, euphoria, etc.)
Spot long-term trend continuation or weakening signals
Add context to price action with external on-chain and sentiment data
Time rotation events such as altseason risk
Disclaimer:
This script does not constitute financial advice.
It is intended for informational and research purposes only.
Users should conduct their own due diligence and analysis before making investment decisions.






















