Skip to main content

A streamlined benchmarking platform for single-cell time-series analysis

Project description

scTimeBench-Logo scTimeBench

python License bioRXiv Google Colab Install Pypi Zenodo Documentation

scTimeBench Overview

Table of Contents

Environment Setup

scTimeBench was tested and supported using Python 3.10. If any other version that is 3.10+ does not work when using the benchmark, please submit an issue to this GitHub.

Important Note: this setup is needed twice. Once for the user to run the benchmark metrics, and the second time for the method itself needing to read from scTimeBench.method_utils.method_runner and other important shared constants. In short, this means we need to install scTimeBench into two separate virtual environments:

  1. Your normal pip installation where you'll be running the benchmark from. This will require the extra "[benchmark]" group installation (pip) or the extra group installation --extra benchmark (uv).
  2. For each method's virtual environment, you need to install the scTimeBench.

Suggested UV Installation

Due to external dependencies and a more complex setup, we have decided to package everything under uv (see: https://github.com/astral-sh/uv). To start with, you need to get all the necessary extern dependencies, which can be done either by running:

git submodule update --init extern/

If you wish to benchmark across all methods, feel free to clone the submodules for all the methods as well with:

git submodule update --init

Then, install uv and run the following:

uv sync --extra benchmark

If you're using uv under a method's virtual environment, either the pip installation or the following will suffice:

uv sync

Standard Pip

If the external dependencies such as pypsupertime or sceptic are not used (which they are not used by default), you can install using pip as follows:

pip install scTimeBench[benchmark]

to run the benchmark. For your own method, simply install without the extra benchmarking requirements with

pip install scTimeBench

There are extra dependencies that can be found under pyproject.toml.

Benchmark Architecture

Benchmark Architecture scTimeBench is controlled by a central configuration file which determines which datasets, methods, and metrics to run. An example of this can be found under configs/scNODE/gex.yaml.

Detailed Layout of File Structure

  • configs/: possible yaml config files to use as a starting point
  • extern/: external packages that required edits for compatability such as pyPsupertime and Sceptic.
  • methods/: the different methods that are possible to use, including defined submodules. Add your own methodology here.
  • src/: where the scTimeBench package lies. See src/ReadMe.md for more documentation on the modules that exist there.
  • test/: unit tests for each method, dataset, metric, and other important modules.

Command-Line Interface Details

The entrypoint for the benchmark is defined as scTimeBench. Run scTimeBench --help for more details, or refer to src/scTimeBench/config.py and the documentation.

Example Run

Run the package with:

scTimeBench --config configs/scNODE/gex.yaml

For a full running example using scNODE, refer to our example Jupyter Notebook.

Contributing to scTimeBench

If you want to contribute, please install the dev environments with:

uv sync --extra dev --extra benchmark

or use pip in editable mode with:

pip install -e ".[dev, benchmark]"

To enable the autoformatting, please run:

pre-commit install

before committing.

Follow our example tutorials on adding new methods, datasets, and metrics in our documentation here: https://li-lab-mcgill.github.io/scTimeBench/.

Testing

If your change heavily modifies the architecture, please run the necessary tests under the test/ environment using pytest. Read more on the different available tests under test/ReadMe.md. See more information on the pytest documentation: https://docs.pytest.org/en/stable/. A useful flag is -s to view the entire output of the test.

Citation

@article {scTimeBench,
	author = {Osakwe, Adrien and Huang, Eric Haoran and Li, Yue},
	title = {scTimeBench: A streamlined benchmarking platform for single-cell time-series analysis},
	elocation-id = {2026.03.16.712069},
	year = {2026},
	doi = {10.64898/2026.03.16.712069},
	publisher = {Cold Spring Harbor Laboratory},
	URL = {https://www.biorxiv.org/content/early/2026/03/18/2026.03.16.712069},
	eprint = {https://www.biorxiv.org/content/early/2026/03/18/2026.03.16.712069.full.pdf},
	journal = {bioRxiv}
}

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

sctimebench-0.1.1.tar.gz (77.1 kB view details)

Uploaded Source

Built Distribution

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

sctimebench-0.1.1-py3-none-any.whl (97.7 kB view details)

Uploaded Python 3

File details

Details for the file sctimebench-0.1.1.tar.gz.

File metadata

  • Download URL: sctimebench-0.1.1.tar.gz
  • Upload date:
  • Size: 77.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for sctimebench-0.1.1.tar.gz
Algorithm Hash digest
SHA256 91141097e68754aa07a02edadc42d36937d5859d6f4e5532a26c276d49bb8864
MD5 2770c6f66cc85483c17c4121b1e216b2
BLAKE2b-256 4ed3f93232be6e953a9bc11112a1a91c83b06de186bc971cb924416d5b485e63

See more details on using hashes here.

File details

Details for the file sctimebench-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: sctimebench-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 97.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for sctimebench-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5b32e77ad3d9429cf550c2ac2a9b6f63f315ba2c1abc6079b4c0e967efe544af
MD5 184eb5a9c19e9008d999ee750827dee3
BLAKE2b-256 ca579ffa6527d6cad8a40bf20d0aa6f6188ce1cef65405d54f19b7df23056854

See more details on using hashes here.

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