Related Software#
The Python ecosystem contains numerous packages that can be used to store and process time series data. The following list is by no means exhaustive. If you miss anything, feel free to open a PR.
Table of contents
For time series data containers, see our wiki entry.
Machine learning#
Libraries#
Project Name |
Description |
---|---|
Anomaly Detection Tool Kit, a Python package for unsupervised/rule-based time series anomaly detection |
|
Collection of forecasting models, wraps existing statistical and machine learning models for forecasting, automated benchmarking |
|
A sensible, human-friendly approach to creating, manipulating, formatting and converting dates, times, and timestamps |
|
Time series platform with feature extraction aiming for non uniformly sampled signals |
|
Feature selection pipeline for hctsa and the so-called catch22 feature set |
|
A python library for forecasting with scikit-learn like API |
|
Python collection of time series forecasting tools, from preprocessing to models (uni-/multivariate, prophet, neural networks) and backtesting utilities |
|
Library for unsupervised learning with time series including dimensionality reduction, clustering, and Markov model estimation |
|
Collection of data augmentation tools, including feature extraction from time series, wraps existing toolkits like tsfresh |
|
Diviner by Databricks enables large-scale time series forecasting and serves as a wrapper around other open source forecasting libraries |
|
Time series distances |
|
Scipy-based dynamic time warping |
|
Time series feature extraction, with possible conditionality on other variables with a pandas compatible relational-database-like data container |
|
Computational tools for financial economics |
|
financial function library |
|
A Time Series Library for Apache Spark |
|
Shapelet discovery by genetic algorithms |
|
scikit-learn compatible wrapper around the GLM module in statsmodels |
|
Probabilistic forecasting and anomaly detection using deep learning by Amazon |
|
A Time Series Library for rorecasting by LinkedIn which contains the interpretable “Silverkite” algorithm. |
|
Matlab based feature extraction which can be controlled from python |
|
Hidden Markov Models with scikit-learn compatible API |
|
A toolkit by Facebook for time series analysis, including detection, forecasting, feature extraction/embedding, multivariate analysis, etc. |
|
A Time Series library with accelerated analytics on GPUS, it provides feature extraction and motif discovery among other functionalities. |
|
Toolkit for survival analysis |
|
Add linear models including instrumental variable and panel data models that are missing from statsmodels. |
|
Time series inference engine built on top of TensorFlow to forecast data, detect outliers, and automate your process using future knowledge. |
|
A Python library for detecting patterns and anomalies in massive datasets using the Matrix Profile |
|
Deep learning for time series classification with automated hyperparameter selection |
|
A Neural Network based model, inspired by Facebook Prophet and AR-Net, built on PyTorch |
|
Time series analysis for neuroscience data |
|
Non-linear time series analysis |
|
Bayesian time series forecasting package by uber |
|
Probabilistic models ranging from individual probability distributions to compositional models such as Bayesian networks and hidden Markov models. |
|
Time series analysis for hydrological data |
|
Time series forecasting for time series data that has multiple seasonality with linear or non-linear growth |
|
ARMA models for dynamic system Estimation |
|
Analysis of extensive molecular dynamics simulations based on Markov models |
|
Classical time series forecasting models |
|
Hubness-aware machine learning in Python including time series classification via dynamic time warping based KNN classification |
|
Toolbox for outlier detection |
|
A scikit-learn compatible machine learning library for supervised/panel forecasting |
|
Port of R’s auto.arima method to Python |
|
Contains time series preprocessing, transformation as well as classification techniques |
|
time series annotation: change point detection, segmentation |
|
Library from salesforce for forecasting, anomaly detection, and change point detection |
|
A Python library to perform Functional Data Analysis, compatible with scikit-learn, including representation, preprocessing, exploratory analysis and machine learning methods |
|
Extension of scikit-learn to supervised learning of streaming data (dynamic online learning), including regression/classification and change detection |
|
Survival analysis built on top of scikit-learn |
|
Toolkit to estimate trends and seasonality in time series |
|
Extends the scikit-learn pipeline concept to time series annotation |
|
Extends the scikit-learn pipeline concept to time series data for classification, regression and forecasting |
|
A scikit-learn compatible library for learning with time series/panel data including time series classification/regression and (supervised/panel) forecasting |
|
StatsForecast by Nixtla offers a collection of widely used univariate time series forecasting models optimized for high performance using numba |
|
Contains a submodule for classical time series models and hypothesis tests |
|
Calculates matrix profile for time series subsequence all-pairs-similarity-search |
|
Package provides BATS and TBATS time series forecasting methods |
|
Bayesian Structural Time Series model in Tensorflow Probability |
|
Toolkit for temporal cross-validation, part of the Data Science for Social Good predictive analytics framework |
|
A library for unevenly-spaced time series analysis |
|
Calculate technical indicators for financial time series (python wrapper around TA-Lib) |
|
Calculate technical indicators for financial time series |
|
scikit-learn compatible time series regressor as a meta-estimator for forecasting |
|
Extracts and filters features from time series, allowing supervised classificators and regressor to be applied to time series data |
|
Direct time series classifiers and regressors |
|
Preprocess time series (resampling, denoising etc.), still WIP |
|
Toolbox for Outlier, Adversarial and Drift detection |
Specific model implementations#
Project name |
Description |
---|---|
Python implementation of the winning forecasting method of the M4 competition combining exponential smoothing with a recurrent neural network using PyTorch |
|
A collection of common deep learning architectures for time series classification |
|
Collection of statistical and machine learning forecasting methods |
|
Collection of forecasting models and best practices, interfaces existing libraries in Python and R |
|
LSTM for forecasting model |
|
An LSTM for time series classification |
|
Shapelet classifier based on a multi layer neural network |
|
Time series classification using random convolutional kernels |
|
Time Series Prediction with tf.contrib.timeseries |
|
Fully convolutional neural networks for state-of-the-art time series classification |
|
Time to event forecast by RNN based Weibull density estimation |
|
alternative to Prophet for timeseries modelling when multiple time series are expected |
Time series databases and frameworks#
Project Name |
Description |
---|---|
High performance datastore for time series and tick data |
|
Fully automated time series classification pipeline, deployed as a web service |
|
Time series platform with feature extraction aiming for non uniformly sampled signals |
|
Scalable analysis of image and time series data in Python based on spark |
|
File-based time-series database format |
|
Financial time series database framework, design, benchmarks |
|
Python software for exploring, visualizing, and analyzing neurophysiological time series data (MEG, EEG, etc) |
Acknowledgements#
Thanks to Max Christ who started the list here.