Function Prototype
/* Directional Movement Index */
/* Type: indicator */
/* Input arrays: 3 Options: 1 Output arrays: 1 */
/* Inputs: high, low, close */
/* Options: period */
/* Outputs: dx */
int ti_dx_start(TI_REAL const *options);
int ti_dx(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 Directional Movement Index can help determine trend strength.
It takes one option, the period n
.
Calculation is as follows:
$$\text{tr}_{t} = maximum(high_{t} - low_{t}, |high_{t} - close_{t-1}|, |low_{t} - close_{t-1}|)$$
$$\text{atr}_{t} = \frac{n-1}{n} \text{atr}_{t-1} + \text{tr}_{t}$$
$$
up_{t} = \begin{cases}
0 & high_{t} - high_{t-1} \lt 0 \vee high_{t} - high_{t-1} \lt low_{t-1} - low_{t}
\\ high_{t} - high_{t-1} & \text{ else}
\end{cases}
$$
$$
down_{t} = \begin{cases}
0 & low_{t-1} - low_{t} \lt 0 \vee low_{t-1} - low_{t} \lt high_{t} - high_{t-1}
\\ low_{t-1} - low_{t} & \text{ else}
\end{cases}
$$
$$\text{dm_up}_{t} = \frac{n-1}{n} \text{dm_up}_{t-1} + up_{t}$$
$$\text{dm_down}_{t} = \frac{n-1}{n} \text{dm_down}_{t-1} + down_{t}$$
$$\text{di_up}_{t} = \frac{\text{dm_up}_{t}}{\text{atr}_{t}} $$
$$\text{di_down}_{t} = \frac{\text{dm_down}_{t}}{\text{atr}_{t}} $$
$$\text{dm_diff}_{t} = | \text{di_up}_{t} - \text{di_down}_{t} | $$
$$\text{dm_sum}_{t} = \text{di_up}_{t} + \text{di_down}_{t} $$
$$\text{dx}_{t} = 100 \frac{\text{dm_diff}_{t}}{\text{dm_sum}_{t}} $$
See Also
References
- Wilder, J. Welles (1978) New Concepts in Technical Trading Systems
- Achelis, S. (2000) Technical Analysis from A to Z, 2nd Edition
- Wikipedia: Average directional movement index
Example Usage
Calling From C
/* Example usage of Directional Movement Index */
/* Assuming that 'high', 'low', and 'close' are pre-loaded arrays of size 'in_size'. */
TI_REAL *inputs[] = {high, low, close};
TI_REAL options[] = {5}; /* period */
TI_REAL *outputs[1]; /* dx */
/* Determine how large the output size is for our options. */
const int out_size = in_size - ti_dx_start(options);
/* Allocate memory for output. */
outputs[0] = malloc(sizeof(TI_REAL) * out_size); assert(outputs[0] != 0); /* dx */
/* Run the actual calculation. */
const int ret = ti_dx(in_size, inputs, options, outputs);
assert(ret == TI_OKAY);
Calling From Lua (with Tulip Chart bindings)
-- Example usage of Directional Movement Index
dx = ti.dx(high, low, close, 5)
Example Calculation
period = 5
date | high | low | close | dx |
---|---|---|---|---|
2005-11-01 | 82.15 | 81.29 | 81.59 | |
2005-11-02 | 81.89 | 80.64 | 81.06 | |
2005-11-03 | 83.03 | 81.31 | 82.87 | |
2005-11-04 | 83.30 | 82.65 | 83.00 | |
2005-11-07 | 83.85 | 83.07 | 83.61 | 50.19 |
2005-11-08 | 83.90 | 83.11 | 83.15 | 51.36 |
2005-11-09 | 83.33 | 82.49 | 82.84 | 11.09 |
2005-11-10 | 84.30 | 82.30 | 83.99 | 41.52 |
2005-11-11 | 84.84 | 84.15 | 84.55 | 52.77 |
2005-11-14 | 85.00 | 84.11 | 84.36 | 55.91 |
2005-11-15 | 85.90 | 84.03 | 85.53 | 69.96 |
2005-11-16 | 86.58 | 85.39 | 86.54 | 76.91 |
2005-11-17 | 86.98 | 85.76 | 86.89 | 80.26 |
2005-11-18 | 88.00 | 87.17 | 87.77 | 86.51 |
2005-11-21 | 87.87 | 87.01 | 87.29 | 75.61 |
Chart
Other Indicators
Previous indicator: Detrended Price Oscillator
Next indicator: Exponential Decay
Random indicator: Variance Over Period
Copyright © 2016-2024 Tulip Charts LLC. All Rights Reserved.