Skip to main content

TS-ICL: A Flexible Time-Index Foundation Model for Time Series via In-Context Learning

Project description

TS-ICL architecture

TS-ICL: a Time-Indexed Foundation Model for Time Series Forecasting & Imputation via In-Context Learning

arXiv PyPI test Python

Paper: TS-ICL: A Flexible Time-Indexed Foundation Model for Time Series via In-Context Learning

TS-ICL is a continuous probabilistic Time Series Foundation Model (TSFM) that unifies forecasting and imputation in a single zero-shot architecture, requiring no task-specific training or fine-tuning.

TS-ICL architecture

Installation

pip install tsicl

Model checkpoint can be found on TS-ICL's Huggingface repo.

Requirements: Python ≥ 3.12, PyTorch ≥ 2.5.1


Quick Start

from tsicl import TSICL

model = TSICL(model_path="checkpoints/tsicl-v1.ckpt")

# Forecasting — predict the next 96 timesteps
point, quantiles = model.forecast(
    inputs            = my_series,        # e.g. 1-D numpy array or tensor
    prediction_length = 96,
    quantile_levels   = [0.1, 0.5, 0.9],
    denormalize       = True
)

# Imputation — reconstruct NaN values
point, quantiles = model.impute(
    inputs          = my_series_with_nans,
    quantile_levels = [0.1, 0.5, 0.9],
    denormalize     = True
)

Both methods return a (point_prediction, quantile_predictions) tuple. NaN values are handled natively — no preprocessing required.


Notebooks

Step-by-step tutorials on synthetic Gaussian Processes:

Notebook Description
get_started_imputation.ipynb Pointwise & block missingness, covariate-aware imputation, output format, batch processing
get_started_forecasting.ipynb Univariate forecasting, partially observed look-back, covariate-aware forecasting, batch processing

Model

TS-ICL processes each time series through four successive modules:

  1. Time Series Encoder — a Perceiver-like architecture that compresses observed (timestamp, value) pairs into M = 32 learnable latent tokens via cross-attention. Accepts inputs of arbitrary length without preprocessing.
  2. Channel Mixer — aggregates information across channels via cross-attention. Selectively integrates covariate representations into the target's representation when covariates are provided.
  3. Temporal Context Query Module — maps any query timestamp to a context-aware embedding using Fourier (NeRF-style) positional encoding. Enables prediction at arbitrary timestamps, including on irregular grids.
  4. In-Context Regressor — a causal Transformer that reads observed (representation, value) pairs as in-context training examples and outputs 99 quantiles at the queried timestamps.

A single checkpoint (tsicl-v1.ckpt) contains two specialised components — one trained with masking for imputation, one with causal masking for forecasting — sharing the same architecture backbone.


Performance

Forecasting — fev-bench

TS-ICL is highly competitive with the best forecasting foundation models, while being fast at inference. TS-ICL efficently leverages covariate (when relevant) and is also robust to sparse look-back windows.

fev-bench results

Example — pointwise forecast with a known covariate (GFC17 dataset):

Forecast with covariate example

Forecasting — TIME benchmark

TIME benchmark results

Imputation — fm-impute-bench

TS-ICL achieves state-of-the-art imputation across 132 univariate and 24 covariate-aware tasks, outperforming the best tabular foundation model baseline while being ~50× faster at inference.

fm-impute-bench results

Example — block imputation with uncertainty quantification (COVID-19 energy dataset):

Block imputation with uncertainty quantification example

Citation

If you use TS-ICL for research purposes, please consider citing the associated paper:

@article{lenaour2026tsicl,
  title={TS-ICL: A Flexible Time-Indexed Foundation Model for Time Series via In-Context Learning},
  author={Le Naour, Etienne and Nabil, Tahar and Petralia, Adrien},
  journal={arXiv preprint arXiv:2606.05878},
  year={2026}
}

Contributors


License

TS-ICL weights and code are released under a non-commercial license, see LICENSE.

Contact

To learn more or request a commercial license, please contact us at: tsicl-contact_at_edf.fr (replace _at_ with @).

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

tsicl-0.2.0.tar.gz (55.7 kB view details)

Uploaded Source

Built Distribution

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

tsicl-0.2.0-py3-none-any.whl (76.3 kB view details)

Uploaded Python 3

File details

Details for the file tsicl-0.2.0.tar.gz.

File metadata

  • Download URL: tsicl-0.2.0.tar.gz
  • Upload date:
  • Size: 55.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tsicl-0.2.0.tar.gz
Algorithm Hash digest
SHA256 98578bdeea86236bd10343d699af3ad4e0e2bdc6a91f501f55473e622daa23c9
MD5 ae1c3d1c2da8295568343c73057cc42b
BLAKE2b-256 98942d931ec53f3b20a70af521d5cbce3a1abbaa24c89282ef60457f9f0c8413

See more details on using hashes here.

Provenance

The following attestation bundles were made for tsicl-0.2.0.tar.gz:

Publisher: publish.yml on EDF-Lab/ts-icl

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

File details

Details for the file tsicl-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: tsicl-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 76.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tsicl-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a46b5c93d22d93e3f2f0bfc5042192687bb6c8e4437347eb44e570ee48b11551
MD5 e500aba3a245b2aab5054dedd5ec0933
BLAKE2b-256 262cfe8b5b635a7a41ce2bc129862382c730d07bf7a188782a83c49770d24375

See more details on using hashes here.

Provenance

The following attestation bundles were made for tsicl-0.2.0-py3-none-any.whl:

Publisher: publish.yml on EDF-Lab/ts-icl

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