
# See More, Forecast Better and Faster: Enhancing Time Series Foundation Models via Inference-Time Plug-and-Play Downsampling

This repository contains the official implementation of **SPRINT** for the ICML'26 submission:

> **See More, Forecast Better and Faster: Enhancing Time Series Foundation Models via Inference-Time Plug-and-Play Downsampling**

SPRINT is a **training-free**, **plug-and-play** inference-time framework that enhances Time Series Foundation Models (TSFMs) for long-term and ultra-long-term forecasting.

This codebase is built upon **TSLib / Time-Series-Library** (https://github.com/thuml/Time-Series-Library).



## Repository Structure

All runnable code lives in `./code`:

```
icml26_SPRINT/
	README.md
	code/
		run.py
		scripts/
			Base.sh
			SPRINT.sh
		models/
			SPRINT.py
			Base.py
			...
		dataset/
			ETTh1.csv
			Service.csv
		foundation_models/
			...
```

- `code/models/SPRINT.py`: the implementation of **SPRINT**.
- `code/scripts/Base.sh`: zero-shot evaluation scripts for **base TSFMs**.
- `code/scripts/SPRINT.sh`: zero-shot evaluation scripts for **TSFMs + SPRINT**.
- `code/dataset/`: datasets used by the scripts (see below).
- `code/foundation_models/`: downloaded TSFM checkpoints / assets (see below).


## Quickstart

> [!IMPORTANT]
> SPRINT is **training-free**. Please run everything in **zero-shot mode** with `--is_training 0` (already the default in our scripts).

### 1) Environment

This repo follows the dependency conventions of **Time-Series-Library** and the selected TSFMs.
In practice you need at least: `python>=3.10`, `torch`, `numpy`, `pandas`, `einops`, and `torchcubicspline`.

Some TSFMs depend on `transformers` with specific versions. We summarize the constraints in:

- `code/foundation_models/env.config`

> [!NOTE]
> Different TSFMs may require different environments. You can either (1) create separate envs per TSFM, or (2) install a compatible `transformers` version depending on which TSFM you run.


### 2) Datasets

Our code is based on Time-Series-Library, so you can use the datasets provided by that benchmark.

- Put all dataset files under `code/dataset/`.
- Our repository includes:
	- `ETTh1.csv` as a runnable example.
	- `Service.csv` (a high-frequency sampled dataset we collected and open-sourced).

The provided scripts may iterate over multiple datasets (e.g., `ETTh2`, `ETTm1`, `weather`, `Solar`, etc.).
If you want to run them, please download the corresponding files from Time-Series-Library and place them into `code/dataset/` with the expected filenames.


### 3) Foundation Model Checkpoints

SPRINT works as a wrapper around TSFMs.
For each TSFM, please download the checkpoints following the **official links in our paper**, and place them under:

```
code/foundation_models/
```

This repository already provides the folder layout (e.g., `timer-base-84m/`, `timesfm-*/`, `chronos-t5-small/`, `moirai-*/`, etc.).

> [!IMPORTANT]
> Some TSFMs require extra packages or special versions:
> - `Timer`, `Sundial`: `transformers==4.40.1`
> - `Chronos`: `transformers==4.56.2`
> - `Moirai`: may require `uni2ts` (see the note in `code/foundation_models/env.config`)


## Run Experiments (Zero-shot)

All scripts assume you run them from `./code`.

### Option A: Base TSFM (no SPRINT)

Run the base TSFM evaluation script:

```bash
cd code
bash scripts/Base.sh
```

Optional arguments:

```bash
bash scripts/Base.sh <exp_name> <is_training> <gpu_id>
```

- `exp_name`: experiment name (default: `test`)
- `is_training`: must be `0` for zero-shot evaluation (default: `0`)
- `gpu_id`: CUDA device id (default: `0`)


### Option B: TSFM + SPRINT (plug-and-play)

Run the SPRINT evaluation script:

```bash
cd code
bash scripts/SPRINT.sh
```

Optional arguments:

```bash
bash scripts/SPRINT.sh <exp_name> <is_training> <gpu_id>
```


## What the Scripts Do

`scripts/Base.sh` and `scripts/SPRINT.sh` iterate over:

- multiple datasets (e.g., `ETTh1`, `ETTh2`, `ETTm1`, ..., `Service`)
- multiple prediction lengths (e.g., `96 192 336 720 1440`)
- multiple TSFM backbones (e.g., `timer`, `moirai`, `timesfm`, `timemoe`, `chronos`, `visionts`, `toto`)

Internally, they call:

```bash
python -u run.py ...
```

Where:

- `--model` selects the wrapper: `Base` or `SPRINT`
- `--model_type` selects the TSFM backbone (e.g., `timesfm`, `timer`, ...)


## Outputs

By default:

- logs: `code/logs/`
- metrics: `code/logs/metrics/`
- detailed metrics: `code/logs/detail_metrics/`
- raw predictions / test artifacts: `code/test_results/`


## Acknowledgement

This implementation is based on the Time-Series-Library (TSLib): https://github.com/thuml/Time-Series-Library


## Citation

If you find this repo useful, please cite our paper (to be updated after acceptance).

