VoVix DEVMA🌌 VoVix DEVMA: A Deep Dive into Second-Order Volatility Dynamics 
 Welcome to VoVix+, a sophisticated trading framework that transcends traditional price analysis. This is not merely another indicator; it is a complete system designed to dissect and interpret the very fabric of market volatility. VoVix+ operates on the principle that the most powerful signals are not found in price alone, but in the behavior of volatility itself. It analyzes the rate of change, the momentum, and the structure of market volatility to identify periods of expansion and contraction, providing a unique edge in anticipating major market moves. 
 This document will serve as your comprehensive guide, breaking down every mathematical component, every user input, and every visual element to empower you with a profound understanding of how to harness its capabilities. 
 🔬 THEORETICAL FOUNDATION: THE MATHEMATICS OF MARKET DYNAMICS 
 VoVix+ is built upon a multi-layered mathematical engine designed to measure what we call "second-order volatility." While standard indicators analyze price, and first-order volatility indicators (like ATR) analyze the range of price, VoVix+ analyzes the dynamics of the volatility itself. This provides insight into the market's underlying state of stability or chaos. 
 1. The VoVix Score: Measuring Volatility Thrust 
 The core of the system begins with the VoVix Score. This is a normalized measure of volatility acceleration or deceleration. 
 Mathematical Formula: 
VoVix Score = (ATR(fast) - ATR(slow)) / (StDev(ATR(fast)) + ε)
 Where: 
 ATR(fast)   is the Average True Range over a short period, representing current, immediate volatility. 
 ATR(slow)   is the Average True Range over a longer period, representing the baseline or established volatility. 
 StDev(ATR(fast))   is the Standard Deviation of the fast ATR, which measures the "noisiness" or consistency of recent volatility. 
 ε (epsilon)   is a very small number to prevent division by zero. 
 Market Implementation: 
 Positive Score (Expansion):   When the fast ATR is significantly higher than the slow ATR, it indicates a rapid increase in volatility. The market is "stretching" or expanding. 
 Negative Score (Contraction):   When the fast ATR falls below the slow ATR, it indicates a decrease in volatility. The market is "coiling" or contracting. 
 Normalization:   By dividing by the standard deviation, we normalize the score. This turns it into a standardized measure, allowing us to compare volatility thrust across different market conditions and timeframes. A score of 2.0 in a quiet market means the same, relatively, as a score of 2.0 in a volatile market. 
 2. Deviation Analysis (DEV): Gauging Volatility's Own Volatility 
 The script then takes the analysis a step further. It calculates the standard deviation of the VoVix Score itself. 
 Mathematical Formula: 
DEV = StDev(VoVix Score, lookback_period)
 Market Implementation: 
 This DEV value represents the magnitude of chaos or stability in the market's volatility dynamics. A high DEV value means the volatility thrust is erratic and unpredictable. A low DEV value suggests the change in volatility is smooth and directional. 
 3. The DEVMA Crossover: Identifying Regime Shifts 
 This is the primary signal generator. We take two moving averages of the DEV value. 
 Mathematical Formula: 
fastDEVMA = SMA(DEV, fast_period)
slowDEVMA = SMA(DEV, slow_period)
 The Core Signal: 
 The strategy triggers on the crossover and crossunder of these two DEVMA lines. This is a profound concept: we are not looking at a moving average of price or even of volatility, but a moving average of the standard deviation of the normalized rate of change of volatility. 
 Bullish Crossover (fastDEVMA > slowDEVMA):   This signals that the short-term measure of volatility's chaos is increasing relative to the long-term measure. This often precedes a significant market expansion and is interpreted as a bullish volatility regime. 
 Bearish Crossunder (fastDEVMA < slowDEVMA):   This signals that the short-term measure of volatility's chaos is decreasing. The market is settling down or contracting, often leading to trending moves or range consolidation. 
 ⚙️ INPUTS MENU: CONFIGURING YOUR ANALYSIS ENGINE 
 Every input has been meticulously designed to give you full control over the strategy's behavior. Understanding these settings is key to adapting VoVix+ to your specific instrument, timeframe, and trading style. 
 🌀 VoVix DEVMA Configuration 
 🧬 Deviation Lookback:   This sets the lookback period for calculating the DEV value. It defines the window for measuring the stability of the VoVix Score. A shorter value makes the system highly reactive to recent changes in volatility's character, ideal for scalping. A longer value provides a smoother, more stable reading, better for identifying major, long-term regime shifts. 
 ⚡ Fast VoVix Length:   This is the lookback period for the fastDEVMA. It represents the short-term trend of volatility's chaos. A smaller number will result in a faster, more sensitive signal line that reacts quickly to market shifts. 
 🐌 Slow VoVix Length:   This is the lookback period for the slowDEVMA. It represents the long-term, baseline trend of volatility's chaos. A larger number creates a more stable, slower-moving anchor against which the fast line is compared. 
 How to Optimize:   The relationship between the Fast and Slow lengths is crucial. A wider gap (e.g., 20 and 60) will result in fewer, but potentially more significant, signals. A narrower gap (e.g., 25 and 40) will generate more frequent signals, suitable for more active trading styles. 
 🧠 Adaptive Intelligence 
 🧠 Enable Adaptive Features:   When enabled, this activates the strategy's performance tracking module. The script will analyze the outcome of its last 50 trades to calculate a dynamic win rate. 
 ⏰ Adaptive Time-Based Exit:   If Enable Adaptive Features is on, this allows the strategy to adjust its Maximum Bars in Trade setting based on performance. It learns from the average duration of winning trades. If winning trades tend to be short, it may shorten the time exit to lock in profits. If winners tend to run, it will extend the time exit, allowing trades more room to develop. This helps prevent the strategy from cutting winning trades short or holding losing trades for too long. 
 ⚡ Intelligent Execution 
 📊 Trade Quantity:   A straightforward input that defines the number of contracts or shares for each trade. This is a fixed value for consistent position sizing. 
 🛡️ Smart Stop Loss:   Enables the dynamic stop-loss mechanism. 
 🎯 Stop Loss ATR Multiplier:   Determines the distance of the stop loss from the entry price, calculated as a multiple of the current 14-period ATR. A higher multiplier gives the trade more room to breathe but increases risk per trade. A lower multiplier creates a tighter stop, reducing risk but increasing the chance of being stopped out by normal market noise. 
 💰 Take Profit ATR Multiplier:   Sets the take profit target, also as a multiple of the ATR. A common practice is to set this higher than the Stop Loss multiplier (e.g., a 2:1 or 3:1 reward-to-risk ratio). 
 🏃 Use Trailing Stop:   This is a powerful feature for trend-following. When enabled, instead of a fixed stop loss, the stop will trail behind the price as the trade moves into profit, helping to lock in gains while letting winners run. 
 🎯 Trail Points & 📏 Trail Offset ATR Multipliers:   These control the trailing stop's behavior. Trail Points defines how much profit is needed before the trail activates. Trail Offset defines how far the stop will trail behind the current price. Both are based on ATR, making them fully adaptive to market volatility. 
 ⏰ Maximum Bars in Trade:   This is a time-based stop. It forces an exit if a trade has been open for a specified number of bars, preventing positions from being held indefinitely in stagnant markets. 
 ⏰ Session Management 
 These inputs allow you to confine the strategy's trading activity to specific market hours, which is crucial for day trading instruments that have defined high-volume sessions (e.g., stock market open). 
 🎨 Visual Effects & Dashboard 
 These toggles give you complete control over the on-chart visuals and the dashboard. You can disable any element to declutter your chart or focus only on the information that matters most to you. 
 📊 THE DASHBOARD: YOUR AT-A-GLANCE COMMAND CENTER 
 The dashboard centralizes all critical information into one compact, easy-to-read panel. It provides a real-time summary of the market state and strategy performance. 
 🎯 VOVIX ANALYSIS 
 Fast & Slow:   Displays the current numerical values of the fastDEVMA and slowDEVMA. The color indicates their direction: green for rising, red for falling. This lets you see the underlying momentum of each line. 
 Regime:   This is your most important environmental cue. It tells you the market's current state based on the DEVMA relationship.  🚀 EXPANSION (Green)  signifies a bullish volatility regime where explosive moves are more likely.  ⚛️ CONTRACTION (Purple)  signifies a bearish volatility regime, where the market may be consolidating or entering a smoother trend. 
 Quality:   Measures the strength of the last signal based on the magnitude of the DEVMA difference. An  ELITE  or  STRONG  signal indicates a high-conviction setup where the crossover had significant force. 
 PERFORMANCE 
 Win Rate & Trades:   Displays the historical win rate of the strategy from the backtest, along with the total number of closed trades. This provides immediate feedback on the strategy's historical effectiveness on the current chart. 
 EXECUTION 
 Trade Qty:   Shows your configured position size per trade. 
 Session:   Indicates whether trading is currently  OPEN  (allowed) or  CLOSED  based on your session management settings. 
 POSITION 
 Position & PnL:   Displays your current position (LONG, SHORT, or FLAT) and the real-time Profit or Loss of the open trade. 
 🧠 ADAPTIVE STATUS 
 Stop/Profit Mult:   In this simplified version, these are placeholders. The primary adaptive feature currently modifies the time-based exit, which is reflected in how long trades are held on the chart. 
 🎨 THE VISUAL UNIVERSE: DECIPHERING MARKET GEOMETRY 
 The visuals are not mere decorations; they are geometric representations of the underlying mathematical concepts, designed to give you an intuitive feel for the market's state. 
 The Core Lines: 
 FastDEVMA (Green/Maroon Line):   The primary signal line.  Green  when rising, indicating an increase in short-term volatility chaos.  Maroon  when falling. 
 SlowDEVMA (Aqua/Orange Line):   The baseline.  Aqua  when rising, indicating a long-term increase in volatility chaos.  Orange  when falling. 
 🌊 Morphism Flow (Flowing Lines with Circles): 
 What it represents:   This visualizes the momentum and strength of the fastDEVMA. The width and intensity of the "beam" are proportional to the signal strength. 
 Interpretation:   A thick, steep, and vibrant flow indicates powerful, committed momentum in the current volatility regime. The floating '●' particles represent kinetic energy; more particles suggest stronger underlying force. 
 📐 Homotopy Paths (Layered Transparent Boxes): 
 What it represents:   These layered boxes are centered between the two DEVMA lines. Their height is determined by the DEV value. 
 Interpretation:   This visualizes the overall "volatility of volatility." Wider boxes indicate a chaotic, unpredictable market. Narrower boxes suggest a more stable, predictable environment. 
 🧠 Consciousness Field (The Grid): 
 What it represents:   This grid provides a historical lookback at the DEV range. 
 Interpretation:   It maps the recent "consciousness" or character of the market's volatility. A consistently wide grid suggests a prolonged period of chaos, while a narrowing grid can signal a transition to a more stable state. 
 📏 Functorial Levels (Projected Horizontal Lines): 
 What it represents:   These lines extend from the current fastDEVMA and slowDEVMA values into the future. 
 Interpretation:   Think of these as dynamic support and resistance levels for the volatility structure itself. A crossover becomes more significant if it breaks cleanly through a prior established level. 
 🌊 Flow Boxes (Spaced Out Boxes): 
 What it represents:   These are compact visual footprints of the current regime, colored green for Expansion and red for Contraction. 
 Interpretation:   They provide a quick, at-a-glance confirmation of the dominant volatility flow, reinforcing the background color. 
 Background Color: 
 This provides an immediate, unmistakable indication of the current volatility regime.  Light Green  for Expansion and  Light Aqua/Blue  for Contraction, allowing you to assess the market environment in a split second. 
 📊 BACKTESTING PERFORMANCE REVIEW & ANALYSIS 
 The following is a factual, transparent review of a backtest conducted using the strategy's default settings on a specific instrument and timeframe. This information is presented for educational purposes to demonstrate how the strategy's mechanics performed over a historical period. It is crucial to understand that these results are historical, apply only to the specific conditions of this test, and are  not  a guarantee or promise of future performance. Market conditions are dynamic and constantly change. 
 Test Parameters & Conditions 
 To ensure the backtest reflects a degree of real-world conditions, the following parameters were used. The goal is to provide a transparent baseline, not an over-optimized or unrealistic scenario. 
 Instrument:   CME E-mini Nasdaq 100 Futures (NQ1!) 
 Timeframe:   5-Minute Chart 
 Backtesting Range:   March 24, 2024, to July 09, 2024 
 Initial Capital:   $100,000 
 Commission:   $0.62 per contract   (A realistic cost for futures trading). 
 Slippage:   3 ticks per trade   (A conservative setting to account for potential price discrepancies between order placement and execution). 
 Trade Size:   1 contract per trade. 
 Performance Overview (Historical Data) 
 The test period generated  465 total trades , providing a statistically significant sample size for analysis, which is well above the recommended minimum of 100 trades for a strategy evaluation. 
 Profit Factor:   The historical Profit Factor was  2.663 . This metric represents the gross profit divided by the gross loss. In this test, it indicates that for every dollar lost, $2.663 was gained. 
 Percent Profitable:   Across all 465 trades, the strategy had a historical win rate of  84.09% . While a high figure, this is a historical artifact of this specific data set and settings, and should not be the sole basis for future expectations. 
 Risk & Trade Characteristics 
 Beyond the headline numbers, the following metrics provide deeper insight into the strategy's historical behavior. 
 Sortino Ratio (Downside Risk):   The Sortino Ratio was  6.828 . Unlike the Sharpe Ratio, this metric only measures the volatility of negative returns. A higher value, such as this one, suggests that during this test period, the strategy was highly efficient at managing downside volatility and large losing trades relative to the profits it generated. 
 Average Trade Duration:   A critical characteristic to understand is the strategy's holding period. With an  average of only 2 bars per trade , this configuration operates as a very short-term, or scalping-style, system. Winning trades averaged 2 bars, while losing trades averaged 4 bars. This indicates the strategy's logic is designed to capture quick, high-probability moves and exit rapidly, either at a profit target or a stop loss. 
 Conclusion and Final Disclaimer 
 This backtest demonstrates one specific application of the VoVix+ framework. It highlights the strategy's behavior as a short-term system that, in this historical test on NQ1!, exhibited a high win rate and effective management of downside risk.  Users are strongly encouraged to conduct their own backtests  on different instruments, timeframes, and date ranges to understand how the strategy adapts to varying market structures. Past performance is not indicative of future results, and all trading involves significant risk. 
 🔧 THE DEVELOPMENT PHILOSOPHY: FROM VOLATILITY TO CLARITY 
 The journey to create VoVix+ began with a simple question: "What drives major market moves?" The answer is often not a change in price direction, but a fundamental shift in market volatility. Standard indicators are reactive to price. We wanted to create a system that was predictive of market state. VoVix+ was designed to go one level deeper—to analyze the behavior, character, and momentum of volatility itself. 
 The challenge was twofold. First, to create a robust mathematical model to quantify these abstract concepts. This led to the multi-layered analysis of ATR differentials and standard deviations. Second, to make this complex data intuitive and actionable. This drove the creation of the "Visual Universe," where abstract mathematical values are translated into geometric shapes, flows, and fields. The adaptive system was intentionally kept simple and transparent, focusing on a single, impactful parameter (time-based exits) to provide performance feedback without becoming an inscrutable "black box." The result is a tool that is both profoundly deep in its analysis and remarkably clear in its presentation. 
⚠️  RISK DISCLAIMER AND BEST PRACTICES 
 VoVix+ is an advanced analytical tool, not a guarantee of future profits. All financial markets carry inherent risk. The backtesting results shown by the strategy are historical and do not guarantee future performance. This strategy incorporates realistic commission and slippage settings by default, but market conditions can vary. Always practice sound risk management, use position sizes appropriate for your account equity, and never risk more than you can afford to lose. It is recommended to use this strategy as part of a comprehensive trading plan. This was developed specifically for Futures 
 "The prevailing wisdom is that markets are always right. I take the opposite view. I assume that markets are always wrong. Even if my assumption is occasionally wrong, I use it as a working hypothesis." 
    —  George Soros 
— Dskyz, Trade with insight. Trade with anticipation.
Search in scripts for "backtesting"
Multi-Confluence Swing Hunter V1# Multi-Confluence Swing Hunter V1 - Complete Description
Overview
The Multi-Confluence Swing Hunter V1 is a sophisticated low timeframe scalping strategy specifically optimized for MSTR (MicroStrategy) trading. This strategy employs a comprehensive point-based scoring system that combines optimized technical indicators, price action analysis, and reversal pattern recognition to generate precise trading signals on lower timeframes.
Performance Highlight: 
In backtesting on MSTR 5-minute charts, this strategy has demonstrated over 200% profit performance, showcasing its effectiveness in capturing rapid price movements and volatility patterns unique to MicroStrategy's trading behavior.
The strategy's parameters have been fine-tuned for MSTR's unique volatility characteristics, though they can be optimized for other high-volatility instruments as well.
## Key Innovation & Originality
This strategy introduces a unique **dual scoring system** approach:
- **Entry Scoring**: Identifies swing bottoms using 13+ different technical criteria
- **Exit Scoring**: Identifies swing tops using inverse criteria for optimal exit timing
Unlike traditional strategies that rely on simple indicator crossovers, this system quantifies market conditions through a weighted scoring mechanism, providing objective, data-driven entry and exit decisions.
## Technical Foundation
### Optimized Indicator Parameters
The strategy utilizes extensively backtested parameters specifically optimized for MSTR's volatility patterns:
**MACD Configuration (3,10,3)**:
- Fast EMA: 3 periods (vs standard 12)
- Slow EMA: 10 periods (vs standard 26)  
- Signal Line: 3 periods (vs standard 9)
- **Rationale**: These faster parameters provide earlier signal detection while maintaining reliability, particularly effective for MSTR's rapid price movements and high-frequency volatility
**RSI Configuration (21-period)**:
- Length: 21 periods (vs standard 14)
- Oversold: 30 level
- Extreme Oversold: 25 level
- **Rationale**: The 21-period RSI reduces false signals while still capturing oversold conditions effectively in MSTR's volatile environment
**Parameter Adaptability**: While optimized for MSTR, these parameters can be adjusted for other high-volatility instruments. Faster-moving stocks may benefit from even shorter MACD periods, while less volatile assets might require longer periods for optimal performance.
### Scoring System Methodology
**Entry Score Components (Minimum 13 points required)**:
1. **RSI Signals** (max 5 points):
   - RSI < 30: +2 points
   - RSI < 25: +2 points  
   - RSI turning up: +1 point
2. **MACD Signals** (max 8 points):
   - MACD below zero: +1 point
   - MACD turning up: +2 points
   - MACD histogram improving: +2 points
   - MACD bullish divergence: +3 points
3. **Price Action** (max 4 points):
   - Long lower wick (>50%): +2 points
   - Small body (<30%): +1 point
   - Bullish close: +1 point
4. **Pattern Recognition** (max 8 points):
   - RSI bullish divergence: +4 points
   - Quick recovery pattern: +2 points
   - Reversal confirmation: +4 points
**Exit Score Components (Minimum 13 points required)**:
Uses inverse criteria to identify swing tops with similar weighting system.
## Risk Management Features
### Position Sizing & Risk Control
- **Single Position Strategy**: 100% equity allocation per trade
- **No Overlapping Positions**: Ensures focused risk management
- **Configurable Risk/Reward**: Default 5:1 ratio optimized for volatile assets
### Stop Loss & Take Profit Logic
- **Dynamic Stop Loss**: Based on recent swing lows with configurable buffer
- **Risk-Based Take Profit**: Calculated using risk/reward ratio
- **Clean Exit Logic**: Prevents conflicting signals
## Default Settings Optimization
### Key Parameters (Optimized for MSTR/Bitcoin-style volatility):
- **Minimum Entry Score**: 13 (ensures high-conviction entries)
- **Minimum Exit Score**: 13 (prevents premature exits)
- **Risk/Reward Ratio**: 5.0 (accounts for volatility)
- **Lower Wick Threshold**: 50% (identifies true hammer patterns)
- **Divergence Lookback**: 8 bars (optimal for swing timeframes)
### Why These Defaults Work for MSTR:
1. **Higher Score Thresholds**: MSTR's volatility requires more confirmation
2. **5:1 Risk/Reward**: Compensates for wider stops needed in volatile markets
3. **Faster MACD**: Captures momentum shifts quickly in fast-moving stocks
4. **21-period RSI**: Reduces noise while maintaining sensitivity
## Visual Features
### Score Display System
- **Green Labels**: Entry scores ≥10 points (below bars)
- **Red Labels**: Exit scores ≥10 points (above bars)
- **Large Triangles**: Actual trade entries/exits
- **Small Triangles**: Reversal pattern confirmations
### Chart Cleanliness
- Indicators plotted in separate panes (MACD, RSI)
- TP/SL levels shown only during active positions
- Clear trade markers distinguish signals from actual trades
## Backtesting Specifications
### Realistic Trading Conditions
- **Commission**: 0.1% per trade
- **Slippage**: 3 points
- **Initial Capital**: $1,000
- **Account Type**: Cash (no margin)
### Sample Size Considerations
- Strategy designed for 100+ trade sample sizes
- Recommended timeframes: 4H, 1D for swing trading
- Optimal for trending/volatile markets
## Strategy Limitations & Considerations
### Market Conditions
- **Best Performance**: Trending markets with clear swings
- **Reduced Effectiveness**: Highly choppy, sideways markets
- **Volatility Dependency**: Optimized for moderate to high volatility assets
### Risk Warnings
- **High Allocation**: 100% position sizing increases risk
- **No Diversification**: Single position strategy
- **Backtesting Limitation**: Past performance doesn't guarantee future results
## Usage Guidelines
### Recommended Assets & Timeframes
- **Primary Target**: MSTR (MicroStrategy) - 5min to 15min timeframes
- **Secondary Targets**: High-volatility stocks (TSLA, NVDA, COIN, etc.)
- **Crypto Markets**: Bitcoin, Ethereum (with parameter adjustments)
- **Timeframe Optimization**: 1min-15min for scalping, 30min-1H for swing scalping
### Timeframe Recommendations
- **Primary Scalping**: 5-minute and 15-minute charts
- **Active Monitoring**: 1-minute for precise entries
- **Swing Scalping**: 30-minute to 1-hour timeframes
- **Avoid**: Sub-1-minute (excessive noise) and above 4-hour (reduces scalping opportunities)
## Technical Requirements
- **Pine Script Version**: v6
- **Overlay**: Yes (plots on price chart)
- **Additional Panes**: MACD and RSI indicators
- **Real-time Compatibility**: Confirmed bar signals only
## Customization Options
All parameters are fully customizable through inputs:
- Indicator lengths and levels
- Scoring thresholds
- Risk management settings
- Visual display preferences
- Date range filtering
## Conclusion
This scalping strategy represents a comprehensive approach to low timeframe trading that combines multiple technical analysis methods into a cohesive, quantified system specifically optimized for MSTR's unique volatility characteristics. The optimized parameters and scoring methodology provide a systematic way to identify high-probability scalping setups while managing risk effectively in fast-moving markets.
The strategy's strength lies in its objective, multi-criteria approach that removes emotional decision-making from scalping while maintaining the flexibility to adapt to different instruments through parameter optimization. While designed for MSTR, the underlying methodology can be fine-tuned for other high-volatility assets across various markets.
**Important Disclaimer**: This strategy is designed for experienced scalpers and is optimized for MSTR trading. The high-frequency nature of scalping involves significant risk. Past performance does not guarantee future results. Always conduct your own analysis, consider your risk tolerance, and be aware of commission/slippage costs that can significantly impact scalping profitability.
Arbitrage Spot-Futures Don++Strategy: Spot-Futures Arbitrage Don++ 
This strategy has been designed to  detect and exploit arbitrage opportunities between the Spot and Futures markets  of the same trading pair (e.g. BTC/USDT). The aim is to take advantage of price differences (spreads) between the two markets, while minimizing risk through dynamic position management.
 [Operating principle 
The strategy is based on calculating the  spread  between Spot and Futures prices. When this spread exceeds a certain threshold (positive or negative), reverse positions are opened simultaneously on both markets:
- i] Long Spot + Short Futures  when the spread is positive.
- i] Short Spot + Long Futures  when the spread is negative.
Positions are closed when the spread returns to a value close to zero or after a user-defined maximum duration.
 [Strategy strengths 
1.  Adaptive thresholds  :
   - Entry/exit thresholds can be dynamic (based on moving averages and standard deviations) or fixed, offering greater flexibility to adapt to market conditions.
2.  Robust data management :
   - The script checks the validity of data before executing calculations, thus avoiding errors linked to missing or invalid data.
3.  Risk limitation  :
   - A position size based on a percentage of available capital (default 10%) limits exposure.
   - A time filter limits the maximum duration of positions to avoid losses due to persistent spreads.
4.  Clear visualization :
   - Charts include horizontal lines for entry/exit thresholds, as well as visual indicators for spread and Spot/Futures prices.
5.  Alerts and logs :
   - Alerts are triggered on entries and exits to inform the user in real time.
 [Points for improvement or completion 
Although this strategy is functional and robust, it still has a few limitations that could be addressed in future versions:
1.  [Limited historical data  :
   - TradingView does not retrieve real-time data for multiple symbols simultaneously. This can limit the accuracy of calculations, especially under conditions of high volatility.
2.  [Lack of liquidity management :
   - The script does not take into account the volumes available on the order books. In conditions of low liquidity, it may be difficult to execute orders at the desired prices.
3.  [Non-dynamic transaction costs  :
   - Transaction costs (exchange fees, slippage) are set manually. A dynamic integration of these costs via an external API would be more realistic.
4.  User-dependency for symbols :
   - Users must manually specify Spot and Futures symbols. Automatic symbol validation would be useful to avoid configuration errors.
5.  Lack of advanced backtesting :
   - Backtesting is based solely on historical data available on TradingView. An implementation with third-party data (via an API) would enable the strategy to be tested under more realistic conditions.
6.  [Parameter optimization  :
   - Certain parameters (such as analysis period or spread thresholds) could be optimized for each specific trading pair.
 [How can I contribute?
If you'd like to help improve this strategy, here are a few ideas:
 1. Add additional filters: 
   - For example, a filter based on volume or volatility to avoid false signals.
 2. Integrate dynamic costs: 
   - Use an external API to retrieve actual costs and adjust thresholds accordingly.
 3. Improve position management: 
   - Implement hedging or scalping mechanisms to maximize profits.
 4. Test on other pairs: 
   - Evaluate the strategy's performance on other assets (ETH, SOL, etc.) and adjust parameters accordingly.
 5. Publish backtesting results :
   - Share detailed analyses of the strategy's performance under different market conditions.
 [Conclusion 
This Spot-Futures arbitrage strategy is a powerful tool for exploiting price differentials between markets. Although it is already functional, it can still be improved to meet more complex trading scenarios. Feel free to test, modify and share your ideas to make this strategy even more effective!
 [Thank you for contributing to this open-source community!  
If you have any questions or suggestions, please feel free to comment or contact me directly.
Reversal & Breakout Strategy with ORB### Reversal & Breakout Strategy with ORB
This strategy combines three distinct trading approaches—reversals, trend breakouts, and opening range breakouts (ORB)—into a single, cohesive system. The goal is to capture high-probability setups across different market conditions, leveraging a mashup of technical indicators for confirmation and risk management. Below, I’ll explain why this combination works, how the components interact, and how to use it effectively.
#### Why the Mashup?
- **Reversals**: Identifies overextended moves using RSI (overbought/oversold) and SMA50 crosses, filtered by VWAP and SMA200 trend direction. This targets mean-reversion opportunities in trending markets.
- **Breakouts**: Uses EMA9/EMA20 crossovers with VWAP and SMA200 confirmation to catch momentum-driven trend continuations.
- **Opening Range Breakout (ORB)**: Detects early momentum by breaking the high/low of a user-defined opening range (default: 15 bars) with volume confirmation. This adds a time-based edge, ideal for intraday trading.
The synergy comes from blending these methods: reversals catch pullbacks, breakouts ride trends, and ORB exploits early volatility—all filtered by trend (SMA200) and anchored by VWAP for context.
#### How It Works
1. **Indicators**:
   - **EMA9/EMA20**: Fast-moving averages for breakout signals.
   - **SMA50**: Medium-term trend filter for reversals.
   - **SMA200**: Long-term trend direction to align trades.
   - **RSI (14)**: Measures overbought (>70) or oversold (<30) conditions.
   - **VWAP**: Acts as a dynamic support/resistance level.
   - **ATR (14)**: Sets stop-loss distance (default: 1.5x ATR).
   - **Volume**: Confirms ORB breakouts (1.5x average volume of opening range).
2. **Entry Conditions**:
   - **Long**: Triggers on reversal (SMA50 cross + RSI < 30 + below VWAP + uptrend), breakout (EMA9 > EMA20 + above VWAP + uptrend), or ORB (break above opening range high + volume).
   - **Short**: Triggers on reversal (SMA50 cross + RSI > 70 + above VWAP + downtrend), breakout (EMA9 < EMA20 + below VWAP + downtrend), or ORB (break below opening range low + volume).
3. **Risk Management**:
   - Risks 5% of equity per trade (based on the initial capital set in the strategy tester).
   - Stop-loss: Based on lowest low/highest high over 7 bars ± 1.5x ATR.
   - Targets: Two exits at 1:1 and 1:2 risk:reward (50% of position at each).
   - Break-even: Stop moves to entry price after the first target is hit.
4. **Backtesting Settings**:
   - Commission: Hardcoded at 0.1% per trade (realistic for most brokers).
   - Slippage: Hardcoded at 2 ticks (realistic for most markets).
   - Tested on datasets yielding 100+ trades (e.g., 2-min or 5-min charts over months).
#### How to Use It
- **Timeframe**: Works best on intraday (2-min, 5-min) or daily charts. Adjust `Opening Range Bars` (e.g., 15 bars = 30 min on 2-min chart) for your timeframe.
- **Settings**: 
  - Set your initial equity in the TradingView strategy tester’s "Properties" tab under "Initial Capital" (e.g., $10,000). The script automatically risks 5% of this equity per trade.
  - Adjust `Stop Loss ATR Multiplier` or `Risk:Reward Targets` based on your risk tolerance.
  - Note that commission (0.1%) and slippage (2 ticks) are fixed in the script for backtesting consistency.
- **Execution**: Enter on signal, monitor plotted stop (red) and targets (green/blue). The strategy supports pyramiding (up to 2 positions) for scaling into trends.
#### Backtesting Notes
Results are realistic with commission (0.1%) and slippage (2 ticks) included. For a sufficient sample, test on volatile instruments (e.g., stocks, forex) over 3-6 months on lower timeframes. The default 1.5x ATR stop may seem wide, but it’s justified to avoid premature exits in volatile markets—feel free to tweak it with justification. The script assumes an initial capital of $10,000 in the strategy tester for the 5% risk calculation (e.g., $500 risk per trade); adjust this in the "Properties" tab as needed.
This mashup isn’t just a random mix; it’s a deliberate fusion of complementary strategies, offering traders flexibility across market phases. Questions? Let me know!
Naive Bayes Candlestick Pattern Classifier v1.1 BETAAn intermezzo on why i made this script publication..
A : Candlestick Pattern took hours to backtest, why not using Machine Learning techniques?
B : Machine Learning, no that's gonna be really heavy bro!
A : Not really, because we use Naive Bayes.
B : The simplest, yet powerful machine learning algorithm to separate (a.k.a classify) multivariate data.
----------------------------------------------------------------------------------------------------------------------
Hello, everyone!
After deep research in extracting meaningful information from the market, I ended up building this powerful machine learning indicator based on the evolution of Bayesian Statistics. This indicator not only leverages the simplicity of Naive Bayes but also extends its application to candlestick pattern analysis, making it an invaluable tool for traders who are looking to enhance their technical analysis without spending countless hours manually backtesting each pattern on each market!. 
What most interesting part is actually after learning all of likely useless methods like fibonacci, supply and demand, volume profile, etc. We always ended up back to basic like support and resistance and candlestick patterns, but with a slight twist on strategy algorithm design and statistical approach. Thus, the only reason why i made this, because i exactly know that you guys will ended up in this position as time goes by.
The essence of this indicator lies in its ability to automate the recognition and statistical evaluation of various candlestick patterns. Traditionally, traders have relied on visual inspection and manual backtesting to determine the effectiveness of patterns like Bullish Engulfing, Bearish Engulfing, Harami variations, Hammer formations, and even more complex multi-candle patterns such as Three White Soldiers, Three Black Crows, Dark Cloud Cover, and Piercing Pattern. However, these conventional methods are both time-consuming and prone to subjective bias.
To address these challenges, I employed Naive Bayes—a probabilistic classifier that, despite its simplicity, offers robust performance in various domains. Naive Bayes assumes that each feature is independent of the others given the class label, which, although a strong assumption, works remarkably well in practice, especially when the dataset is large like market data and the feature space is high-dimensional. In our case, each candlestick pattern acts as a feature that can be statistically evaluated based on its historical performance. The indicator calculates a probability that a given pattern will lead to a price reversal, by comparing the pattern’s close price to the highest or lowest price achieved in a lookahead window.
One of the standout features of this script is its flexibility. Each candlestick pattern is not only coded into the system but also comes with individual toggles to enable or disable them based on your trading strategy. This means you can choose to focus on single-candle patterns like Bullish Engulfing or more complex multi-candle formations such as Three White Soldiers, without modifying the core code. The built-in customization options allow you to adjust colors and labels for each pattern, giving you the freedom to tailor the visual output to your preference. This level of customization ensures that the indicator integrates seamlessly into your existing TradingView setup.
Moreover, the indicator isn’t just about pattern recognition—it also incorporates outcome-based learning. Every time a pattern is detected, it looks ahead a predefined number of bars to evaluate if the expected reversal actually materialized. This outcome is then stored in arrays, and over time, the script dynamically calculates the probability of success for each pattern. These probabilities are presented in a real-time updating table on your chart, which shows not only the percentage probability but also the count of historical occurrences. With this information at your fingertips, you can quickly gauge the reliability of each pattern in your chosen market and timeframe.
Another significant advantage of this approach is its speed and efficiency. While more complex machine learning models like neural networks might require heavy computational resources and longer training times, the Naive Bayes classifier in this script is lightweight, instantaneous and can be updated on the fly with each new bar. This real-time capability is essential for modern traders who need to make quick decisions in fast-paced markets.
Furthermore, by automating the process of backtesting, the indicator frees up your time to focus on other aspects of trading strategy development. Instead of manually analyzing hundreds or even thousands of candles, you can rely on the statistical power of Naive Bayes to provide you with insights on which patterns are most likely to result in profitable moves. This not only enhances your efficiency but also helps to eliminate the cognitive biases that often plague manual analysis.
In summary, this indicator represents a fusion of traditional candlestick analysis with modern machine learning techniques. It harnesses the simplicity and effectiveness of Naive Bayes to deliver a dynamic, real-time evaluation of various candlestick patterns. Whether you are a seasoned trader looking to refine your technical analysis or a beginner eager to understand market dynamics, this tool offers a powerful, customizable, and efficient solution. Welcome to a new era where advanced statistical methods meet practical trading insights—happy trading and may your patterns always be in your favor!
Note : On this current released beta version, you must manually adjust reversal percentage move based on each market. Further updates may include automated best range detection and probability.
Multi-indicator Signal Builder [Skyrexio]Overview 
 Multi-Indicator Signal Builder  is a versatile, all-in-one script designed to streamline your trading workflow by combining multiple popular technical indicators under a single roof. It features a single-entry, single-exit logic, intrabar stop-loss/take-profit handling, an optional time filter, a visually accessible condition table, and a built-in statistics label. Traders can choose any combination of 12+ indicators (RSI, Ultimate Oscillator, Bollinger %B, Moving Averages, ADX, Stochastic, MACD, PSAR, MFI, CCI, Heikin Ashi, and a “TV Screener” placeholder) to form entry or exit conditions. This script aims to simplify strategy creation and analysis, making it a powerful toolkit for technical traders.
 Indicators Overview 
 1.	RSI (Relative Strength Index) 
Measures recent price changes to evaluate overbought or oversold conditions on a 0–100 scale.
 2.	Ultimate Oscillator (UO) 
Uses weighted averages of three different timeframes, aiming to confirm price momentum while avoiding false divergences.
 3.	Bollinger %B 
Expresses price relative to Bollinger Bands, indicating whether price is near the upper band (overbought) or lower band (oversold).
 4.	Moving Average (MA) 
Smooths price data over a specified period. The script supports both SMA and EMA to help identify trend direction and potential crossovers.
 5.	ADX (Average Directional Index) 
Gauges the strength of a trend (0–100). Higher ADX signals stronger momentum, while lower ADX indicates a weaker trend.
 6.	Stochastic 
Compares a closing price to a price range over a given period to identify momentum shifts and potential reversals.
 7.	MACD (Moving Average Convergence/Divergence) 
Tracks the difference between two EMAs plus a signal line, commonly used to spot momentum flips through crossovers.
 8.	PSAR (Parabolic SAR) 
Plots a trailing stop-and-reverse dot that moves with the trend. Often used to signal potential reversals when price crosses PSAR.
 9.	MFI (Money Flow Index) 
Similar to RSI but incorporates volume data. A reading above 80 can suggest overbought conditions, while below 20 may indicate oversold.
 10.	CCI (Commodity Channel Index) 
Identifies cyclical trends or overbought/oversold levels by comparing current price to an average price over a set timeframe.
 11.	Heikin Ashi 
A type of candlestick charting that filters out market noise. The script uses a streak-based approach (multiple consecutive bullish or bearish bars) to gauge mini-trends.
 12.	TV Screener 
A placeholder condition designed to integrate external buy/sell logic (like a TradingView “Buy” or “Sell” rating). Users can override or reference external signals if desired.
 
 Unique Features 
 1.	Multi-Indicator Entry and Exit 
You can selectively enable any subset of 12+ classic indicators, each with customizable parameters and conditions. A position opens only if all enabled entry conditions are met, and it closes only when all enabled exit conditions are satisfied, helping reduce false triggers.
 2.	Single-Entry / Single-Exit with Intrabar SL/TP 
The script supports a single position at a time. Once a position is open, it monitors intrabar to see if the price hits your stop-loss or take-profit levels before the bar closes, making results more realistic for fast-moving markets.
 3.	Time Window Filter 
Users may specify a start/end date range during which trades are allowed, making it convenient to focus on specific market cycles for backtesting or live trading.
 4.	Condition Table and Statistics 
A table at the bottom of the chart lists all active entry/exit indicators. Upon each closed trade, an integrated statistics label displays net profit, total trades, win/loss count, average and median PnL, etc.
 5.	Seamless Alerts and Automation 
  Configure alerts in TradingView using “Any alert() function call.”
  The script sends JSON alert messages you can route to your own webhook.
  The indicator can be integrated with Skyrexio alert bots to automate execution on major cryptocurrency exchanges 
 6.	Optional MA/PSAR Plots 
For added visual clarity, optionally plot the chosen moving averages or PSAR on the chart to confirm signals without stacking multiple indicators.
 
 Methodology 
 1. Multi-Indicator Entry Logic 
When multiple entry indicators are enabled (e.g., RSI + Stochastic + MACD), the script requires all signals to align before generating an entry. Each indicator can be set for crossovers, crossunders, thresholds (above/below), etc. This “AND” logic aims to filter out low-confidence triggers.
 2. Single-Entry Intrabar SL/TP 
   One Position At a Time:  Once an entry signal triggers, a trade opens at the bar’s close.
   Intrabar Checks:  Stop-loss and take-profit levels (if enabled) are monitored on every tick. If either is reached, the position closes immediately, without waiting for the bar to end. 
 3. Exit Logic 
   All Conditions Must Agree:  If the trade is still open (SL/TP not triggered), then all enabled exit indicators must confirm a closure before the script exits on the bar’s close. 
 4. Time Filter 
   Optional Trading Window:  You can activate a date/time range to constrain entries and exits strictly to that interval. 
 
 Justification of Methodology 
   Indicator Confluence:  Combining multiple tools (RSI, MACD, etc.) can reduce noise and false signals.
   Intrabar SL/TP:  Capturing real-time spikes or dips provides a more precise reflection of typical live trading scenarios.
   Single-Entry Model:  Straightforward for both manual and automated tracking (especially important in bridging to bots).
   Custom Date Range:  Helps refine backtesting for specific market conditions or to avoid known irregular data periods. 
 
 How to Use 
 1.	Add the Script to Your Chart 
  In TradingView, open  Indicators , search for “Multi-indicator Signal Builder”.
  Click to add it to your chart. 
 2.	Configure Inputs 
   Time Filter:  Set a start and end date for trades.
   Alerts Messages:  Input any JSON or text payload needed by your external service or bot.
   Entry Conditions:  Enable and configure any indicators (e.g., RSI, MACD) for a confluence-based entry.
   Close Conditions:  Enable exit indicators, along with optional SL (negative %) and TP (positive %) levels. 
 3.	Set Up Alerts 
  In TradingView, select “Create Alert” → Condition = “Any alert() function call” → choose this script.
   Entry Alert:  Triggers on the script’s entry signal.
   Close Alert:  Triggers on the script’s close signal (or if SL/TP is hit).
   Skyrexio Alert Bots:  You can route these alerts via webhook to Skyrexio alert bots to automate order execution on major crypto exchanges (or any other supported broker). 
 4.	Visual Reference 
  A  condition table  at the bottom summarizes active signals.
   Statistics Label  updates automatically as trades are closed, showing PnL stats and distribution metrics. 
 
 Backtesting Guidelines 
   Symbol/Timeframe:  Works on multiple assets and timeframes; always do thorough testing.
   Realistic Costs:  Adjust commissions and potential slippage to match typical exchange conditions.
   Risk Management:  If using the built-in stop-loss/take-profit, set percentages that reflect your personal risk tolerance.
   Longer Test Horizons:  Verify performance across diverse market cycles to gauge reliability. 
 Example of statistic calculation 
   Test Period:  2023-01-01 to 2025-12-31
   Initial Capital:  $1,000
   Commission:  0.1%, Slippage ~5 ticks
   Trade Count:  468 (varies by strategy conditions)
   Win rate:  76% (varies by strategy conditions)
   Net Profit:  +96.17% (varies by strategy conditions) 
 
 Disclaimer 
This indicator is provided  strictly for informational and educational purposes . 
  It does not constitute financial or trading advice.
  Past performance never guarantees future results.
  Always test thoroughly in demo environments before using real capital. 
 
Enjoy exploring the  Multi-Indicator Signal Builder!  Experiment with different indicator combinations and adjust parameters to align with your trading preferences, whether you trade manually or link your alerts to external automation services. Happy trading and stay safe!
SPY/TLT Strategy█ STRATEGY OVERVIEW  
The "SPY/TLT Strategy" is a trend-following crossover strategy designed to trade the relationship between TLT and its Simple Moving Average (SMA). The default configuration uses TLT (iShares 20+ Year Treasury Bond ETF) with a 20-period SMA, entering long positions on bullish crossovers and exiting on bearish crossunders. **This strategy is NOT optimized and performs best in trending markets.**
█ KEY FEATURES  
   
  SMA Crossover System: Uses price/SMA relationship for signal generation (Default: 20-period)  
  Dynamic Time Window: Configurable backtesting period (Default: 2014-2099)  
  Equity-Based Position Sizing: Default 100% equity allocation per trade  
  Real-Time Visual Feedback: Price/SMA plot with trend-state background coloring  
  Event-Driven Execution: Processes orders at bar close for accurate backtesting  
   
█ SIGNAL GENERATION  
1. LONG ENTRY CONDITION  
   
  TLT closing price crosses ABOVE SMA  
  Occurs within specified time window  
  Generates market order at next bar open
   
2. EXIT CONDITION  
   
  TLT closing price crosses BELOW SMA  
  Closes all open positions immediately
   
█ ADDITIONAL SETTINGS  
   
  SMA Period: Simple Moving Average length (Default: 20)  
  Start Time and End Time: The time window for trade execution (Default: 1 Jan 2014 - 1 Jan 2099)  
  Security Symbol: Ticker for analysis (Default: TLT)  
   
█ PERFORMANCE OVERVIEW  
   
  Ideal Market Conditions: Strong trending environments  
  Potential Drawbacks: Whipsaws in range-bound markets  
  Backtesting results should be analyzed to optimize the MA Period and EMA Filter settings for specific instruments
   
CauchyTrend [InvestorUnknown]The CauchyTrend is an experimental tool that leverages a Cauchy-weighted moving average combined with a modified Supertrend calculation. This unique approach provides traders with insight into trend direction, while also offering an optional ATR-based range analysis to understand how often the market closes within, above, or below a defined volatility band.
 Core Concepts 
 Cauchy Distribution and Gamma Parameter 
 
 The Cauchy distribution is a probability distribution known for its heavy tails and lack of a defined mean or variance. It is characterized by two parameters: a location parameter (x0, often 0 in our usage) and a scale parameter (γ, "gamma").
 Gamma (γ): Determines the "width" or scale of the distribution. Smaller gamma values produce a distribution more concentrated near the center, giving more weight to recent data points, while larger gamma values spread the weight more evenly across the sample.
 In this indicator, gamma influences how much emphasis is placed on values closer to the current price versus those further away in time. This makes the resulting weighted average either more reactive or smoother, depending on gamma’s value.
 
 // Cauchy PDF formula used for weighting:
// f(x; γ) = (1/(π*γ)) *  
f_cauchyPDF(offset, gamma) =>
    numerator   = gamma * gamma
    denominator = (offset * offset) + (gamma * gamma)
    pdf = (1 / (math.pi * gamma)) * (numerator / denominator)
    pdf
 
  
  
 A chart showing different Cauchy PDFs with various gamma values, illustrating how gamma affects the weight distribution. 
 Cauchy-Weighted Moving Average (CWMA) 
 
 Using the Cauchy PDF, we calculate normalized weights to create a custom Weighted Moving Average. Each bar in the lookback period receives a weight according to the Cauchy PDF. The result is a Cauchy Weighted Average (cwm_avg) that differs from typical moving averages, potentially offering unique sensitivity to price movements.
 
 // Summation of weighted prices using Cauchy distribution weights
cwm_avg = 0.0
for i = 0 to length - 1
    w_norm = array.get(weights, i) / sum_w
    cwm_avg += array.get(values, i) * w_norm 
 Supertrend with a Cauchy Twist 
 
 The indicator integrates a modified Supertrend calculation using the cwm_avg as its reference point. The Supertrend logic typically sets upper and lower bands based on volatility (ATR), and flips direction when price crosses these bands.
 In this case, the Cauchy-based average replaces the usual baseline, aiming to capture trend direction via a different weighting mechanism.
 When price closes above the upper band, the trend is considered bullish; closing below the lower band signals a bearish trend.
 
 ATR Stats Range (Optional) 
Beyond the fundamental trend detection, the indicator optionally computes ATR-based stats to understand price distribution relative to a volatility corridor centered on the cwm_avg line:
 
 Volatility Range:
 Defined as cwm_avg ± (ATR * atr_mult), this range creates upper and lower bands. Turning on atr_stats computes how often the daily close falls: Within the range, Above the upper ATR boundary, Below the lower ATR boundary, Within the range but above cwm_avg, Within the range but below cwm_avg
 These statistics can help traders gauge how the market behaves relative to this volatility envelope and possibly identify if the market tends to revert to the mean or break out more often.
 
  
 Backtesting and Performance Metrics 
The code is integrated with a backtesting library that allows users to assess strategy performance historically:
 
 Equity Curve Calculation: Compares CauchyTrend-based signals against the underlying asset.
 Performance Metrics Table: Once enabled, displays key metrics such as mean returns, Sharpe Ratio, Sortino Ratio, and more, comparing the strategy to a simple Buy & Hold approach.
 
 Alerts and Notifications 
The indicator provides Alerts for key events:
 
 Long Alert: Triggered when the trend flips bullish.
 Short Alert: Triggered when the trend flips bearish.
 
 Customization and Calibration 
Important: The default parameters are not optimized for any specific instrument or time frame. Traders should:
 
 Adjust the length and gamma parameters to influence how sharply or broadly the cwm_avg reacts to price changes.
 Tune the atr_len and atr_mult for the Supertrend logic to better match the asset’s volatility characteristics.
 Experiment with atr_stats on/off to see if that additional volatility distribution information provides helpful insights.
 
Traders may find certain sets of parameters that align better with their preferred trading style, risk tolerance, or asset volatility profile.
 Disclaimer: This indicator is for educational and informational purposes only. Past performance in backtesting does not guarantee future results. Always perform due diligence, and consider consulting a qualified financial advisor before trading.
AadTrend [InvestorUnknown]The AadTrend indicator is an experimental trading tool that combines a user-selected moving average with the Average Absolute Deviation (AAD) from this moving average. This combination works similarly to the Supertrend indicator but offers additional flexibility and insights. In addition to generating Long and Short signals, the AadTrend indicator identifies RISK-ON and RISK-OFF states for each trade direction, highlighting areas where taking on more risk may be considered.
 Core Concepts and Features 
 Moving Average (User-Selected Type) 
The indicator allows users to select from various types of moving averages to suit different trading styles and market conditions:
 
 Simple Moving Average (SMA)
 Exponential Moving Average (EMA)
 Hull Moving Average (HMA)
 Double Exponential Moving Average (DEMA)
 Triple Exponential Moving Average (TEMA)
 Relative Moving Average (RMA)
 Fractal Adaptive Moving Average (FRAMA)
 
 Average Absolute Deviation (AAD) 
The Average Absolute Deviation measures the average distance between each data point and the mean, providing a robust estimation of volatility.
 aad(series float src, simple int length, simple string avg_type) =>
    avg = // Moving average as selected by the user
    abs_deviations = math.abs(src - avg)
    ta.sma(abs_deviations, length) 
 
 This provides a volatility measure that adapts to recent market conditions.
 
 Combining Moving Average and AAD 
The indicator creates upper and lower bands around the moving average using the AAD, similar to how the Supertrend indicator uses Average True Range (ATR) for its bands.
 AadTrend(series float src, simple int length, simple float aad_mult, simple string avg_type) =>
    // Calculate AAD (volatility measure)
    aad_value = aad(src, length, avg_type)
    // Calculate the AAD-based moving average by scaling the price data with AAD
    avg = switch avg_type
        "SMA" =>    ta.sma(src, length)
        "EMA" =>    ta.ema(src, length)
        "HMA" =>    ta.hma(src, length)
        "DEMA" =>   ta.dema(src, length)
        "TEMA" =>   ta.tema(src, length)
        "RMA" =>    ta.rma(src, length)
        "FRAMA" =>  ta.frama(src, length)
    avg_p = avg + (aad_value * aad_mult)
    avg_m = avg - (aad_value * aad_mult)
    var direction = 0
    if ta.crossover(src, avg_p)
        direction := 1
    else if ta.crossunder(src, avg_m)
        direction := -1
     
 A chart displaying the moving average with upper and lower AAD bands enveloping the price action. 
  
 Signals and Trade States 
 1. Long and Short Signals 
 
 Long Signal: Generated when the price crosses above the upper AAD band,
 Short Signal: Generated when the price crosses below the lower AAD band.
 
 2. RISK-ON and RISK-OFF States 
These states provide additional insight into the strength of the current trend and potential opportunities for taking on more risk.
 
 RISK-ON Long: When the price moves significantly above the upper AAD band after a Long signal.
 RISK-OFF Long: When the price moves back below the upper AAD band, suggesting caution.
 RISK-ON Short: When the price moves significantly below the lower AAD band after a Short signal.
 RISK-OFF Short: When the price moves back above the lower AAD band.
 
 Highlighted areas on the chart representing RISK-ON and RISK-OFF zones for both Long and Short positions. 
  
 A chart showing the filled areas corresponding to trend directions and RISK-ON zones 
  
 Backtesting and Performance Metrics 
While the AadTrend indicator focuses on generating signals and highlighting risk areas, it can be integrated with backtesting frameworks to evaluate performance over historical data.
Integration with Backtest Library:
 import InvestorUnknown/BacktestLibrary/1 as backtestlib 
  
 Customization and Calibration 
 1. Importance of Calibration 
 
 Default Settings Are Experimental: The default parameters are not optimized for any specific market condition or asset.
 User Calibration: Traders should adjust the length, aad_mult, and avg_type parameters to align the indicator with their trading strategy and the characteristics of the asset being analyzed.
 
 2. Factors to Consider 
 
 Market Volatility: Higher volatility may require adjustments to the aad_mult to avoid false signals.
 Trading Style: Short-term traders might prefer faster-moving averages like EMA or HMA, while long-term traders might opt for SMA or FRAMA.
 
 Alerts and Notifications 
The AadTrend indicator includes built-in alert conditions to notify traders of significant market events:
Long and Short Alerts:
 alertcondition(long_alert, "LONG (AadTrend)", "AadTrend flipped ⬆LONG⬆")
alertcondition(short_alert, "SHORT (AadTrend)", "AadTrend flipped ⬇Short⬇") 
RISK-ON and RISK-OFF Alerts:
 alertcondition(risk_on_long, "RISK-ON LONG (AadTrend)", "RISK-ON LONG (AadTrend)")
alertcondition(risk_off_long, "RISK-OFF LONG (AadTrend)", "RISK-OFF LONG (AadTrend)")
alertcondition(risk_on_short, "RISK-ON SHORT (AadTrend)", "RISK-ON SHORT (AadTrend)")
alertcondition(risk_off_short, "RISK-OFF SHORT (AadTrend)", "RISK-OFF SHORT (AadTrend)") 
 Important Notes and Disclaimer 
 
 Experimental Nature: The AadTrend indicator is experimental and should be used with caution.
 No Guaranteed Performance: Past performance is not indicative of future results. Backtesting results may not reflect real trading conditions.
 User Responsibility: Traders and investors should thoroughly test and calibrate the indicator settings before applying it to live trading.
 Risk Management: Always use proper risk management techniques, including stop-loss orders and position sizing.
 
MadTrend [InvestorUnknown]The MadTrend indicator is an experimental tool that combines the Median and Median Absolute Deviation (MAD) to generate signals, much like the popular Supertrend indicator. In addition to identifying Long and Short positions, MadTrend introduces RISK-ON and RISK-OFF states for each trade direction, providing traders with nuanced insights into market conditions. 
 Core Concepts 
 Median and Median Absolute Deviation (MAD) 
 
 Median: The middle value in a sorted list of numbers, offering a robust measure of central tendency less affected by outliers.
 Median Absolute Deviation (MAD): Measures the average distance between each data point and the median, providing a robust estimation of volatility.
 
 Supertrend-like Functionality 
 
 MadTrend utilizes the median and MAD in a manner similar to how Supertrend uses averages and volatility measures to determine trend direction and potential reversal points.
 
 RISK-ON and RISK-OFF States 
 
 RISK-ON: Indicates favorable conditions for entering or holding a position in the current trend direction.
 RISK-OFF: Suggests caution, signaling RISK-ON end and potential trend weakening or reversal.
 
 Calculating MAD 
 
 The mad function calculates the median of the absolute deviations from the median, providing a robust measure of volatility.
 
 // Function to calculate the Median Absolute Deviation (MAD)
mad(series float src, simple int length) =>
    med = ta.median(src, length)  // Calculate median
    abs_deviations = math.abs(src - med)  // Calculate absolute deviations from median
    ta.median(abs_deviations, length)  // Return the median of the absolute deviations 
 MADTrend Function 
 
 The MADTrend function calculates the median and MAD-based upper (med_p) and lower (med_m) bands. It determines the trend direction based on price crossing these bands.
 
 MADTrend(series float src, simple int length, simple float mad_mult) =>
    // Calculate MAD (volatility measure)
    mad_value = mad(close, length)
    // Calculate the MAD-based moving average by scaling the price data with MAD
    median = ta.median(close, length)  
    med_p = median + (mad_value * mad_mult)
    med_m = median - (mad_value * mad_mult)
    var direction = 0
    if ta.crossover(src, med_p)
        direction := 1
    else if ta.crossunder(src, med_m)
        direction := -1
     
 Trend Direction and Signals 
 
 Long Position (direction = 1): When the price crosses above the upper MAD band (med_p).
 Short Position (direction = -1): When the price crosses below the lower MAD band (med_m).
 RISK-ON: When the price moves further in the direction of the trend (beyond median +- MAD) after the initial signal.
 RISK-OFF: When the price retraces towards the median, signaling potential weakening of the trend.
 
 RISK-ON and RISK-OFF States 
 
 RISK-ON LONG: Price moves above the upper band after a Long signal, indicating strengthening bullish momentum.
 RISK-OFF LONG: Price falls back below the upper band, suggesting potential weakness in the bullish trend.
 RISK-ON SHORT: Price moves below the lower band after a Short signal, indicating strengthening bearish momentum.
 RISK-OFF SHORT: Price rises back above the lower band, suggesting potential weakness in the bearish trend.
 
Picture below show example RISK-ON periods which can be identified by “cloud” 
  
 Note: Highlighted areas on the chart indicating RISK-ON and RISK-OFF periods for both Long and Short positions. 
 Implementation Details 
Inputs and Parameters:
 
 Source (input_src): The price data used for calculations (e.g., close, open, high, low).
 Median Length (length): The number of periods over which the median and MAD are calculated.
 MAD Multiplier (mad_mult): Determines the distance of the upper and lower bands from the median.
 
Calculations:
 
 Median and MAD are recalculated each period based on the specified length.
 Upper (med_p) and Lower (med_m) Bands are computed by adding and subtracting the scaled MAD from the median.
 
Visual representation of the indicator on a price chart:
  
 Backtesting and Performance Metrics 
The MadTrend indicator includes a Backtesting Mode with a performance metrics table to evaluate its effectiveness compared to a simple buy-and-hold strategy.
Equity Calculation: 
 
 Calculates the equity curve based on the signals generated by the indicator.
 
Performance Metrics:
 
 Metrics such as Mean Returns, Standard Deviation, Sharpe Ratio, Sortino Ratio, and Omega Ratio are computed.
 The metrics are displayed in a table for both the strategy and the buy-and-hold approach.
 Note: Due to the use of labels and plot shapes, automatic chart scaling may not function ideally in Backtest Mode.
 
  
 Alerts and Notifications 
MadTrend provides alert conditions to notify traders of significant events:
 
 Trend Change Alerts
 RISK-ON and RISK-OFF Alerts - Provides real-time notifications about the RISK-ON and RISK-OFF states for proactive trade management.
 
 Customization and Calibration 
 
 Default Settings: The provided default settings are experimental and not optimized. They serve as a starting point for users.
 Parameter Adjustment: Traders are encouraged to calibrate the indicator's parameters (e.g., length, mad_mult) to suit their specific trading style and the characteristics of the asset being analyzed.
 Source Input: The indicator allows for different price inputs (open, high, low, close, etc.), offering flexibility in how the median and MAD are calculated.
 
 Important Notes 
 
 Market Conditions: The effectiveness of the MadTrend indicator can vary across different market conditions. Regular calibration is recommended.
 Backtest Limitations: Backtesting results are historical and do not guarantee future performance.
 Risk Management: Always apply sound risk management practices when using any trading indicator. 
Z-Score Weighted Trend System I [InvestorUnknown]The  Z-Score Weighted Trend System I  is an advanced and experimental trading indicator designed to utilize a combination of  slow and fast indicators  for a comprehensive analysis of market trends. The system is designed to identify stable trends using slower indicators while capturing rapid market shifts through dynamically weighted fast indicators. The core of this indicator is the dynamic weighting mechanism that utilizes the  Z-score of price , allowing the system to respond effectively to significant market movements.
 Dynamic Z-Score-Based Weighting System 
 
 The Z-Score Weighted Trend System I utilizes the Z-score of price to assign weights dynamically to fast indicators. This mechanism is designed to capture rapid market shifts at potential turning points, providing timely entry and exit signals.
 Traders can choose from two primary weighting mechanisms:
 Threshold-Based Weighting: The fast indicators are given weight only when the absolute Z-score exceeds a user-defined threshold. Below this threshold, fast indicators have no impact on the final signal.
 Continuous Weighting: By setting the threshold to zero, fast indicators always contribute to the final signal, regardless of Z-score levels. However, this increases the likelihood of false signals during ranging or low-volatility markets
 
 // Calculate weight for Fast Indicators based on Z-Score (Slow Indicator weight is kept to 1 for simplicity)
f_zscore_weights(series float z, simple float weight_thre) =>
    float fast_weight   = na
    float slow_weight   = na
    if weight_thre > 0
        if math.abs(z) <= weight_thre
            fast_weight := 0
            slow_weight := 1
        else
            fast_weight := 0 + math.sqrt(math.abs(z))
            slow_weight := 1
    else
        fast_weight     := 0 + math.sqrt(math.abs(z))
        slow_weight     := 1
     
 Choice of Z-Score Normalization 
Traders have the flexibility to select different Z-score processing methods to better suit their trading preferences:
 
 Raw Z-Score or Moving Average: Traders can opt for either the raw Z-score or a moving average of the Z-score to smooth out fluctuations.
 Normalized Z-Score (ranging from -1 to 1) or Z-Score Percentile: The normalized Z-score is simply the raw Z-score divided by 3, while the Z-score percentile utilizes a normal distribution for transformation.
 
 f_zscore_perc(series float zscore_src, simple int zscore_len, simple string zscore_a, simple string zscore_b, simple string ma_type, simple int ma_len) =>
    z = (zscore_src - ta.sma(zscore_src, zscore_len)) / ta.stdev(zscore_src, zscore_len)
    zscore = switch zscore_a
        "Z-Score"           => z
        "Z-Score MA"        => ma_type == "EMA" ? (ta.ema(z, ma_len)) : (ta.sma(z, ma_len))
    output = switch zscore_b
        "Normalized Z-Score"   => (zscore / 3) > 1 ? 1 : (zscore / 3) < -1 ? -1 : (zscore / 3)
        "Z-Score Percentile"    => (f_percentileFromZScore(zscore) - 0.5) * 2
    output 
  
 Slow and Fast Indicators 
The indicator uses a combination of slow and fast indicators:
 
 Slow Indicators (constant weight) for stable trend identification: DMI (Directional Movement Index), CCI (Commodity Channel Index), Aroon
 Fast Indicators (dynamic weight) to identify rapid trend shifts: ZLEMA (Zero-Lag Exponential Moving Average), IIRF (Infinite Impulse Response Filter)
 
Each indicator is calculated using for-loop methods to provide a smoothed and averaged view of price data over varying lengths, ensuring stability for slow indicators and responsiveness for fast indicators.
 Signal Calculation 
The final trading signal is determined by a weighted combination of both slow and fast indicators. The slow indicators provide a stable view of the trend, while the fast indicators offer agile responses to rapid market movements. The signal calculation takes into account the dynamic weighting of fast indicators based on the Z-score:
 // Calculate Signal (as weighted average)
float sig = math.round(((DMI*slow_w) + (CCI*slow_w) + (Aroon*slow_w) + (ZLEMA*fast_w) + (IIRF*fast_w)) / (3*slow_w + 2*fast_w), 2) 
 Backtest Mode and Performance Metrics 
The indicator features a detailed backtesting mode, allowing traders to compare the effectiveness of their selected settings against a traditional Buy & Hold strategy. The backtesting provides:
 
 Equity calculation based on signals generated by the indicator.
 Performance metrics comparing Buy & Hold metrics with the system’s signals, including: Mean, positive, and negative return percentages, Standard deviations, Sharpe, Sortino, and Omega Ratios
 
 // Calculate Performance Metrics
f_PerformanceMetrics(series float base, int Lookback, simple float startDate, bool Annualize = true) =>
    // Initialize variables for positive and negative returns
    pos_sum = 0.0
    neg_sum = 0.0
    pos_count = 0
    neg_count = 0
    returns_sum = 0.0
    returns_squared_sum = 0.0
    pos_returns_squared_sum = 0.0
    neg_returns_squared_sum = 0.0
    // Loop through the past 'Lookback' bars to calculate sums and counts
    if (time >= startDate)
        for i = 0 to Lookback - 1
            r = (base  - base ) / base 
            returns_sum += r
            returns_squared_sum += r * r
            if r > 0
                pos_sum += r
                pos_count += 1
                pos_returns_squared_sum += r * r
            if r < 0
                neg_sum += r
                neg_count += 1
                neg_returns_squared_sum += r * r
    float   export_array = array.new_float(12)
    // Calculate means
    mean_all        = math.round((returns_sum / Lookback), 4)
    mean_pos        = math.round((pos_count != 0 ? pos_sum / pos_count : na), 4)
    mean_neg        = math.round((neg_count != 0 ? neg_sum / neg_count : na), 4)
    // Calculate standard deviations
    stddev_all      = math.round((math.sqrt((returns_squared_sum - (returns_sum * returns_sum) / Lookback) / Lookback)) * 100, 2)
    stddev_pos      = math.round((pos_count != 0 ? math.sqrt((pos_returns_squared_sum - (pos_sum * pos_sum) / pos_count) / pos_count) : na) * 100, 2)
    stddev_neg      = math.round((neg_count != 0 ? math.sqrt((neg_returns_squared_sum - (neg_sum * neg_sum) / neg_count) / neg_count) : na) * 100, 2)
    // Calculate probabilities
    prob_pos        = math.round((pos_count / Lookback) * 100, 2)
    prob_neg        = math.round((neg_count / Lookback) * 100, 2)
    prob_neu        = math.round(((Lookback - pos_count - neg_count) / Lookback) * 100, 2)
    // Calculate ratios
    sharpe_ratio    = math.round((mean_all / stddev_all * (Annualize ? math.sqrt(Lookback) : 1))* 100, 2)
    sortino_ratio   = math.round((mean_all / stddev_neg * (Annualize ? math.sqrt(Lookback) : 1))* 100, 2)
    omega_ratio = math.round(pos_sum / math.abs(neg_sum), 2)
    // Set values in the array
    array.set(export_array, 0, mean_all),       array.set(export_array, 1, mean_pos),           array.set(export_array, 2, mean_neg),
    array.set(export_array, 3, stddev_all),     array.set(export_array, 4, stddev_pos),         array.set(export_array, 5, stddev_neg),
    array.set(export_array, 6, prob_pos),       array.set(export_array, 7, prob_neu),           array.set(export_array, 8, prob_neg),
    array.set(export_array, 9, sharpe_ratio),   array.set(export_array, 10, sortino_ratio),     array.set(export_array, 11, omega_ratio)
    // Export the array
    export_array
//} 
  
 Calibration Mode 
A Calibration Mode is included for traders to focus on individual indicators, helping them fine-tune their settings without the influence of other components. In Calibration Mode, the user can visualize each indicator separately, making it easier to adjust parameters.
 Alerts 
The indicator includes alerts for long and short signals when the indicator changes direction, allowing traders to set automated notifications for key market events.
 // Alert Conditions
alertcondition(long_alert, "LONG (Z-Score Weighted Trend System)", "Z-Score Weighted Trend System flipped ⬆LONG⬆")
alertcondition(short_alert, "SHORT (Z-Score Weighted Trend System)", "Z-Score Weighted Trend System flipped ⬇Short⬇") 
 Important Note:  
 
 The default settings of this indicator are not optimized for any particular market condition. They are generic starting points for experimentation. Traders are encouraged to use the calibration tools and backtesting features to adjust the system to their specific trading needs. 
 The results generated from the backtest are purely historical and are not indicative of future results. Market conditions can change, and the performance of this system may differ under different circumstances. Traders and investors should exercise caution and conduct their own research before using this indicator for any trading decisions. 
Relative Strength Index Custom [BRTLab]RSI Custom — Strategy-Oriented RSI with Multi-Timeframe Precision 
The Relative Strength Index Custom is designed with a focus on developing robust trading strategies. This powerful indicator leverages the logic of calculating RSI on higher timeframes (HTFs) while allowing traders to execute trades on lower timeframes (LTFs). Its unique ability to extract accurate RSI data from higher timeframes without waiting for those candles to close provides a real-time advantage, eliminating the "look-ahead" bias that often
distorts backtest results.
  
 Key Features 
 
 Multi-Timeframe RSI for Strategy Development 
This indicator stands out by allowing you to calculate RSI on higher timeframes, even while operating on lower timeframe charts. This means you can, for example, calculate RSI on the 1-hour or daily chart and execute trades on a 1-minute chart without needing to wait for the higher timeframe candle to close. This feature is crucial for strategy-building as it eliminates backtesting issues where data from the future is inadvertently used, providing more reliable backtest results.
  
Example: On a 15-minute chart, you can use the 1-hour RSI to open positions based on higher timeframe momentum, but you get this signal in real-time, improving timing and accuracy.
 Accurate Data Extraction from Higher Timeframes 
The indicator's custom logic ensures that accurate RSI data is retrieved from higher timeframes, providing an edge by delivering timely information for lower timeframe decisions. This prevents delayed signals often encountered when waiting for higher timeframe candles to close, which is crucial for high-frequency and intraday traders looking for precise entries based on multi-timeframe data.
 Customizable RSI Settings for Strategy Tuning 
The script offers full customization of the RSI, including length and source price (close, open, high, or low), allowing traders to tailor the RSI to fit specific trading strategies. These settings are housed in the "RSI Settings" section, enabling precise adjustments that align with your overall strategy.
 No Future-Looking in Backtests 
Traditional backtests often suffer from "future-looking" bias, where calculations unintentionally use data from candles that haven’t yet closed. This indicator is specifically designed to prevent such issues by calculating RSI values in real-time. This is particularly important when creating and testing strategies, as it ensures that the conditions under which trades would have been made are accurately represented in historical tests.
 RSI-Based Moving Average for Additional Filtering 
The built-in moving average (MA) based on RSI values helps filter out noise, making it easier to identify genuine trend shifts. This is particularly useful in strategies where moving average crossovers act as additional confirmation for trade entries and exits.
 Overbought and Oversold Zone Detection 
Visual gradient fills on the RSI chart help traders identify overbought and oversold zones (above 70 and below 30, respectively). These zones are crucial for timing reversal trades or confirming momentum-based strategies.
 
 How This Indicator Enhances Your Strategy 
 
 Increased Accuracy for Intraday Strategies 
For traders who operate on lower timeframes, using higher timeframe RSI data gives a broader perspective of market momentum while still maintaining precision for short-term trade entries. The real-time data extraction means you don't need to wait for HTF candles to close, which can dramatically improve your entry timing.
 Strategic Edge in Backtesting 
One of the greatest challenges in backtesting strategies is avoiding future-looking bias. This indicator is built to overcome this by using real-time multi-timeframe data, ensuring the accuracy and reliability of historical strategy testing, which provides confidence in your strategies when applied to live markets.
 Advanced Filtering for Trend Strategies 
By combining the RSI values with a customizable moving average (MA) and visualizing key momentum zones with overbought/oversold fills, the indicator allows for more refined trade filters. This ensures that signals generated by your strategy are based on solid momentum data and not short-term price fluctuations.
Post-Open Long Strategy with ATR-based Stop Loss and Take ProfitThe "Post-Open Long Strategy with ATR-Based Stop Loss and Take Profit" is designed to identify buying opportunities after the German and US markets open. It combines various technical indicators to filter entry signals, focusing on breakout moments following price lateralization periods.
 Key Components and Their Interaction: 
 Bollinger Bands (BB): 
Description: Uses BB with a 14-period length and standard deviation multiplier of 1.5, creating narrower bands for lower timeframes.
Role in the Strategy: Identifies low volatility phases (lateralization). The lateralization condition is met when the price is near the simple moving average of the BB, suggesting an imminent increase in volatility.
 Exponential Moving Averages (EMA): 
10-period EMA: Quickly detects short-term trend direction.
200-period EMA: Filters long-term trends, ensuring entries occur in a bullish market.
Interaction: Positions are entered only if the price is above both EMAs, indicating a consolidated positive trend.
Relative Strength Index (RSI):
Description: 7-period RSI with a threshold above 30.
Role in the Strategy: Confirms the market is not oversold, supporting the validity of the buy signal.
 Average Directional Index (ADX): 
Description: 7-period ADX with 7-period smoothing and a threshold above 10.
Role in the Strategy: Assesses trend strength. An ADX above 10 indicates sufficient momentum to justify entry.
 Average True Range (ATR) for Dynamic Stop Loss and Take Profit: 
Description: 14-period ATR with multipliers of 2.0 for Stop Loss and 4.0 for Take Profit.
Role in the Strategy: Adjusts exit levels based on current volatility, enhancing risk management.
Resistance Identification and Breakout:
Description: Analyzes the highs of the last 20 candles to identify resistance levels with at least two touches.
Role in the Strategy: A breakout above this level signals a potential continuation of the bullish trend.
 Time Filters and Market Conditions: 
Trading Hours: Operates only during the opening of the German market (8:00 - 12:00) and US market (15:30 - 19:00).
Panic Candle: The current candle must close negative, leveraging potential emotional reactions in the market.
 Avoiding Entry During Pullbacks: 
Description: Checks that the two previous candles are not both bearish.
Role in the Strategy: Avoids entering during a potential pullback, improving trade success probability.
Post-Open Long Strategy with ATR-Based Stop Loss and Take Profit
The "Post-Open Long Strategy with ATR-Based Stop Loss and Take Profit" is designed to identify buying opportunities after the German and US markets open. It combines various technical indicators to filter entry signals, focusing on breakout moments following price lateralization periods.
Key Components and Their Interaction:
Bollinger Bands (BB):
Description: Uses BB with a 14-period length and standard deviation multiplier of 1.5, creating narrower bands for lower timeframes.
Role in the Strategy: Identifies low volatility phases (lateralization). The lateralization condition is met when the price is near the simple moving average of the BB, suggesting an imminent increase in volatility.
Exponential Moving Averages (EMA):
10-period EMA: Quickly detects short-term trend direction.
200-period EMA: Filters long-term trends, ensuring entries occur in a bullish market.
Interaction: Positions are entered only if the price is above both EMAs, indicating a consolidated positive trend.
Relative Strength Index (RSI):
Description: 7-period RSI with a threshold above 30.
Role in the Strategy: Confirms the market is not oversold, supporting the validity of the buy signal.
Average Directional Index (ADX):
Description: 7-period ADX with 7-period smoothing and a threshold above 10.
Role in the Strategy: Assesses trend strength. An ADX above 10 indicates sufficient momentum to justify entry.
Average True Range (ATR) for Dynamic Stop Loss and Take Profit:
Description: 14-period ATR with multipliers of 2.0 for Stop Loss and 4.0 for Take Profit.
Role in the Strategy: Adjusts exit levels based on current volatility, enhancing risk management.
Resistance Identification and Breakout:
Description: Analyzes the highs of the last 20 candles to identify resistance levels with at least two touches.
Role in the Strategy: A breakout above this level signals a potential continuation of the bullish trend.
 Time Filters and Market Conditions: 
Trading Hours: Operates only during the opening of the German market (8:00 - 12:00) and US market (15:30 - 19:00).
Panic Candle: The current candle must close negative, leveraging potential emotional reactions in the market.
Avoiding Entry During Pullbacks:
Description: Checks that the two previous candles are not both bearish.
Role in the Strategy: Avoids entering during a potential pullback, improving trade success probability.
Entry and Exit Conditions:
 Long Entry: 
The price breaks above the identified resistance.
The market is in a lateralization phase with low volatility.
The price is above the 10 and 200-period EMAs.
RSI is above 30, and ADX is above 10.
No short-term downtrend is detected.
The last two candles are not both bearish.
The current candle is a "panic candle" (negative close).
Order Execution: The order is executed at the close of the candle that meets all conditions.
Exit from Position:
Dynamic Stop Loss: Set at 2 times the ATR below the entry price.
Dynamic Take Profit: Set at 4 times the ATR above the entry price.
The position is automatically closed upon reaching the Stop Loss or Take Profit.
How to Use the Strategy:
Application on Volatile Instruments:
Ideal for financial instruments that show significant volatility during the target market opening hours, such as indices or major forex pairs.
Recommended Timeframes:
Intraday timeframes, such as 5 or 15 minutes, to capture significant post-open moves.
Parameter Customization:
The default parameters are optimized but can be adjusted based on individual preferences and the instrument analyzed.
Backtesting and Optimization:
Backtesting is recommended to evaluate performance and make adjustments if necessary.
Risk Management:
Ensure position sizing respects risk management rules, avoiding risking more than 1-2% of capital per trade.
Originality and Benefits of the Strategy:
Unique Combination of Indicators: Integrates various technical metrics to filter signals, reducing false positives.
Volatility Adaptability: The use of ATR for Stop Loss and Take Profit allows the strategy to adapt to real-time market conditions.
Focus on Post-Lateralization Breakout: Aims to capitalize on significant moves following consolidation periods, often associated with strong directional trends.
Important Notes:
Commissions and Slippage: Include commissions and slippage in settings for more realistic simulations.
Capital Size: Use a realistic trading capital for the average user.
Number of Trades: Ensure backtesting covers a sufficient number of trades to validate the strategy (ideally more than 100 trades).
Warning: Past results do not guarantee future performance. The strategy should be used as part of a comprehensive trading approach.
With this strategy, traders can identify and exploit specific market opportunities supported by a robust set of technical indicators and filters, potentially enhancing their trading decisions during key times of the day.
ICT Power Of Three | Flux Charts💎 GENERAL OVERVIEW 
Introducing our new ICT Power Of Three Indicator! This indicator is built around the ICT's "Power Of Three" strategy. This strategy makes use of these 3 key smart money concepts : Accumulation, Manipulation and Distribution. Each step is explained in detail within this write-up. For more information about the process, check the "HOW DOES IT WORK" section.
  
Features of the new ICT Power Of Three Indicator :
 
  Implementation of ICT's Power Of Three Strategy
  Different Algorithm Modes
  Customizable Execution Settings
  Customizable Backtesting Dashboard
  Alerts for Buy, Sell, TP & SL Signals
 
 📌 HOW DOES IT WORK ? 
The "Power Of Three" comes from these three keywords "Accumulation, Manipulation and Distribution". Here is a brief explanation of each keyword :
Accumulation -> Accumulation phase is when the smart money accumulate their positions in a fixed range. This phase indicates price stability, generally meaning that the price constantly switches between up & down trend between a low and a high pivot point. When the indicator detects an accumulation zone, the Power Of Three strategy begins.
Manipulation -> When the smart money needs to increase their position sizes, they need retail traders' positions for liquidity. So, they manipulate the market into the opposite direction of their intended direction. This will result in retail traders opening positions the way that the smart money intended them to do, creating liquidity. After this step, the real move that the smart money intended begins.
Distribution -> This is when the real intention of the smart money comes into action. With the new liquidity thanks to the manipulation phase, the smart money add their positions towards the opposite direction of the retail mindset. The purpose of this indicator is to detect the accumulation and manipulation phases, and help the trader move towards the same direction as the smart money for their trades.
  
Detection Methods Of The Indicator :
Accumulation -> The indicator detects accumulation zones as explained step-by-step :
1. Draw two lines from the lowest point and the highest point of the latest X bars.
2. If the (high line - low line) is lower than Average True Range (ATR) * accumulationConstant
3. After the condition is validated, an accumulation zone is detected. The accumulation zone will be invalidated and manipulation phase will begin when the range is broken.
Manipulation -> If the accumulation range is broken, check if the current bar closes / wicks above the (high line + ATR * manipulationConstant) or below the (low line - ATR * manipulationConstant). If the condition is met, the indicator detects a manipulation zone.
Distribution -> The purpose of this indicator is to try to foresee the distribution zone, so instead of a detection, after the manipulation zone is detected the indicator automatically create a "shadow" distribution zone towards the opposite direction of the freshly detected manipulation zone. This shadow distribution zone comes with a take-profit and stop-loss layout, customizable by the trader in the settings.
The X bars, accumulationConstant and manipulationConstant are subject to change with the "Algorithm Mode" setting. Read the "Settings" section for more information.
This indicator follows these steps and inform you step by step by plotting them in your chart.
  
 🚩UNIQUENESS 
This indicator is an all-in-one suite for the ICT's Power Of Three concept. It's capable of plotting the strategy, giving signals, a backtesting dashboard and alerts feature. Different and customizable algorithm modes will help the trader fine-tune the indicator for the asset they are currently trading. The backtesting dashboard allows you to see how your settings perform in the current ticker. You can also set up alerts to get informed when the strategy is executable for different tickers.
  
 ⚙️SETTINGS 
1. General Configuration
Algorithm Mode -> The indicator offers 3 different detection algorithm modes according to your needs. Here is the explanation of each mode.
a) Small Manipulation
This mode has the default bar length for the accumulation detection, but a lower manipulation constant, meaning that slighter imbalances in the price action can be detected as manipulation. This setting can be useful on tickers that have lower liquidity, thus can be manipulated easier.
b) Big Manipulation
This mode has the default bar length for the accumulation detection, but a higher manipulation constant, meaning that heavier imbalances on the price action are required in order to detect manipulation zones. This setting can be useful on tickers that have higher liquidity, thus can be manipulated harder.
c) Short Accumulation
This mode has a ~70% lower bar length requirement for accumulation zone detection, and the default manipulation constant. This setting can be useful on tickers that are highly volatile and do not enter accumulation phases too often.
Breakout Method -> If "Close" is selected, bar close price will be taken into calculation when Accumulation & Manipulation zone invalidation. If "Wick" is selected, a wick will be enough to validate the corresponding zone.
2. TP / SL
TP / SL Method -> If "Fixed" is selected, you can adjust the TP / SL ratios from the settings below. If "Dynamic" is selected, the TP / SL zones will be auto-determined by the algorithm.
Risk -> The risk you're willing to take if "Dynamic" TP / SL Method is selected. Higher risk usually means a better winrate at the cost of losing more if the strategy fails. This setting is has a crucial effect on the performance of the indicator, as different tickers may have different volatility so the indicator may have increased performance when this setting is correctly adjusted.
3. Visuals
Show Zones -> Enables / Disables rendering of Accumulation (yellow) and Manipulation (red) zones. 
Chande Kroll Trend Strategy (SPX, 1H) | PINEINDICATORSThe "Chande Kroll Stop Strategy" is designed to optimize trading on the SPX using a 1-hour timeframe. This strategy effectively combines the Chande Kroll Stop indicator with a Simple Moving Average (SMA) to create a robust method for identifying long entry and exit points. This detailed description will explain the components, rationale, and usage to ensure compliance with TradingView's guidelines and help traders understand the strategy's utility and application.
Objective
The primary goal of this strategy is to identify potential long trading opportunities in the SPX by leveraging volatility-adjusted stop levels and trend-following principles. It aims to capture upward price movements while managing risk through dynamically calculated stops.
Chande Kroll Stop Parameters:
Calculation Mode: Offers "Linear" and "Exponential" options for position size calculation. The default mode is "Exponential."
Risk Multiplier: An adjustable multiplier for risk management and position sizing, defaulting to 5.
ATR Period: Defines the period for calculating the Average True Range (ATR), with a default of 10.
ATR Multiplier: A multiplier applied to the ATR to set stop levels, defaulting to 3.
Stop Length: Period used to determine the highest high and lowest low for stop calculation, defaulting to 21.
SMA Length: Period for the Simple Moving Average, defaulting to 21.
Calculation Details:
ATR Calculation: ATR is calculated over the specified period to measure market volatility.
Chande Kroll Stop Calculation:
High Stop: The highest high over the stop length minus the ATR multiplied by the ATR multiplier.
Low Stop: The lowest low over the stop length plus the ATR multiplied by the ATR multiplier.
SMA Calculation: The 21-period SMA of the closing price is used as a trend filter.
Entry and Exit Conditions:
Long Entry: A long position is initiated when the closing price crosses over the low stop and is above the 21-period SMA. This condition ensures that the market is trending upward and that the entry is made in the direction of the prevailing trend.
Exit Long: The long position is exited when the closing price falls below the high stop, indicating potential downward movement and protecting against significant drawdowns.
Position Sizing:
The quantity of shares to trade is calculated based on the selected calculation mode (linear or exponential) and the risk multiplier. This ensures position size is adjusted dynamically based on current market conditions and user-defined risk tolerance.
Exponential Mode: Quantity is calculated using the formula: riskMultiplier / lowestClose * 1000 * strategy.equity / strategy.initial_capital.
Linear Mode: Quantity is calculated using the formula: riskMultiplier / lowestClose * 1000.
Execution:
When the long entry condition is met, the strategy triggers a buy signal, and a long position is entered with the calculated quantity. An alert is generated to notify the trader.
When the exit condition is met, the strategy closes the position and triggers a sell signal, accompanied by an alert.
Plotting:
Buy Signals: Indicated with an upward triangle below the bar.
Sell Signals: Indicated with a downward triangle above the bar.
Application
This strategy is particularly effective for trading the SPX on a 1-hour timeframe, capitalizing on price movements by adjusting stop levels dynamically based on market volatility and trend direction.
Default Setup
Initial Capital: $1,000
Risk Multiplier: 5
ATR Period: 10
ATR Multiplier: 3
Stop Length: 21
SMA Length: 21
Commission: 0.01
Slippage: 3 Ticks
Backtesting Results
Backtesting indicates that the "Chande Kroll Stop Strategy" performs optimally on the SPX when applied to the 1-hour timeframe. The strategy's dynamic adjustment of stop levels helps manage risk effectively while capturing significant upward price movements. Backtesting was conducted with a realistic initial capital of $1,000, and commissions and slippage were included to ensure the results are not misleading.
Risk Management
The strategy incorporates risk management through dynamically calculated stop levels based on the ATR and a user-defined risk multiplier. This approach ensures that position sizes are adjusted according to market volatility, helping to mitigate potential losses. Trades are sized to risk a sustainable amount of equity, adhering to the guideline of risking no more than 5-10% per trade.
Usage Notes
Customization: Users can adjust the ATR period, ATR multiplier, stop length, and SMA length to better suit their trading style and risk tolerance.
Alerts: The strategy includes alerts for buy and sell signals to keep traders informed of potential entry and exit points.
Pyramiding: Although possible, the strategy yields the best results without pyramiding.
Justification of Components
The Chande Kroll Stop indicator and the 21-period SMA are combined to provide a robust framework for identifying long trading opportunities in trending markets. Here is why they work well together:
Chande Kroll Stop Indicator: This indicator provides dynamic stop levels that adapt to market volatility, allowing traders to set logical stop-loss levels that account for current price movements. It is particularly useful in volatile markets where fixed stops can be easily hit by random price fluctuations. By using the ATR, the stop levels adjust based on recent market activity, ensuring they remain relevant in varying market conditions.
21-Period SMA: The 21-period SMA acts as a trend filter to ensure trades are taken in the direction of the prevailing market trend. By requiring the closing price to be above the SMA for long entries, the strategy aligns itself with the broader market trend, reducing the risk of entering trades against the overall market direction. This helps to avoid false signals and ensures that the trades are in line with the dominant market movement.
Combining these two components creates a balanced approach that captures trending price movements while protecting against significant drawdowns through adaptive stop levels. The Chande Kroll Stop ensures that the stops are placed at levels that reflect current volatility, while the SMA filter ensures that trades are only taken when the market is trending in the desired direction.
Concepts Underlying Calculations
ATR (Average True Range): Used to measure market volatility, which informs the stop levels.
SMA (Simple Moving Average): Used to filter trades, ensuring positions are taken in the direction of the trend.
Chande Kroll Stop: Combines high and low price levels with ATR to create dynamic stop levels that adapt to market conditions.
Risk Disclaimer
Trading involves substantial risk, and most day traders incur losses. The "Chande Kroll Stop Strategy" is provided for informational and educational purposes only. Past performance is not indicative of future results. Users are advised to adjust and personalize this trading strategy to better match their individual trading preferences and risk tolerance.
Bitcoin Momentum StrategyThis is a very simple long-only strategy I've used since December 2022 to manage my Bitcoin position. 
I'm sharing it as an open-source script for other traders to learn from the code and adapt it to their liking if they find the system concept interesting.
 General Overview 
Always do your own research and backtesting - this script is not intended to be traded blindly (no script should be) and I've done limited testing on other markets beyond Ethereum and BTC, it's just a template to tweak and play with and make into one's own.
The results shown in the strategy tester are from Bitcoin's inception so as to get a large sample size of trades, and potential returns have diminished significantly as BTC has grown to become a mega cap asset, but the script includes a date filter for backtesting and it has still performed solidly in recent years (speaking from personal experience using it myself - DYOR with the date filter).
The main advantage of this system in my opinion is in limiting the max drawdown significantly versus buy & hodl. Theoretically much better returns can be made by just holding, but that's also a good way to lose 70%+ of your capital in the inevitable bear markets (also speaking from experience).
In saying all of that, the future is fundamentally unknowable and past results in no way guarantee future performance.
 System Concept: 
Capture as much Bitcoin upside volatility as possible while side-stepping downside volatility as quickly as possible.
The system uses a simple but clever momentum-style trailing stop technique I learned from one of my trading mentors who uses this approach on momentum/trend-following stock market systems.
Basically, the system "ratchets" up the stop-loss to be much tighter during high bearish volatility to protect open profits from downside moves, but loosens the stop loss during sustained bullish momentum to let the position ride.
It is invested most of the time, unless BTC is trading below its 20-week EMA in which case it stays in cash/USDT to avoid holding through bear markets. It only trades one position (no pyramiding) and does not trade short, but can easily be tweaked to do whatever you like if you know what you're doing in Pine. 
 Default parameters: 
HTF: Weekly Chart
EMA: 20-Period
ATR: 5-period
Bar Lookback: 7
 Entry Rule #1: 
Bitcoin's current price must be trading above its higher-timeframe EMA (Weekly 20 EMA).
 Entry Rule #2: 
Bitcoin must not be in 'caution' condition (no large bearish volatility swings recently). 
Enter at next bar's open if conditions are met and we are not already involved in a trade.
 "Caution" Condition: 
Defined as true if BTC's recent 7-bar swing high minus current bar's low is > 1.5x ATR, or Daily close < Daily 20-EMA.
 Trailing Stop: 
Stop is trailed 1 ATR from recent swing high, or 20% of ATR if in caution condition (ie. 0.2 ATR).
Exit on next bar open upon a close below stop loss. 
I typically use a limit order to open & exit trades as close to the open price as possible to reduce slippage, but the strategy script uses market orders. 
I've never had any issues getting filled on limit orders close to the market price with BTC on the Daily timeframe, but if the exchange has relatively low slippage I've found market orders work fine too without much impact on the results particularly since BTC has consistently remained above $20k and highly liquid.
 Cost of Trading: 
The script uses no leverage and a default total round-trip commission of 0.3% which is what I pay on my exchange based on their tier structure, but this can vary widely from exchange to exchange and higher commission fees will have a significantly negative impact on realized gains so make sure to always input the correct theoretical commission cost when backtesting any script. 
Static slippage is difficult to estimate in the strategy tester given the wide range of prices & liquidity BTC has experienced over the years and it largely depends on position size, I set it to 150 points per buy or sell as BTC is currently very liquid on the exchange I trade and I use limit orders where possible to enter/exit positions as close as possible to the market's open price as it significantly limits my slippage. 
But again, this can vary a lot from exchange to exchange (for better or worse) and if BTC volatility is high at the time of execution this can have a negative impact on slippage and therefore real performance, so make sure to adjust it according to your exchange's tendencies. 
Tax considerations should also be made based on short-term trade frequency if crypto profits are treated as a CGT event in your region.
 Summary: 
A simple, but effective and fairly robust system that achieves the goals I set for it. 
From my preliminary testing it appears it may also work on altcoins but it might need a bit of tweaking/loosening with the trailing stop distance as the default parameters are designed to work with Bitcoin which obviously behaves very differently to smaller cap assets.
Good luck out there!
Advanced VWAP_Pullback Strategy_Trend-Template QualifierGeneral Description and Unique Features of this Script 
 Introducing the Advanced VWAP Momentum-Pullback Strategy (long-only) that offers several unique features: 
1.	Our script/strategy utilizes Mark Minervini's Trend-Template as a qualifier for identifying stocks and other financial securities in confirmed uptrends. Mark Minervini, a 2x US Investment Champion, developed the Trend-Template, which covers eight different and independent characteristics that can be adjusted and optimized in this trend-following strategy to ensure the best results. The strategy will only trigger buy-signals in case the optimized qualifiers are being met.
2.	Our strategy is based on the supply/demand balance in the market, making it timeless and effective across all timeframes. Whether you are day trading using 1- or 5-min charts or swing-trading using daily charts, this strategy can be applied and works very well.
3.	We have also integrated technical indicators such as the RSI and the MA / VWAP crossover into this strategy to identify low-risk pullback entries in the context of confirmed uptrends. By doing so, the risk profile of this strategy and drawdowns are being reduced to an absolute minimum.
 Minervini’s Trend-Template and the ‘Stage-Analysis’ of the Markets 
This strategy is a so-called 'long-only' strategy. This means that we only take long positions, short positions are not considered. 
The best market environment for such strategies are periods of stable upward trends in the so-called stage 2 - uptrend. 
In stable upward trends, we increase our market exposure and risk. 
In sideways markets and downward trends or bear markets, we reduce our exposure very quickly or go 100% to cash and wait for the markets to recover and improve. This allows us to avoid major losses and drawdowns. 
 This simple rule gives us a significant advantage over most undisciplined traders and amateurs! 
 
'The Trend is your Friend'. This is a very old but true quote.
What's behind it???
• 98% of stocks made their biggest gains in a Phase 2 upward trend.
• If a stock is in a stable uptrend, this is evidence that larger institutions are buying the stock sustainably.
• By focusing on stocks that are in a stable uptrend, the chances of profit are significantly increased.
• In a stable uptrend, investors know exactly what to expect from further price developments. This makes it possible to locate low-risk entry points. 
The goal is not to buy at the lowest price – the goal is to buy at the right price!
Each stock goes through the same maturity cycle – it starts at stage 1 and ends at stage 4
   
 
Stage 1 – Neglect Phase – Consolidation
Stage 2 – Progressive Phase – Accumulation
Stage 3 – Topping Phase – Distribution
Stage 4 – Downtrend – Capitulation
This strategy focuses on identifying stocks in confirmed stage 2 uptrends. This in itself gives us an advantage over long-term investors and less professional traders.
By focusing on stocks in a stage 2 uptrend, we avoid losses in downtrends (stage 4) or less profitable consolidation phases (stages 1 and 3). We are fully invested and put our money to work for us, and we are fully invested when stocks are in their stage 2 uptrends.
But how can we use technical chart analysis to find stocks that are in a stable stage 2 uptrend?
Mark Minervini has developed the so-called 'trend template' for this purpose. This is an essential part of our JS-TechTrading pullback strategy. For our watchlists, only those individual values that meet the tough requirements of Minervini's trend template are eligible.
 The Trend Template 
•	200d MA increasing over a period of at least 1 month, better 4-5 months or longer
•	150d MA above 200d MA
•	50d MA above 150d MA and 200d MA
•	Course above 50d MA, 150d MA and 200d MA
•	Ideally, the 50d MA is increasing over at least 1 month
•	Price at least 25% above the 52w low
•	Price within 25% of 52w high
•	High relative strength according to IBD. 
NOTE: In this basic version of the script, the Trend-Template has to be used as a separate indicator on TradingView (Public Trend-Template indicators are available in TradingView – community scripts). It is recommended to only execute buy signals in case the stock or financial security is in a stage 2 uptrend, which means that the criteria of the trend-template are fulfilled.
This strategy can be applied to all timeframes from 5 min to daily.
 The VWAP Momentum-Pullback Strategy 
For the JS-TechTrading VWAP Momentum-Pullback Strategy, only stocks and other financial instruments that meet the selected criteria of Mark Minervini's trend template are recommended for algorithmic trading with this startegy.
A further prerequisite for generating a buy signals is that the individual value is in a short-term oversold state (RSI). 
When the selling pressure is over and the continuation of the uptrend can be confirmed by the MA / VWAP crossover after reaching a price low, a buy signal is issued by this strategy.
Stop-loss limits and profit targets can be set variably. You also have the option to make use of the trailing stop exit strategy.
  
 Relative Strength Index (RSI) 
The Relative Strength Index (RSI) is a technical indicator developed by Welles Wilder in 1978. The RSI is used to perform a market value analysis and identify the strength of a trend as well as overbought and oversold conditions. The indicator is calculated on a scale from 0 to 100 and shows how much an asset has risen or fallen relative to its own price in recent periods.
The RSI is calculated as the ratio of average profits to average losses over a certain period of time. A high value of the RSI indicates an overbought situation, while a low value indicates an oversold situation. Typically, a value > 70 is considered an overbought threshold and a value < 30 is considered an oversold threshold. A value above 70 signals that a single value may be overvalued and a decrease in price is likely , while a value below 30 signals that a single value may be undervalued and an increase in price is likely.
For example, let's say you're watching a stock XYZ. After a prolonged falling movement, the RSI value of this stock has fallen to 26. This means that the stock is oversold and that it is time for a potential recovery. Therefore, a trader might decide to buy this stock in the hope that it will rise again soon.
The MA / VWAP Crossover Trading Strategy
This strategy combines two popular technical indicators: the Moving Average (MA) and the Volume Weighted Average Price (VWAP). The MA VWAP crossover strategy is used to identify potential trend reversals and entry/exit points in the market.
The VWAP is calculated by taking the average price of an asset for a given period, weighted by the volume traded at each price level. The MA, on the other hand, is calculated by taking the average price of an asset over a specified number of periods. When the MA crosses above the VWAP, it suggests that buying pressure is increasing, and it may be a good time to enter a long position. When the MA crosses below the VWAP, it suggests that selling pressure is increasing, and it may be a good time to exit a long position or enter a short position.
Traders typically use the MA VWAP crossover strategy in conjunction with other technical indicators and fundamental analysis to make more informed trading decisions. As with any trading strategy, it is important to carefully consider the risks and potential rewards before making any trades.
This strategy is applicable to all timeframes and the relevant parameters for the underlying indicators (RSI and MA/VWAP) can be adjusted and optimized as needed. 
   
 Backtesting 
Backtesting gives outstanding results on all timeframes and drawdowns can be reduced to a minimum level. In this example, the hourly chart for MCFT has been used.
Settings for backtesting are:
-	Period from Jan 2020 until March 2023
-	Starting capital 100k USD
-	Position size = 25% of equity
-	0.01% commission = USD 2.50.- per Trade
-	Slippage = 2 ticks
 Other comments 
- This strategy has been designed to identify the most promising, highest probability entries and trades for each stock or other financial security.
- The combination of the Trend-Template and the RSI qualifiers results in a highly selective strategy which only considers the most promising swing-trading entries. As a result, you will normally only find a low number of trades for each stock or other financial security per year in case you apply this strategy for the daily charts. Shorter timeframes will result in a higher number of trades / year.
- Consequently, traders need to apply this strategy for a full watchlist rather than just one financial security.
JS-TechTrading: VWAP Momentum_Pullback StrategyGeneral Description and Unique Features of this Script
Introducing the VWAP Momentum-Pullback Strategy (long-only) that offers several unique features: 
1.	Our script/strategy utilizes Mark Minervini's Trend-Template as a qualifier for identifying stocks and other financial securities in confirmed uptrends.
NOTE: In this basic version of the script, the Trend-Template has to be used as a separate indicator on TradingView (Public Trend-Template indicators are available on TradingView – community scripts). It is recommended to only execute buy signals in case the stock or financial security is in a stage 2 uptrend, which means that the criteria of the trend-template are fulfilled.
2.	Our strategy is based on the supply/demand balance in the market, making it timeless and effective across all timeframes. Whether you are day trading using 1- or 5-min charts or swing-trading using daily charts, this strategy can be applied and works very well.
3.	We have also integrated technical indicators such as the RSI and the MA / VWAP crossover into this strategy to identify low-risk pullback entries in the context of confirmed uptrends. By doing so, the risk profile of this strategy and drawdowns are being reduced to an absolute minimum.
 Minervini’s Trend-Template and the ‘Stage-Analysis’ of the Markets 
This strategy is a so-called 'long-only' strategy. This means that we only take long positions, short positions are not considered. 
The best market environment for such strategies are periods of stable upward trends in the so-called stage 2 - uptrend. 
In stable upward trends, we increase our market exposure and risk. 
In sideways markets and downward trends or bear markets, we reduce our exposure very quickly or go 100% to cash and wait for the markets to recover and improve. This allows us to avoid major losses and drawdowns. 
 This simple rule gives us a significant advantage over most undisciplined traders and amateurs!
 
'The Trend is your Friend'. This is a very old but true quote.
What's behind it??? 
• 98% of stocks made their biggest gains in a Phase 2 upward trend.
• If a stock is in a stable uptrend, this is evidence that larger institutions are buying the stock sustainably.
• By focusing on stocks that are in a stable uptrend, the chances of profit are significantly increased.
• In a stable uptrend, investors know exactly what to expect from further price developments. This makes it possible to locate low-risk entry points. 
The goal is not to buy at the lowest price – the goal is to buy at the right price!
Each stock goes through the same maturity cycle – it starts at stage 1 and ends at stage 4
   
 
Stage 1 – Neglect Phase – Consolidation
Stage 2 – Progressive Phase – Accumulation
Stage 3 – Topping Phase – Distribution
Stage 4 – Downtrend – Capitulation
This strategy focuses on identifying stocks in confirmed stage 2 uptrends. This in itself gives us an advantage over long-term investors and less professional traders.
By focusing on stocks in a stage 2 uptrend, we avoid losses in downtrends (stage 4) or less profitable consolidation phases (stages 1 and 3). We are fully invested and put our money to work for us, and we are fully invested when stocks are in their stage 2 uptrends.
But how can we use technical chart analysis to find stocks that are in a stable stage 2 uptrend?
Mark Minervini has developed the so-called 'trend template' for this purpose. This is an essential part of our JS-TechTrading pullback strategy. For our watchlists, only those individual values that meet the tough requirements of Minervini's trend template are eligible.
 The Trend Template 
•	200d MA increasing over a period of at least 1 month, better 4-5 months or longer
•	150d MA above 200d MA
•	50d MA above 150d MA and 200d MA
•	Course above 50d MA, 150d MA and 200d MA
•	Ideally, the 50d MA is increasing over at least 1 month
•	Price at least 25% above the 52w low
•	Price within 25% of 52w high
•	High relative strength according to IBD. 
NOTE: In this basic version of the script, the Trend-Template has to be used as a separate indicator on TradingView (Public Trend-Template indicators are available in TradingView – community scripts). It is recommended to only execute buy signals in case the stock or financial security is in a stage 2 uptrend, which means that the criteria of the trend-template are fulfilled.
This strategy can be applied to all timeframes from 5 min to daily.
 The VWAP Momentum-Pullback Strateg y
For the JS-TechTrading VWAP Momentum-Pullback Strategy, only stocks and other financial instruments that meet the selected criteria of Mark Minervini's trend template are recommended for algorithmic trading with this startegy.
A further prerequisite for generating a buy signals is that the individual value is in a short-term oversold state (RSI). 
When the selling pressure is over and the continuation of the uptrend can be confirmed by the MA / VWAP crossover after reaching a price low, a buy signal is issued by this strategy.
Stop-loss limits and profit targets can be set variably.
   
 Relative Strength Index (RSI) 
The Relative Strength Index (RSI) is a technical indicator developed by Welles Wilder in 1978. The RSI is used to perform a market value analysis and identify the strength of a trend as well as overbought and oversold conditions. The indicator is calculated on a scale from 0 to 100 and shows how much an asset has risen or fallen relative to its own price in recent periods.
The RSI is calculated as the ratio of average profits to average losses over a certain period of time. A high value of the RSI indicates an overbought situation, while a low value indicates an oversold situation. Typically, a value > 70 is considered an overbought threshold and a value < 30 is considered an oversold threshold. A value above 70 signals that a single value may be overvalued and a decrease in price is likely , while a value below 30 signals that a single value may be undervalued and an increase in price is likely.
For example, let's say you're watching a stock XYZ. After a prolonged falling movement, the RSI value of this stock has fallen to 26. This means that the stock is oversold and that it is time for a potential recovery. Therefore, a trader might decide to buy this stock in the hope that it will rise again soon.
 The MA / VWAP Crossover Trading Strategy 
This strategy combines two popular technical indicators: the Moving Average (MA) and the Volume Weighted Average Price (VWAP). The MA VWAP crossover strategy is used to identify potential trend reversals and entry/exit points in the market.
The VWAP is calculated by taking the average price of an asset for a given period, weighted by the volume traded at each price level. The MA, on the other hand, is calculated by taking the average price of an asset over a specified number of periods. When the MA crosses above the VWAP, it suggests that buying pressure is increasing, and it may be a good time to enter a long position. When the MA crosses below the VWAP, it suggests that selling pressure is increasing, and it may be a good time to exit a long position or enter a short position.
Traders typically use the MA VWAP crossover strategy in conjunction with other technical indicators and fundamental analysis to make more informed trading decisions. As with any trading strategy, it is important to carefully consider the risks and potential rewards before making any trades.
This strategy is applicable to all timeframes and the relevant parameters for the underlying indicators (RSI and MA/VWAP) can be adjusted and optimized as needed. 
 
 Backtesting 
Backtesting gives outstanding results on all timeframes and drawdowns can be reduced to a minimum level. In this example, the hourly chart for MCFT has been used.
Settings for backtesting are:
-	Period from April 2020 until April 2021 (1 yr)
-	Starting capital 100k USD
-	Position size = 25% of equity
-	0.01% commission = USD 2.50.- per Trade
-	Slippage = 2 ticks
 Other comments 
•	This strategy has been designed to identify the most promising, highest probability entries and trades for each stock or other financial security.
•	The RSI qualifier is highly selective and filters out the most promising swing-trading entries. As a result, you will normally only find a low number of trades for each stock or other financial security per year in case you apply this strategy for the daily charts. Shorter timeframes will result in a higher number of trades / year.
•	As a result, traders need to apply this strategy for a full watchlist rather than just one financial security.
Tailored-Custom Hamonic Patterns█ OVERVIEW 
We have included by default 3 known Patterns. The Bat, the Butterfly and the Gartley. But have you ever wondered how effective other,
not yet known models could be? Don't ask yourself the question anymore, it's time to find out for yourself! You have the option to customize
your own Patterns with the Backtesting tool and set Retracement Ratios and Targets for your own Patterns. In addition to this, in order to determine
the Trend at a glance and make Pattern detection more efficient, we have linked the calculation of Patterns to Bands of several types to choose
 from  (Bollinger, Keltner, Donchian)  that you can select from a drop-down menu in the settings and play with the Multiplier
and the Adaptive Length of the Patterns to see how it affects the success rate in the Backtesting table.
█ HOW DOES IT WORK? 
- Harmonic Patterns 
-Pattern Names, Colors, Style etc… Everything is customizable.
-Dynamic Adaptative Length with Min/Max Length.
- XAB/ABC Ratio 
-Min/Max XAB/ABC Configurable Ratio for each Pattern to create your own Patterns.
 (This is really the particular option of this Indicator, because it allows you to be able to Backtest in real time
after having played at configuring your own Ratios) 
- Bands 
-Contrary to the original logic of the HeWhoMustNotBeNamed script, here when the price breaks out of the upper Bands
 (example, Bollinger band, Keltner Channel or Donchian Channel) , with a predetermined Minimum and Maximum Length and Multiplier, we can consider
the Trend to be Bearish  (and not Bullish)  and similarly when the price breaks down in the lower band, we can consider the Trend
to be Bullish  (not Bearish) . We have also added the middle line of the Channels (which can be useful for 'Scalper' type Traders.
-The Length of the Bands Filter is directly related to the Dynamic Length of the Patterns.
-You can use a drop-down menu to select from the following Bands Filters : 
 SMA, EMA, HMA, RMA, WMA, VWMA, HIGH/LOW, LINREG, MEDIAN. 
-Sticky and Adaptive Bands options has been included.
- Projections 
-BD/CD Projection Ratio configurable for each Pattern.
 (Projections are visible as Dotted Lines which we can choose to Extend or not) 
- Targets 
-Target, PRZ and Stop Levels are set to optimal values based on individual Patterns.  (The PRZ Level corresponds to point D
of the detected Pattern so its value should always be 0)  but you can change the Targets value  (defined in %)  as you wish.
Again here, you have the option to fully configure the Style and Extend the Lines or not.
- Backtesting Table 
-As said previously, with the possibility of testing the Success Rate of each of the 3 Customizable Patterns,
this option is part of the logic of this Indicator.
- Alerts 
-We originally believe that this Indicator does not even need Alerts. But we still decided to include at least one Alert
 that you can set for when a new Pattern is detected.
█ NOTES 
Thanks to HeWhoMustNotBeNamed for his permission to reuse some part of his zigzag scripts.
Remember to only make a decision once you are sure of your analysis. Good trading sessions to everyone and don't forget,
risk management remains the most important!
Machine Learning: Lorentzian Classification█ OVERVIEW
A Lorentzian Distance Classifier (LDC) is a Machine Learning classification algorithm capable of categorizing historical data from a multi-dimensional feature space. This indicator demonstrates how Lorentzian Classification can also be used to predict the direction of future price movements when used as the distance metric for a novel implementation of an Approximate Nearest Neighbors (ANN) algorithm.
█ BACKGROUND
In physics, Lorentzian space is perhaps best known for its role in describing the curvature of space-time in Einstein's theory of General Relativity (2). Interestingly, however, this abstract concept from theoretical physics also has tangible real-world applications in trading.
Recently, it was hypothesized that Lorentzian space was also well-suited for analyzing time-series data (4), (5). This hypothesis has been supported by several empirical studies that demonstrate that Lorentzian distance is more robust to outliers and noise than the more commonly used Euclidean distance (1), (3), (6). Furthermore, Lorentzian distance was also shown to outperform dozens of other highly regarded distance metrics, including Manhattan distance, Bhattacharyya similarity, and Cosine similarity (1), (3). Outside of Dynamic Time Warping based approaches, which are unfortunately too computationally intensive for PineScript at this time, the Lorentzian Distance metric consistently scores the highest mean accuracy over a wide variety of time series data sets (1).
Euclidean distance is commonly used as the default distance metric for NN-based search algorithms, but it may not always be the best choice when dealing with financial market data. This is because financial market data can be significantly impacted by proximity to major world events such as FOMC Meetings and Black Swan events. This event-based distortion of market data can be framed as similar to the gravitational warping caused by a massive object on the space-time continuum. For financial markets, the analogous continuum that experiences warping can be referred to as "price-time".
Below is a side-by-side comparison of how neighborhoods of similar historical points appear in three-dimensional Euclidean Space and Lorentzian Space: 
  
This figure demonstrates how Lorentzian space can better accommodate the warping of price-time since the Lorentzian distance function compresses the Euclidean neighborhood in such a way that the new neighborhood distribution in Lorentzian space tends to cluster around each of the major feature axes in addition to the origin itself. This means that, even though some nearest neighbors will be the same regardless of the distance metric used, Lorentzian space will also allow for the consideration of historical points that would otherwise never be considered with a Euclidean distance metric. 
Intuitively, the advantage inherent in the Lorentzian distance metric makes sense. For example, it is logical that the price action that occurs in the hours after Chairman Powell finishes delivering a speech would resemble at least some of the previous times when he finished delivering a speech. This may be true regardless of other factors, such as whether or not the market was overbought or oversold at the time or if the macro conditions were more bullish or bearish overall. These historical reference points are extremely valuable for predictive models, yet the Euclidean distance metric would miss these neighbors entirely, often in favor of irrelevant data points from the day before the event. By using Lorentzian distance as a metric, the ML model is instead able to consider the warping of price-time caused by the event and, ultimately, transcend the temporal bias imposed on it by the time series. 
For more information on the implementation details of the Approximate Nearest Neighbors (ANN) algorithm used in this indicator, please refer to the detailed comments in the source code. 
█ HOW TO USE 
Below is an explanatory breakdown of the different parts of this indicator as it appears in the interface:
  
Below is an explanation of the different settings for this indicator:
  
 General Settings: 
 
  Source - This has a default value of "hlc3" and is used to control the input data source.
  Neighbors Count - This has a default value of 8, a minimum value of 1, a maximum value of 100, and a step of 1. It is used to control the number of neighbors to consider.
  Max Bars Back - This has a default value of 2000.
  Feature Count - This has a default value of 5, a minimum value of 2, and a maximum value of 5. It controls the number of features to use for ML predictions.
  Color Compression - This has a default value of 1, a minimum value of 1, and a maximum value of 10. It is used to control the compression factor for adjusting the intensity of the color scale.
  Show Exits - This has a default value of false. It controls whether to show the exit threshold on the chart.
  Use Dynamic Exits - This has a default value of false. It is used to control whether to attempt to let profits ride by dynamically adjusting the exit threshold based on kernel regression.
 
 Feature Engineering Settings: 
Note: The Feature Engineering section is for fine-tuning the features used for ML predictions. The default values are optimized for the 4H to 12H timeframes for most charts, but they should also work reasonably well for other timeframes. By default, the model can support features that accept two parameters (Parameter A and Parameter B, respectively). Even though there are only 4 features provided by default, the same feature with different settings counts as two separate features. If the feature only accepts one parameter, then the second parameter will default to EMA-based smoothing with a default value of 1. These features represent the most effective combination I have encountered in my testing, but additional features may be added as additional options in the future. 
 
  Feature 1 - This has a default value of "RSI" and options are: "RSI", "WT", "CCI", "ADX". 
  Feature 2 - This has a default value of "WT" and options are: "RSI", "WT", "CCI", "ADX". 
  Feature 3 - This has a default value of "CCI" and options are: "RSI", "WT", "CCI", "ADX". 
  Feature 4 - This has a default value of "ADX" and options are: "RSI", "WT", "CCI", "ADX". 
  Feature 5 - This has a default value of "RSI" and options are: "RSI", "WT", "CCI", "ADX". 
 
 Filters Settings: 
 
  Use Volatility Filter - This has a default value of true. It is used to control whether to use the volatility filter.
  Use Regime Filter - This has a default value of true. It is used to control whether to use the trend detection filter.
  Use ADX Filter - This has a default value of false. It is used to control whether to use the ADX filter.
  Regime Threshold - This has a default value of -0.1, a minimum value of -10, a maximum value of 10, and a step of 0.1. It is used to control the Regime Detection filter for detecting Trending/Ranging markets.
  ADX Threshold - This has a default value of 20, a minimum value of 0, a maximum value of 100, and a step of 1. It is used to control the threshold for detecting Trending/Ranging markets.
 
 Kernel Regression Settings: 
 
  Trade with Kernel - This has a default value of true. It is used to control whether to trade with the kernel.
  Show Kernel Estimate - This has a default value of true. It is used to control whether to show the kernel estimate.
  Lookback Window - This has a default value of 8 and a minimum value of 3. It is used to control the number of bars used for the estimation. Recommended range: 3-50
  Relative Weighting - This has a default value of 8 and a step size of 0.25. It is used to control the relative weighting of time frames. Recommended range: 0.25-25
  Start Regression at Bar - This has a default value of 25. It is used to control the bar index on which to start regression. Recommended range: 0-25
 
 Display Settings: 
 
  Show Bar Colors - This has a default value of true. It is used to control whether to show the bar colors.
  Show Bar Prediction Values - This has a default value of true. It controls whether to show the ML model's evaluation of each bar as an integer.
  Use ATR Offset - This has a default value of false. It controls whether to use the ATR offset instead of the bar prediction offset.
  Bar Prediction Offset - This has a default value of 0 and a minimum value of 0. It is used to control the offset of the bar predictions as a percentage from the bar high or close.
 
 Backtesting Settings: 
 
  Show Backtest Results - This has a default value of true. It is used to control whether to display the win rate of the given configuration.
 
█ WORKS CITED
(1) R. Giusti and G. E. A. P. A. Batista, "An Empirical Comparison of Dissimilarity Measures for Time Series Classification," 2013 Brazilian Conference on Intelligent Systems, Oct. 2013, DOI: 10.1109/bracis.2013.22.
(2) Y. Kerimbekov, H. Ş. Bilge, and H. H. Uğurlu, "The use of Lorentzian distance metric in classification problems," Pattern Recognition Letters, vol. 84, 170–176, Dec. 2016, DOI: 10.1016/j.patrec.2016.09.006.
(3) A. Bagnall, A. Bostrom, J. Large, and J. Lines, "The Great Time Series Classification Bake Off: An Experimental Evaluation of Recently Proposed Algorithms." ResearchGate, Feb. 04, 2016.
(4) H. Ş. Bilge, Yerzhan Kerimbekov, and Hasan Hüseyin Uğurlu, "A new classification method by using Lorentzian distance metric," ResearchGate, Sep. 02, 2015.
(5) Y. Kerimbekov and H. Şakir Bilge, "Lorentzian Distance Classifier for Multiple Features," Proceedings of the 6th International Conference on Pattern Recognition Applications and Methods, 2017, DOI: 10.5220/0006197004930501.
(6) V. Surya Prasath et al., "Effects of Distance Measure Choice on KNN Classifier Performance - A Review."  .
█ ACKNOWLEDGEMENTS
@veryfid - For many invaluable insights, discussions, and advice that helped to shape this project.
@capissimo - For open sourcing his interesting ideas regarding various KNN implementations in PineScript, several of which helped inspire my original undertaking of this project.
@RikkiTavi - For many invaluable physics-related conversations and for his helping me develop a mechanism for visualizing various distance algorithms in 3D using JavaScript
@jlaurel - For invaluable literature recommendations that helped me to understand the underlying subject matter of this project.
@annutara - For help in beta-testing this indicator and for sharing many helpful ideas and insights early on in its development.
@jasontaylor7 - For helping to beta-test this indicator and for many helpful conversations that helped to shape my backtesting workflow
@meddymarkusvanhala - For helping to beta-test this indicator
@dlbnext - For incredibly detailed backtesting testing of this indicator and for sharing numerous ideas on how the user experience could be improved.
Weird Renko StratThis strategy uses Renko, it generates a signal when there is a reversal in Renko. When using historical data, it provides a good entry and an okay exit. However, in a real-time environment, this strategy is subject to repaint and may produce a false signal.
As a result, the backtesting result should not be used as a metric to predict future results. It is highly recommended to forward-test the strategy before using it in real trading. I forward test it from 12/18/2022 to 12/21/2022 in paper trading, using the alert feature in Tradingview. I made 60 trades trading the BTCUSDT BINANCE 3 min with 26 as the param and under the condition that I use 20x margin, compounding my yield, and having 0 trading fee, a steady loss is generated: from $10 to $3.02.
This is quite interesting. As if I flip the signal from "Long" to "Short" and another way too, it will be a steady profit from $10 to $21.85. Hence, if I'm trying to anti-trade the real-time alert signal, the current "4 Days Result" will be good. Nevertheless, I still have to forward-test it for longer to see if it will fail eventually.
Dive into the setting of the strategy
- Margin is the leverage you use. 1 means 1x, 10 means 10x. It affects the backtest yield when you backtest
- Compound Yield button is for compound calculation, disable it to go back to normal backtesting
- Anti Strategy button is to do the opposite direction trade, when the original strat told you to "Long", you "Short" instead. Enable it to use the feature
- Param is the block size for the Renko chart
- Drawdown is just a visual tool for you in case you want to place a stop loss (represent by the semitransparent red area in the chart)
- From date Thru Date is to specify the backtest range of the strategy, This feature is turned off by default. It is controlled by the Max Backtest Timeframe which will be explain below
- Max Backtest Timeframe control the From date Thru Date function, disable it to enable the From Date Thru Date function
Param is the most important input in this strategy as it directly affects performance. It is highly recommended to backtest nearly all the possible parameters before deploying it in real trading. Some factors should be considered:
- Price of the asset (like an asset of 1 USD vs an asset of 10000 USD required different param)
- Timeframe (1-minute param is different than 1-month param)
I believe this is caused by the volatility of the selected timeframe since different timeframe has different volatility. Param should be fine-tuned before usage.
Here is the param I'm using:
BTCUSDT BINANCE 3min: 26
BTCUSDT BINANCE 5min: 28
BTCUSDT BINANCE 1day: 15
Background of the strategy:
- The strategy starts with $10 at the start of backtesting (customizable in setting)
- The trading fee is set to 0.00% which is not common for most of the popular exchanges (customizable in setting)
- The contract size is not a fixed amount, but it uses your balance to buy it at the open price. If you are using the compound mode, your balance will be your current total balance. If you are using the non-compound mode, it will just use the $10 you start with unless you change the amount you start with. If you are using a margin higher than 1, it will calculate the corresponding contract size properly based on your margin. (Only these options are allowed, you are not able to change them without changing the code)
Grid Strategy Back Tester (Long/Short/Neutral)Preface   
I'd like to send a thank you to @xxattaxx-DisDev.
The 'Line' Code, which was the most difficult to plan the Grid Indicator, was solved through the  'Grid Bot Simulator' script of @xxattaxx-DisDev.
 A brief description of the indicators 
These indicators are designed for backtesting of grid trading that can be opened on various exchanges.
Grid trading is a method of selling at particular intervals as prices rise and fall for gird interval price range. 
This indicator is actually designed to see what the Long / Short / Neutral grid has achieved and how much it has achieved over a given period of time.
 How to use 
1. Lower Limit and Upper Limit are required when putting indicators on the chart.
After that, choose the 'Time' when to open the grid.
Also, select Long / Short / Neutral direction if necessary.
2. Statistics Table
  
 Matched Grid  shows how many grid pairs were engaged during the backtesting period.
 The Daily Average Matching Profit  is calculated based on the number of these closed grids.
 Total Matching Profit  is calculated as Matching Grid * Per Matching Profit.
 Position Profit/Loss  shows the benefits and losses from your current position.
 Total Profit/Loss  is sum of Total Matching Profit and Position Profit/Loss.
 The Expanded APY  shows the benefits of running the strategy on these terms for a year.
 Max Loss of Upper   is the maximum loss assumed to be directly at the top of the grid range.
 BEP days (Upper)  show how many days of maintenance relative to Average Matching Profit can result in greater profit than maximum loss if the grid continues to move within range.
(In the case of Long Strategy, it appears to be 'Min Profit', which shows minimal benefit if it reaches the top.)
 Max Loss of Lower  and  BEP days (Lower)  shows the opposite.
(In the case of Short Strategy, it is also referred to as 'Min Profit', which shows minimal benefit if it reaches the bottom.)
3. Grid Info
  
Total Grid Number, Upper Limit, and Lower Limit show the values you set in INPUT.
 Grid Open Price  shows the price for the period you decide to open.
 Starting Position  shows the number of positions that were initially held in the case of a Long / Short Strategy.
(0 for Neutral Strategy)
 Per Grid qty  shows how many positions are allocated to one grid
 Grid Interval  shows the spacing of each grid.
 Per Matched Profit  shows how much profit is generated when a single grid is matched.
 Caution 
Backtesting results for these indicators may vary depending on the time frame. 
Therefore, I recommend that you use it only to compare Profit/Loss over time.
*In addition, there is a problem that all lines in the grid are not implemented, but it is independent of the backtest results.
--------------------------------------
 서문 
지표를 기획함에 있어서 가장 어려웠던 line 코드를 @xxattaxx-DisDev의 'Grid Bot Simulator' 스크립트를 통해 해결할 수 있었습니다.
이에 감사의 말씀을 드립니다.
 해당 지표에 대한 간단한 설명 
해당 지표는 다양한 거래소에서 오픈할 수 있는 그리드 매매에 대한 백테스팅을 위해 만들어졌습니다.
그리드매매는, 특정 가격 구간에 대해 가격이 오르고 내림에 따라 일정 간격에 맞춰 매매를 하는 방식입니다. 
이 지표는 실질적으로 롱/숏/중립 그리드가 어떠한 성과를, 특정 기간동안 얼마나 냈는지를 확인하고자 만들어졌습니다.
 사용방법 
 1. 인풋 
지표를 차트위에 넣을 때, Lower Limit과 Upper Limit이 필요합니다.
그 후 그리드를 언제부터 오픈할 것인지를 선택하세요.
또, 필요하다면 Long / Short / Neutral의 방향을 선택하세요.
 2. 그리드 통계  
Matched Grid는, 백테스팅 기간동안 체결된 그리드 쌍이 몇개인지를 보여줍니다.
이 체결된 그리드의 갯수를 바탕으로 Daily Average Matched Profit이 계산됩니다.
Total Matched Profit은, Matched Grid * Per Matched Profit으로 계산됩니다.
Position Profit/Loss는, 현재 갖고 있는 포지션으로 인한 이익과 손실을 보여줍니다.
Total Matched Profit과 Position Profit/Loss를 합친 금액이 Total Profit/Loss가 됩니다.
Expcted APY는, 이러한 조건으로 전략을 1년동안 운영했을 때의 이익을 보여줍니다.
Max Loss of Upper는, 그리드 범위의 최상단에 바로 도달했을 경우를 가정한 최대 손실입니다.
BEP days(Upper)는, 그리드가 범위 내에서 계속 움직일 경우, Average Matched Profit을 기준으로 며칠동안 유지되어야 최대손실보다 더 큰 이익이 발생할 수 있는지를 보여줍니다.
(Long Strategy의 경우, ‘Min Profit’이라고 나타나는데, 최상단에 도달했을 경우 최소한의 이익을 보여줍니다)
Max Loss of Lower는 그 반대의 경우를 보여줍니다.
(Short Strategy의 경우,  역시 ‘Min Profit’이라고 나타나는데, 최하단에 도착했을 경우 최소한의 이익을 보여줍니다)
 3. 그리드 정보  
그리드 갯수, Upper Limt, Lower Limt은 자신이 설정한 값을 보여줍니다.
Grid Open Price는, 자신이 오픈하기로 정했던 기간의 가격을 보여줍니다.
Starting Position은, 롱/숏 그리드의 경우에 처음에 들고 시작했던 포지션의 갯수를 보여줍니다.
Neutral Strategy의 경우 0입니다.
Per Grid qty는, 하나의 그리드에 얼마만큼의 포지션이 배분되었는지를 보여주며
Grid Interval은 각 그리드의 간격을 보여줍니다.
또, Per Matched Profit은 하나의 그리드가 체결될 때 얼마만큼의 이익이 발생하는 지를 보여줍니다.
 
이러한 지표에 대한 역테스트 결과는 시간 프레임에 따라 달라질 수 있습니다. 
따라서 시간 경과에 따른 손익을 비교할 때만 사용하는 것이 좋습니다.
*추가로, 그리드의 라인이 모두 구현되지 않는 문제가 있지만, 백테스팅 결과와는 무관합니다.
Hammer & Shooting Star [C] - KaspricciHammer and Shooting Star  
This indicator identifies Hammer and Shooting Star candles and marks them with a respective label. It uses a set of predefined fibonacci levels to measure the size of the body in comparison to the overall size of the candle. You can change the fibonacci level according to your preferences.
You can enable a confirmation of the Hammer or Shooting Star candle by a following green or red candle.
 Settings 
 
   Fibonacci Level  - Select on of the predefined fibonacci levels as a threshold for the maximum size of the body compared to the overall size of the candle.
   Confirm by next candle  - by default turned off. If turned on, this will check the subsequent candle and only mark a Hammer followed by a green candle or a Shooting Star followed by a red candle.
   Show labels on chart  - by default turned on. If turned off, the indicator will hide the labels on the chart.
 
 Alerts 
You can create alerts for Hammer and Shooting Star candles. The indicator provides the respective conditions.
 Linking with Backtesting Strategy 
I also added a feature to combine this indicator with a backtesting strategy.  It provides a plot  Connector   which can be selected in a backtesting strategy supporting this linking feature. 
Signals:
 
  Signal:  2 - Hammer candle (long entry) 
  Signal: -2 - Shooting Start candle (short entry)
 
You can see the signal values in the status line of the indicator. This is based on the  External Signal Protocol  defined by  PineCoders .






















