Multimodal extension for time series foundation models
Project description
TSFMx
TSFMx (TSFMx Standardizes Fusion of Multimodal exogenous features) is a framework for extending TSFMs (including TimesFM and Chronos) with multimodal inputs such as text.
Installation
pip install tsfmx[all]
Quick Start
1. Setup
Clone the Time-MMD dataset:
./scripts/clone_time_mmd.sh
Split the dataset into train / val / test:
PYTHONPATH=. uv run python scripts/split_time_mmd_datasets.py \
--train-ratio 0.6 \
--val-ratio 0.2
2. Pre-compute Text Embeddings
TimesFM:
PYTHONPATH=. uv run python scripts/cache_time_mmd_datasets.py \
--model-config examples/time_mmd/configs/models/timesfm.yml \
--text-encoder-type english
PYTHONPATH=. uv run python scripts/cache_time_mmd_datasets.py \
--model-config examples/time_mmd/configs/models/timesfm.yml \
--text-encoder-type english --augment
Chronos:
PYTHONPATH=. uv run python scripts/cache_time_mmd_datasets.py \
--model-config examples/time_mmd/configs/models/chronos.yml \
--text-encoder-type english
PYTHONPATH=. uv run python scripts/cache_time_mmd_datasets.py \
--model-config examples/time_mmd/configs/models/chronos.yml \
--text-encoder-type english --augment
3. Fusion Hyperparameter Tuning
Run a W&B Sweeps search for the fusion mode (adapter frozen, fusion layer trained):
TimesFM:
PYTHONPATH=. uv run python scripts/tune_time_mmd_fusion_sweep.py \
--model-config examples/time_mmd/configs/models/timesfm.yml \
--sweep-config examples/time_mmd/configs/sweeps/fusion_1layer.yml \
--best-checkpoint-path outputs/sweeps/fusion/best_fusion_timesfm.pt
Chronos:
PYTHONPATH=. uv run python scripts/tune_time_mmd_fusion_sweep.py \
--model-config examples/time_mmd/configs/models/chronos.yml \
--sweep-config examples/time_mmd/configs/sweeps/fusion_1layer.yml \
--best-checkpoint-path outputs/sweeps/fusion/best_fusion_chronos.pt
To run the adapter mode (adapter fine-tuned, no fusion):
TimesFM:
PYTHONPATH=. uv run python scripts/tune_time_mmd_adapter_sweep.py \
--model-config examples/time_mmd/configs/models/timesfm.yml \
--sweep-config examples/time_mmd/configs/sweeps/adapter.yml
Chronos:
PYTHONPATH=. uv run python scripts/tune_time_mmd_adapter_sweep.py \
--model-config examples/time_mmd/configs/models/chronos.yml \
--sweep-config examples/time_mmd/configs/sweeps/adapter.yml
4. Finetune Hyperparameter Tuning
After fusion tuning, run a W&B Sweeps search for the finetune mode (adapter + fusion trained jointly), starting from the best fusion checkpoint:
TimesFM:
PYTHONPATH=. uv run python scripts/tune_time_mmd_finetune_sweep.py \
--model-config examples/time_mmd/configs/models/timesfm.yml \
--sweep-config examples/time_mmd/configs/sweeps/finetune_1layer.yml \
--fusion-checkpoint-path outputs/sweeps/fusion/best_fusion_timesfm.pt
Chronos:
PYTHONPATH=. uv run python scripts/tune_time_mmd_finetune_sweep.py \
--model-config examples/time_mmd/configs/models/chronos.yml \
--sweep-config examples/time_mmd/configs/sweeps/finetune_1layer.yml \
--fusion-checkpoint-path outputs/sweeps/fusion/best_fusion_chronos.pt
Acknowledgments
We thank the Time-MMD team for providing the multimodal time series dataset used in our examples and experiments.
License
MIT
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tsfmx-1.1.1.tar.gz.
File metadata
- Download URL: tsfmx-1.1.1.tar.gz
- Upload date:
- Size: 20.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f9bc3f2faec7a6692e3a0984dbf5abe8390b0a2025d10e48209cee6b78d1bf7b
|
|
| MD5 |
5893cbfaa3b02d9aa9b952956a8fe340
|
|
| BLAKE2b-256 |
ba14a1c03596431bbcaaad824507d0d1ac9e938738ad2648c50b562ee38dfc1f
|
Provenance
The following attestation bundles were made for tsfmx-1.1.1.tar.gz:
Publisher:
publish-to-pypi.yml on himura467/tsfmx
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tsfmx-1.1.1.tar.gz -
Subject digest:
f9bc3f2faec7a6692e3a0984dbf5abe8390b0a2025d10e48209cee6b78d1bf7b - Sigstore transparency entry: 1552231027
- Sigstore integration time:
-
Permalink:
himura467/tsfmx@e84f5097f583963c4aa63bf02c0f90f0e3133005 -
Branch / Tag:
refs/tags/v1.1.1 - Owner: https://github.com/himura467
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@e84f5097f583963c4aa63bf02c0f90f0e3133005 -
Trigger Event:
release
-
Statement type:
File details
Details for the file tsfmx-1.1.1-py3-none-any.whl.
File metadata
- Download URL: tsfmx-1.1.1-py3-none-any.whl
- Upload date:
- Size: 27.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cd20d808d1ec63fa210640181b146033da25db54e1eef0903360f7f2cedae8c3
|
|
| MD5 |
1e6c7c8f28cf4600bfff3e2b564b6178
|
|
| BLAKE2b-256 |
308568b7d9c178e23eef7091ee4b31361af758eb306dcb7e20e21a14928a601c
|
Provenance
The following attestation bundles were made for tsfmx-1.1.1-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on himura467/tsfmx
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tsfmx-1.1.1-py3-none-any.whl -
Subject digest:
cd20d808d1ec63fa210640181b146033da25db54e1eef0903360f7f2cedae8c3 - Sigstore transparency entry: 1552231035
- Sigstore integration time:
-
Permalink:
himura467/tsfmx@e84f5097f583963c4aa63bf02c0f90f0e3133005 -
Branch / Tag:
refs/tags/v1.1.1 - Owner: https://github.com/himura467
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@e84f5097f583963c4aa63bf02c0f90f0e3133005 -
Trigger Event:
release
-
Statement type: