Skip to main content

Minkowski-profile analysis toolkit for spatial transcriptomics

Project description

minkiPy

3D density distribution separated into level sets

minkiPy is a Python package for differential analysis of gene spatial organisation in spatial transcriptomics data, using Minkowski functionals and tensors.

This repository accompanies the paper "Differential Analysis of Gene Spatial Organisation with Minkowski Functionals and Tensors" and includes:

  • the minkiPy package,
  • a command-line interface,
  • an exploratory notebook to get started quickly on your own data,
  • full workflow notebooks used for end-to-end analyses.

Contents

  1. Input format
  2. Method summary
  3. Installation
  4. Quick start (Python)
  5. Command-line usage
  6. MPI usage patterns
  7. Repository layout

Input format

minkiPy expects a pandas.DataFrame with transcript-level coordinates and these columns:

  • gene
  • global_x
  • global_y
import pandas as pd

transcripts_df = pd.DataFrame({
    "gene": [...],
    "global_x": [...],
    "global_y": [...],
})

Notes:

  • gene is a string identifier.
  • global_x and global_y should share the same coordinate system (usually micrometres).
  • Converting platform-specific files to this format is done upstream.

Method summary

For each gene, minkiPy reconstructs a spatial density field and computes a profile across level sets.

Each profile contains:

  • W0 (area),
  • W1 (boundary length),
  • W2 (Euler-characteristic-related term),
  • beta (anisotropy index from a Minkowski tensor).

Profiles are shaped (4, LS) per gene.

Optional Monte Carlo runs estimate covariance. Distances can then be covariance-aware Gaussian 2-Wasserstein, or Euclidean for fast exploration.

These profiles are the starting point for downstream analysis: sample and gene comparisons, condition-level ranking of spatial reorganisation, and embedding/graph analyses.


Installation

mpi4py needs an MPI runtime (mpirun/mpiexec) installed on your machine.

Before choosing an option:

  • Option A (pip from PyPI) does not require cloning this repository.
  • Options B/C (YAML or local development) require a local clone first:
git clone https://github.com/BAUDOTlab/minkiPy.git
cd minkiPy

Option A (recommended): pip

  1. Check MPI:
mpirun --version

If missing, install MPI first:

  • Ubuntu/Debian
    sudo apt update
    sudo apt install -y openmpi-bin libopenmpi-dev
    
  • macOS (Homebrew)
    brew install open-mpi
    
  • Conda-only
    conda install -c conda-forge openmpi mpi4py
    
  1. Update pip tooling:
python -m pip install --upgrade pip setuptools wheel
  1. Install:
pip install minkipy-st
  1. Verify:
python -c "import minkiPy; print('minkiPy import OK')"
python -m minkiPy --help

Option B: Conda environment from YAML

Use this option from the repository root (after git clone and cd minkiPy).

  1. Update Conda first:
conda update -n base -c defaults conda
  1. Create the environment:
conda env create -f minkiPy_env.yaml
  1. Activate it:
conda activate minkiPy
  1. Install package from source (editable):
pip install -e .
  1. (Optional) Add a Jupyter kernel:
python -m ipykernel install --user --name minkiPy --display-name "Python (minkiPy)"

Option C: Local development install

Use this option from the repository root (after git clone and cd minkiPy).

python -m pip install --upgrade pip setuptools wheel
pip install -e .

Troubleshooting

If installation fails:

  1. Retry after updating pip tooling:
python -m pip install --upgrade pip setuptools wheel
  1. For Conda setups, also update Conda:
conda update -n base -c defaults conda
  1. Create a clean virtual environment and reinstall:
python -m venv .venv
source .venv/bin/activate   # Windows (PowerShell): .venv\Scripts\Activate.ps1
python -m pip install --upgrade pip setuptools wheel
pip install minkipy-st
  1. If MPI errors persist, re-check mpirun --version and ensure MPI + mpi4py are compatible.

Quick start (Python)

import minkiPy

h5_path = minkiPy.compute_Minkowski_profiles(
    transcripts_df,
    name="sample_A",
    output_path="results",
    resolution=20.0,
    nbr=25,
    n_cov_samples=None,  # default MC realisations; set 0 for faster exploratory runs
    # mpi_procs:
    # None -> auto-detect
    # 1    -> single process
    # >1   -> spawn MPI processes
)

Typical output file:

results/minkiPy_merged_resolution_<resolution>_<name>.h5

Example downstream loading:

filepaths = [
    "results/minkiPy_merged_resolution_20.0_sample_A.h5",
    "results/minkiPy_merged_resolution_20.0_sample_B.h5",
]

ordered_conditions = ["sample_A", "sample_B"]

data = minkiPy.process_data(
    filepaths,
    ordered_conditions=ordered_conditions,
    verbose=True,
)

Downstream analysis (beyond process_data)

After process_data, typical downstream steps include:

  • condition-level averaging with add_averaged_condition_datasets,
  • sample or gene distances with compute_sample_distances and compute_gene_distances,
  • graph and embedding visualisations (plot_dataset_graphs_from_data, plot_gene_graphs_from_data, plot_pca_grid_by_condition),
  • differential ranking and trend plots (plot_top_changing_genes, plot_w2_abslog2fc_with_trend),
  • profile-level diagnostics (plot_minkowski_profile, plot_w2_diag_vs_euclid_distributions, plot_w2_diag_vs_full_plus_euclid_distributions).

To get started quickly with your own data, begin with minkiPy_exploratory_workflow.ipynb.


Command-line usage

Run under MPI:

mpirun -n 8 python -m minkiPy \
  --input transcripts.csv \
  --name sample_A \
  --output-path results \
  --resolution 20 \
  --nbr 25

Custom column names:

mpirun -n 8 python -m minkiPy \
  --input transcripts.tsv \
  --sep '\t' \
  --gene-col gene_symbol \
  --x-col x \
  --y-col y \
  --name sample_A \
  --output-path results

Supported formats: .csv, .txt, .tsv, .parquet.


MPI usage patterns

1) Standard MPI launch

Launch your script with mpirun/mpiexec. compute_Minkowski_profiles(...) uses the active MPI communicator.

2) Auto-MPI from Python or notebook

h5_path = minkiPy.compute_Minkowski_profiles(
    transcripts_df,
    name="sample_A",
    output_path="results",
    resolution=20.0,
    nbr=25,
    mpi_procs=60,
    use_hwthreads=True,
)

Useful parameters:

  • mpi_procs (int | None, default None)
  • use_hwthreads (bool, default False)
  • oversubscribe (bool, default False)
  • extra_mpirun_args (list[str] | None)

Repository layout

minkiPy/
├── minkiPy/                              # Core package
│   ├── minkowski_core.py                 # Per-gene Minkowski profile computation
│   ├── mpi_driver.py                     # MPI distribution + auto-MPI wrapper
│   ├── cli.py                            # Command-line logic
│   ├── io.py                             # NPZ/HDF5 output writing and merge
│   └── downstream/                       # Post-processing, distances, visualisation
├── minkiPy_env.yaml                      # Conda environment definition
├── minkiPy_exploratory_workflow.ipynb    # Introductory exploratory workflow
├── minkiPy_FSHD_complete_workflow.ipynb  # Full FSHD workflow
├── minkiPy_CRC_complete_workflow.ipynb   # Full CRC workflow
└── examples/                             # Data staging for notebooks

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

minkipy_st-0.1.3.tar.gz (96.5 kB view details)

Uploaded Source

Built Distribution

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

minkipy_st-0.1.3-py3-none-any.whl (96.8 kB view details)

Uploaded Python 3

File details

Details for the file minkipy_st-0.1.3.tar.gz.

File metadata

  • Download URL: minkipy_st-0.1.3.tar.gz
  • Upload date:
  • Size: 96.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for minkipy_st-0.1.3.tar.gz
Algorithm Hash digest
SHA256 4d65e9cc8003589996a99dfe4f5c47a6dbefdcdffd15dc0df21e3bc176758313
MD5 9c0f1e1f774ecf53e6dc9fa6eaea143d
BLAKE2b-256 e2fb9783200de4b27b78348babffd79e9475b979501c2894c7d6786d1f3ed5e4

See more details on using hashes here.

File details

Details for the file minkipy_st-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: minkipy_st-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 96.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for minkipy_st-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 b0fb23af89c083f90852e335f1b2b98088df5012c22e39512ec6ae6882c28b18
MD5 e3bf87b8eebe6ec520a4dbf17cab207b
BLAKE2b-256 da5e3f8651c736e7528d54f22afe69b771ba436b68268226844f36704a02bc3b

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