Welcome to the BasicTS tutorial! This guide will walk you through the steps of training and evaluating a model using BasicTS.
Before diving in, let’s take a moment to introduce BasicTS.
What is BasicTS?
Important
BasicTS is a powerful and flexible tool designed specifically for time series forecasting. Whether you are new to this field or an experienced professional, BasicTS provides reliable support. With BasicTS, you can effortlessly build, train, and evaluate your time series forecasting models. You can also compare the performance of various models to find the best solution. We have integrated over 30 algorithms and 20 datasets, with more being added continuously.
Who Should Use BasicTS?
Important
BasicTS is perfect for both beginners and experts. For beginners looking to enter the world of time series forecasting, BasicTS allows you to quickly grasp the basic pipeline and build your own forecasting model. For experts, BasicTS offers a robust platform for rigorous model comparison, ensuring precise research and development.
Core Features
Important
Two key features define BasicTS: fairness and scalability. All models are trained and evaluated under the same conditions, eliminating biases introduced by external factors. This ensures trustworthy comparisons. Additionally, BasicTS is highly scalable, allowing customization of datasets, model structures, and metrics according to your needs. For example, to add a learning rate scheduler, simply specify CFG.TRAIN.LR_SCHEDULER.TYPE = 'MultiStepLR'
in the configuration file.
Now, let’s begin our journey and explore how to implement your time series forecasting projects with BasicTS!
First, clone the BasicTS repository:
cd /path/to/your/project
git clone https://github.com/zezhishao/BasicTS.git
We recommend using BasicTS on Linux systems (e.g., Ubuntu or CentOS).
Python 3.6 or higher is required (3.8 or higher is recommended).
We recommend using Miniconda or Anaconda to create a virtual Python environment.
BasicTS is flexible regarding the PyTorch version. You can install PyTorch according to your Python version. We recommend using pip
for installation.
After ensuring PyTorch is installed correctly, you can install the other dependencies:
pip install -r requirements.txt
# Install Python
conda create -n BasicTS python=3.11
conda activate BasicTS
# Install PyTorch
pip install torch==2.3.1 torchvision==0.18.1 torchaudio==2.3.1 --index-url https://download.pytorch.org/whl/cu121
# Install other dependencies
pip install -r requirements.txt
# Install Python
conda create -n BasicTS python=3.9
conda activate BasicTS
# Install PyTorch
pip install torch==1.10.0+cu111 torchvision==0.11.0+cu111 torchaudio==0.10.0 -f https://download.pytorch.org/whl/torch_stable.html
# Install other dependencies
pip install -r requirements.txt
You can download the all_data.zip
file from Google Drive or Baidu Netdisk. Unzip the files to the datasets/
directory:
cd /path/to/BasicTS # not BasicTS/basicts
unzip /path/to/all_data.zip -d datasets/
These datasets have been preprocessed and are ready for use.
Note
The data.dat
file is an array in numpy.memmap
format that stores the raw time series data with a shape of [L, N, C], where L is the number of time steps, N is the number of time series, and C is the number of features.
The desc.json
file is a dictionary that stores the dataset’s metadata, including the dataset name, domain, frequency, feature descriptions, regular settings, and null values.
Other files are optional and may contain additional information, such as adj_mx.pkl
, which represents a predefined prior graph between the time series.
Note
If you are interested in the preprocessing steps, you can refer to the preprocessing script and raw_data.zip
.
The forward
function should follow the conventions of BasicTS. An example of the Multi-Layer Perceptron (MLP
) model can be found in examples/arch.py.
BasicTS provides a unified and standard pipeline in basicts.runner.BaseTimeSeriesForecastingRunner
. You still need to define the specific forward process in the forward
function within the runner. Fortunately, BasicTS provides a ready-to-use implementation in basicts.runner.SimpleTimeSeriesForecastingRunner
, which can handle most situations. The runner for the MLP
model can use this built-in runner.
All pipeline details and hyperparameters can be configured in a .py
file. This configuration file allows you to import your model and runner and set all the options such as model, runner, dataset, scaler, optimizer, loss, and other hyperparameters. An example configuration file for the MLP
model on the PEMS08
dataset can be found in examples/regular_config.py.
Note
The configuration file is the core of training and evaluation in BasicTS. Examples/complete_config.py
outlines all the options available for configuration.
basicts.launch_training
is the entry point for training. You can run the following command to train your model:
-
Train the MLP Model Mentioned Above
python experiments/train.py -c examples/regular_config.py -g 0
or:
-
Reproducing Other Built-in Models
BasicTS provides a variety of built-in models. You can reproduce these models with the following command:
python experiments/train.py -c baselines/${MODEL_NAME}/${DATASET_NAME}.py --gpus '0'
Replace
${DATASET_NAME}
and${MODEL_NAME}
with any supported models and datasets. For example, to run Graph WaveNet on the METR-LA dataset:python experiments/train.py -c baselines/GWNet/METR-LA.py --gpus '0'
basicts.launch_evaluation
is the entry point for evaluation. You can run the following command to evaluate your model:
python experiments/evaluate.py -cfg {CONFIG_FILE}.py -ckpt {CHECKPOINT_PATH}.pth -g 0
This tutorial has equipped you with the fundamentals to get started with BasicTS, but there’s much more to discover. Before delving into advanced topics, let’s take a closer look at the structure of BasicTS:
The core components of BasicTS include Dataset
, Scaler
, Model
, Metrics
, Runner
, and Config
. To streamline the debugging process, BasicTS operates as a localized framework, meaning all the code runs directly on your machine. There’s no need to pip install basicts; simply clone the repository, and you’re ready to run the code locally.
Below are some advanced topics and additional features to help you maximize the potential of BasicTS:
- 🎉 Getting Stared
- 💡 Understanding the Overall Design Convention of BasicTS
- 📦 Exploring the Dataset Convention and Customizing Your Own Dataset
- 🛠️ Navigating The Scaler Convention and Designing Your Own Scaler
- 🧠 Diving into the Model Convention and Creating Your Own Model
- 📉 Examining the Metrics Convention and Developing Your Own Loss & Metrics
- 🏃♂️ Mastering The Runner Convention and Building Your Own Runner
- 📜 Interpreting the Config File Convention and Customizing Your Configuration
- 🔍 Exploring a Variety of Baseline Models