BTC Volume Index 1.1 beta [Dia]Indicator calculates total volume across multiple bitcoin exchanges. The influence of each exchange can be adjusted seperately.
0 fee exchanges default to 50%
0 fee futures default to 10%
Define custom lookback periods for price breakout detection.
Look for low-volume price reversals in those candles immediately following high volume peaks. The lower the volume  and the greater the open/close price difference of that 2nd candle is compared to the previous one, the higher the likelihood of a local top/bottom being in.
Note: 
Bar highlighting is still experimental, future versions will include better filtering options.
 Use for confirmation only, not as standalone trading system.
ابحث في النصوص البرمجية عن "btc期权交割时间"
Other alts compensated capitalization [Peregringlk]DISCLAIMER: I'm not a native English speaker, so let me know please about mistakes in my wording.
Introduction
==========
This indicator (the middle one in the image) shows how the "others altcoins" (all altcoins except coins with high capitalization) are adding own value to its capitalization by removing BTC price changes. By "own value" I mean USD value gaining by actual buys in BTC markets beyong arbitrage effects of BTC price changes.
The main idea is that, if bitcoin has increased is value by 20%, and the other altcoins has increased its capitalization by 30%, the chart will only plot an increased of 10%. In other words, it will show its increased capitalization measured in BTC (the combined altcoin/BTC market is uptrending). Its purpose is to try to identify altseasons. A bit more concisely, the graph will only grow when both USD and BTC capitalization are growing. If any of them are going down, the graph will go down as well.
Rationale
========
   - Altseasons are characterized by an incresed in BTC value of almost every altcoin during some period of time, although not all at once, but distributed over the altseason. For example, in the crazy altseason of Dec17/Jan18, almost every (low capitalized) altcoin increased its BTC value by a minimum of +300%, some at the beginning of the season, some at the end.
  - When this happens, BTC loss capitalization dominance, but this also can happen if BTC is downtrending while altcoins are being bought in BTC markets but its USD value doesn't change too much. This happens when altcoins are uptrending in BTC price, but there are actually no gain of USD value because the BTC gain in value is not enough to compensate the BTC fall in price. Since BTC is losing USD price, but altcoins are not, dominance falls. So, looking at BTC dominance is not enough to spot possible beginnings of altseasons, because of arbitrage of other effects.
  - The "big altcoins" are removed from the counting because one single big capitalized altcoin that grows, let's say, a 20%, will have an observable effect on the total altcoin capitalization, even if the rest of the altcoins are stagnated in price. For example, at today's date (8th April 2020), Ethereum by itself has the 23.89% of the total altcoins capitalization. A +10% in Ethereum price will increase the total altcoin capitalization by a +2.38%. I wanted to remove that effect to focus on generalized price changes of all altcoins. Remember that there are only 9 big altcoins 9 coins representing the 71% of the alts capitalization, while there are exists more than 5000 altcoins in total.
 - Another key factor is that I want to focus on what happens in alt/BTC markets, because almost every altcoin can be traded against BTC, and most of them can only be traded against BTC. However, big altcoins can usually be traded against USD or other alt coins or fiat currencies as well. Removing the big alts from the equation helps (just a bit) to simplify the interpretation of the chart because arbitrage effects of those "impactfull" alts are limited (although not removed, because arbitrage also happens cross-markets).
  - There are situations where BTC price is going up, alts USD capitalization is going up as well, but alts BTC capitalization is going down because altcoins are being sold in BTC markets, it just happens that the speed of the selling is not high enough as to compensated the increased in BTC price. That makes the USD capitalization grows, while alts are really being dumped in BTC markets. I wanted to reflect that effect as well by making sure that the graph is growing only when both USD and BTC capitalization of alts are growing.
Interpretation
============
If you want, you can see this chart as if plotting the Other alts capitalization as if priced against a fictional coin FCOIN, that start by having a price of 1, that combines the up and downs of both BTC price and alts USD capitalization in a very conservative way: if FCOIN price goes up, means that the other alts are gained USD value but only when they have overcome BTC price changes. Otherwise, it goes down.
If this fictional FCOIN has went up during some days straight with a total gain of maybe, greater than 10%, we are maybe in front of the start of an altseason. Sometimes, maybe (it requires some more years to extract a theory out of here), it can be used as proxy of the BTC near future (trend changes or continuations): if this FCOIN goes up, while BTC is doing nothing relevant or even is going down, it could signal that "people" is getting prepared and a generalized altcoin accumulation process has started, because of  a combined people's assumption that BTC will start to have an stable uptrend, or will continue the current trend soon. There's some matches in the past about that, but there are also false positives, as usual.
Additionally, four customizable EMAs are added to the script, by default 21, 50, 100 and 150.
Definitions
=========
  - Let's call `altcap_btc` the altcoin capitalization in USD, divided by BTC price. In other words, `altcap_btc` is the capitalization in terms of BTC.
  - Let's call `x` the BTC price change rate as `btc_price_current_candle / btc_price_previous_candle`. So, if BTC has grown a +20%, `x = 1.20`, and if BTC has gone down a -20%, `x = 0.80`.
  - Let's call `y` the `altcap_btc` price change rate, calculated as before but for `altcap_btc`.
  - For pure math equivalence, `x * y` is thus the USD capitalization change rate.
Calculation
=========
For plotting the graph, for each candle, I choose a change rate, and then I plot the total accumulated change rate as by `ch0 * ch1 * ch2 * .... * ch_today`, where each `chX` is the choosen change rate of each candle since the beginning of the chart. So, if the "alts compensated value" has grown yesterday +20% and today's -10%, `1.20 * 0.9 = 1.08`, which means that in two days the compensated value has grown an 8% in total.
  - If `x * y > 1` (USD cap is growing), I take `y` as change rate (alt/btc change rate).
        - If both `x` and `y` are `> 1`, then the graph grows because I'm taking `y`.
        - If `x > 1` and `y < 1`, the graph goes down because I'm taking `y`, reflecting the BTC markets are dumping.
        - If `x < 1` and `y > 1`, the graph goes up because I'm taking `y`, reflecting the BTC markets are pumping so much that it overcomes the btc fall.
        - `x < 1` and `y < 1` is impossible here because `x * y` must be `> 1` by precondition.
 - If `x * y < 1` (USD cap is going down), I take `y` or `x * y` depending on the individual change rates:
        - If `x` and `y` go in different directions (one up and the other down), I take `x * y` to reflect that USD capitalization has gone down. I don't take `y` here because it could be `> 1`, and I don't want to make the graph grow if alts are lossing USD value. Also, if `y < 1` and I take `y` the graph will go down faster than USD capitalization and I want to show that "alts compensated value is gown down slower than BTC because some boughts are happening". I don't take `x` either here for the same reasons.
       - If both `x` and `y` are `< 1`, I take `y`, because otherwise the graph would be less than 0.000001 today after two years of bleeding, making literally impossible to see if alts "grow tomorrow".
      - `x > 1` and `y > 1` is impossible here because `x * y` must be `< 1` by precondition.
Spot Symbols for CryptoLibrary   "CryptoSpotSymbols" 
This Library has one purpose only. It generate Symbols for the Crypto Spot Market, like all the currencies pairs of most Crypto Exchanges available to TradingView.
Have a look at  .find() , which is an  all in one  function.
 Binance(basecurrency) 
  Generate 27 Symbols for the Spot Market of Binance.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 BinanceUS(basecurrency) 
  Generate seven Symbols for the Spot Market of BinanceUS.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Bitfinex(basecurrency) 
  Generate 12 Symbols for the Spot Market of Bitfinex.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 bitFlyer(basecurrency) 
  Generate three Symbols for the Spot Market of bitFlyer.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Bitget(basecurrency) 
  Generate seven Symbols for the Spot Market of Bitget.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Bithumb(basecurrency) 
  Generate two Symbols for the Spot Market of Bithumb.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 bitkub(basecurrency) 
  Generate one Symbol for the Spot Market of bitkub.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns: THB
 BitMEX(basecurrency) 
  Generate two Symbols for the Spot Market of BitMEX.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 bitpanda_pro(basecurrency) 
  Generate six Symbols for the Spot Market of bitpanda pro.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 bitrue(basecurrency) 
  Generate nine Symbols for the Spot Market of bitrue.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Bitstamp(basecurrency) 
  Generate eight Symbols for the Spot Market of Bitstamp.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 BITTREX(basecurrency) 
  Generate six Symbols for the Spot Market of BITTREX.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 BTSE(basecurrency) 
  Generate 15 Symbols for the Spot Market of BTSE.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 BYBIT(basecurrency) 
  Generate five Symbols for the Spot Market of BYBIT.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 CapitalCom(basecurrency) 
  Generate five Symbols for the Spot Market of capital.com.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 coinbase(basecurrency) 
  Generate seven Symbols for the Spot Market of coinbase.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 CoinEx(basecurrency) 
  Generate three Symbols for the Spot Market of CoinEx.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 CurrencyCom(basecurrency) 
  Generate 30 Symbols for the Spot Market of currency.com.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Delta(basecurrency) 
  Generate one Symbol for the Spot Market of Delta.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns: USDT
 Deribit(basecurrency) 
  Generate two Symbols for the Spot Market of Deribit.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 easyMarkets(basecurrency) 
  Generate one Symbol for the Spot Market of easyMarkets.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns: USD
 Eightcap(basecurrency) 
  Generate one Symbol for the Spot Market of Eightcap.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns: USD
 ExMo(basecurrency) 
  Generate ten Symbols for the Spot Market of ExMo.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 FOREXcom(basecurrency) 
  Generate four Symbols for the Spot Market of FOREX.com.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 FXCM(basecurrency) 
  Generate three Symbols for the Spot Market of FXCM.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 GateIO(basecurrency) 
  Generate five Symbols for the Spot Market of Gate.io.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Gemini(basecurrency) 
  Generate ten Symbols for the Spot Market of Gemini.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Kraken(basecurrency) 
  Generate 14 Symbols for the Spot Market of Kraken.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 KuCoin(basecurrency) 
  Generate 13 Symbols for the Spot Market of KuCoin.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 MEXC(basecurrency) 
  Generate six Symbols for the Spot Market of MEXC.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 OANDA(basecurrency) 
  Generate one Symbol for the Spot Market of OANDA.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns: USD
 OKX(basecurrency) 
  Generate six Symbols for the Spot Market of OKX.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Pepperstone(basecurrency) 
  Generate one Symbol for the Spot Market of Pepperstone.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns: USD
 phemex(basecurrency) 
  Generate four Symbols for the Spot Market of phemex.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 POLONIEX(basecurrency) 
  Generate nine Symbols for the Spot Market of POLONIEX.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Pyth(basecurrency) 
  Generate three Symbols for the Spot Market of Pyth.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 Skilling(basecurrency) 
  Generate four Symbols for the Spot Market of Skilling.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 TimeX(basecurrency) 
  Generate six Symbols for the Spot Market of TimeX.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 TradeStation(basecurrency) 
  Generate four Symbols for the Spot Market of TradeStation.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 UpBit(basecurrency) 
  Generate four Symbols for the Spot Market of UpBit.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 whitebit(basecurrency) 
  Generate 13 Symbols for the Spot Market of whitebit.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 WOOX(basecurrency) 
  Generate two Symbols for the Spot Market of WOO.
  Parameters:
     basecurrency (simple string) : Its the Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`.
  Returns:  
 find(exchange, basecurrency) 
  Generate up to 30 Symbols for the Spot Market, depending on the market picked.
  Parameters:
     exchange (simple string) : The name of an Exchange. Case insensitivity. Optional. Default value is `syminfo.prefix`. If something else is put in here it will return `na` values.
     basecurrency (simple string) : The Basecurrency to generate the Symbols with. Optional. Default value is `syminfo.basecurrency`
  Returns: 30x string as tuple
CL Daily Bitcoin Volume (All exchange included, even Mt.GOX)This daily volume data contains collective total from 
____________________________________________________
Historical:
BTC-e	BTC/USD (From Q3 2011 to Q3 2016)
BTCChina	BTC/CNY (From Q3 2011 to Q2 2017)
Coinsetter	BTC/USD (From Q3 2014 to Q1 2016)
MtGox	BTC/USD (From July 2010 - 2014 only))
OKcoin International	BTC/USD (From Q3 2014 to Q2 2017)
____________________________________________________
Institutions:
CME Bitcoin Futures
Grayscale Bitcoin Trust OTC
____________________________________________________
Spot exchanges:
Bitfinex	BTC/USD
Bitstamp	BTC/USD
Coinbase   BTC/USD
Coinbase   BTC/EUR
Binance    BTC/USDT
Binance    BTC/USDC
Binance    BTC/PAX
Gemini	BTC/USD
itBit	        BTC/USD
Kraken	BTC/EUR
Kraken      BTC/USD
Huobi        BTC/USDT
Korbit       BTC/KRW
Bitflyer     BTC/JPY
____________________________________________________
Others:
Bitmex
Noro's SILA v1.6L StrategyBacktesting 
Backtesting (for all the time of existence of couple) only with software configurations to default (without optimization of parameters):
US = Uptrend-Sensivity
DS = Downtrend-Sensivity
It is recommended and by default:
- the normal market requires US=DS (for example US=5, DS=5)
- very bear market requires US DS, (for example US=5, DS=0)
- very bull market requires US DS, (US=0, DS=5)
Cryptocurrencies it is very bull market (US=0, DS=5)
 Backtesting BTC/FIAT 
D1 timeframe 
identical parameters for all pairs
BTC/USD (Bitstamp) profit of +41805%
BTC/EUR (BTC-e) profit of +1147%
BTC/RUB (BTC-e) profit of +1162%
BTC/JPY (Bitflyer) profit of +215%
BTC/CNY (BTCChina) profit of 54948%
Backtesting ALTCOIN/BTC
D1 timeframe 
identical parameters for all pairs
the exchange Poloniex
top-10 of cryptocurrencies on capitalization at the time of this text
NA = TradingView can't make backtest because of too low price of this cryptocurrency, or on the website there are no quotations of this cryptocurrency
ETH/BTC (Etherium) profit of +11690%
XRP/BTC (Ripple) loss of-100%
LTC/BTC (Litecoin) NA
ETC/BTC (Etherium Classic) profit of +214%
NEM/BTC loss of-49%
DASH/BTC profit of +106%
IOTA/BTC NA
XMR/BTC (Monero) profit of +96%
STRAT/BTC (Stratis) loss of-31%
ALTCOIN/ALTCOIN - not recomended
I don't need your money, I need reputation and likes.
MARA / mNAV=1 (x)What it does
This script overlays two signals on the MARA chart:
mNAV=1 fair-value line — the MARA price implied by Bitcoin NAV:
mNAV1 = (BTC price × BTC holdings) / MARA shares
Premium/Discount ratio — how far MARA trades vs. its NAV fair value:
Ratio = Close / mNAV1 (1.00 = fair; >1 = premium; <1 = discount)
Inputs
Shares outstanding (default: 370,460,000)
BTC holdings (official or estimated; you can roll forward +25 BTC/day if you want)
BTC symbol used for pricing (e.g., BTCUSD, BTCUSDT, BTCUSDTPERP)
How to use
When Price < mNAV=1 and Ratio < 1.00 → MARA trades at a discount to BTC NAV (potential mean-reversion if BTC is stable).
When Price > mNAV=1 and Ratio > 1.00 → premium (premium often compresses during BTC chop/weakness).
Rule of thumb (with ~53k BTC and 370.46M shares): +$1,000 BTC ≈ +$0.14 on the mNAV=1 line.
Visuals
Blue line = mNAV=1 (fair value) plotted directly on the MARA chart.
Purple line = Ratio (×) on a separate right-hand scale centered around 1.00.
Optional shading: green when Ratio > 1.05 (+5% premium), red when Ratio < 0.95 (−5% discount).
Alerts (suggested)
Premium > +5%: Ratio > 1.05
Discount < −5%: Ratio < 0.95
Notes
This is a proxy for NAV parity; it assumes your BTC holdings input is correct (official last report or your estimate).
Choice of BTC symbol matters; use the feed that best matches your workflow (spot, perp, or index).
The ratio is most informative when BTC is range-bound; during fast BTC moves MARA can overshoot temporarily.
ZenAlgo - DominatorThis indicator provides a structured multi-ticker overview of market momentum and relative strength by analyzing short-term price behavior across selected assets in comparison with broader crypto dominance and Bitcoin/ETH performance.
 Ticker and Market Data Handling 
The script accepts up to 9 user-defined symbols (tickers) along with BTCUSD and ETHUSD. For each symbol:
 
  It retrieves the current price.
  It also requests the daily opening price from the "D" timeframe to compute intraday percentage change.
  For BTC, ETH, and dominance (sum of BTC, USDT, and USDC dominance), daily change is calculated using this same method.
 
This comparison enables tracking relative performance from the daily open, which provides meaningful insight into intraday strength or weakness among different assets.
 Dominance Logic 
The indicator aggregates dominance data from  BTC ,  USDT , and  USDC  using TradingView’s  CRYPTOCAP  indices. This combined dominance is used as a reference in directional and status calculations. ETH dominance is also analyzed independently.
Changes in dominance are used to infer whether market attention is shifting toward Bitcoin/stablecoins (typically indicating risk-off sentiment) or away from them (typically risk-on behavior, benefiting altcoins).
 Price Direction Estimation 
The script estimates directional bias using an EMA-based deviation technique:
 
  A short EMA (user-defined  lookback , default 4 bars) is calculated.
  The current close is compared to the EMA to assess directional bias.
  Recent candle changes are also inspected to confirm a consistent short-term trend (e.g., 3 consecutive higher closes for "up").
  A small threshold is used to avoid classifying flat movements as trends.
 
This directionality logic is applied separately to:
 
  The selected ticker's price
  BTC price
  Combined dominance
 
This allows the script to contextualize the movement of each asset within broader market conditions.
 Market Status Evaluation 
A custom function analyzes ETH and BTC dominance trends along with their relative strength to define the overall market regime:
 
   Altseason  is identified when BTC dominance is declining, ETH dominance rising, and ETH outperforms BTC.
   BTC Season  occurs when BTC dominance is rising, ETH dominance falling, and BTC outperforms ETH.
  If neither condition is met, the state is  Neutral .
 
This classification is shown alongside each ticker's row in the table and helps traders assess whether market conditions favor Bitcoin, Ethereum, or altcoins in general.
 Ticker Status Classification 
Each ticker is analyzed independently using the earlier directional logic. Its status is then determined as follows:
 
   Full Bull : Ticker is trending up while dominance is declining or BTC is also rising.
   Bullish : Ticker is trending up but not supported by broader bullish context.
   Bearish : Ticker is trending down but without broader confirmation.
   Full Bear : Ticker is trending down while dominance rises or BTC falls.
   Neutral : No strong directional bias or conflicting context.
 
This classification reflects short-term momentum and macro alignment and is color-coded in the results table.
 Table Display and Plotting 
A configurable table is shown on the chart, which:
 
  Displays the name and status of each selected ticker.
  Optionally includes BTC, ETH, and market state.
  Uses color-coding for intuitive interpretation.
 
Additionally, price changes from the daily open are plotted for each selected ticker, BTC, ETH, and combined dominance. These values are also labeled directly on the chart.
 Labeling and UX Enhancements 
 
  Labels next to the current candle display price and percent change for each active ticker and for BTC, ETH, and combined dominance.
  Labels update each bar, and old labels are deleted to avoid clutter.
  Ticker names are dynamically shortened by stripping exchange prefixes.
 
 How to Use This Indicator 
This tool helps traders:
 
  Spot early rotations between Bitcoin and altcoins.
  Identify intraday momentum leaders or laggards.
  Monitor which tickers align with or diverge from broader market trends.
  Detect possible sentiment shifts based on dominance trends.
 
It is best used on lower to mid timeframes (15m–4h) to capture intraday to short-term shifts. Users should cross-reference with longer-term trend tools or structural indicators when making directional decisions.
 Interpretation of Values 
 
   % Change : Measures intraday move from daily open. Strong positive/negative values may indicate breakouts or reversals.
   Status : Describes directional strength relative to market conditions.
   Market State : Gives a general bias toward BTC dominance, ETH strength, or altcoin momentum.
 
 Limitations & Considerations 
 
  The indicator does not analyze liquidity or volume directly.
  All logic is based on short-term movements and may produce false signals in ranging or low-volume environments.
  Dominance calculations rely on external CRYPTOCAP indices, which may differ from exchange-specific flows.
 
 Added Value Over Other Free Tools 
Unlike basic % change tables or price overlays, this indicator:
 
  Integrates dominance-based macro context into ticker evaluation.
  Dynamically classifies market regimes (BTC season / Altseason).
  Uses multi-factor logic to determine ticker bias, avoiding single-metric interpretation.
  Displays consolidated information in a table and chart overlays for rapid assessment.
Bitcoin Leverage Sentiment - Strategy [presentTrading]█ Introduction and How it is Different
The "Bitcoin Leverage Sentiment - Strategy  " represents a novel approach in the realm of cryptocurrency trading by focusing on sentiment analysis through leveraged positions in Bitcoin. Unlike traditional strategies that primarily rely on price action or technical indicators, this strategy leverages the power of Z-Score analysis to gauge market sentiment by examining the ratio of leveraged long to short positions. By assessing how far the current sentiment deviates from the historical norm, it provides a unique lens to spot potential reversals or continuation in market trends, making it an innovative tool for traders who wish to incorporate market psychology into their trading arsenal.
BTC 4h L/S Performance
  
local
  
█ Strategy, How It Works: Detailed Explanation
🔶 Data Collection and Ratio Calculation
Firstly, the strategy acquires data on leveraged long (**`priceLongs`**) and short positions (**`priceShorts`**) for Bitcoin. The primary metric of interest is the ratio of long positions relative to the total of both long and short positions:
BTC Ratio=priceLongs / (priceLongs+priceShorts)
This ratio reflects the prevailing market sentiment, where values closer to 1 indicate a bullish sentiment (dominance of long positions), and values closer to 0 suggest bearish sentiment (prevalence of short positions).
🔶 Z-Score Calculation
The Z-Score is then calculated to standardize the BTC Ratio, allowing for comparison across different time periods. The Z-Score formula is:
Z = (X - μ) / σ
Where:
- X is the current BTC Ratio.
- μ is the mean of the BTC Ratio over a specified period (**`zScoreCalculationPeriod`**).
- σ is the standard deviation of the BTC Ratio over the same period.
The Z-Score helps quantify how far the current sentiment deviates from the historical norm, with high positive values indicating extreme bullish sentiment and high negative values signaling extreme bearish sentiment.
  
🔶 Signal Generation: Trading signals are derived from the Z-Score as follows:
Long Entry Signal: Occurs when the BTC Ratio Z-Score crosses above the thresholdLongEntry, suggesting bullish sentiment.
- Condition for Long Entry = BTC Ratio Z-Score > thresholdLongEntry
Long Exit/Short Entry Signal: Triggered when the BTC Ratio Z-Score drops below thresholdLongExit for exiting longs or below thresholdShortEntry for entering shorts, indicating a shift to bearish sentiment.
- Condition for Long Exit/Short Entry = BTC Ratio Z-Score < thresholdLongExit or BTC Ratio Z-Score < thresholdShortEntry
Short Exit Signal: Happens when the BTC Ratio Z-Score exceeds the thresholdShortExit, hinting at reducing bearish sentiment and a potential switch to bullish conditions.
- Condition for Short Exit = BTC Ratio Z-Score > thresholdShortExit
🔶Implementation and Visualization: The strategy applies these conditions for trade management, aligning with the selected trade direction. It visualizes the BTC Ratio Z-Score with horizontal lines at entry and exit thresholds, illustrating the current sentiment against historical norms.
█ Trade Direction
The strategy offers flexibility in trade direction, allowing users to choose between long, short, or both, depending on their market outlook and risk tolerance. This adaptability ensures that traders can align the strategy with their individual trading style and market conditions.
█ Usage
To employ this strategy effectively:
1. Customization: Begin by setting the trade direction and adjusting the Z-Score calculation period and entry/exit thresholds to match your trading preferences.
2. Observation: Monitor the Z-Score and its moving average for potential trading signals. Look for crossover events relative to the predefined thresholds to identify entry and exit points.
3. Confirmation: Consider using additional analysis or indicators for signal confirmation, ensuring a comprehensive approach to decision-making.
█ Default Settings
- Trade Direction: Determines if the strategy engages in long, short, or both types of trades, impacting its adaptability to market conditions.
- Timeframe Input: Influences signal frequency and sensitivity, affecting the strategy's responsiveness to market dynamics.
- Z-Score Calculation Period: Affects the strategy’s sensitivity to market changes, with longer periods smoothing data and shorter periods increasing responsiveness.
- Entry and Exit Thresholds: Set the Z-Score levels for initiating or exiting trades, balancing between capturing opportunities and minimizing false signals.
- Impact of Default Settings: Provides a balanced approach to leverage sentiment trading, with adjustments needed to optimize performance across various market conditions.
Antares_messages_publicLibrary   "Antares_messages_public" 
This library add messages for yours strategy for use in Antares trading system for binance and bybit exchanges. 
Данная библиотека позволяет формировать сообщения в алертах стратегий для Antares в более упрощенном для пользователя режиме, включая всплывающие подсказки и т.д.
 set_leverage(token, market, ticker_id, leverage) 
  Set leverage for ticker on specified market.
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     leverage (float) : (float)  leverage level. Устанавливаемое плечо.
  Returns: 'Set leverage message'.
 pause(time_pause) 
  Set pause in message.  '::' -left and  '::' -right included.
  Parameters:
     time_pause (int) 
 LongLimit(token, market, ticker_id, type_qty, quantity, price, orderId, leverageforqty) 
  Buy order with limit price and quantity. 
Лимитный ордер на покупку(в лонг).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     price (float) : (float) price for limit order. Цена по которой должен быть установлен лимитный ордер.
     orderId (string) : (string) if use order id you may change or cancel your order after or set it ''. Используйте OrderId если хотите изменить или отменить ордер в будущем.
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Limit Buy order'. Лимитный ордер на покупку (лонг).
 LongMarket(token, market, ticker_id, type_qty, quantity, leverageforqty) 
  Market Buy order with quantity. 
Рыночный ордер на покупку (в лонг).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     leverageforqty (int) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Market Buy order'. Маркетный ордер на покупку (лонг).
 ShortLimit(token, market, ticker_id, type_qty, quantity, price, leverageforqty, orderId) 
  Sell order with limit price and quantity.
Лимитный ордер на продажу(в шорт).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     price (float) : (float) price for limit order. Цена по которой должен быть установлен лимитный ордер.
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
     orderId (string) : (string) if use order id you may change or cancel your order after or set it ''. Используйте OrderId если хотите изменить или отменить ордер в будущем.
  Returns: 'Limit Sell order'. Лимитный ордер на продажу (шорт).
 ShortMarket(token, market, ticker_id, type_qty, quantity, leverageforqty) 
  Sell by market price and quantity.
Рыночный ордер на продажу(в шорт).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     leverageforqty (int) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Market Sell order'. Маркетный ордер на продажу (шорт).
 Cancel_by_ticker(token, market, ticker_id) 
  Cancel all orders for market and ticker in setups. Отменяет все ордера на заданной бирже и заданном токене(паре).
  Parameters:
     token (string) 
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
  Returns: 'Cancel all orders'. Отмена всех ордеров на заданной бирже и заданном токене(паре).
 Cancel_by_id(token, market, ticker_id, orderId) 
  Cancel order by Id for market and ticker in setups. Отменяет ордер по Id на заданной бирже и заданном токене(паре).
  Parameters:
     token (string) 
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     orderId (string) 
  Returns: 'Cancel order'. Отмена ордера по Id на заданной бирже и заданном токене(паре).
 Close_positions(token, market, ticker_id) 
  Close all positions for market and ticker in setups. Закрывает все позиции на заданной бирже и заданном токене(паре).
  Parameters:
     token (string) 
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
  Returns: 'Close positions'
 CloseLongLimit(token, market, ticker_id, type_qty, quantity, price, orderId, leverageforqty) 
  Close limit order for long position. (futures)
Лимитный ордер на продажу(в шорт) для закрытия лонговой позиции(reduceonly).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     price (float) : (float) price for limit order. Цена по которой должен быть установлен лимитный ордер.
     orderId (string) : (string) if use order id you may change or cancel your order after or set it ''. Используйте OrderId если хотите изменить или отменить ордер в будущем.
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Limit Sell order reduce only (close long position)'. Лимитный ордер на продажу для снижения текущего лонга(в шорт не входит).
 CloseLongMarket(token, market, ticker_id, type_qty, quantity, leverageforqty) 
  Close market order for long position.
Рыночный ордер на продажу(в шорт) для закрытия лонговой позиции(reduceonly).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Market Sell order reduce only (close long position)'. Ордер на снижение/закрытие текущего лонга(в шорт не входит) по рыночной цене.
 CloseShortLimit(token, market, ticker_id, type_qty, quantity, price, orderId, leverageforqty) 
  Close limit order for short position.
Лимитный ордер на покупку(в лонг) для закрытия шортовой позиции(reduceonly).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     price (float) : (float) price for limit order. Цена по которой должен быть установлен лимитный ордер.
     orderId (string) : (string) if use order id you may change or cancel your order after or set it ''. Используйте OrderId если хотите изменить или отменить ордер в будущем.
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Limit Buy order reduce only (close short position)' . Лимитный ордер на покупку (лонг) для сокращения/закрытия текущего шорта.
 CloseShortMarket(token, market, ticker_id, type_qty, quantity, leverageforqty) 
  Set Close limit order for long position.
Рыночный ордер на покупку(в лонг) для сокращения/закрытия шортовой позиции(reduceonly).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Market Buy order reduce only (close short position)'. Маркетного ордера на покупку (лонг) для сокращения/закрытия текущего шорта.
 cancel_all_close(token, market, ticker_id) 
  Parameters:
     token (string) 
     market (string) 
     ticker_id (string) 
 limit_tpsl_bybitfu(token, ticker_id, order_id, side, type_qty, quantity, price, tp_price, sl_price, leverageforqty) 
  Set multi order for Bybit : limit + takeprofit + stoploss
Выставление тройного ордера на Bybit лимитка со стоплоссом и тейкпрофитом
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     order_id (string) 
     side (bool) : (bool) "buy side" if true or "sell side" if false. true для лонга, false для шорта.
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     price (float) : (float) price for limit order by 'side'. Цена лимитного ордера
     tp_price (float) : (float) price for take profit order. 
     sl_price (float) : (float) price for stoploss order
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: Set multi order for Bybit : limit + takeprofit + stoploss.
 replace_limit_tpsl_bybitfu(token, ticker_id, order_id, side, type_qty, quantity, price, tp_price, sl_price, leverageforqty) 
  Change multi order for Bybit : limit + takeprofit + stoploss
Изменение тройного ордера на Bybit лимитка со стоплоссом и тейкпрофитом
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     order_id (string) 
     side (bool) : (bool) "buy side" if true or "sell side" if false. true для лонга, false для шорта.
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size, see at 'type_qty'. Размер ордера, базы или % в соответствии с 'type_qty'
     price (float) : (float) price for limit order by 'side'. Цена лимитного ордера
     tp_price (float) : (float) price for take profit order. 
     sl_price (float) : (float) price for stoploss order
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: Set multi order for Bybit : limit + takeprofit + stoploss.
 long_stop(token, market, ticker_id, type_qty, quantity, l_stop, leverageforqty) 
  Stop market order for long position 
Рыночный стоп-ордер на продажу для закрытия лонговой позиции.
  Parameters:
     token (string) 
     market (string) : (string) 'binance' , 'binancefru'  etc.. Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size. Размер ордера.
     l_stop (float) : (float) price for activation stop order. Цена активации стоп-ордера.
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Stop Market Sell order (close long position)'. Маркетный стоп-ордер на снижения/закрытия текущего лонга.
 short_stop(token, market, ticker_id, type_qty, quantity, s_stop, leverageforqty) 
  Stop market order for short position 
Рыночный стоп-ордер на покупку(в лонг) для закрытия шорт позиции.
  Parameters:
     token (string) 
     market (string) : (string) 'binance' , 'binancefru'  etc.. Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size. Размер ордера.
     s_stop (float) : (float) price for activation stop order. Цена активации стоп-ордера.
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Stop Market Buy order (close short position)'. Маркетный стоп-ордер на снижения/закрытия текущего шорта.
 change_stop_l(token, market, ticker_id, type_qty, quantity, l_stop, leverageforqty) 
  Change Stop market order for long position 
Изменяем стоп-ордер на продажу(в шорт) для закрытия лонг позиции.
  Parameters:
     token (string) 
     market (string) : (string) 'binance' , 'binancefru'  etc.. Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size. Размер ордера.
     l_stop (float) : (float) price for activation stop order. Цена активации стоп-ордера.
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Change Stop Market Buy order (close long position)'. Смещает цену активации Маркетного стоп-ордер на снижения/закрытия текущего лонга.
 change_stop_s(token, market, ticker_id, type_qty, quantity, s_stop, leverageforqty) 
  Change Stop market order for short position 
Смещает цену активации Рыночного стоп-ордера на покупку(в лонг) для закрытия шорт позиции.
  Parameters:
     token (string) 
     market (string) : (string) 'binance' , 'binancefru'  etc.. Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) 
     quantity (float) : (float) orders size. Размер ордера.
     s_stop (float) : (float) price for activation stop order. Цена активации стоп-ордера.
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Change Stop Market Buy order (close short position)'. Смещает цену активации Маркетного стоп-ордер на снижения/закрытия текущего шорта.
 open_long_position(token, market, ticker_id, type_qty, quantity, l_stop, leverageforqty) 
  Cancel and close all orders and positions by ticker , then open Long position by market price with stop order
Отменяет все лимитки и закрывает все позы по тикеру, затем открывает лонг по маркету с выставлением стопа (переворот позиции, при необходимости).
  Parameters:
     token (string) 
     market (string) : (string) 'binance' , 'binancefru'  etc.. Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size. Размер ордера.
     l_stop (float) : (float). Price for activation stop loss. Цена активации стоп-лосса.
     leverageforqty (int) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'command_all_close + LongMarket + long_stop.
 open_short_position(token, market, ticker_id, type_qty, quantity, s_stop, leverageforqty) 
  Cancel and close all orders and positions , then open Short position by market price with stop order 
Отменяет все лимитки и закрывает все позы по тикеру, затем открывает шорт по маркету с выставлением стопа(переворот позиции, при необходимости).
  Parameters:
     token (string) 
     market (string) : (string) 'binance' , 'binancefru'  etc.. Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) orders size. Размер ордера.
     s_stop (float) : (float). Price for activation stop loss. Цена активации стоп-лосса.
     leverageforqty (int) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'command_all_close + ShortMarket + short_stop'.
 open_long_trade(token, market, ticker_id, type_qty, quantity, l_stop, qty_ex1, price_ex1, qty_ex2, price_ex2, qty_ex3, price_ex3, leverageforqty) 
  Cancell and close all orders and positions , then open Long position by market price with stop order and take 1 ,take 2, take 3
Отменяет все лимитки и закрывает все позы по тикеру, затем открывает лонг по маркету с выставлением стопа и 3 тейками (переворот позиции, при необходимости).
  Parameters:
     token (string) 
     market (string) : (string) 'binance' , 'binancefru'  etc.. Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     quantity (float) : (float) enter order size, see at type_qty. Размер ордера входа, согласно type_qty.
     l_stop (float) : (float). Price for activation stop loss. Цена активации стоп-лосса.
     qty_ex1 (float) : (float). Quantity for 1th take see at type_qty, if = 0 string for order dont set. Размер лимитного ордера для 1го тейка, согласно type_qty.. Если 0, то строка для этого тейка не формируется
     price_ex1 (float) : (float). Price for 1th take , if = 0 string for order dont set. Цена лимитного ордера для 1го тейка. Если 0, то строка для этого тейка не формируется
     qty_ex2 (float) : (float). Quantity for 2th take see at type_qty, if = 0 string for order dont set. Размер лимитного ордера для 2го тейка, согласно type_qty..Если 0, то строка для этого тейка не формируется
     price_ex2 (float) : (float). Price for 2th take, if = 0 string for order dont set. Цена лимитного ордера для 2го тейка. Если 0, то строка для этого тейка не формируется
     qty_ex3 (float) : (float). Quantity for 3th take see at type_qty, if = 0 string for order dont set. Размер лимитного ордера для 2го тейка, согласно type_qty..Если 0, то строка для этого тейка не формируется
     price_ex3 (float) : (float). Price for 3th take, if = 0 string for order dont set. Цена лимитного ордера для 3го тейка. Если 0, то строка для этого тейка не формируется
     leverageforqty (int) 
  Returns: 'cancel_all_close + LongMarket + long_stop + CloseLongLimit1 + CloseLongLimit2+CloseLongLimit3'.
 open_short_trade(token, market, ticker_id, type_qty, quantity, s_stop, qty_ex1, price_ex1, qty_ex2, price_ex2, qty_ex3, price_ex3, leverageforqty) 
  Cancell and close all orders and positions , then open Short position by market price with stop order and take 1 and take 2 
Отменяет все лимитки и закрывает все позы по тикеру, затем открывает шорт по маркету с выставлением стопа и 3 тейками (переворот позиции, при необходимости).
  Parameters:
     token (string) 
     market (string) : (string) 'binance' , 'binancefru'  etc.. Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) 
     quantity (float) 
     s_stop (float) : (float). Price for activation stop loss. Цена активации стоп-лосса.
     qty_ex1 (float) : (float). Quantity for 1th take see at type_qty, if = 0 string for order dont set. Размер лимитного ордера для 1го тейка, согласно type_qty.. Если 0, то строка для этого тейка не формируется
     price_ex1 (float) : (float). Price for 1th take , if = 0 string for order dont set. Цена лимитного ордера для 1го тейка. Если 0, то строка для этого тейка не формируется
     qty_ex2 (float) : (float). Quantity for 2th take see at type_qty, if = 0 string for order dont set. Размер лимитного ордера для 2го тейка, согласно type_qty..Если 0, то строка для этого тейка не формируется
     price_ex2 (float) : (float). Price for 2th take, if = 0 string for order dont set. Цена лимитного ордера для 2го тейка. Если 0, то строка для этого тейка не формируется
     qty_ex3 (float) : (float). Quantity for 3th take see at type_qty, if = 0 string for order dont set. Размер лимитного ордера для 2го тейка, согласно type_qty..Если 0, то строка для этого тейка не формируется
     price_ex3 (float) : (float). Price for 3th take, if = 0 string for order dont set. Цена лимитного ордера для 3го тейка. Если 0, то строка для этого тейка не формируется
     leverageforqty (int) 
  Returns: 'command_all_close + ShortMarket + short_stop + CloseShortLimit + CloseShortLimit(2)'.
 Multi_LongLimit(token, market, ticker_id, type_qty, qty1, price1, qty2, price2, qty3, price3, qty4, price4, qty5, price5, qty6, price6, qty7, price7, qty8, price8, leverageforqty) 
  8 or less Buy orders with limit price and quantity. 
До 8 Лимитных ордеров на покупку(в лонг).
  Parameters:
     token (string) : (integer or 0) token for trade in system, if  = 0 then token part mess is empty. Токен,  При значениb = 0 не включается в формирование строки алерта.
     market (string) : (string) Spot 'binance' , 'bybit' . Futures  ('binancefru','binancefro','bybitfu', 'bybitfi'). Строковая переменная названия биржи.
     ticker_id (string) : (string) ticker in market ('btcusdt', 'ethusdt' etc...). Строковая переменная названия тикера (пары).
     type_qty (string) : (string) type of quantity:  1. 'qty' or '' or na - standart (in coins), 2. 'quqty'- in assets (usdt,btc,etc..), 3.open% - open position(futures) or buy (spot) in % of base 4. close% - close in % of position (futures) or sell (spot) coins in % for current quantity
     qty1 (float) 
     price1 (float) 
     qty2 (float) 
     price2 (float) 
     qty3 (float) 
     price3 (float) 
     qty4 (float) 
     price4 (float) 
     qty5 (float) 
     price5 (float) 
     qty6 (float) 
     price6 (float) 
     qty7 (float) 
     price7 (float) 
     qty8 (float) 
     price8 (float) 
     leverageforqty (bool) : (bool) use leverage in qty. Использовать плечо при расчете количества или нет.
  Returns: 'Limit Buy order'. Лимитный ордер на покупку (лонг).
Cryptocurrency Market Sentiment v1.0Introduction: 
   Capable of observing the market sentiment of the cryptocurrency market 
 The relative status of BTC and altcoins   
How it works:
1. The general uptrend process of the cryptocurrency market is BTC  → ETH  → high-cap altcoins  → low-cap altcoins. When funds cannot push up BTC's market cap, funds gradually flow into smaller-cap altcoins until the upward trend ends.
2. Select ETH as the representative of altcoins, and understand the sentiment and current stage
3. Mathematical principle : divide the price of ETH by the price of BTC, and then apply it to the RSI formula . 
How to use it:
1. Similar to the RSI indicator , when CMS enters the overbought zone, it represents an active altcoin market, a passionate market sentiment , and the end of the uptrend.
2. When CMS enters the oversold zone, it indicates the leading stage of BTC in the rising trend or the capital flow back to BTC in the declining process .
3. If CMS is at a low level, long positions should focus on altcoins, and short positions should focus on BTC, and vice versa.
----------------------------------------------------------------------------------------------------------
简单介绍:
 能够观察加密市场市场情绪
 BTC和寨币的相对状态 
如何工作:
1、加密市场一般的上涨过程为 BTC → ETH  → 大市值山寨  → 小市值山寨,当资金无法推动大市值的BTC上涨时,资金就会逐渐流向市值较小的山寨,直到一轮上涨结束。
2、选取ETH作为altcoins的代表,通过ETH与BTC的关系来了解加密市场的情绪和目前上涨的阶段。
3、数学原理:将ETH的价格/BTC的价格,随后将其带入RSI公式
如何使用:
1、与RSI指标类似,当cms进入超买时,代表寨币市场的活跃,市场情绪热烈,上涨进入尾声。
2、当cms进入超卖时,为上涨中BTC领涨的阶段或下降过程中资金回流BTC。
3、如果cms在低位,做多应关注altcoins,做空应关注btc,反之亦然。
Bitcoin Impact AnalyzerSummary of the "Bitcoin Impact Analyzer" script, the adjustments users can make, and an explanation of what the chart and table represent:
Script Summary:
The "Bitcoin Impact Analyzer" script is designed to help traders and analysts understand the relationship between a chosen altcoin and Bitcoin (BTC). It does this by:
Fetching price data for the specified altcoin and Bitcoin.
Calculating several key comparative metrics:
Normalized Prices: Shows the percentage performance of both assets from a common starting point.
Price Correlation: Measures how similarly the two assets' prices move over a defined period.
Beta: Indicates the altcoin's volatility relative to Bitcoin.
Altcoin/BTC Ratio: Shows the altcoin's value expressed in Bitcoin.
Fetching and displaying Bitcoin Dominance (BTC.D) data.
Visualizing these metrics on the chart as distinct plots.
Displaying the current values of these key metrics in a data table on the chart for quick reference.
The script aims to provide insights into whether an altcoin is outperforming or underperforming Bitcoin, how closely its price movements are tied to Bitcoin's, and its relative volatility.
User Adjustments:
Users can customize the script's behavior through several input settings:
Symbol Inputs:
Altcoin Symbol: Users can enter the ticker symbol for any altcoin they wish to analyze (e.g., BINANCE:ETHUSDT, KUCOIN:SOLUSDT).
Bitcoin Reference Symbol: Users can specify the Bitcoin pair to use as a reference, though BINANCE:BTCUSDT is a common default.
Lookback for Correlation/Beta:
Lookback Period: This integer value (default 50 periods) determines how many past candles are used to calculate the price correlation and beta.
A shorter lookback makes the metrics more sensitive to recent price action.
A longer lookback provides a smoother, more stable indication of the longer-term relationship.
Plot Visibility Options:
Users can toggle on or off the display of each individual plot on the chart:
Normalized BTC & Altcoin Prices
Altcoin/BTC Ratio
Correlation Plot
Bitcoin Dominance (BTC.D)
Beta Plot
This allows users to focus on specific metrics and reduce chart clutter.
What the Chart Represents:
The chart visually displays the historical trends and relationships of the selected metrics:
Normalized Prices Plot: Two lines (typically orange for BTC, blue for the altcoin) show the percentage growth of each asset from the start of the loaded chart data (or the first available data point for each symbol). This makes it easy to see which asset has performed better over time on a relative basis.
Correlation Plot: A single line (purple) oscillates between -1 and +1.
Values near +1 indicate a strong positive correlation (altcoin and BTC prices tend to move in the same direction).
Values near -1 indicate a strong negative correlation (they tend to move in opposite directions).
Values near 0 indicate little to no linear relationship.
Lines at +0.7 and -0.7 are often plotted as thresholds for "strong" correlation.
Beta Plot (if enabled): A single line (teal) shows the altcoin's volatility relative to BTC.
A Beta of 1 (often marked by a dashed line) means the altcoin has, on average, the same volatility as BTC.
Beta > 1 suggests the altcoin is more volatile than BTC (moves by a larger percentage for a given BTC move).
Beta < 1 suggests the altcoin is less volatile than BTC.
Bitcoin Dominance Plot: An area plot (gray) shows the percentage of the total cryptocurrency market capitalization that Bitcoin holds. This helps understand broader market sentiment and capital flows.
Altcoin/BTC Ratio Plot: A line (fuchsia) shows the price of the altcoin denominated in BTC.
An upward trend means the altcoin is gaining value against Bitcoin (outperforming).
A downward trend means the altcoin is losing value against Bitcoin (underperforming).
What the Table Represents:
The data table, typically located in the bottom-right corner of the chart, provides a snapshot of the current values for the most important calculated metrics. It includes:
Altcoin: The ticker symbol of the analyzed altcoin.
Bitcoin Ref: The ticker symbol of the Bitcoin reference.
Correlation (lookback): The current correlation coefficient between the altcoin and BTC, based on the specified lookback period. The value is color-coded (e.g., green for strong positive, red for strong negative).
Beta (lookback): The current beta value of the altcoin relative to BTC, based on the specified lookback period. The value may be color-coded to highlight significantly high or low volatility.
BTC.D Current: The current Bitcoin Dominance percentage.
ALT/BTC Ratio: The current price of the altcoin expressed in Bitcoin.
The table offers a quick, at-a-glance summary of the present market dynamics between the two assets without needing to interpret the lines on the chart for their exact current values.
Correlation Table by VanHelsingCorrelation Table by VanHelsing 
 Explanation: 
So we have three asset with correlation to current asset which is a BTC, also you can use it for ETH
But why only three assets? Because this one fits the best to identify a trend of BTC. 
By using let's say a GOLD this table will be far away from accuracy then this three Nasdaq, ES1!(S&P500), DXY the best one for this.
Inside a script we have kama's 
(Developed by Perry Kaufman, Kaufman's Adaptive Moving Average (KAMA) is a moving average designed to account for market noise or volatility. KAMA will closely follow prices when the price swings are relatively small and the noise is low. KAMA will adjust when the price swings widen and follow prices from a greater distance. This trend-following indicator can be used to identify the overall trend, time turning points and filter price movements.)
Now you know that KAMA is good solution for fast reaction of trend change and following it.
Now we have three assets with correlation to BTC and three kama's for them to know which trend is there.
Good!
What next? 
Next is a scoring for up trend and down trend for BTC
For Understanding I will use DXY and BTC correlation
Lets consider that DXY is moving down and kama detected it,
we have down trend on DXY. How we can score it for BTC buy or sell?
Down trend DXY and negaive correlation to BTC lets say -0.5
In this way it scoring it like 0.5 for buy BTC, because if DXY moving down it means BTC moving up because of negative correlation.
Lets say DXY moving up and correlation with BTC is again -0.5
then what? It scoring -0.5 for sell BTC because since DXY moves up and correlation is negative BTC should move down.
Okay again what if DXY moving up and correlation is positive 0.5?
Then BTC is 0.5 for buy
What if DXY down correlation 0.5? Then BTC score for sell is -0.5
In first look it seems litle bit complicated, but actually it is not, it just take a time for understand. Hope you Enjoy this lesson and hope you will enjoy this indicator!
How to read a table:
  
Describtion about minimalistic mode
  
Altcoins capitalization histogram [peregringlk]This script superseeds  "Other altcoins BTC capitalization  histogram". The previous versions was a bit confusing in my opinion and lacked some generalization, so I'm  now publishing this improved version.
It shows 6 pieces of info:
 - Green columns: BTC price change for that day.
 - Red bars: Altcoins capitalization change for that day, measured in bitcoins (altcoins_USD_capitalization / BTCUSD)
 - Green/red background: green if that day the USD capitalization change was a gain, and red if it was a loss.
 - Green line: accum BTC price change for the selected last days.
 - Red line: accum altcoin capitalization change measured in BTC for the selected days.
 - Dotted blue sequence: accum altcoin USD capitalization change for the selected days.
The base line of the histogram is 1 instead of 0, because I'm showing the price changes as multipliers (price change rates), so if there have been a +20% market movement, the calculated value will be 1.2, and if there have been a -20% market movement, then the value will be 0.8. 1 means no movement (preserved price/capitalization). Price and capitalization changes will be calculated using candle closes.
About the accumulated price changes, it will calculate the accumulated multiplication of the corresponding price change multipliers. For example, if you have set you want 3 days for the accumulation rates, and the last three days saw a -20%, +10% and +15% price/capitalization changes, the current value for the line will be 0.8*1.1*1.15 = 1.0120, or a +1.2% price change respect to the day before yesterday.
By default, if you are looking any ALTBTC market (for example, ETHBTC), instead of showing the USD and BTC capitalization of all alts, it will take the BTC and USD prices of the current market (the USD price will be calculated as ALTBTC * BTCUSD; and the BTCUSD price will be taken from BITSTAMP, the one with the longest BTC history I know in tradingview). If you are looking any other markets that is not paired with BTC, then it will take the USD capitalization of all altcoins, and the BTC capitalization will be calculated as altcoins_USD_capitalization / BTCUSD (from BITSTAMP as well).
Also, remember that, in both cases (alts capitalization or price), the graph will consistently respect the following rule:
   - btc_usd_price_change * alt/capitalization_btc_price_change = alt_usd_price_change.
That applies for both the green/red bars respect to the background, and the green/red line respect to the blue dotted sequence.
Lastly, you may want to know if, in case btc price and altbtc price or capitalization go in opposite directions, who gain the battle? For example, if BTCUSD moved +20%, and an ALTBTC price moved -20%, the result is a loss, because 1.2*0.8 = 0.96, so the ALTUSD price or capitalization moved -4% (remember that, for preserving the USD value, if today's bitcoin change rate is x, the altbtc change rate must be 1/x; so for a -20% BTCUSD price movement, there must be at least a +25% ALTBTC price change to don't loss USD value, because 1/0.8 = 1.25). The background is what shows you that: if the background is green, it means that for that day there was a total USD gain of value, and when it's red, then it was a loss of USD value.
You can customize the following things:
 -  Accum change rate interval: the "selected days". By default 7.
 -  Take alts-capitalization?: By default unmarked. The effect when is unmarked  is what I have explained in the previous paragraph. If you mark it, then it will use the USD_capitalization of all alts no matter what market you are looking right now.
 - Which capitalization do you want? There are three options, that applies when "Take alts-capitalization?" is marked, or otherwise, when you are not looking a BTC-paired market.
 - - - All-alts (default option): take CRYPTOCAP:TOTAL2 security as reference Alts-capitalization, which represents all altcoins.
 - - - Other-alts: take CRYPTOCAP:OTHERS security as reference Alts-capitalization, which represents all altcoin except the 9 most capitalized alts.
 - - - Big-alts: take CRYPTOCAP:TOTAL2 - CRYPTOCAP:OTHERS as reference Alts-capitalization, which represenst only the 9 most capitalized alts.
The idea of this script is:
   A) Figuring out what is causing a USD value gain or loss, the alts market movements, or the BTC price change. So you can spot if some altcoin, or all altcoins combined, are gaining or loosing value by themselves or because of bitcoin.
  B) Trying to spot or discover some patterns that allows you to identify altseasons. Once an altseason has been developed, the chart will show it in a pretty obvious way (massive red line bells and dotted blue lines with very high values during a period of various weeks). The hard problem is to spot it in advance, and maybe this graph can help.
三维资金流向(多色版)1️⃣ Colors Correspond to Capital Flow
Based on your multi-color logic:
Green bars → BTC-only inflow
Blue bars → Major altcoins-only inflow
Yellow bars → BTC + major altcoins inflow simultaneously
Red bars → USDT inflow (risk-off / capital retreat)
On the chart, you can observe:
Red bars densely appearing → BTC and alt prices often consolidate or decline, indicating market funds are retreating to safety.
Green bars concentrated → BTC is generally in an uptrend, indicating capital is mainly flowing into BTC.
Blue bars appearing → Major altcoins may rise while BTC is flat, showing that altcoins are absorbing funds.
Yellow bars appearing → BTC and altcoins rise together, usually signaling an overall bullish market.
2️⃣ Observed Patterns
Capital flow vs price movement:
Green + Yellow bars concentrated → BTC shows clear upward movement
Blue bars concentrated → Altcoins rise noticeably
Red bars → Both BTC and altcoins may decline or consolidate
Capital rotation phenomenon:
Red → Green → Yellow → Blue → Can be seen as a rotation of USDT → BTC → BTC+Alt → Alt
This indicates that at different stages, the market rotates between risk-off, major assets, and altcoins.
Volatility:
Tall, frequently alternating bars → Market volatility is high
Short bars → Capital flow is weak, market tends to move sideways
CMC Macro Regime PanelOverview (what it is):
A macro‑regime gate built entirely from TradingView-native symbols (CRYPTOCAP, FRED, DXY/VIX, HYG/LQD). It aggregates central‑bank liquidity (Fed balance sheet − RRP − Treasury General Account), USD strength, credit conditions, stablecoin flows/dominance, tech beta and BTC–NDX co‑move into one normalized score (CLRC). The panel outputs Risk‑ON/OFF regimes, an Early 3/5 pre‑signal, and an automatic BTC vs ETH vs ALTs preference. It is intentionally scoped to Daily & Weekly reads (no intraday timing). Publish with a clean chart and a clear description as per TradingView rules. 
TradingView
Why we also use other TradingView screens (and why that is compliant)
This script pulls data via request.security() from official TV symbols only; users often want to open the raw series on separate charts to sanity‑check:
CRYPTOCAP indices: TOTAL, TOTAL2, TOTAL3 (market cap aggregates) and dominance tickers like BTC.D, USDT.D. Helpful for regime & rotation (ALTs vs BTC). TradingView provides definitions for crypto market cap and dominance symbols. 
TradingView
+3
TradingView
+3
TradingView
+3
FRED releases: WALCL (Fed assets, weekly), RRPONTSYD (ON RRP, daily), WTREGEN (TGA, weekly), M2SL (M2, monthly). These are the official macro sources exposed on TV. 
FRED
+3
FRED
+3
FRED
+3
Risk proxies: TVC:DXY (USD index), TVC:VIX (implied vol), AMEX:HYG/AMEX:LQD (credit), NASDAQ:NDX (tech beta), BINANCE:ETHBTC. VIX/NDX relationship is well-documented; VIX measures 30‑day expected S&P500 vol. 
TradingView
+2
TradingView
+2
Compliance note: Using multiple screens is optional for users, but it explains/justifies how components work together (a requirement for public scripts). Keep publication chart clean; use extra screens only to illustrate in the description. 
TradingView
How it works (high level)
Liquidity block (Weekly/Monthly)
Net Liquidity = WALCL − RRPONTSYD − WTREGEN (YoY z‑score). WALCL is weekly (as of Wednesday) via H.4.1; RRP is daily; TGA is a Fed liability series. M2 YoY is monthly. 
FRED
+3
FRED
+3
FRED
+3
Risk conditions (Daily)
DXY 3‑month momentum (inverted), VIX level (inverted), Credit (HYG/LQD ratio or HY OAS). VIX is a 30‑day constant‑maturity implied vol index per Cboe methodology. 
Cboe
+1
Crypto‑internal (Daily)
Stablecoins (USDT+USDC+DAI 30‑day log change), USDT dominance (20‑day, inverted), TOTAL3 (63‑day momentum). Dominance symbols on TV follow a documented formula. 
TradingView
Beta & co‑move (Daily)
NDX 63‑day momentum, BTC↔NDX 90‑day correlation.
All components become z‑scores (optionally clipped), weighted, missing inputs drop and weights renormalize. We never use lookahead; we confirm on bar close to avoid repainting per Pine docs (barstate.isconfirmed, multi‑TF). 
TradingView
+2
TradingView
+2
What you see on the chart
White line (CLRC) = macro regime score.
Background: Green = Risk‑ON, Red = Risk‑OFF, Teal = Early 3/5 (pre‑signal).
Table: shows each component’s z‑score and the Preference: BTC / ETH / ALTs / Mixed.
Signals & interpretation
Designed for Daily (1D) and Weekly (1W) only.
Regime gates (default Fast preset):
Enter ON: CLRC ≥ +0.8; Hold ON while ≥ +0.5.
Enter OFF: CLRC ≤ −1.0; Hold OFF while ≤ −0.5.
0 / ±1 reading: CLRC is a standardized composite.
~0 = neutral baseline (no macro edge).
≥ +1 = strong macro tailwind (≈ +1σ).
≤ −1 = strong headwind (≈ −1σ).
Early 3/5 (teal): a fast pre‑signal when at least 3 of 5 daily checks align: USDT.D↓, DXY↓, VIX↓, HYG/LQD↑, ETHBTC↑ or TOTAL3↑. It often precedes a full ON flip—use for pre‑positioning rather than full sizing.
BTC/ETH/ALTs selector (only when ON):
ALTs when BTC.D↓ and (ETHBTC↑ or TOTAL3↑) ⇒ rotate down the risk curve.
BTC when BTC.D↑ and ETHBTC↓ ⇒ keep it concentrated.
ETH when ETHBTC↑ while BTC.D flat/up ⇒ add ETH beta.
(Dominance mechanics are documented by TV.) 
TradingView
Dissonance (incompatibility) rules — when to stand down
Use these overrides to avoid false comfort:
CLRC > +1 but USDT.D↑ and/or VIX spikes day‑over‑day → downgrade to Neutral; wait for USDT.D to stabilize and VIX to cool (VIX is a fear gauge of 30‑day expectation). 
Cboe Global Markets
CLRC > +1 but DXY↑ sharply (USD squeeze) → size below normal; require DXY momentum to roll over.
CLRC < −1 but Early 3/5 = true two days in a row → start reducing underweights; look for ON flip within a few bars.
NetLiq improving (W) but credit (HYG/LQD) deteriorating (D) → treat as mixed regime; prefer BTC over ALTs.
How to use (step‑by‑step)
A. Read on Daily (1D) — main regime
Open CRYPTOCAP:TOTAL3, 1D (panel applied).
Wait for bar close (use alerts on confirmed bar). Pine docs recommend barstate.isconfirmed to avoid repainting on realtime bars. 
TradingView
If ON, check Preference (BTC / ETH / ALTs).
Then drop to 4H on your trading pair for micro entries (this indicator itself is not for intraday timing).
B. Confirm weekly macro (1W) — once per week)
Review WALCL/RRP/TGA after the H.4.1 release on Thursdays ~4:30 pm ET. WALCL is “Weekly, as of Wednesday”; M2 is Monthly—so do not expect daily responsiveness from these. 
Federal Reserve
+2
FRED
+2
Recommended check times (practical schedule)
Daily regime read: right after your chart’s daily close (confirmed bar). For consistent timing across crypto, many users set chart timezone to UTC and read ~00:05 UTC; you can change chart timezone in TV’s settings. 
TradingView
In‑day monitoring: optional spot checks 16:00 & 20:00 UTC (DXY/VIX move during US hours), but act only after the daily bar confirms.
Weekly macro pass: Thu 21:30–22:30 UTC (after H.4.1 4:30 pm ET) or Fri after daily close, to let weekly FRED series propagate. 
Federal Reserve
Limitations & data latency (be explicit)
Higher‑TF data & confirmation: FRED weekly/monthly series will not reflect intraday risk in crypto; we aggregate them for regime, not for entry timing.
Repainting 101: Realtime bars move until close. This script does not use lookahead and follows Pine guidance on multi‑TF series; still, always act on confirmed bars. 
TradingView
+1
Public‑library compliance: Title EN‑only; description starts in EN; clean chart; justify component mash‑up; no lookahead; no unrealistic claims. 
TradingView
Alerts you can use
“Macro Risk‑ON (entry)” — fires on ON flip (confirmed bar).
“Macro Risk‑OFF (entry)” — fires on OFF flip.
“Early 3/5” — fires when the teal pre‑signal appears (not a regime flip).
“Preference change” — BTC/ETH/ALTs toggles while ON.
Publish note: Alerts are fine; just avoid implying guaranteed accuracy/performance. 
TradingView
Background research (why these inputs matter)
Liquidity → Crypto: Fed H.4.1 timing and series definitions (WALCL, RRP, TGA) formalize the “net liquidity” concept used here. 
FRED
+3
Federal Reserve
+3
FRED
+3
Stablecoins ↔ Non‑stable crypto: empirical work shows bi‑directional causality between stablecoin market cap and non‑stable crypto cap; stablecoin growth co‑moves with broader crypto activity.
Global liquidity link: world liquidity positively relates to total crypto market cap; lagged effects are observed at monthly horizons.
VIX/Uncertainty effect: fear shocks impair BTC’s “safe haven” behavior; VIX is a meaningful risk‑off read.
FEDFUNDS Rate Divergence Oscillator [BackQuant]FEDFUNDS Rate Divergence Oscillator  
 1. Concept and Rationale 
The United States Federal Funds Rate is the anchor around which global dollar liquidity and risk-free yield expectations revolve. When the Fed hikes, borrowing costs rise, liquidity tightens and most risk assets encounter head-winds. When it cuts, liquidity expands, speculative appetite often recovers. Bitcoin, a 24-hour permissionless asset sometimes described as “digital gold with venture-capital-like convexity,” is particularly sensitive to macro-liquidity swings.
The FED Divergence Oscillator quantifies the behavioural gap between short-term monetary policy (proxied by the effective Fed Funds Rate) and Bitcoin’s own percentage price change. By converting each series into identical rate-of-change units, subtracting them, then optionally smoothing the result, the script produces a single bounded-yet-dynamic line that tells you, at a glance, whether Bitcoin is outperforming or underperforming the policy backdrop—and by how much.
 2. Data Pipeline 
•  Fed Funds Rate  – Pulled directly from the FRED database via the ticker “FRED:FEDFUNDS,” sampled at daily frequency to synchronise with crypto closes.
•  Bitcoin Price  – By default the script forces a daily timeframe so that both series share time alignment, although you can disable that and plot the oscillator on intraday charts if you prefer.
•  User Source Flexibility  – The BTC series is not hard-wired; you can select any exchange-specific symbol or even swap BTC for another crypto or risk asset whose interaction with the Fed rate you wish to study.
 3. Math under the Hood 
(1)  Rate of Change (ROC)  – Both the Fed rate and BTC close are converted to percent return over a user-chosen lookback (default 30 bars). This means a cut from 5.25 percent to 5.00 percent feeds in as –4.76 percent, while a climb from 25 000 to 30 000 USD in BTC over the same window converts to +20 percent.
(2)  Divergence Construction  – The script subtracts the Fed ROC from the BTC ROC. Positive values show BTC appreciating faster than policy is tightening (or falling slower than the rate is cutting); negative values show the opposite.
(3)  Optional Smoothing  – Macro series are noisy. Toggle “Apply Smoothing” to calm the line with your preferred moving-average flavour: SMA, EMA, DEMA, TEMA, RMA, WMA or Hull. The default EMA-25 removes day-to-day whips while keeping turning points alive.
(4)  Dynamic Colour Mapping  – Rather than using a single hue, the oscillator line employs a gradient where deep greens represent strong bullish divergence and dark reds flag sharp bearish divergence. This heat-map approach lets you gauge intensity without squinting at numbers.
(5)  Threshold Grid  – Five horizontal guides create a structured regime map:
 • Lower Extreme (–50 pct) and Upper Extreme (+50 pct) identify panic capitulations and euphoria blow-offs.
 • Oversold (–20 pct) and Overbought (+20 pct) act as early warning alarms.
 • Zero Line demarcates neutral alignment.
 4. Chart Furniture and User Interface 
• Oscillator fill with a secondary DEMA-30 “shader” offers depth perception: fat ribbons often precede high-volatility macro shifts.
• Optional bar-colouring paints candles green when the oscillator is above zero and red below, handy for visual correlation.
• Background tints when the line breaches extreme zones, making macro inflection weeks pop out in the replay bar.
• Everything—line width, thresholds, colours—can be customised so the indicator blends into any template.
 5. Interpretation Guide 
 Macro Liquidity Pulse 
 • When the oscillator spends weeks above +20 while the Fed is still raising rates, Bitcoin is signalling liquidity tolerance or an anticipatory pivot view. That condition often marks the embryonic phase of major bull cycles (e.g., March 2020 rebound).
 • Sustained prints below –20 while the Fed is already dovish indicate risk aversion or idiosyncratic crypto stress—think exchange scandals or broad flight to safety.
 Regime Transition Signals 
 • Bullish cross through zero after a long sub-zero stint shows Bitcoin regaining upward escape velocity versus policy.
 • Bearish cross under zero during a hiking cycle tells you monetary tightening has finally started to bite.
 Momentum Exhaustion and Mean-Reversion 
 • Touches of +50 (or –50) come rarely; they are statistically stretched events. Fade strategies either taking profits or hedging have historically enjoyed positive expectancy.
 • Inside-bar candlestick patterns or lower-timeframe bearish engulfings simultaneously with an extreme overbought print make high-probability short scalp setups, especially near weekly resistance. The same logic mirrors for oversold.
 Pair Trading / Relative Value 
 • Combine the oscillator with spreads like BTC versus Nasdaq 100. When both the FED Divergence oscillator and the BTC–NDQ relative-strength line roll south together, the cross-asset confirmation amplifies conviction in a mean-reversion short.
 • Swap BTC for miners, altcoins or high-beta equities to test who is the divergence leader.
 Event-Driven Tactics 
 • FOMC days: plot the oscillator on an hourly chart (disable ‘Force Daily TF’). Watch for micro-structural spikes that resolve in the first hour after the statement; rapid flips across zero can front-run post-FOMC swings.
 • CPI and NFP prints: extremes reached into the release often mean positioning is one-sided. A reversion toward neutral in the first 24 hours is common.
 6. Alerts Suite 
Pre-bundled conditions let you automate workflows:
• Bullish / Bearish zero crosses – queue spot or futures entries.
• Standard OB / OS – notify for first contact with actionable zones.
• Extreme OB / OS – prime time to review hedges, take profits or build contrarian swing positions.
 7. Parameter Playground 
• Shorten ROC Lookback to 14 for tactical traders; lengthen to 90 for macro investors.
• Raise extreme thresholds (for example ±80) when plotting on altcoins that exhibit higher volatility than BTC.
• Try HMA smoothing for responsive yet smooth curves on intraday charts.
• Colour-blind users can easily swap bull and bear palette selections for preferred contrasts.
 8. Limitations and Best Practices 
• The Fed Funds series is step-wise; it only changes on meeting days. Rapid BTC oscillations in between may dominate the calculation. Keep that perspective when interpreting very high-frequency signals.
• Divergence does not equal causation. Crypto-native catalysts (ETF approvals, hack headlines) can overwhelm macro links temporarily.
• Use in conjunction with classical confirmation tools—order-flow footprints, market-profile ledges, or simple price action to avoid “pure-indicator” traps.
 9. Final Thoughts 
The FEDFUNDS Rate Divergence Oscillator distills an entire macro narrative monetary policy versus risk sentiment into a single colourful heartbeat. It will not magically predict every pivot, yet it excels at framing market context, spotting stretches and timing regime changes. Treat it as a strategic compass rather than a tactical sniper scope, combine it with sound risk management and multi-factor confirmation, and you will possess a robust edge anchored in the world’s most influential interest-rate benchmark.
Trade consciously, stay adaptive, and let the policy-price tension guide your roadmap.
Dominance DashboardThe "Dominance Dashboard" is a TradingView indicator designed to provide traders with a clear and concise visual representation of Bitcoin Dominance (BTC.D). This script helps traders monitor BTC.D in real-time, offering insights into market dynamics and potential trading signals based on the changes in Bitcoin's market dominance.
Key Features
Real-Time BTC Dominance: Displays the current Bitcoin Dominance percentage.
Historical Comparison: Shows the previous day's Bitcoin Dominance for comparison.
Visual Indicators: Utilizes color-coded arrows to indicate changes in Bitcoin Dominance (increase or decrease).
Customizable Table Settings: Users can customize the position, size, and colors of the displayed table to suit their preferences.
How It Works
Data Retrieval: The script uses request.security to fetch the latest and previous day's BTC.D data.
Comparison Mechanism: It compares the current BTC Dominance with the previous day's value to determine whether BTC.D has increased, decreased, or remained unchanged.
Dynamic Table Display: Based on user preferences, the script dynamically adjusts the table's position, text size, and colors.
Using the Indicator
Table Settings:
Show Header: Toggle the visibility of the table header.
Position: Choose from various predefined positions (e.g., Top Right, Bottom Right) to place the dashboard on your chart.
Text Size: Select the text size (Tiny, Small, Normal, Large) for better readability.
Text and Border Colors: Customize the text and border colors to match your chart's theme.
Timeframe Settings:
Show Current BTC Dominance: Enable or disable the display of the current BTC Dominance percentage.
Underlying Concepts
BTC Dominance: Bitcoin Dominance (BTC.D) measures Bitcoin's market capitalization relative to the total market capitalization of all cryptocurrencies. Monitoring BTC.D helps traders understand the flow of capital in and out of Bitcoin compared to other cryptocurrencies.
Visual Change Indicators: The script uses simple arrow symbols (🔼 for an increase and 🔽 for a decrease) to provide quick visual cues about the direction of change in BTC Dominance. This feature helps traders quickly assess market conditions without deep analysis.
Practical Use Cases
Market Sentiment Analysis: A rising BTC Dominance could indicate a market shift towards Bitcoin, potentially signaling a bearish sentiment for altcoins. Conversely, a falling BTC Dominance might suggest increased interest in altcoins.
Trend Confirmation: Traders can use BTC Dominance trends to confirm their trading strategies. For example, if a trader is bullish on Bitcoin, an increasing BTC Dominance might reinforce their position.
Portfolio Management: By monitoring BTC Dominance, traders can make informed decisions about portfolio rebalancing between Bitcoin and other cryptocurrencies.
Ark Crypto HeatlineThis is the 'on chart' indicator. See also "Ark Crypto Heatband" indicator for a side-by-side BTC view, without a re-scaled line.
The crypto landscape is largely dominated by BTC and characterised by cyclical stages with varying degrees of mean reversion.
To understand what stage of the cycle we are currently experiencing, it is useful to examine to what degree the current price has extended beyond the long term average that BTC has established. This is true even when analysing other crypto assets as BTC is the dominant force in the crypto asset class.
This indicator uses the 1400 period daily SMA , which is broadly the 200 period weekly SMA. This can be configured, but historically has represented a baseline to which BTC commonly returns.
The graph plots current price in terms of multiples of this long term average. Traditionally, at multiples beyond 10, BTC is considered overextended with a higher likelihood of trending towards the mean thereafter. Colors indicate the extent of price extension.
Where the indicator is applied to non BTCUSD pairs, a smoothed conversion is applied, seeking to superimpose the BTC long period SMA onto the current chart.
The indicator specifically references BTC by default on all charts, as it is designed to use BTC as general purpose indication of where crypto as a whole currently sits. Accordingly the indicator is only to be used on crypto charts.
For best results on BTC, using BNC:BLX will give the longest historical view.
Regime Filter IndicatorRegime Filter – Crypto Market Trend Indicator
📊 Overview
The Regime Filter is a powerful market analysis indicator designed specifically for crypto trading. It helps traders identify whether the market is in a bullish or bearish phase by analyzing key assets in the cryptocurrency market, including Bitcoin (BTC), Bitcoin Dominance (BTC.D), and the Altcoin Market (TOTAL3). The indicator compares these assets against their respective Simple Moving Averages (SMA) to determine the overall market regime, allowing traders to make more informed decisions.
🔍 How It Works
The Regime Filter evaluates three main components to determine the market's sentiment:
1. BTC Dominance (BTC.D) vs. 40 SMA (Medium Timeframe)
    The Bitcoin Dominance (BTC.D) is compared to its 40-period SMA on a mid-timeframe (e.g., 
    1-hour). If BTC.D is below the 40 SMA, it indicates that altcoins are performing well relative 
    to Bitcoin, suggesting a bullish altcoin market. If BTC.D is above the 40 SMA, Bitcoin is 
    gaining dominance, indicating a potential bearish phase for altcoins.
2. TOTAL3 Market Cap vs. 100 SMA (Medium Timeframe)
   The TOTAL3 index, which tracks the total market capitalization of all cryptocurrencies except 
   Bitcoin and Ethereum, is compared to its 100-period SMA. A bullish signal occurs when TOTAL3 
   is above the 100 SMA, indicating strength in altcoins, while a bearish signal occurs when 
   TOTAL3 is below the 100 SMA, signaling a potential weakness in the altcoin market.
3. BTC Price vs. 200 SMA (Higher Timeframe)
    The current Bitcoin price is compared to its 200-period Simple Moving Average (SMA) on a 
    higher timeframe (e.g., 4-hour). A bullish signal is given when the BTC price is above the 200 
    SMA, and a bearish signal when it's below.
🟢 Bullish Market Conditions
The market is considered bullish when:
- BTC Dominance (BTC.D) is below the 40 SMA, suggesting altcoins are gaining momentum.
- TOTAL3 Market Cap is above the 100 SMA, signaling strength in the altcoin market.
- BTC price is above the 200 SMA, indicating an uptrend in Bitcoin.
In these conditions, the background turns green 🟢, and a "Bullish" label is displayed on the chart.
🔴 Bearish Market Conditions
The market is considered bearish when:
- BTC Dominance (BTC.D) is above the 40 SMA, indicating Bitcoin is outperforming altcoins.
- TOTAL3 Market Cap is below the 100 SMA, signaling weakness in altcoins.
- BTC price is below the 200 SMA, indicating a downtrend in Bitcoin.
In these conditions, the background turns red 🔴, and a "Bearish" label appears on the chart.
⚙ Customization Options
- The Regime Filter offers flexibility for traders:
- Enable or Disable Specific SMAs: Customize the indicator by enabling or disabling the 200 SMA for Bitcoin, the 40 SMA for BTC Dominance, and the 100 SMA for TOTAL3.
- Adjust Timeframes: Choose the timeframes for each of the moving averages to suit your preferred trading strategy.
- Real-Time Data Adjustments: The indicator updates in real-time to reflect current market conditions, ensuring timely analysis.
📈 Best Use Cases
- Trend Confirmation: The Regime Filter is ideal for confirming the market's overall trend, 
  helping traders to align their positions with the dominant market sentiment.
- Trade Entry/Exit Signals: Use the indicator to identify favorable entry or exit points based on 
  whether the market is in a bullish or bearish phase.
- Market Overview: Gain a quick understanding of the broader crypto market, with a focus on 
  Bitcoin and altcoins, to make more strategic decisions.
⚠️ Important Notes
Trend-Following Indicator: The Regime Filter is a trend-following tool, meaning it works best in strong trending markets. It may not perform well in choppy, sideways markets.
Risk Management: This indicator is designed to assist in identifying market trends, but it does not guarantee profits. Always apply sound risk management strategies and use additional indicators when making trading decisions.
Not a Profit Guarantee: While this indicator can help identify potential market trends, no trading tool or strategy guarantees profits. Please trade responsibly and ensure that your decisions are based on comprehensive analysis 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!
Realized PriceBitcoin Realized Price is a metric that determines the value of all bitcoins in circulation by dividing the total purchase price by the number of bitcoins. This provides traders with the average cost basis for all bitcoins in circulation, which is also known as Realized Price.
Unlike the current Market Price that reflects the current value of  CRYPTOCAP:BTC , Realized Price shows the average purchase price of all bitcoins in circulation. It is essential to note that Realized Price values each UTXO based on the value when it last moved from one wallet to another, assuming that the movement represents the purchase of the bitcoins.
The significance of Bitcoin Realized Price lies in its ability to provide traders with an overall economic perspective of the Bitcoin market. When the  CRYPTOCAP:BTC  Market Price exceeds the Realized Price, the market participants are making a profit on average. Conversely, when the  CRYPTOCAP:BTC  Market Price is lower than the Realized Price, traders are incurring paper losses on average.
It's worth noting that Realized Price is a modification of Realized Cap, created in 2018 by Antoine Le Calvez.
In addition to BTC I have added LTC and ETH
NB! 
Script is history data depended - use on charts with most history data
BTC -> BNC:BLX
ETH -> BITSTAMP:ETHUSD
LTC -> BITFINEX:LTCUSD
it plots realized price and its deviation - when price break out from these bands it explodes hard - near the realized price is good to accumulate the coin - it is fair price
Examples
BTC
  
  
ETH
  
LTC
 






















