This is an official implementation of xPatch: Dual-Stream Time Series Forecasting with Exponential Seasonal-Trend Decomposition.
Exponential Patch (xPatch) is a novel dual-stream architecture that utilizes exponential decomposition.
Simple Moving Average (SMA) is the unweighted mean of the previous data points.
Exponential Moving Average (EMA) is an exponential smoothing method that assigns greater weight to more recent data points while smoothing out older data.
Dual-flow architecture consists of an MLP-based linear stream and a CNN-based non-linear stream.
In the unified experimental settings, xPatch achieves the best averaged performance on 60% of the datasets using the MSE metric and 70% of the datasets using the MAE metric.
In the hyperparameter search settings, xPatch achieves the best averaged performance on 70% of the datasets using the MSE metric and 90% of the datasets using the MAE metric.
We explore the ability of different models to learn from a longer lookback window.
We explore the impact of the dual flow network in xPatch architecture and assess the contribution of each stream. The four possible configurations:
- Original: Seasonality -> non-linear stream, Trend -> linear stream
- Reversed: Seasonality -> linear stream, Trend -> non-linear stream
- Non-linear only: Seasonality -> non-linear stream, Trend -> non-linear stream
- Linear only: Seasonality -> linear stream, Trend -> linear stream
-
Install conda environment:
conda env create -f environment.yml
-
Download data. You can download the datasets from Google Driver, Baidu Driver or Kaggle Datasets. All datasets are pre-processed and can be used easily. Create a seperate folder
./dataset
and put all the files in the directory. -
Train the model. We provide the experiment scripts of all benchmarks under the folder
./scripts
. The script for unified settings is xPatch_unified, while for hyperparameter search you can use xPatch_search. You can reproduce the experiments by:
bash scripts/xPatch_unified.sh
All experiments were conducted on a single Quadro RTX 6000 GPU. You can adjust the hyperparameters based on your needs (e.g. batch size, patch length, lookback windows and prediction lengths, alpha parameter for exponential decomposition). We also provide code for the baseline models and for ablation experiments from Appendix (EMA decomposition, arctangent loss, sigmoid learning rate adjustment scheme, inference time) in ./ablation
.
We appreciate the following github repos for their valuable code and effort:
- Autoformer (https://github.com/thuml/Autoformer)
- FEDformer (https://github.com/MAZiqing/FEDformer)
- ETSformer (https://github.com/salesforce/ETSformer)
- DLinear (https://github.com/cure-lab/LTSF-Linear)
- RLinear (https://github.com/plumprc/RTSF)
- PatchTST (https://github.com/yuqinie98/PatchTST)
- CARD (https://github.com/wxie9/CARD)
- TimeMixer (https://github.com/kwuking/TimeMixer)
- iTransformer (https://github.com/thuml/iTransformer)
- Time-Series-Library (https://github.com/thuml/Time-Series-Library)
- RevIN (https://github.com/ts-kim/RevIN)
If you have any questions or concerns, please contact us at stitsyuk@kaist.ac.kr or submit an issue.
If you find this repository useful in your research, please consider citing our paper as follows:
@inproceedings{Stitsyuk-2025-xPatch,
title = {xPatch: Dual-Stream Time Series Forecasting with Exponential Seasonal-Trend Decomposition},
author = {Stitsyuk, Artyom and Choi, Jaesik},
booktitle = {Proceedings of the AAAI Conference on Artificial Intelligence},
year = {2025}
}