Julia DeepAR
DeepAR Probabilistic Forecasting with Autoregressive Recurrent Networks
DeepAR.jl is a Julia module designed for probabilistic forecasting using autoregressive recurrent networks, based on the concept introduced in the paper DeepAR: Probabilistic Forecasting with Autoregressive Recurrent Networks.
Installation
Currently, DeepAR is not registered in Julia’s General registry. To install, clone the repository directly.
Features
DeepAR allows the training and use of deep learning models for time series forecasting. Key features include:
- Time series forecasting using autoregressive models.
- Training and prediction with custom hyperparameters.
Usage
Importing the Module
To use DeepAR, first import the module along with required dependencies:
using DeepAR
Hyperparameters
Define the hyperparameters for the DeepAR model using DeepARParams
:
-
η::Float64
: Learning rate for model training. Default is1e-2
. -
n_mean::Int
: Number of samples used for computing the predictive mean. Default is100
.
Training
Train a DeepAR model with the train_DeepAR
function:
- Parameters:
-
model
: The DeepAR model. -
loaderXtrain
: DataLoader with input sequences. -
loaderYtrain
: DataLoader with target sequences. -
hparams
:DeepARParams
instance.
-
- Returns a vector of loss values.
Forecasting
Generate forecasts using the forecasting_DeepAR
function:
- Parameters:
-
model
: Trained DeepAR model. -
ts
: Time series data. -
t₀
: Starting time step for forecasting. -
τ
: Number of time steps to forecast. -
n_samples
: Number of samples per forecast (default: 100).
-
- Returns a vector of forecasted values.
Example
using DeepAR
model = Chain(
RNN(1 => 10, relu), RNN(10 => 10, relu), Dense(10 => 16, relu), Dense(16 => 2, identity)
)
train_data = Float32.(randn(1, 1001))
deepAR_params = DeepARParams(; η=0.01, epochs=100, n_mean=100)
loaderXtrain = DataLoader(train_data[1:end-1], batchsize=1000)
loaderYtrain = DataLoader(train_data[2:end], batchsize=1000)
# Train the model
loss = train_DeepAR(model, loaderXtrain, loaderYtrain, deepAR_params)
Contributing
Contributions to the DeepAR module are welcome. Please submit issues and pull requests on the repository.
License
DeepAR is licensed under MIT License. Please check the repository for more details.
For more detailed information and updates, refer to the DeepAR GitHub repository.