Kaufman Adaptive Moving Average

Technical Analysis Indicator: kama

Fork me on GitHub

Function Prototype

/* Kaufman Adaptive Moving Average */
/* Type: overlay */
/* Input arrays: 1    Options: 1    Output arrays: 1 */
/* Inputs: real */
/* Options: period */
/* Outputs: kama */
int ti_kama_start(TI_REAL const *options);
int ti_kama(int size,
      TI_REAL const *const *inputs,
      TI_REAL const *options,
      TI_REAL *const *outputs);

Description

This documentation is still a work in progress. It has omissions, and it probably has errors too. If you see any issues, or have any general feedback, please get in touch.

The Kaufman Adaptive Moving Average tries to adjust it's smoothing to match the current market condition. It adapts to a fast moving average when prices are moving steadily in one direction and a slow moving average when the market exhibits a lot of noise.

It takes one parameter, the efficiency ratio period n.

Kaufman Adaptive Moving Average first calculates the efficiency ratio over the period n as:

$$e_{t} = \frac{|in_{t}-in_{t-n}|}{\sum_{i=0}^{n-1} |in_{t-i} - in_{t-i-1}|}$$

The efficiency ratio e is a low value when the market contains a lot of noise, and it is a larger value when the market is moving consistently in one direction.

A scalar, a is then calculated as:

$$f = \frac{2}{2+1}$$
$$s = \frac{2}{30+1}$$
$$a_{t} = (e_{t}(f-s)+s)^2$$

Finally Kaufman Adaptive Moving Average can be calculated as:

$$kama_{t} = in_{t}a + (1-a)kama_{t-1}$$

See Also

References

Example Usage

Calling From C

/* Example usage of Kaufman Adaptive Moving Average */
/* Assuming that 'input' is a pre-loaded array of size 'in_size'. */
TI_REAL *inputs[] = {input};
TI_REAL options[] = {5}; /* period */
TI_REAL *outputs[1]; /* kama */

/* Determine how large the output size is for our options. */
const int out_size = in_size - ti_kama_start(options);

/* Allocate memory for output. */
outputs[0] = malloc(sizeof(TI_REAL) * out_size); assert(outputs[0] != 0); /* kama */

/* Run the actual calculation. */
const int ret = ti_kama(in_size, inputs, options, outputs);
assert(ret == TI_OKAY);

Calling From Lua (with Tulip Chart bindings)

-- Example usage of Kaufman Adaptive Moving Average
kama = ti.kama(input, 5)

Example Calculation

period = 5

dateinputkama
2005-11-0181.59
2005-11-0281.06
2005-11-0382.87
2005-11-0483.00
2005-11-0783.6183.61
2005-11-0883.1583.56
2005-11-0982.8483.45
2005-11-1083.9983.51
2005-11-1184.5583.65
2005-11-1484.3683.69
2005-11-1585.5384.13
2005-11-1686.5485.03
2005-11-1786.8985.69
2005-11-1887.7786.45
2005-11-2187.2986.67

Chart

 

Other Indicators

Previous indicator: Hull Moving Average

Next indicator: Klinger Volume Oscillator

Random indicator: Detrended Price Oscillator