OPEN-SOURCE SCRIPT
Updated

Functions Allowing Series As Length - PineCoders FAQ

█ WARNING


Improvements to the following Pine built-ins have deprecated the vast majority of this publication's functions, as the built-ins now accept "series int" `length` arguments:



NOTE
For an ​EMA function that allows a "series int" argument for `length`, please see `ema2()` in the ta library by TradingView.



█ ORIGINAL DESCRIPTION


Pinescript requires many of its built-in functions to use a simple int as their period length, which entails the period length cannot vary during the script's execution. These functions allow using a series int or series float for their period length, which means it can vary on each bar.

The functions shared in this script include:
  • Rolling sum: Sum(src,p)
  • Simple moving average: Sma(src,p)
  • Rolling variance: Variance(src,p)
  • Rolling standard deviation: Stdev(src,p)
  • Rolling covariance: Covariance(x,y,p)
  • Rolling correlation: Correlation(x,y,p)


If p is a float then it is rounded to the nearest int.

How to Use the Script
Most of the functions in the script are dependent on the Sma function. The Correlation function uses the Covariance and Stdev functions. Be sure you include all the required functions in your script.

Make sure the series you use as the length argument is greater than 0, else the functions will return na. When using a series as length argument, the following error might appear:

This can be frequent if you use barssince(condition) where condition is a relatively rare event. You can fix it by including max_bars_back=5000 in your study declaration statement as follows:


Example
The chart shows the Sma, Stdev, Covariance and Correlation functions. The Sma uses the closing price as input and bars as period length where:



The Stdev uses the closing price as input and bars + 9 as period length. The Covariance and Correlation use the closing price as x and bar_index as y, with bars + 9 as period length.



Look first. Then leap.

Release Notes
Updated Comments
Release Notes
- Added the linearly weighted moving average as Wma and the least squares moving average as Lsma.
- Updated Comments
Release Notes
- Added Ema function
- Added Atr function
- Updated comments

Disclaimer