Function Prototype
/* Lag */
/* Type: math */
/* Input arrays: 1 Options: 1 Output arrays: 1 */
/* Inputs: real */
/* Options: period */
/* Outputs: lag */
int ti_lag_start(TI_REAL const *options);
int ti_lag(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 Lag indicator just introduces lag to its input. It is useful for "lookback" in building trading algorithms.
Lag takes one parameter, the lag period n
.
It is calculated as:
$$lag_{t} = in_{t-n}$$
See Also
References
Example Usage
Calling From C
/* Example usage of Lag */
/* 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]; /* lag */
/* Determine how large the output size is for our options. */
const int out_size = in_size - ti_lag_start(options);
/* Allocate memory for output. */
outputs[0] = malloc(sizeof(TI_REAL) * out_size); assert(outputs[0] != 0); /* lag */
/* Run the actual calculation. */
const int ret = ti_lag(in_size, inputs, options, outputs);
assert(ret == TI_OKAY);
Calling From Lua (with Tulip Chart bindings)
-- Example usage of Lag
lag = ti.lag(input, 5)
Example Calculation
period = 5
date | input | lag |
---|---|---|
2005-11-01 | 81.59 | |
2005-11-02 | 81.06 | |
2005-11-03 | 82.87 | |
2005-11-04 | 83.00 | |
2005-11-07 | 83.61 | |
2005-11-08 | 83.15 | 81.59 |
2005-11-09 | 82.84 | 81.06 |
2005-11-10 | 83.99 | 82.87 |
2005-11-11 | 84.55 | 83.00 |
2005-11-14 | 84.36 | 83.61 |
2005-11-15 | 85.53 | 83.15 |
2005-11-16 | 86.54 | 82.84 |
2005-11-17 | 86.89 | 83.99 |
2005-11-18 | 87.77 | 84.55 |
2005-11-21 | 87.29 | 84.36 |
Chart
Other Indicators
Previous indicator: Klinger Volume Oscillator
Next indicator: Linear Regression
Random indicator: Vector Exponential
Copyright © 2016-2024 Tulip Charts LLC. All Rights Reserved.