You can install NeuralForecast
with:
pip install neuralforecast
or
conda install -c conda-forge neuralforecast
Vist our Installation Guide for further details.
Minimal Example
from neuralforecast import NeuralForecast
from neuralforecast.models import NBEATS
from neuralforecast.utils import AirPassengersDF
nf = NeuralForecast(
models = [NBEATS(input_size=24, h=12, max_steps=100)],
freq = 'M'
)
nf.fit(df=AirPassengersDF)
nf.predict()
Get Started with this quick guide.
There is a shared belief in Neural forecasting methods' capacity to improve forecasting pipeline's accuracy and efficiency.
Unfortunately, available implementations and published research are yet to realize neural networks' potential. They are hard to use and continuously fail to improve over statistical methods while being computationally prohibitive. For this reason, we created NeuralForecast
, a library favoring proven accurate and efficient models focusing on their usability.
.fit
and .predict
.NHITS
implementation, published at AAAI 2023. See paper and experiments.NBEATSx
implementation, published at the International Journal of Forecasting. See paper.StatsForecast
, MLForecast
, and HierarchicalForecast
interface NeuralForecast().fit(Y_df).predict()
, inputs and outputs.utilsforecast
and coreforecast
for visualization and data-wrangling efficient methods.Ray
and Optuna
for automatic hyperparameter optimization.Missing something? Please open an issue or write us in
The documentation page contains all the examples and tutorials.
π Automatic Hyperparameter Optimization: Easy and Scalable Automatic Hyperparameter Optimization with Auto
models on Ray
or Optuna
.
π‘οΈ Exogenous Regressors: How to incorporate static or temporal exogenous covariates like weather or prices.
π Transformer Models: Learn how to forecast with many state-of-the-art Transformers models.
π Hierarchical Forecasting: forecast series with very few non-zero observations.
π©βπ¬ Add Your Own Model: Learn how to add a new model to the library.
See the entire collection here.
Missing a model? Please open an issue or write us in
If you wish to contribute to the project, please refer to our contribution guidelines.
This work is highly influenced by the fantastic work of previous contributors and other scholars on the neural forecasting methods presented here. We want to highlight the work of Boris Oreshkin, Slawek Smyl, Bryan Lim, and David Salinas. We refer to Benidis et al. for a comprehensive survey of neural forecasting methods.
Thanks goes to these wonderful people (emoji key):
azul π» π§ |
Cristian Challu π» π§ |
JosΓ© Morales π» π§ |
mergenthaler π π» |
Kin π» π π£ |
Greg DeVos π€ |
Alejandro π» |
stefanialvs π¨ |
Ikko Ashimine π |
vglaucus π |
Pietro Monticone π |
This project follows the all-contributors specification. Contributions of any kind welcome!