no place to be ending but somewhere to start

Smoothing algorithms have a variety of applications from reducing short-term fluctuations in time series data, to forecasting, to edge detection and noise reduction in image processing. In this post, we’ll take a look at a group of smoothing algorithms available in traquer applied to time-series data.

some context

The following smoothing algorithms use Apple’s (AAPL) daily stock price over a roughly 6.5 year period as input. When applicable, a window size of 16 is used which is probably closer to the lower end of lookback lengths. In most cases, the suggested defaults (from Bing) of a algorithm are used. Yes, the hottest take in this post is Bing is better than Google at the time of writing (the author’s views may not reflect reality).

This post aims to highlight differences in behaviour between algorithms and does not intend to suggest which algorithms are best. Depending on use case, a flatter, smoother result may be desirable and in other cases, the opposite. Additionally, the post is subjective and should be questioned as the author has no statistical background, has not been in school for many years, and continues to refute the solution to the Monty Hall problem.

the basics

A common smoothing technique is to apply weights to each point across a window of values. These weights can be set to: treat all values in window equally; linearly place more weight on recent data or some other pattern. The first set of moving averages cover: Simple Moving Average (SMA), (linearly) Weighted Moving Average (WMA), Fibonacci Weighted Moving Average (FWMA), and Pascal’s Triangle Weighted Moving Average (PWMA).

weighted moving averages

analysis

exponential and simple derivatives

Rather than looking back a fixed length, another technique is to incrementally roll forward and combine the entire past with the new data. Exponential Weighted Moving Average (EWMA) and Wilder’s Moving Average (Wilder) leverage this technique. Additionally, applying these techniques multiple times can produce alternative smoothed data which is what Double Exponential Weighted (DEMA), Triple Exponential Weighted (TEMA), and Triangular Moving Average (TRIMA) do.

exponential moving averages

analysis

1 + 1 = window

Beyond the moving average algorithms described above, alternative algorithms can be applied from simple techniques such as adding scaling factors or leveraging linear regression to applying Gaussian distributions and what can be described as “an equation formed by spilling a box of toothpicks on the floor.” These algorithms are broken in 3 arbitrary groups.

group 1

The following shows T3 Moving Average (T3), McGinley Dynamic Moving Average (MDMA), Hull’s Moving Average (HULL), and Zero Lag Moving Average (ZLMA).

group 1 moving averages

analysis

group 2

The next group consists of Linear Regression Forecast LRF, Volatility Index Dynamic Average (VIDYA), Variable Moving Average (VMA), and Kaufman Adaptive Moving Average (KAMA).

group 2 moving averages

analysis

group3

The last group contains algorithms with arguably the most novel designs, some of them inexplicable. These are: Kernel Regression (KERNEL), Arnaud Legoux Moving Average (ALMA), Holt-Winter Moving Average (HWMA), Super Smoother Filter (SSF), and MESA Adaptive Moving Average (MAMA).

It should be noted that the Kernel Regression algorithm is slightly modified from what is typically stated on internet. The implementation only tracks up to 255 datapoints and does not factor in future data. Therefore, it’s actually only apply half of the Gaussian curve.

group 3 moving averages

analysis

measurements

The following shows the difference between the smoothed data and the raw data. Mean Absolute Error (MAE) shows the average residual; Root Mean Squared Error (RMSE) shows similar measure but captures outliers better; Mean Directional Accuracy (MDA) captures how closes it matches direction changes and R-squared (RSQ) is the average R-squared value over 50 datapoint windows.

A higher MDA/RSQ and lower MAE/RMSE does not necessarily suggest a better line. It most likely implies the line contains more noise.

ALGO MAE RMSE MDA RSQ RUNTIME (us)
ACTUAL 0.0000 0.0000 1.0000 1.0000  
FWMA 1.1653 1.6557 0.7002 0.9147 5.0735
TEMA 1.4368 2.0997 0.6131 0.8631 13.558
ZLMA 1.5841 2.3050 0.5973 0.8309 4.5029
DEMA 1.8107 2.5952 0.5745 0.7978 8.9601
LRF 1.7882 2.6150 0.5751 0.7987 10.636
HULL 1.8476 2.7010 0.5470 0.7820 12.586
MAMA 1.8615 2.7206 0.5669 0.8218 124.05
SSF 1.9658 2.7901 0.5377 0.7629 11.013
KERNEL 2.1897 3.0360 0.5354 0.7380 331.98
WMA 2.5509 3.4808 0.4962 0.6761 6.1506
HWMA 2.7944 3.8717 0.5359 0.6913 18.845
EWMA 2.9089 3.8791 0.5038 0.6554 3.9494
VIDYA 2.7790 4.0803 0.5132 0.7336 13.455
MDMA 3.3796 4.5220 0.5026 0.6145 19.092
SMA 3.4003 4.5472 0.4874 0.5301 3.8258
TRIMA 3.6072 4.8562 0.4769 0.4843 5.1022
PWMA 3.8432 5.2218 0.4833 0.4445 5.0097
WILDER 4.2392 5.5003 0.4868 0.5096 12.539
KAMA 3.8181 5.6028 0.4962 0.5792 6.0502
T3 4.1574 5.6869 0.4699 0.4175 27.265
VMA 5.1780 6.7629 0.4863 0.5203 17.301
ALMA 5.1010 6.7661 0.4711 0.3427 8.1427

conclusion

This post has no intention of declaring which algorithm performs the best. It is partially an exercise to validate whether the author’s usage of EWMA/Wilder is justified and partially a self-promotion of the traquer library. Keep in mind, these results use default values and each algorithm’s behaviour may change based on input settings.