Statistical Pairs Trading IndicatorZ-Score Stat Trading — Statistical Pairs Trading Indicator 
📊🔗
---
 What is it?   
Z-Score Stat Trading is a powerful indicator for statistical pairs trading and quantitative analysis of two correlated assets.  
It calculates the Z-Score of the log-price spread between any two symbols you choose, providing both long-term and short-term Z-Score signals.  
You’ll also see real-time correlation, volatility, spread, and the number of long/short signals in a handy on-chart table!
---
 How to Use 🛠️ 
1.  Add the indicator  to your chart.
2.  Select two assets  (symbols) to analyze in the settings.
3.  Watch the Z-Score plots  (blue and orange lines) and threshold levels (+2, -2 by default).
4.  Check the info table  for:
   - Correlation
   - Volatility
   - Spread
   - Number of long (NL) and short (NS) signals in the last 1000 bars
5.  Set up alerts  for signal generation or threshold crossings if you want to be notified automatically.
---
 Trading Strategy 💡 
- This indicator is designed for  statistical arbitrage (mean reversion)  strategies.
-  Long Signal (🟢):   
  When both Z-Scores drop below the negative threshold (e.g., -2), a long signal is generated.  
  → Buy Symbol A, Sell Symbol B, expecting the spread to revert to the mean.
-  Short Signal (🔴):   
  When both Z-Scores rise above the positive threshold (e.g., +2), a short signal is generated.  
  → Sell Symbol A, Buy Symbol B, again expecting mean reversion.
- The info table helps you quickly assess the frequency of signals and the current statistical relationship between your chosen assets.
---
 Best Practices & Warnings 🚦 
-  Avoid high leverage!  Pairs trading can be risky, especially during periods of divergence. Use conservative position sizing.
-  Check for cointegration:  Before using this indicator, make sure both assets are cointegrated or have a strong historical relationship. This increases the reliability of mean reversion signals.
-  Check correlation:  Only use asset pairs with a high correlation (preferably 0.8–0.9 or higher) for best results. The correlation value is shown in the info table.
-  Scale in and out gradually:  When entering or exiting positions, consider doing so in parts rather than all at once. This helps manage slippage and risk, especially in volatile markets.
---
 ⚠️ Note on Performance:   
This indicator may work a bit slowly, especially on large timeframes or long chart histories, because the calculation of NL and NS (number of long/short signals) is computationally intensive.
---
 Disclaimer ⚠️ 
This script is provided  for educational and informational purposes only .  
It is  not financial advice  or a recommendation to buy or sell any asset.  
Use at your own risk. The author assumes no responsibility for any trading decisions or losses.
Stategy
3Commas BotBjorgum 3Commas Bot 
 A strategy in a box to get you started today 
With 3rd party API providers growing in popularity, many are turning to automating their strategies on their favorite assets. With so many options and layers of customization possible, TradingView offers a place no better for young or even experienced coders to build a platform from to meet these needs. 3Commas has offered easy access with straight forward TradingView compatibility. Before long many have their brokers hooked up and are ready to send their alerts (or perhaps they have been trying with mixed success for some time now) only they realize there might just be a little bit more to building a strategy that they are comfortable letting out of their sight to trade their money while they eat, sleep, etc. Many may have ideas for entry criteria they are excited to try,  but further questions arise... "What about risk mitigation?" "How can I set stop or limit orders?" "Is there not some basic shell of a strategy that has laid some of this out for me to get me going?"
Well now there is just that. This strategy is meant for those that have begun to delve into the world of algorithmic trading providing a template that offers risk defined positions complete with stops, limit orders, and even trailing stops should one so choose to employ any of these criteria. It provides a framework that is easily manipulated (with some basic working knowledge of pine coding) to encompass ones own ideas and entry criteria, while also providing an already functioning strategy. 
  
The default settings have a basic 1:1 risk to reward ratio, which sets a limit and a stop equal distance from the entry. The entry is a simple MA cross (up for long, down for short). There a variety of MA's to choose from and the user can define the lengths of the averages. The ratio can be adjusted from the menu along with a volatility based adder (ATR) that helps to distance a stop from support or resistance. These values are calculated off the swing low/high of the user defined lookback period. Risk is calculated from position entry to stop, and projected upwards to the limit as a function of the desired risk to reward ratio. Of note: the default settings include 0.05% commissions. Competitive commissions of the leading cryptocurrency exchanges are .1% round trip (one buy and one sell) for market orders. There is also some slippage to allow time for alerts to be sent and orders to fill giving the back test results a more accurate representation of real time conditions. Its recommended to research the going rates for your exchange and set them to default for the strategy you use or build. 
 To get started a user would: 
1) Make a copy of the code and paste in their bot keys in the area provided under the "3Comma Keys" section
         - eg. Long bot "start deal" copied from 3commas in to define "Long" etc. (code is commented)
2) Place alert on desired asset with desired settings ensuring to select "Order fills and alert() function calls"
3) Paste webhook into the webhook box and select webhook URL alerts (3rd party provided webhook)
3) Delete contents of alert message box and replace with {{strategy.order.alert_message}} and nothing else
       - the codes will be sent to the webhook appropriately as the strategy enters and exits positions. Only 1 alert is needed  
 settings used for the display image:  
1hr chart on BTCUSD 
-ATR stop
-Risk adjustment 1.2
-ATR multiplier 1.3
-RnR 0.6
-MAs HEMA/SMA
-MA Length 50/100
-Order size percent of equity 
-Trail trigger 60% of target
Experiment with your own settings on your crypto of choice or implement your own code!
  
 Implementing your trailing stop (optional) 
Among the options for possible settings is a trailing stop. This stop will ratchet higher once triggered as a function of the Average True Range (ATR). There is a variable level to choose where the user would like to begin trailing the stop during the trade. The level can be assigned with a decimal between 0 and 1 (eg. 0.5 = 50% of the distance between entry and the target which must be exceeded before the trail triggers to begin). This can allow for some dips to occur during the trade possibly keeping you in the trade for longer, while potentially reducing risk of drawdown over time. The default for this setting is 0 meaning unless adjusted, the trail will trigger on entry if the trailing stop exit method is selected.  An example can be seen below: 
  
Again, optional as well is the choice to implement a limit order. If one were to select a trailing stop they could choose not to set a limit, which could allow a trail to run further until hit. Drawdowns of this strategy would be foregoing locking gains at highs on target on other trades. This is a trade-off the user can decide on and test. An example of this working in favor can be observed below:
  
 Conclusion 
Although a simple strategy is implemented here, the benefits of this script allow a user a starting platform to build their strategies from with built in risk mitigation. This allows the user to sidestep some of the potential difficulties' that can arise while learning Pine and taking on the endeavor of automating their trading strategies. It is meant as an aid, a structure, and an educational piece that can be seen as a "pick-up-and-go" strategy with easy 3Commas compatibility. Additionally, this can help users become more comfortable with strategy alert messages and sending strings in the form of alerts from Pine. As well, FAQs are often littered with questions regarding "strategy.exit" calls, how to implement stops. how to properly set a trailing stop based on ATR, and more. The time this can save an individual to get started is likely of the best "take-aways" here. 
Happy trading 
Trend Following Long Only StrategyThis script tries to ride bull trends and stay out of the market in bear trends.


