Skip to main content

🎨 A toolkit to explore the Aignostics OpenTME dataset.

Project description

License CI Dependabot Renovate enabled codecov Ruff Copier Open in molab

🎨 TME Studio

Welcome to TME Studio! This readme explains the content of TME Studio, and the dataset it is built on: OpenTME.

Already familiar and just want to get started? Move on to the Setup instructions.

Want to view an interactive demo first? Open the molab demo app!

Content

What is OpenTME?

OpenTME is an open-source project by Aignostics that provides academic researchers with pre-computed quantitative TME (Tumor Micro-Environment) features across H&E-stained WSIs from The Cancer Genome Atlas (TCGA). It provides comprehensive spatial outputs characterizing key cellular and tissue components of the TME, including cancer cells, immune cells, and stromal features, as well as their relationships within the tissue architecture.

All outputs were generated using Atlas H&E-TME, Aignostics' AI-powered computational pathology application for the automated identification and quantification of TME features in FFPE H&E-stained tissue samples.

What is TME Studio?

TME Studio contains a set of tutorials and example notebooks to help you explore OpenTME. TME Studio is provided as an entry point into OpenTME, and intended to accelerate research output from the OpenTME data.

Content

The structure of the notebooks in this repo looks as follows:

tme_studio/
|-- aignostics_tme_studio/
    |-- src/
        |-- notebooks/
            |-- demo/
            |-- examples/
            |-- tutorials/
  • Tutorials: Tutorials: Step-by-step notebooks to help users get started, covering foundational tasks such as loading and exploring the dataset, and providing a guide through the OpenTME features.

  • Examples: Concise notebooks demonstrating specific analysis types, such as immune desert classification and Kaplan–Meier survival plots. The examples showcase what types of analyses might be possible with OpenTME. Note that these are examples, and are not statistically rigorous, but may be used as a starting point for your own analysis.

  • Demo: contains a demo notebook showcasing all features in OpenTME and some example analyses.

If you are unfamiliar with the OpenTME dataset, we suggest beginning at src/aignostics_tme_studio/notebooks/tutorials/1_getting_started.py. To get a feeling for all the different features you can find in OpenTME, have a look at the demo notebook src/aignostics_tme_studio/notebooks/demo/demo.py.

Setup instructions

To run the TME Studio notebooks, follow these installation instructions:

Prerequisites

Tool Version Purpose
mise latest Task runner & tool version manager
Git latest Version control

Installing mise

mise manages tool versions (Python, uv, trivy, etc.) and runs all project tasks. Install it first:

curl https://mise.run | sh

# activate mise in the current shell and add to shell config for future sessions
echo 'eval "$(mise activate --shims bash)"' >> ~/.bashrc
source ~/.bashrc

For .zsh users:

echo 'eval "$(mise activate --shims zsh)"' >> ~/.zshrc
source ~/.zshrc

For other shells, see mise installation docs.

Verify the installation:

mise --version

# Check path - mise shims should be first in the PATH to ensure the correct tool versions are used
echo $PATH

which uv # Path should contain the `mise/shims/uv` shim, not a system-wide uv installation; please do not install uv in the same directory as `mise` to avoid conflicts

Cloning the repository

Authenticate with GitHub using the Github CLI to clone the repository:

gh auth login

gh repo clone aignostics/tme-studio

cd tme-studio
mise trust
gh auth setup-git

Installation

# Install all dev dependencies, pre-commit hooks, and keyring tooling
mise run install

# Verify everything works
mise run lint

# List all existing mise tasks
mise tasks

This runs uv sync --all-extras to install all dependencies (including private registry packages), then sets up pre-commit hooks.

🤗 Hugging Face access

Creating an access token

  1. Make sure you have a Hugging Face account. If you don't have one, you can create one for free at hf.co/join.
  2. Get access to the dataset by going to https://huggingface.co/datasets/Aignostics/OpenTME and clicking "Access"

Note: You will eceive an email from Hugging Face as soon as your access request has been reviewed. This may take a few working days.

Note: No need to download the dataset! The tutorials will show you how to access the dataset via the Hugging Face API.

  1. Create an access token by going to https://huggingface.co/settings/tokens

Authenticating with your token

You can now use your token in two ways:

  1. Enter it in the designated box for it inside each notebook. You will have to repeat this action each time you open a notebook.

  2. Log in via the Hugging Face CLI (recommended). In this case your token will be stored and you won't have to enter your token each time you open a notebook.

    1. Download the Hugging Face CLI
    2. Log into hugging face by calling
hf auth login

and log in with your access token.

Note: If you invalidated your token, you can force logging in with a new token by calling hf auth login \--force

Starting Marimo

You are now ready to explore the notebooks! 🎨

Start marimo by calling the following command and opening the URL in your browser:

uv run marimo edit

Use the marimo UI opened in your browser to navigate to the notebooks.

Alternatively, you can run

uv run marimo edit path/to/notebook.py

to open a specific notebook directly.

Further Reading

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

aignostics_tme_studio-0.2.1.tar.gz (6.3 MB view details)

Uploaded Source

Built Distribution

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

aignostics_tme_studio-0.2.1-py3-none-any.whl (6.3 MB view details)

Uploaded Python 3

File details

Details for the file aignostics_tme_studio-0.2.1.tar.gz.

File metadata

  • Download URL: aignostics_tme_studio-0.2.1.tar.gz
  • Upload date:
  • Size: 6.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for aignostics_tme_studio-0.2.1.tar.gz
Algorithm Hash digest
SHA256 03fb22e4ec5b08a848db216efb5c2d7593583bfa8a5ef6c42bb5f17d8961615f
MD5 c0dbf6f6748c0de24df91a5442822ec6
BLAKE2b-256 116f3f948f095e4ec8c17c66376a20f9849cdd20a9db8998a78e5c0eb5f025d3

See more details on using hashes here.

File details

Details for the file aignostics_tme_studio-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: aignostics_tme_studio-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 6.3 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for aignostics_tme_studio-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 fa401cfe9c1a15d654972d7c7dc6d96c61b6bda01a814c64c4ad4861802a7d6d
MD5 58ef1165ccb29cd15ac6c25efba80471
BLAKE2b-256 2cae378b2621732dc807af86f2fed5261c9f400d83fc454a5f0f293d0035c902

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