Skip to main content

CellNiche represents cellular microenvironments in atlas-scale spatial omics data with contrastive learning

Project description

CellNiche

Overview ✨

CellNiche is a lightweight and scalable representation learning framework for atlas-scale spatial omics that identifies and characterizes cellular microenvironments. It flexibly accommodates multiple forms of cellular identity representations, including expression matrices, pretrained embeddings, and discrete cell labels, making it well suited for heterogeneous spatial omics data. With efficient computation and strong robustness across input types, CellNiche supports cross-sample analysis of cancer spatial omics cohorts and the construction of large-scale virtual organ atlases.

Please check our paper CellNiche represents cellular microenvironments in atlas-scale spatial omics data with contrastive learning on Nature Communications.

Installation ⚙️

From Source (recommend)

git clone https://github.com/Super-LzzZ/CellNiche.git
cd CellNiche

From PyPI

pip install CellNiche

Requirements

  • Python ≥ 3.9
  • PyTorch ≥ 1.12
  • PyTorch Geometric (torch-geometric, torch-scatter, torch-sparse, torch-cluster, torch-spline-conv)
  • Scanpy ≥ 1.9
  • Anndata ≥ 0.9
  • scikit-learn ≥ 1.3
  • numpy ≥ 1.22
  • scipy ≥ 1.10
  • pandas ≥ 2.0
  • networkx ≥ 3.1
  • tqdm ≥ 4.67.1

You can install most dependencies with:

pip install torch torchvision torchaudio
pip install torch-geometric torch-scatter torch-sparse torch-cluster torch-spline-conv
pip install scanpy anndata scikit-learn numpy scipy pandas networkx tqdm

A successful example

conda create -n cellniche python=3.9
conda activate cellniche
pip install torch==2.0.1 torchvision==0.15.2 torchaudio==2.0.2
pip install torch_cluster-1.6.3+pt20cu117-cp39-cp39-linux_x86_64.whl
pip install torch_scatter-2.1.2+pt20cu117-cp39-cp39-linux_x86_64.whl
pip install torch_sparse-0.6.18+pt20cu117-cp39-cp39-linux_x86_64.whl
pip install torch_spline_conv-1.2.2+pt20cu117-cp39-cp39-linux_x86_64.whl
pip install torch-geometric==2.6.1
pip install CellNiche

pip install pyyaml
...

Tutorials 📚

Spatial proteomics data or single-cell spatial transcriptomics data

The data required to run tutorials is located in data/. Please note that due to Github size limitations, you have to download the relevant data for analysis from Google Drive.

CellNiche for single-slice

CellNiche for integrated multiple slices from the same experiment

CellNiche for integrated multiple slices across different technologies

Getting Started 🚀

bash (recommend)

python -m cellniche.main --config ./configs/cortex_osmFISH.yaml

python

# way 1: If you download from source (better suited for personalized use)
sys.path.append('/share/home/liangzhongming/phd_code/530/CellNiche/release')
import cellniche as cn

# way 2: If you download from PyPI (better suited for stable use)
# import cellniche as cn


# Parse arguments from a YAML config
# Run training/inference
adata = cn.cli(["--config", "./configs/cortex_osmFISH.yaml"])

Contribution

For questions or comments, please use the issue tracker and/or email Zhongming Liang (liangzhongming21@mails.ucas.ac.cn).

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

cellniche-0.1.8.tar.gz (20.9 kB view details)

Uploaded Source

Built Distribution

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

cellniche-0.1.8-py3-none-any.whl (22.9 kB view details)

Uploaded Python 3

File details

Details for the file cellniche-0.1.8.tar.gz.

File metadata

  • Download URL: cellniche-0.1.8.tar.gz
  • Upload date:
  • Size: 20.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.13

File hashes

Hashes for cellniche-0.1.8.tar.gz
Algorithm Hash digest
SHA256 7da523332fef14f7d81fea254e6460a3480639d098c832eb20df22b2d78cdeb8
MD5 983ffa58e09e922c4eb01c98951c1aad
BLAKE2b-256 540e8f19510349c9235f888e46ea9abc5fca3fed62d2c5c4141ae760f3be7c32

See more details on using hashes here.

File details

Details for the file cellniche-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: cellniche-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 22.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.13

File hashes

Hashes for cellniche-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 9e86bd99a5fd0c7e1fa610f15e622fc38eee560b2ef6cbba9abcc9082293d528
MD5 96cbc34fdeed0342fe1c883c3583b2aa
BLAKE2b-256 b75278d141f369f191c9a643f73ecd21763f89f20b6d76fb283477da3beece80

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