7 unstable releases
| 0.4.0 | Apr 7, 2026 |
|---|---|
| 0.3.1 | Jul 11, 2024 |
| 0.3.0 | Sep 25, 2023 |
| 0.2.2 | Jun 20, 2023 |
| 0.1.0 | Oct 15, 2021 |
#60 in Math
7,956 downloads per month
Used in 10 crates
(2 directly)
53KB
1.5K
SLoC
STL Rust
Seasonal-trend decomposition for Rust
🎉 Zero dependencies
Installation
Add this line to your application’s Cargo.toml under [dependencies]:
stlrs = "0.4"
Getting Started
Decompose a time series
use stlrs::Stl;
let series = vec![
5.0, 9.0, 2.0, 9.0, 0.0, 6.0, 3.0, 8.0, 5.0, 8.0,
7.0, 8.0, 8.0, 0.0, 2.0, 5.0, 0.0, 5.0, 6.0, 7.0,
3.0, 6.0, 1.0, 4.0, 4.0, 4.0, 3.0, 7.0, 5.0, 8.0
];
let period = 7; // period of the seasonal component
let fit = Stl::fit(&series, period)?;
Get the components
let seasonal = fit.seasonal();
let trend = fit.trend();
let remainder = fit.remainder();
Robustness
Use robustness iterations
let fit = Stl::params().robust(true).fit(&series, period)?;
Get robustness weights
let weights = fit.weights();
Multiple Seasonality
Specify multiple periods
use stlrs::Mstl;
let fit = Mstl::fit(&series, &[7, 365])?;
Parameters
Set STL parameters
let fit = Stl::params()
.seasonal_length(7) // length of the seasonal smoother
.trend_length(15) // length of the trend smoother
.low_pass_length(7) // length of the low-pass filter
.seasonal_degree(0) // degree of locally-fitted polynomial in seasonal smoothing
.trend_degree(1) // degree of locally-fitted polynomial in trend smoothing
.low_pass_degree(1) // degree of locally-fitted polynomial in low-pass smoothing
.seasonal_jump(1) // skipping value for seasonal smoothing
.trend_jump(2) // skipping value for trend smoothing
.low_pass_jump(1) // skipping value for low-pass smoothing
.inner_loops(2) // number of loops for updating the seasonal and trend components
.outer_loops(0) // number of iterations of robust fitting
.robust(false) // if robustness iterations are to be used
.fit(&series, period)?;
Set MSTL parameters
let fit = Mstl::params()
.iterations(2) // number of iterations
.lambda(0.5) // lambda for Box-Cox transformation
.seasonal_lengths(&[11, 15]) // lengths of the seasonal smoothers
.stl_params(Stl::params()) // STL params
.fit(&series, &periods)?;
Strength
Get the seasonal strength
let strength = fit.seasonal_strength();
Get the trend strength
let strength = fit.trend_strength();
Credits
This library was ported from the Fortran implementation.
References
- STL: A Seasonal-Trend Decomposition Procedure Based on Loess
- MSTL: A Seasonal-Trend Decomposition Algorithm for Time Series with Multiple Seasonal Patterns
- Measuring strength of trend and seasonality
History
View the changelog
Contributing
Everyone is encouraged to help improve this project. Here are a few ways you can help:
- Report bugs
- Fix bugs and submit pull requests
- Write, clarify, or fix documentation
- Suggest or add new features
To get started with development:
git clone https://github.com/ankane/stl-rust.git
cd stl-rust
cargo test