Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mims-harvard/units
A unified multi-task time series model.
https://github.com/mims-harvard/units
anomaly-detection classification ecg eeg few-shot forecasting foundation-models imputation multi-task prompt-tuning time-series unified-model zero-shot
Last synced: 3 months ago
JSON representation
A unified multi-task time series model.
- Host: GitHub
- URL: https://github.com/mims-harvard/units
- Owner: mims-harvard
- License: mit
- Created: 2024-02-16T16:17:21.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-04-01T20:35:03.000Z (10 months ago)
- Last Synced: 2024-08-02T06:19:32.980Z (6 months ago)
- Topics: anomaly-detection, classification, ecg, eeg, few-shot, forecasting, foundation-models, imputation, multi-task, prompt-tuning, time-series, unified-model, zero-shot
- Language: Python
- Homepage: https://zitniklab.hms.harvard.edu/projects/UniTS/
- Size: 66.4 KB
- Stars: 381
- Watchers: 14
- Forks: 51
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-time-series - [code
README
# Unified Time Series Model
[**Project Page**](https://zitniklab.hms.harvard.edu/projects/UniTS/) | [**Paper link**](https://arxiv.org/pdf/2403.00131.pdf) **(Neurips 2024)**
UniTS is a unified time series model that can process various tasks across multiple domains with shared parameters and does not have any task-specific modules.
Authors: [Shanghua Gao](https://shgao.site/) [Teddy Koker](https://teddykoker.com) [Owen Queen](https://owencqueen.github.io/) [Thomas Hartvigsen](https://www.tomhartvigsen.com/) [Theodoros Tsiligkaridis](https://sites.google.com/view/theo-t) [Marinka Zitnik](https://zitniklab.hms.harvard.edu/)
## Overview
Foundation models, especially LLMs, are profoundly transforming deep learning. Instead of training many task-specific models, we can adapt a single pretrained model to many tasks via few-shot prompting or fine-tuning. However, current foundation models apply to sequence data but not to time series, which present unique challenges due to the inherent diverse and multi-domain time series datasets, diverging task specifications across forecasting, classification and other types of tasks, and the apparent need for task-specialized models.We developed UniTS, a unified time series model that supports a universal task specification, accommodating classification, forecasting, imputation, and anomaly detection tasks. This is achieved through a novel unified network backbone, which incorporates sequence and variable attention along with a dynamic linear operator and is trained as a unified model.
Across 38 multi-domain datasets, UniTS demonstrates superior performance compared to task-specific models and repurposed natural language-based LLMs. UniTS exhibits remarkable zero-shot, few-shot, and prompt learning capabilities when evaluated on new data domains and tasks.
## Setups
### 1. Requirements
Install Pytorch2.0+ and the required packages.
```
pip install -r requirements.txt
```### 2. Prepare data
```
bash download_data_all.sh
```
Datasets configs for different multi-task settings are shown in `.ymal` files of the `data_provider` folder.By default, all experiments follow the multi-task setting where one UniTS model is jointly trained on mulitple datasets.
### 3. Train and evaluate model
#### 1. Multi-task learning on forecasting and classification tasks:
- Pretraining + Prompt learning
```
bash ./scripts/pretrain_prompt_learning/UniTS_pretrain_x128.sh
```- Supervised learning
```
bash ./scripts/supervised_learning/UniTS_supervised.sh
```#### 2. Few-shot transfer learning on new forecasting and classification tasks:
**Note: Please follow the instruction in following training scripts to get the pretrained ckpt first.**
- Finetuning
```
# please set the pretrianed model path in the script.
bash ./scripts/few_shot_newdata/UniTS_finetune_few_shot_newdata_pct20.sh
```- Prompt tuning
```
# please set the pretrianed model path in the script.
bash ./scripts/few_shot_newdata/UniTS_prompt_tuning_few_shot_newdata_pct20.sh
```#### 3. Few-shot transfer learning on anomaly detection tasks:
- Finetuning
```
# please set the pretrianed model path in the script.
bash ./scripts/few_shot_anomaly_detection/UniTS_finetune_few_shot_anomaly_detection.sh
```
- Prompt tuning
```
# please set the pretrianed model path in the script.
bash ./scripts/few_shot_anomaly_detection/UniTS_prompt_tuning_few_shot_anomaly_detection.sh
```#### 4. Few-shot transfer learning on imputation tasks:
- Finetuning
```
# please set the pretrianed model path in the script.
bash ./scripts/few_shot_imputation/UniTS_finetune_few_shot_imputation_mask050.sh
```- Prompt tuning
```
# please set the pretrianed model path in the script.
bash ./scripts/few_shot_imputation/UniTS_prompt_tuning_few_shot_imputation_mask050.sh
```#### 5. Zero-shot learning on new forecasting length:
```
# please set the pretrianed model path in the script.
bash ./scripts/zero_shot/UniTS_forecast_new_length_unify.sh
```#### 6. Zero-shot learning on new forecasting datasets:
```
# A special verison of UniTS with shared prompt/mask tokens needs to be trained for this setting.
bash ./scripts/zero_shot/UniTS_zeroshot_newdata.sh
```## Use UniTS on your own data.
UniTS is a highly flexible unified time series model, supporting tasks such as forecasting, classification, imputation, and anomaly detection with a single shared model and shared weights. We provide a [Tutorial](Tutorial.md) to assist you in using your own data with UniTS.## Pretrained weights
We provide the pretrained weights for models mentioned above in [checkpoints](https://github.com/mims-harvard/UniTS/releases/tag/ckpt).## Citation
```
@article{gao2024building,
title={UniTS: Building a Unified Time Series Model},
author={Gao, Shanghua and Koker, Teddy and Queen, Owen and Hartvigsen, Thomas and Tsiligkaridis, Theodoros and Zitnik, Marinka},
journal={arXiv},
url={https://arxiv.org/pdf/2403.00131.pdf},
year={2024}
}
```## Acknowledgement
This codebase is built based on the [Time-Series-Library](https://github.com/thuml/Time-Series-Library). Thanks!## Disclaimer
DISTRIBUTION STATEMENT: Approved for public release. Distribution is unlimited.
This material is based upon work supported by the Under Secretary of Defense for Research and Engineering under Air Force Contract No. FA8702-15-D-0001. Any opinions, findings, conclusions or recommendations expressed in this material are those of the author(s) and do not necessarily reflect the views of the Under Secretary of Defense for Research and Engineering.
© 2024 Massachusetts Institute of Technology.
Subject to FAR52.227-11 Patent Rights - Ownership by the contractor (May 2014)
The software/firmware is provided to you on an As-Is basis
Delivered to the U.S. Government with Unlimited Rights, as defined in DFARS Part 252.227-7013 or 7014 (Feb 2014). Notwithstanding any copyright notice, U.S. Government rights in this work are defined by DFARS 252.227-7013 or DFARS 252.227-7014 as detailed above. Use of this work other than as specifically authorized by the U.S. Government may violate any copyrights that exist in this work.