Skip to main content

Data Augmentation for Time series Data: A Review

Project description

⚠️ Alert: If you are using this code with Keras v3, make sure you are using Keras ≥ 3.6.0. Earlier versions of Keras v3 do not honor trainable=False, which will result in training hand-crafted filters in LITEMV unexpectedly.

Overview
CI/CD github-actions-main github-actions-tests
Code pypi python-versions !black license
Community website

Re-framing Time Series Augmentation Through the Lens of Generative Models

Authors: Ali Ismail-Fawaz1, Maxime Devanne1, Stefano Berreti2, Jonathan Weber1 and Germain Forestier1,3

1 IRIMAS, Universite de Haute-Alsace, France
2 MICC, University of Florence, Italy
3 DSAI, Monash University, Australia

This repository is the source code of the article titled "Re-framing Time Series Augmentation Through the Lens of Generative Models" accepted in the 10th Workshop on Advanced Analytics and Learning on Temporal Data (AALTD 2025) in conjunction with the 2025 European Conference on Machine Learning and Principles and Practice of Knowledge Discovery in Databases (ECML-PKDD 2025). In this article, we present a benchmark comparison between 22 data augmentation techniques on 131 time series classification datasets of the UCR archive.

Abstract

Time series classification is widely used in many fields, but it often suffers from a lack of labeled data. To address this, researchers commonly apply data augmentation techniques that generate synthetic samples through transformations such as jittering, warping, or resampling. However, with an increasing number of available augmentation methods, it becomes difficult to choose the most suitable one for a given task. In many cases, this choice is based on intuition or visual inspection. Assessing the impact of this choice on classification accuracy requires training models, which is time-consuming and depends on the dataset. In this work, we adopt a generative model perspective and evaluate augmentation methods prior to training any classifier, using metrics that quantify both fidelity and diversity of the generated samples. We benchmark 22 augmentation techniques on 131 public datasets using eight metrics. Our results provide a practical and efficient way to compare augmentation methods without relying solely on classifier performance.

Data

In this work we utilize 131 datasets of the UCR archive taken from the original repository and the new added datasets.

However you are not obligated to download them as our code loads the datasets through the Time Series Classification webpage using aeon-toolkit.

Docker

This repository supports the usage of docker. In order to create the docker image using the dockerfile, simply run the following command (assuming you have docker installed and nvidia cuda container as well):

docker build --build-arg USER_ID=$(id -u) --build-arg GROUP_ID=$(id -g) -t data-augmentation-review-image .

After the image has been successfully built, you can create the docker container using the following command:

docker run --gpus all -it --name data-augmentation-review-container -v "$(pwd):/home/myuser/code" --user $(id -u):$(id -g) data-augmentation-review-image bash

The code will be stored under the directory /home/myuser/code/ inside the docker container. This will allow you to use GPU acceleration.

Requirements

If you do not want to use docker, simply install the project using the following command:

python3 -m venv ./data-augmentation-review-venv
source ./data-augmentation-review-venv/bin/activate
pip install --upgrade pip
pip install -e .[dev]

Make sure you have jq installed on your system. This project supports python>=3.10 only.

You can see the list of dependencies and their required version in the pyptoject.toml file.

Running the code on a single experiment

If you wish to run a single experiment on a single dataset, using a single augmentation method, using a single model then first you have to execute your docker container to open a terminal inside if you're not inside the container:

docker exec -it data-augmentation-review-container bash

Then you can run the following command for example to run Amplitude Warping on the Adiac dataset:

python3 main.py task=generate_data dataset_name=Adiac generate_data.method=AW

The code uses hydra for the parameter configuration, simply see the hydra configuration file for a detailed view on the parameters of our experiments.

Running the whole benchmark

If you wish to run all the experiments to reproduce the results of our article simply run the following for data generation experiments:

chmod +x run_generate_data.sh
nohup ./run_generate_data.sh &

and the following for training the feature extractor:

chmod +x run_train_feature_extractor.sh
nohup ./run_train_feature_extractor.sh &

and the following for evaluation of the generations:

chmod +x run_evaluate_generation.sh
nohup ./run_evaluate_generation.sh &

Cite this work

If you use this work please cite the following:

@inproceedings{ismail-fawaz2025Data-Aug-4-TSC,
  author = {Ismail-Fawaz, Ali and Devanne, Maxime and Berretti, Sefano and Weber, Jonathan and Forestier, Germain},
  title = {Re-framing Time Series Augmentation Through the Lens of Generative Models},
  booktitle = {ECML/PKDD Workshop on Advanced Analytics and Learning on Temporal Data},
  city = {Porto},
  country = {Portugal},
  year = {2025}
}

Acknowledgments

This work was supported by the ANR DELEGATION project (grant ANR-21-CE23-0014) of the French Agence Nationale de la Recherche. The authors would like to acknowledge the High Performance Computing Center of the University of Strasbourg for supporting this work by providing scientific sup- port and access to computing resources. Part of the computing resources were funded by the Equipex Equip@Meso project (Programme Investissements d’Avenir) and the CPER Alsacalcul/Big Data. The authors would also like to thank the creators and providers of the UCR Archive

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

data_aug_4_tsc-0.0.1.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

data_aug_4_tsc-0.0.1-py3-none-any.whl (17.5 kB view details)

Uploaded Python 3

File details

Details for the file data_aug_4_tsc-0.0.1.tar.gz.

File metadata

  • Download URL: data_aug_4_tsc-0.0.1.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for data_aug_4_tsc-0.0.1.tar.gz
Algorithm Hash digest
SHA256 39ab5e2a24e740f1f975d924badc6334441f81f7d16625ea2503310ebd696f74
MD5 f88302d90fc46c50e8329ce07065ef42
BLAKE2b-256 5831cce816c6e890085d6bb48047397943915e6345c46941f4968c6ee922c327

See more details on using hashes here.

Provenance

The following attestation bundles were made for data_aug_4_tsc-0.0.1.tar.gz:

Publisher: publish.yml on MSD-IRIMAS/Data-Augmentation-4-TSC

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file data_aug_4_tsc-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: data_aug_4_tsc-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 17.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for data_aug_4_tsc-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 129ef9837151f185aa94b4d00e4f0537e77e80a3b5a8db18259d75cd99edd5a4
MD5 e815c371692eadf2e8db9779bb5c4fa3
BLAKE2b-256 cc4d227ae3aae43c655b70d9fd1b33006ae403aeb915b063dad86fe7fe4918ae

See more details on using hashes here.

Provenance

The following attestation bundles were made for data_aug_4_tsc-0.0.1-py3-none-any.whl:

Publisher: publish.yml on MSD-IRIMAS/Data-Augmentation-4-TSC

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page