Skip to main content

Parallel differential expression for single-cell perturbation sequencing

Project description

pdex

parallel differential expression for single-cell perturbation sequencing

Installation

Add to your pyproject.toml file with uv

uv add pdex

Summary

This is a python package for performing parallel differential expression between multiple groups and a control.

It is optimized for very large datasets and very large numbers of perturbations.

It makes use of shared memory to parallelize the computation to a high number of threads and minimizes the IPC between processes to reduce overhead.

It supports the following metrics:

  • Wilcoxon Rank Sum
  • Anderson-Darling
  • T-Test

Usage

import anndata as ad
import numpy as np
import pandas as pd

from pdex import parallel_differential_expression

PERT_COL = "perturbation"
CONTROL_VAR = "control"

N_CELLS = 1000
N_GENES = 100
N_PERTS = 10
MAX_UMI = 1e6


def build_random_anndata(
    n_cells: int = N_CELLS,
    n_genes: int = N_GENES,
    n_perts: int = N_PERTS,
    pert_col: str = PERT_COL,
    control_var: str = CONTROL_VAR,
) -> ad.AnnData:
    """Sample a random AnnData object."""
    return ad.AnnData(
        X=np.random.randint(0, MAX_UMI, size=(n_cells, n_genes)),
        obs=pd.DataFrame(
            {
                pert_col: np.random.choice(
                    [f"pert_{i}" for i in range(n_perts)] + [control_var],
                    size=n_cells,
                    replace=True,
                ),
            }
        ),
    )


def main():
    adata = build_random_anndata()

    # Run pdex with default metric (wilcoxon)
    results = parallel_differential_expression(
        adata,
        reference=CONTROL_VAR,
        groupby_key=PERT_COL,
    )
    assert results.shape[0] == N_GENES * N_PERTS

    # Run pdex with alt metric (anderson)
    results = parallel_differential_expression(
        adata,
        reference=CONTROL_VAR,
        groupby_key=PERT_COL,
        metric="anderson"
    )
    assert results.shape[0] == N_GENES * N_PERTS

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

pdex-0.1.25.tar.gz (14.2 kB view details)

Uploaded Source

Built Distribution

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

pdex-0.1.25-py3-none-any.whl (11.3 kB view details)

Uploaded Python 3

File details

Details for the file pdex-0.1.25.tar.gz.

File metadata

  • Download URL: pdex-0.1.25.tar.gz
  • Upload date:
  • Size: 14.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.3

File hashes

Hashes for pdex-0.1.25.tar.gz
Algorithm Hash digest
SHA256 bfb7c5280a2d8783fe6a39bbba540e3cd8a0f894de4d80cdb2a1ca89cae30e19
MD5 3d1f85a7b4d734cbdaa88d172f923961
BLAKE2b-256 2dab386d0f603f69089f88a4a5b6ed232d0556ea2d9a30d3d772db9bd3ec1b8d

See more details on using hashes here.

File details

Details for the file pdex-0.1.25-py3-none-any.whl.

File metadata

  • Download URL: pdex-0.1.25-py3-none-any.whl
  • Upload date:
  • Size: 11.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.3

File hashes

Hashes for pdex-0.1.25-py3-none-any.whl
Algorithm Hash digest
SHA256 febd95bd3975cb2b20a432da8f0c49a0cff2bbca78ed3427e1e089bee4e525ba
MD5 5f65c422a8382cee9d544ff5eb2c13cd
BLAKE2b-256 3cb3831924f9fca4111d1620c461cdbccc4578b76745005efeee5c7b5ce64616

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