A python package for multi-variate time series prediction
Project description
fireTS
UPDATES
- 5/31/2020
forecastmethod is AVAILABLE now inNARXmodels!!! (DirectAutoRegressoris not suitable to do forecast, so there is no forecast method for it.) Here is a quick start example. Check "examples/Basic usage of NARX and DirectAutoregressor.ipynb" for more details.
import numpy as np
from sklearn.linear_model import LinearRegression
from fireTS.models import NARX
x = np.random.randn(100, 1)
y = np.random.randn(100)
mdl = NARX(LinearRegression(), auto_order=2, exog_order=[2])
mdl.fit(x, y)
y_forecast = mdl.forecast(x, y, step=10, X_future=np.random.randn((9, 1)))
Introduction
fireTS is a sklean style package for multi-variate time-series prediction. Here is a simple code snippet to showcase the awesome features provided by fireTS package.
from fireTS.models import NARX, DirectAutoRegressor
from sklearn.ensemble import RandomForestRegressor
from xgboost import XGBRegressor
import numpy as np
# Random training data
x = np.random.randn(100, 2)
y = np.random.randn(100)
# Build a non-linear autoregression model with exogenous inputs
# using Random Forest regression as the base model
mdl1 = NARX(
RandomForestRegressor(n_estimators=10),
auto_order=2,
exog_order=[2, 2],
exog_delay=[1, 1])
mdl1.fit(x, y)
ypred1 = mdl1.predict(x, y, step=3)
# Build a general autoregression model and make multi-step prediction directly
# using XGBRegressor as the base model
mdl2 = DirectAutoRegressor(
XGBRegressor(n_estimators=10),
auto_order=2,
exog_order=[2, 2],
exog_delay=[1, 1],
pred_step=3)
mdl2.fit(x, y)
ypred2 = mdl2.predict(x, y)
sklearnstyle API. The package providesfitandpredictmethods, which is very similar tosklearnpackage.- Plug-and-go. You are able to plug in any machine learning regression algorithms provided in
sklearnpackage and build a time-series forecasting model. - Create the lag features for you by specifying the autoregression order
auto_order, the exogenous input orderexog_order, and the exogenous input delayexog_delay. - Support multi-step prediction. The package can make multi-step prediction in two different ways: recursive way and direct way.
NARXmodel is to build a one-step-ahead-predictive model, and the model will be used recursively to make multi-step prediction (future exogenous input information is needed).DirectAutoRegressormakes multi-step prediction directly (no future exogenous input information is needed) by specifying the prediction step in the constructor. - Support grid search to tune the hyper-parameters of the base model (cannot do grid search on the orders and delays of the time series model for now).
I developed this package when writing this paper. It is really handy to generate lag features and leverage various regression algorithms provided by sklearn to build non-linear multi-variate time series models. The API can also be used to build deep neural network models to make time-series prediction. The paper used this package to build LSTM models and make multi-step predictions.
The documentation can be found here. The documentation provides the mathematical equations of each model. It is highly recommended to read the documentation before using the model.
Nonlinear AutoRegression with eXogenous (NARX) model
fireTS.models.NARX model is trying to train a one-step-ahead-prediction model
and make multi-step prediction recursively given the future exogenous inputs.
Given the output time series to predict y(t) and exogenous inputs X(t) The model will generate target and features as follows:
| Target | Features |
|---|---|
| y(t + 1) | y(t), y(t - 1), ..., y(t - p + 1), X(t - d), X(t - d - 1), ..., X(t - d - q + 1) |
where p is the autogression order auto_order, q is the exogenous input order exog_order, d is the exogenous delay exog_delay.
NARX model can make any step ahead prediction given the future exogenous inputs. To make multi-step prediction, set the step in the predict method.
Direct Autoregressor
fireTS.models.DirectAutoRegressor model is trying to train a
multi-step-head-prediction model directly. No future exogenous inputs are
required to make the multi-step prediction.
Given the output time series to predict y(t) and exogenous inputs X(t) The model will generate target and features as follows:
| Target | Features |
|---|---|
| y(t + k) | y(t), y(t - 1), ..., y(t - p + 1), X(t - d), X(t - d - 1), ..., X(t - d - q + 1) |
where p is the autogression order auto_order, q is the exogenous input order exog_order, d is the exogenous delay exog_delay, k is the prediction step pred_step.
Direct autoregressor does not require future exogenous input information to make multi-step prediction. Its predict method cannot specify prediction step.
Installation
NOTE: Only python3 is supported.
It is highly recommended to use pip to install fireTS, follow this
link to install pip.
After pip is installed,
pip install fireTS
To get the latest development version,
git clone https://github.com/jxx123/fireTS.git
cd fireTS
pip install -e .
Quick Start
- Use
RandomForestRegressoras base model to build aNARXmodel
from fireTS.models import NARX
from sklearn.ensemble import RandomForestRegressor
import numpy as np
x = np.random.randn(100, 1)
y = np.random.randn(100)
mdl = NARX(RandomForestRegressor(), auto_order=2, exog_order=[2], exog_delay=[1])
mdl.fit(x, y)
ypred = mdl.predict(x, y, step=3)
- Use
RandomForestRegressoras base model to build aDirectAutoRegressormodel
from fireTS.models import DirectAutoRegressor
from sklearn.ensemble import RandomForestRegressor
import numpy as np
x = np.random.randn(100, 1)
y = np.random.randn(100)
mdl = DirectAutoRegressor(RandomForestRegressor(),
auto_order=2,
exog_order=[2],
exog_delay=[1],
pred_step=3)
mdl.fit(x, y)
ypred = mdl.predict(x, y)
- Usage of grid search
from fireTS.models import NARX
from sklearn.ensemble import RandomForestRegressor
import numpy as np
x = np.random.randn(100, 1)
y = np.random.randn(100)
# DirectAutoRegressor can do grid search as well
mdl = NARX(RandomForestRegressor(), auto_order=2, exog_order=[2], exog_delay=[1])
# Grid search
para_grid = {'n_estimators': [10, 30, 100]}
mdl.grid_search(x, y, para_grid, verbose=2)
# Best hyper-parameters are set after grid search, print the model to see the difference
print(mdl)
# Fit the model and make the prediction
mdl.fit(x, y)
ypred = mdl.predict(x, y, step=3)
The examples folder provides more realistic examples. The example1 and example2 use the data simulated by simglucose pakage to fit time series model and make multi-step prediction.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file fireTS-0.0.8.tar.gz.
File metadata
- Download URL: fireTS-0.0.8.tar.gz
- Upload date:
- Size: 5.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0.post20200518 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ce7c6dd9f10b9f8f69ae47782a012b7cebd8a15fb36283d9114a7ba507bb7586
|
|
| MD5 |
067442148a0f40d5ece84b38e01b78ee
|
|
| BLAKE2b-256 |
ba29eb85f25d5b0ec5fb54440d9b9186944081254657c873fdbfbad927bcbaaf
|
File details
Details for the file fireTS-0.0.8-py3-none-any.whl.
File metadata
- Download URL: fireTS-0.0.8-py3-none-any.whl
- Upload date:
- Size: 9.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0.post20200518 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
53ee54c9fb263305ccdf5bb797f1e54d42087647c497ce4444600b9c7aa79823
|
|
| MD5 |
d5f021e8a1dcbe82d720da9ff17522de
|
|
| BLAKE2b-256 |
6f620721b34b77bb0f68e418423cbe54144d35d121804df62e13429cae7db03c
|