Skip to main content

MultiNeuronChat is a Python library for inferring condition‑related changes in synaptic cell‑cell communication from scRNA-/snRNA-Seq datasets in case vs control study designs.

Project description

MultiNeuronChat

MultiNeuronChat is a Python library for inferring condition‑related changes in synaptic cell‑cell communication from single‑cell / single‑nucleus RNA‑seq (sc/snRNA‑seq) datasets in case vs control study designs.
It builds on the mathematical model of Zhao et al. 2023 method NeuronChat and extends it to multi‑condition comparisons with subject‑level statistics.


Installation

From PyPI:

pip install multineuronchat

Python ≥ 3.9 is recommended.


Quick start (minimal end-to-end)

MultiNeuronChat expects a cell-wise log-normalized gene expression matrix in Loom format. You can either normalize your matrix manually or use the provided implementation:

from multineuronchat.normalize import cell_wise_log_normalization

cell_wise_log_normalization(
    # Path to the input Loom file 
    path_to_loom="path/to/data.loom",
    # Path to the cell-wise log-normalized output Loom file
    path_to_normalized_loom='path/to/cellwise_normalized_data.loom',
    # Whether to print computational progress
    verbose=True
)

This log-normalized loom file can then be used to run MultiNeuronChat:

from multineuronchat.MultiNeuronChatObject import MultiNeuronChatObject

# 1) Configure your analysis
mnc = MultiNeuronChatObject(
    condition_label_column="condition",           # column attribute in Loom
    condition_names=("control", "case"),          # order matters
    subject_label_column="subject",               # column attribute in Loom
    cell_type_label_column="cell_types",          # column attribute in Loom
    db="human_extended"                           # "human", "mouse", "human_extended", or path to custom DB
)

# 2) Compute communication scores
mnc.compute_communication_scores(
    # Path to the cell-wise log-normalized Loom file
    path_to_data_loom="path/to/cellwise_normalized_data.loom",
    # The row name of the gene attribute in the Loom file
    gene_label_row='gene',
    # The number of processes to use for the parallel computations of communication scores
    n_processes=4,
    # The minimum number of cells of a specific cell type within a specific subject to include in the analysis
    min_n_cells_threshold=20,
    # Whether to print computational progress
    verbose=True
)

# 3) (Optional) Focus hypotheses with masks (Wasserstein / EMD)
from multineuronchat.masks import compute_wasserstein_mask
mask = compute_wasserstein_mask(mnc, top_percentile=99.0)

# 4) Significance testing and multiple testing correction
pvals = mnc.compute_significance(
    # The statistical test to use when comparing the communication score distributions between conditions
    statistical_test='KS',
    # Optional mask to focus the significance testing on specific interactions. If None, all interactions are tested.
    mask=mask,
    # The number of resamples to use for permutation testing when appropriate
    n_resamples=10_000,
    # The random state for reproducibility
    random_state=42
)

# 5) Control FDR (Benjamini–Yekutieli by default; use "bh" for Benjamini–Hochberg)
pvals_adj = mnc.correct_p_values(statistical_test="KS", method="by")

Input data requirements

For MultiNeuronChat to function, your input Loom file must meet the following criteria:

  • Row attributes:
    • genes that were measured (gene)
  • Column attributes:
    • labels assigning a subject to each cell (subject in the example above but can be configured)
    • condition labels (condition in the example above but can be configured)
    • cell type labels (cell_types in the example above but can be configured)

Gene symbols should match the selected interaction database (human, mouse, or your custom DB).

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

multineuronchat-2025.11.11.tar.gz (44.6 kB view details)

Uploaded Source

Built Distribution

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

multineuronchat-2025.11.11-py3-none-any.whl (47.2 kB view details)

Uploaded Python 3

File details

Details for the file multineuronchat-2025.11.11.tar.gz.

File metadata

  • Download URL: multineuronchat-2025.11.11.tar.gz
  • Upload date:
  • Size: 44.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for multineuronchat-2025.11.11.tar.gz
Algorithm Hash digest
SHA256 0cb187a9ad71cf2fade81929f5b141c1a91a0c6964df7620ccf89c9e5b2d6509
MD5 4e6ca7e306048c03f307c82565c98d9d
BLAKE2b-256 274b0f8b5fb569866cea5b9f5f0087a637158d84472d8bf025299c1f1e9e0100

See more details on using hashes here.

File details

Details for the file multineuronchat-2025.11.11-py3-none-any.whl.

File metadata

File hashes

Hashes for multineuronchat-2025.11.11-py3-none-any.whl
Algorithm Hash digest
SHA256 fbcfeaf363b779e6355afa078caef9b6416f1e7fe67b42f96b8db8502fb18aa0
MD5 f76dc0771d08a82155eaef3c9e974b20
BLAKE2b-256 88c3e2a78ac309bb2ff99b8ccbadfe8f7786c7856b6c071bb4bc22a4ec84bf76

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