timelag — creating time lagged data series
This crate provides lag_matrix and related functions to create time-lagged
versions of time series. Support for ndarray's Array1
and Array2 traits is available via the ndarray crate feature.
Examples
For singular time series:
use timelag::lag_matrix;
fn singular_series() {
let data = [1.0, 2.0, 3.0, 4.0];
let lag = f64::INFINITY;
let padding = f64::INFINITY;
let lagged = lag_matrix(&data, 3, lag, 5).unwrap();
assert_eq!(
lagged,
&[
1.0, 2.0, 3.0, 4.0, padding, lag, 1.0, 2.0, 3.0, padding, lag, lag, 1.0, 2.0, padding, lag, lag, lag, 1.0, padding, ]
);
}
For matrices with time series along their rows:
use timelag::{lag_matrix_2d, MatrixLayout};
fn matrix_rows() {
let data = [
1.0, 2.0, 3.0, 4.0,
-1.0, -2.0, -3.0, -4.0
];
let lag = f64::INFINITY;
let padding = f64::INFINITY;
let lagged = lag_matrix_2d(&data, MatrixLayout::RowWise(4), 3, lag, 5).unwrap();
assert_eq!(
lagged,
&[
1.0, 2.0, 3.0, 4.0, padding, -1.0, -2.0, -3.0, -4.0, padding,
lag, 1.0, 2.0, 3.0, padding, lag, -1.0, -2.0, -3.0, padding,
lag, lag, 1.0, 2.0, padding, lag, lag, -1.0, -2.0, padding,
lag, lag, lag, 1.0, padding, lag, lag, lag, -1.0, padding,
]
);
}
For matrices with time series along their columns:
use timelag::{lag_matrix_2d, MatrixLayout};
fn matrix_columns() {
let data = [
1.0, -1.0,
2.0, -2.0,
3.0, -3.0,
4.0, -4.0
];
let lag = f64::INFINITY;
let padding = f64::INFINITY;
let lagged = lag_matrix_2d(&data, MatrixLayout::ColumnWise(4), 3, lag, 9).unwrap();
assert_eq!(
lagged,
&[
1.0, -1.0, lag, lag, lag, lag, lag, lag, padding,
2.0, -2.0, 1.0, -1.0, lag, lag, lag, lag, padding,
3.0, -3.0, 2.0, -2.0, 1.0, -1.0, lag, lag, padding,
4.0, -4.0, 3.0, -3.0, 2.0, -2.0, 1.0, -1.0, padding
]
);
}