The ( ) developed by Alan Hull is one of the many moving averages that aim to reduce lag while providing effective smoothing. The make use of 3 linearly weighted ( ) moving averages, with respective periods p/2, p and √p, this involve three convolutions, which affect computation time, a more efficient version exist under the name of exponential (EHMA), this version make use of exponential moving averages instead of linearly weighted ones, which dramatically decrease the computation time, however the difference with the original version is clearly noticeable.
In this post an efficient and simple estimate is proposed, the estimation process will be fully described and some comparison with the original will be presented.
This post and indicator is dedicated to LucF
Estimating a moving average is easier when we look at its weights (represented by the impulse response), we basically want to find a similar set of weights via more efficient calculations, the estimation process is therefore based on fully understanding the weighting architecture of the moving average we want to estimate.
The impulse response of an of period 20 is as follows :
We can see that the first weights increases a bit before decaying, the weights then decay, cross under 0 and increase again. More recent closing price values benefits of the highest weights, while the oldest values have negatives ones, negative weighting is what allow to drastically reduce the lag of the . Based on this information we know that our estimate will be a linear combination of two moving averages with unknown coefficients :
a × MA1 + b × MA2
With a > 0 and b < 0, the lag of MA1 is lower than the lag of MA2. We first need to capture the general of the weights, which has an overall non-linearly decaying shape, therefore the use of an might seem appropriate.
In orange the impulse response of an of period p/2, that is 10. We can see that such impulse response is not a bad estimate of the overall shape of the impulse response, based on this information we might perform our linear combination with a :
2EMA(p/2) + -1SMA(p)
this gives the following impulse response :
As we can see there is a clear lack of accuracy, but because the impulse response of a simple moving is a constant we can't have the short increasing weights of the , we therefore need a non-constant impulse response for our linear combination, a might be appropriate. Therefore we will use :
2WMA(p/2) + -1EMA(p/2)
Note that the lag a is inferior to the lag of an of same period, this is why the period of the is p/2. We obtain :
The shape has improved, but the fit is poor, which mean we should change our coefficients, more precisely increasing the coefficient of the (thus decreasing the one of the ). We will try :
3WMA(p/2) + -2EMA(p/2)
We then obtain :
This estimate seems to have a decent fit, and this linear combination is therefore used.
in blue and the estimate in fuchsia with both period 50, the difference can be noted, however the estimate is relatively accurate.
In the image above the period has been set to 200.
In this post an efficient estimate of the has been proposed, we have seen that the can be estimated via the linear combinations of a and an of each period p/2, this isn't important for the who is based on recursion but is however a big deal for the who use recursion, and therefore p indicate the number of data points to be used in the convolution, knowing that we use only convolution and that this convolution use twice less data points then one of the used in the is a pretty great thing.
Subtle tweaking of the coefficients/moving averages length's might help have an even more accurate estimate, the fact that the make use of a period of √p is certainly the most disturbing aspect when it comes to estimating the . I also described more in depth the process of estimating a moving average.
I hope you learned something in this post, it took me quite a lot of time to prepare, maybe 2 hours, some pinescripters pass an enormous amount of time providing content and helping the community, one of them being LucF, without him i don't think you'll be seeing this indicator as well as many ones i previously posted, I encourage you to thank him and check his work for Pinecoders as well as following him.
Thanks for reading !
Become a Patreon and get access to exclusive technical indicators!
You can also check out some of the indicators I made for luxalgo : https://www.tradingview.com/u/LuxAlgo/#published-scripts