TrendLibrary   "Trend" 
 calculateSlopeTrend(source, length, thresholdMultiplier) 
  Parameters:
     source (float) 
     length (int) 
     thresholdMultiplier (float) 
 Purpose: 
The primary goal of this function is to determine the short-term trend direction of a given data series (like closing prices). It does this by calculating the slope of the data over a specified period and then comparing that slope against a dynamic threshold based on the data's recent volatility. It classifies the trend into one of three states: Upward, Downward, or Flat.
 Parameters: 
 
 `source` (Type: `series float`): This is the input data series you want to analyze. It expects a series of floating-point numbers, typically price data like `close`, `open`, `hl2` (high+low)/2, etc.
 `length` (Type: `int`): This integer defines the lookback period. The function will analyze the `source` data over the last `length` bars to calculate the slope and standard deviation.
 `thresholdMultiplier` (Type: `float`, Default: `0.1`): This is a sensitivity factor. It's multiplied by the standard deviation to determine how steep the slope needs to be before it's considered a true upward or downward trend. A smaller value makes it more sensitive (detects trends earlier, potentially more false signals), while a larger value makes it less sensitive (requires a stronger move to confirm a trend).
 
 Calculation Steps: 
 
 Linear Regression:  It first calculates the value of a linear regression line fitted to the `source` data over the specified `length` (`ta.linreg(source, length, 0)`). Linear regression finds the "best fit" straight line through the data points.
 Slope Calculation:  It then determines the slope of this linear regression line. Since `ta.linreg` gives the *value* of the line on the current bar, the slope is calculated as the difference between the current bar's linear regression value (`linRegValue`) and the previous bar's value (`linRegValue `). A positive difference means an upward slope, negative means downward.
 Volatility Measurement:  It calculates the standard deviation (`ta.stdev(source, length)`) of the `source` data over the same `length`. Standard deviation is a measure of how spread out the data is, essentially quantifying its recent volatility.
 Adaptive Threshold:  An adaptive threshold (`threshold`) is calculated by multiplying the standard deviation (`stdDev`) by the `thresholdMultiplier`. This is crucial because it means the definition of a "flat" trend adapts to the market's volatility. In volatile times, the threshold will be wider, requiring a larger slope to signal a trend. In quiet times, the threshold will be narrower.
 Trend Determination:  Finally, it compares the calculated `slope` to the adaptive `threshold`:
 
 
 If the `slope` is greater than the positive `threshold`, the trend is considered **Upward**, and the function returns `1`.
 If the `slope` is less than the negative `threshold` (`-threshold`), the trend is considered **Downward**, and the function returns `-1`.
 If the `slope` falls between `-threshold` and `+threshold` (inclusive of 0), the trend is considered **Flat**, and the function returns `0`.
 
 Return Value: 
The function returns an integer representing the determined trend direction:
 
 `1`: Upward trend
 `-1`: Downward trend
 `0`: Flat trend
 
In essence, this library function provides a way to gauge trend direction using linear regression, but with a smart filter (the adaptive threshold) to avoid classifying minor noise or low-volatility periods as significant trends.
Linear
LinearRegressionLibrary   "LinearRegression" 
Calculates a variety of linear regression and deviation types, with optional emphasis weighting. Additionally, multiple of slope and Pearson’s R calculations.
 calcSlope(_src, _len, _condition) 
  Calculates the slope of a linear regression over the specified length.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The length of the lookback period for the linear regression.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast for efficiency.
  Returns: (float) The slope of the linear regression.
 calcReg(_src, _len, _condition) 
  Calculates a basic linear regression, returning y1, y2, slope, and average.
  Parameters:
     _src (float) : (float) The source data series.
     _len (int) : (int) The length of the lookback period.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: (float ) An array of 4 values:  .
 calcRegStandard(_src, _len, _emphasis, _condition) 
  Calculates an Standard linear regression with optional emphasis.
  Parameters:
     _src (float) : (series float) The source data series.
     _len (int) : (int) The length of the lookback period.
     _emphasis (float) : (float) The emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: (float )  .
 calcRegRidge(_src, _len, lambda, _emphasis, _condition) 
  Calculates a ridge regression with optional emphasis.
  Parameters:
     _src (float) : (float) The source data series.
     _len (int) : (int) The length of the lookback period.
     lambda (float) : (float) The ridge regularization parameter.
     _emphasis (float) : (float) The emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: (float )  .
 calcRegLasso(_src, _len, lambda, _emphasis, _condition) 
  Calculates a Lasso regression with optional emphasis.
  Parameters:
     _src (float) : (float) The source data series.
     _len (int) : (int) The length of the lookback period.
     lambda (float) : (float) The Lasso regularization parameter.
     _emphasis (float) : (float) The emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: (float )  .
 calcElasticNetLinReg(_src, _len, lambda1, lambda2, _emphasis, _condition) 
  Calculates an Elastic Net regression with optional emphasis.
  Parameters:
     _src (float) : (float) The source data series.
     _len (int) : (int) The length of the lookback period.
     lambda1 (float) : (float) L1 regularization parameter (Lasso).
     lambda2 (float) : (float) L2 regularization parameter (Ridge).
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: (float )  .
 calcRegHuber(_src, _len, delta, iterations, _emphasis, _condition) 
  Calculates a Huber regression using Iteratively Reweighted Least Squares (IRLS).
  Parameters:
     _src (float) : (float) The source data series.
     _len (int) : (int) The length of the lookback period.
     delta (float) : (float) Huber threshold parameter.
     iterations (int) : (int) Number of IRLS iterations.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: (float )  .
 calcRegLAD(_src, _len, iterations, _emphasis, _condition) 
  Calculates a Least Absolute Deviations (LAD) regression via IRLS.
  Parameters:
     _src (float) : (float) The source data series.
     _len (int) : (int) The length of the lookback period.
     iterations (int) : (int) Number of IRLS iterations for LAD.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: (float )  .
 calcRegBayesian(_src, _len, priorMean, priorSpan, sigma, _emphasis, _condition) 
  Calculates a Bayesian linear regression with optional emphasis.
  Parameters:
     _src (float) : (float) The source data series.
     _len (int) : (int) The length of the lookback period.
     priorMean (float) : (float) The prior mean for the slope.
     priorSpan (float) : (float) The prior variance (or span) for the slope.
     sigma (float) : (float) The assumed standard deviation of residuals.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: (float )  .
 calcRFromLinReg(_src, _len, _slope, _average, _y1, _condition) 
  Calculates the Pearson correlation coefficient (R) based on linear regression parameters.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The length of the lookback period.
     _slope (float) : (float) The slope of the linear regression.
     _average (float) : (float) The average value of the source data series.
     _y1 (float) : (float) The starting point (y-intercept of the oldest bar) for the linear regression.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast for efficiency.
  Returns: (float) The Pearson correlation coefficient (R) adjusted for the direction of the slope.
 calcRFromSource(_src, _len, _condition) 
  Calculates the correlation coefficient (R) using a specified length and source data.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The length of the lookback period.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast for efficiency.
  Returns: (float) The correlation coefficient (R).
 calcSlopeLengthZero(_src, _len, _minLen, _step, _condition) 
  Identifies the length at which the slope is flattest (closest to zero).
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The maximum lookback length to consider (minimum of 2).
     _minLen (int) : (int) The minimum length to start from (cannot exceed the max length).
     _step (int) : (int) The increment step for lengths.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast.
  Returns: (int) The length at which the slope is flattest.
 calcSlopeLengthHighest(_src, _len, _minLen, _step, _condition) 
  Identifies the length at which the slope is highest.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The maximum lookback length (minimum of 2).
     _minLen (int) : (int) The minimum length to start from.
     _step (int) : (int) The step for incrementing lengths.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast.
  Returns: (int) The length at which the slope is highest.
 calcSlopeLengthLowest(_src, _len, _minLen, _step, _condition) 
  Identifies the length at which the slope is lowest.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The maximum lookback length (minimum of 2).
     _minLen (int) : (int) The minimum length to start from.
     _step (int) : (int) The step for incrementing lengths.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast.
  Returns: (int) The length at which the slope is lowest.
 calcSlopeLengthAbsolute(_src, _len, _minLen, _step, _condition) 
  Identifies the length at which the absolute slope value is highest.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The maximum lookback length (minimum of 2).
     _minLen (int) : (int) The minimum length to start from.
     _step (int) : (int) The step for incrementing lengths.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast.
  Returns: (int) The length at which the absolute slope value is highest.
 calcRLengthZero(_src, _len, _minLen, _step, _condition) 
  Identifies the length with the lowest absolute R value.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The maximum lookback length (minimum of 2).
     _minLen (int) : (int) The minimum length to start from.
     _step (int) : (int) The step for incrementing lengths.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast.
  Returns: (int) The length with the lowest absolute R value.
 calcRLengthHighest(_src, _len, _minLen, _step, _condition) 
  Identifies the length with the highest R value.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The maximum lookback length (minimum of 2).
     _minLen (int) : (int) The minimum length to start from.
     _step (int) : (int) The step for incrementing lengths.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast.
  Returns: (int) The length with the highest R value.
 calcRLengthLowest(_src, _len, _minLen, _step, _condition) 
  Identifies the length with the lowest R value.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The maximum lookback length (minimum of 2).
     _minLen (int) : (int) The minimum length to start from.
     _step (int) : (int) The step for incrementing lengths.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast.
  Returns: (int) The length with the lowest R value.
 calcRLengthAbsolute(_src, _len, _minLen, _step, _condition) 
  Identifies the length with the highest absolute R value.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The maximum lookback length (minimum of 2).
     _minLen (int) : (int) The minimum length to start from.
     _step (int) : (int) The step for incrementing lengths.
     _condition (bool) : (bool) Flag to enable calculation. Set to true to calculate on every bar; otherwise, set to barstate.islast.
  Returns: (int) The length with the highest absolute R value.
 calcDevReverse(_src, _len, _slope, _y1, _inputDev, _emphasis, _condition) 
  Calculates the regressive linear deviation in reverse order, with optional emphasis on recent data.
  Parameters:
     _src (float) : (float) The source data.
     _len (int) : (int) The length of the lookback period.
     _slope (float) : (float) The slope of the linear regression.
     _y1 (float) : (float) The y-intercept (oldest bar) of the linear regression.
     _inputDev (float) : (float) The input deviation multiplier.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: A 2-element tuple:  .
 calcDevForward(_src, _len, _slope, _y1, _inputDev, _emphasis, _condition) 
  Calculates the progressive linear deviation in forward order (oldest to most recent bar), with optional emphasis.
  Parameters:
     _src (float) : (float) The source data array, where _src  is oldest and _src  is most recent.
     _len (int) : (int) The length of the lookback period.
     _slope (float) : (float) The slope of the linear regression.
     _y1 (float) : (float) The y-intercept of the linear regression (value at the most recent bar, adjusted by slope).
     _inputDev (float) : (float) The input deviation multiplier.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: A 2-element tuple:  .
 calcDevBalanced(_src, _len, _slope, _y1, _inputDev, _emphasis, _condition) 
  Calculates the balanced linear deviation with optional emphasis on recent or older data.
  Parameters:
     _src (float) : (float) Source data array, where _src  is the most recent and _src  is the oldest.
     _len (int) : (int) The length of the lookback period.
     _slope (float) : (float) The slope of the linear regression.
     _y1 (float) : (float) The y-intercept of the linear regression (value at the oldest bar).
     _inputDev (float) : (float) The input deviation multiplier.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: A 2-element tuple:  .
 calcDevMean(_src, _len, _slope, _y1, _inputDev, _emphasis, _condition) 
  Calculates the mean absolute deviation from a forward-applied linear trend (oldest to most recent), with optional emphasis.
  Parameters:
     _src (float) : (float) The source data array, where _src  is the most recent and _src  is the oldest.
     _len (int) : (int) The length of the lookback period.
     _slope (float) : (float) The slope of the linear regression.
     _y1 (float) : (float) The y-intercept (oldest bar) of the linear regression.
     _inputDev (float) : (float) The input deviation multiplier.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: A 2-element tuple:  .
 calcDevMedian(_src, _len, _slope, _y1, _inputDev, _emphasis, _condition) 
  Calculates the median absolute deviation with optional emphasis on recent data.
  Parameters:
     _src (float) : (float) The source data array (index 0 = oldest, index _len - 1 = most recent).
     _len (int) : (int) The length of the lookback period.
     _slope (float) : (float) The slope of the linear regression.
     _y1 (float) : (float) The y-intercept (oldest bar) of the linear regression.
     _inputDev (float) : (float) The deviation multiplier.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns:  
 calcDevPercent(_y1, _inputDev, _condition) 
  Calculates the percent deviation from a given value and a specified percentage.
  Parameters:
     _y1 (float) : (float) The base value from which to calculate deviation.
     _inputDev (float) : (float) The deviation percentage.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: A 2-element tuple:  .
 calcDevFitted(_len, _slope, _y1, _emphasis, _condition) 
  Calculates the weighted fitted deviation based on high and low series data, showing max deviation, with optional emphasis.
  Parameters:
     _len (int) : (int) The length of the lookback period.
     _slope (float) : (float) The slope of the linear regression.
     _y1 (float) : (float) The Y-intercept (oldest bar) of the linear regression.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: A 2-element tuple:  .
 calcDevATR(_src, _len, _slope, _y1, _inputDev, _emphasis, _condition) 
  Calculates an ATR-style deviation with optional emphasis on recent data.
  Parameters:
     _src (float) : (float) The source data (typically close).
     _len (int) : (int) The length of the lookback period.
     _slope (float) : (float) The slope of the linear regression.
     _y1 (float) : (float) The Y-intercept (oldest bar) of the linear regression.
     _inputDev (float) : (float) The input deviation multiplier.
     _emphasis (float) : (float) Emphasis factor: 0 for equal weight; >0 emphasizes recent bars; <0 emphasizes older bars.
     _condition (bool) : (bool) Flag to enable calculation (true = calculate).
  Returns: A 2-element tuple:  .
 calcPricePositionPercent(_top, _bot, _src) 
  Calculates the percent position of a price within a linear regression channel. Top=100%, Bottom=0%.
  Parameters:
     _top (float) : (float) The top (positive) deviation, corresponding to 100%.
     _bot (float) : (float) The bottom (negative) deviation, corresponding to 0%.
     _src (float) : (float) The source price.
  Returns: (float) The percent position within the channel.
 plotLinReg(_len, _y1, _y2, _slope, _devTop, _devBot, _scaleTypeLog, _lineWidth, _extendLines, _channelStyle, _colorFill, _colUpLine, _colDnLine, _colUpFill, _colDnFill) 
  Plots the linear regression line and its deviations, with configurable styles and fill.
  Parameters:
     _len (int) : (int) The lookback period for the linear regression.
     _y1 (float) : (float) The starting y-value of the regression line.
     _y2 (float) : (float) The ending y-value of the regression line.
     _slope (float) : (float) The slope of the regression line (used to determine line color).
     _devTop (float) : (float) The top deviation to add to the line.
     _devBot (float) : (float) The bottom deviation to subtract from the line.
     _scaleTypeLog (bool) : (bool) Use a log scale if true; otherwise, linear scale.
     _lineWidth (int) : (int) The width of the plotted lines.
     _extendLines (string) : (string) How lines should extend (none, left, right, both).
     _channelStyle (string) : (string) The style of the channel lines (solid, dashed, dotted).
     _colorFill (bool) : (bool) Whether to fill the space between the top and bottom deviation lines.
     _colUpLine (color) : (color) Line color when slope is positive.
     _colDnLine (color) : (color) Line color when slope is negative.
     _colUpFill (color) : (color) Fill color when slope is positive.
     _colDnFill (color) : (color) Fill color when slope is negative.
regressionsLibrary   "regressions" 
This library computes least square regression models for polynomials of any form for a given data set of x and y values.
 fit(X, y, reg_type, degrees) 
  Takes a list of X and y values and the degrees of the polynomial and returns a least square regression for the given polynomial on the dataset.
  Parameters:
     X (array) : (float )    X inputs for regression fit.
     y (array) : (float ) 	 y outputs for regression fit.
     reg_type (string) : (string)	 The type of regression. If passing value for degrees use reg.type_custom
     degrees (array) : (int )      The degrees of the polynomial which will be fit to the data. ex: passing array.from(0, 3) would be a polynomial of form c1x^0 + c2x^3 where c2 and c1 will be coefficients of the best fitting polynomial.
  Returns: (regression) returns a regression with the best fitting coefficients for the selecected polynomial
 regress(reg, x) 
  Regress one x input.
  Parameters:
     reg (regression) : (regression) The fitted regression which the y_pred will be calulated with.
     x (float) : (float)      The input value cooresponding to the y_pred.
  Returns: (float)		 The best fit y value for the given x input and regression.
 predict(reg, X) 
  Predict a new set of X values with a fitted regression. -1 is one bar ahead of the realtime
  Parameters:
     reg (regression) : (regression) 		The fitted regression which the y_pred will be calulated with.
     X (array) 
  Returns: (float )		 	The best fit y values for the given x input and regression.
 generate_points(reg, x, y, left_index, right_index) 
  Takes a regression object and creates chart points which can be used for plotting visuals like lines and labels.
  Parameters:
     reg (regression) : (regression)    Regression which has been fitted to a data set.
     x (array) : (float )		x values which coorispond to passed y values
     y (array) : (float )		y values which coorispond to passed x values
     left_index (int) : (int)      		The offset of the bar farthest to the realtime bar should be larger than left_index value.
     right_index (int) : (int)      		The offset of the bar closest to the realtime bar should be less than right_index value.
  Returns: (chart.point )	 Returns an array of chart points
 plot_reg(reg, x, y, left_index, right_index, curved, close, line_color, line_width) 
  Simple plotting function for regression	for more custom plotting use generate_points() to create points then create your own plotting function.
  Parameters:
     reg (regression) : (regression) 	Regression which has been fitted to a data set.
     x (array) 
     y (array) 
     left_index (int) : (int)      		The offset of the bar farthest to the realtime bar should be larger than left_index value.
     right_index (int) : (int)      		The offset of the bar closest to the realtime bar should be less than right_index value.
     curved (bool) : (bool)  		If the polyline is curved or not.
     close (bool) : (bool)  		If true the polyline will be closed.
     line_color (color) : (color) 		The color of the line.
     line_width (int) : (int) 			The width of the line.
  Returns: (polyline)      The polyline for the regression.
 series_to_list(src, left_index, right_index) 
  Convert a series to a list. Creates a list of all the cooresponding source values
from left_index to right_index. This should be called at the highest scope for consistency.
  Parameters:
     src (float) : (float ) 	The source the list will be comprised of.
     left_index (int) : (float )   The left most bar (farthest back historical bar) which the cooresponding source value will be taken for.
     right_index (int) : (float )   The right most bar closest to the realtime bar which the cooresponding source value will be taken for.
  Returns: (float )  	An array of size left_index-right_index
 range_list(start, stop, step) 
  Creates an from the start value to the stop value.
  Parameters:
     start (int) : (float ) 	The true y values.
     stop (int) : (float )   The predicted y values.
     step (int) : (int)   	Positive integer. The spacing between the values. ex: start=1, stop=6, step=2:  
  Returns: (float )  	An array of size stop-start
 regression 
  Fields:
     coeffs (array__float) 
     degrees (array__float) 
     type_linear (series__string) 
     type_quadratic (series__string) 
     type_cubic (series__string) 
     type_custom (series__string) 
     _squared_error (series__float) 
     X (array__float)
LTI_FiltersLinear Time-Invariant (LTI) filters are fundamental tools in signal processing that operate with consistent behavior over time and linearly respond to input signals. They are crucial for analyzing and manipulating signals in various applications, ensuring the output signal's integrity is maintained regardless of when an input is applied or its magnitude. The Windowed Sinc filter is a specific type of LTI filter designed for digital signal processing. It employs a Sinc function, ideal for low-pass filtering, truncated and shaped within a finite window to make it practically implementable. This process involves multiplying the Sinc function by a window function, which tapers off towards the ends, making the filter finite and suitable for digital applications. Windowed Sinc filters are particularly effective for tasks like data smoothing and removing unwanted frequency components, balancing between sharp cutoff characteristics and minimal distortion. The efficiency of Windowed Sinc filters in digital signal processing lies in their adept use of linear algebra, particularly in the convolution process, which combines input data with filter coefficients to produce the desired output. This mathematical foundation allows for precise control over the filtering process, optimizing the balance between filtering performance and computational efficiency. By leveraging linear algebra techniques such as matrix multiplication and Toeplitz matrices, these filters can efficiently handle large datasets and complex filtering tasks, making them invaluable in applications requiring high precision and speed, such as audio processing, financial signal analysis, and image restoration.
Library   "LTI_Filters" 
 offset(length, enable) 
  Calculates the time offset required for aligning the output of a filter with its input, based on the filter's length. This is useful for centered filters where the output is naturally shifted due to the filter's operation.
  Parameters:
     length (simple int) : The length of the filter.
     enable (simple bool) : A boolean flag to enable or dissable the offset calculation.
  Returns: The calculated offset if enabled; otherwise, returns 0.
 lti_filter(filter_type, source, length, prefilter, centered, fc, window_type) 
  General-purpose Linear Time-Invariant (LTI) filter function that can apply various filter types to a data series. Can be used to apply a variety of LTI filters with different characteristics to financial data series or other time series data.
  Parameters:
     filter_type (simple string) : Specifies the type of filter. ("Sinc", "SMA", "WMA")
     source (float) : The input data series to filter.
     length (simple int) : The length of the filter.
     prefilter (simple bool) : Boolean indicating whether to prefilter the input data.
     centered (simple bool) : Determines whether the filter coefficients are centered.
     fc (simple float) : Filter cutoff. Expressed like a length.
     window_type (simple string) : Type of window function to apply. ("Hann", "Hamming", "Blackman", "Triangular", "Lanczos", "None")
  Returns: The filtered data series.
 lti_sma(source, length, prefilter) 
  Applies a Simple Moving Average (SMA) filter to the data series. Useful for smoothing data series to identify trends or for use as a component in more complex indicators.
  Parameters:
     source (float) : The input data series to filter.
     length (simple int) : The length of the SMA filter.
     prefilter (simple bool) : Boolean indicating whether to prefilter the input data.
  Returns: The SMA-filtered data series.
 lti_wma(source, length, prefilter, centered) 
  Applies a Weighted Moving Average (WMA) filter to a data series. Ideal for smoothing data with emphasis on more recent values, allowing for dynamic adjustments to the weighting scheme.
  Parameters:
     source (float) : The input data series to filter.
     length (simple int) : The length of the WMA filter.
     prefilter (simple bool) : Boolean indicating whether to prefilter the input data.
     centered (simple bool) : Determines whether the filter coefficients are centered.
  Returns: The WMA-filtered data series.
 lti_sinc(source, length, prefilter, centered, fc, window_type) 
  Applies a Sinc filter to a data series, optionally using a window function. Particularly useful for signal processing tasks within financial analysis, such as smoothing or trend identification, with the ability to fine-tune filter characteristics.
  Parameters:
     source (float) : The input data series to filter.
     length (simple int) : The length of the Sinc filter.
     prefilter (simple bool) : Boolean indicating whether to prefilter the input data.
     centered (simple bool) : Determines whether the filter coefficients are centered.
     fc (simple float) : Filter cutoff. Expressed like a length.
     window_type (simple string) : Type of window function to apply. ("Hann", "Hamming", "Blackman", "Triangular", "Lanczos", "None")
  Returns: The Sinc-filtered data series.
regressLibrary   "regress" 
produces the slope (beta), y-intercept (alpha) and coefficient of determination for a linear regression
 regress(x, y, len)  regress: computes alpha, beta, and r^2 for a linear regression of y on x
  Parameters:
     x : the explaining (independent) variable
     y : the dependent variable
     len : use the most recent "len" values of x and y
  Returns:  : alpha is the x-intercept, beta is the slope, an r2 is the coefficient of determination
Note: the chart does not show anything, use the return values to compute model values in your own application, if you wish.




