STEP, an acronym for Spatial Transcriptomics Embedding Procedure, is a deep learning-based tool for the analysis of single-cell RNA (scRNA-seq) and spatially resolved transcriptomics (SRT) data. STEP introduces a unified approach to process and analyze multiple samples of scRNA-seq data as well as align several sections of SRT data, disregarding location relationships. Furthermore, STEP conducts integrative analysis across different modalities like scRNA-seq and SRT.
Project description
STEP: Spatial Transcriptomics Embedding Procedure
Introduction
STEP, an acronym for Spatial Transcriptomics Embedding Procedure, is a foundation deep learning/AI architecture for the analysis of spatially resolved transcriptomics (SRT) data, and is also compatible with scRNA-seq data. STEP roots on the precise captures of three major varitions occured in the SRT (and scRNA-seq) data: Transcriptional Variations, Batch Variations and Spatial Variations with the correponding modular designs: Backbone model: a Transformer based model togther with gene module seqeunce mapping; Batch-effect model: A pair of inverse transformations utilizing the batch-embedding conception for the decoupled batch-effect elimination; Spatial model: a GCN-based spatial filter/smoother working on the extracted embedding from the Backbone model, different from the usage of GCN in other methods as a feature extractor. Thus, with the proper combinations of these models, STEP introduces a unified approach to systematically process and analyze single or multiple samples of SRT data, disregarding location relationships between sections (meaning both contiguous and non-contiguous sections), to reveal multi-scale bilogical heterogeneities (cell types and spatial domains) in multi-resolution SRT data. Furthermore, STEP can also conduct integrative analysis on scRNA-seq and SRT data.
Key Features
- Integration of multiple scRNA-seq and single-cell resolution SRT samples to reveal cell-type level heterogeneities.
- Alignment of various SRT data sections contiguous or non-contiguous to identify spatial domains across sections.
- Scalable to different data resolutions, i.e., wild range of technologies and platforms of SRT data, including Visium HD, Visum, MERFISH, STARmap, Stereo-seq, ST, etc.
- Scalable to large datasets with a high number of cells and spatial locations.
- Performance of integrative analysis across modalities (scRNA-seq and SRT) and cell-type deconvolution for the non-single-cell resolution SRT data.
Other Capabilities
- Capability to produce not only the batch-corrected embeddings but also batch-corrected gene expression profiles for scRNA-seq data.
- Capability to perform spatial mapping of reference scRNA-seq data points to the spatial locations of SRT data based on the learned co-embeddings and kNN.
- Comprehensive
adata
processing by specifically desingedBaseDataset
class and its view versionMaskedDataset
class for the SRT data, which can be easily integrated with the PyTorchDataLoader
class for training and validation. - Low computational cost and high efficiency in processing large-scale SRT data: 4-8 GB GPU memory is sufficient for processing a dataset with 100,000 spatial locations with 2000+ sample-size in fast mode, and consumes less than 6 minutes for training in 2000 iterations (tested on NVIDIA RTX 3090).
System Requiremtns
- Software Requirements: Python 3.10+, CUDA 11.6+, PyTorch 1.13.1+, and dgl 1.1.3+.
- Hardware Requirements: NVIDIA GPU with CUDA support (recommended), 8GB+ GPU memory. As possible as high RAM and CPU cores for storing and processing large-scale data (this is not required by STEP, but by the data itself).
Installation
Quick Installation (Recommended for Python 3.10, Linux, CUDA 11.7)
pip install step-kit[cu117]
This command installs STEP along with compatible versions of PyTorch and DGL.
Basic Installation
pip install step-kit
⚠️ Critical Note:
- This basic installation does not include PyTorch and DGL.
- STEP will not function without PyTorch and DGL properly installed.
- You must install these dependencies separately before using STEP.
Manual Dependency Installation
If you need to install specific versions of PyTorch and DGL:
-
Install DGL (example for latest DGL compatible with PyTorch 2.3.x and CUDA 11.8):
pip install dgl -f https://data.dgl.ai/wheels/torch-2.3/cu118/repo.html
-
Install PyTorch (example for PyTorch 2.3.1 with CUDA 11.8):
pip install torch==2.3.1+cu118 -f https://download.pytorch.org/whl/cu118/torch_stable.html
For more information on installing PyTorch and DGL, visit:
- PyTorch: https://pytorch.org/
- DGL: https://www.dgl.ai/
Remember to choose versions compatible with your system configuration and CUDA version (if applicable).
Contribution
We welcome contributions! Please see CONTRIBUTING.md
for more details!
License
step is licensed under LICENSE
Contact
If you have any questions, please feel free to contact us at here, or feel free to open an issue on this repository.
Citation
The preprint of STEP is available at bioRxiv. If you use STEP in your research, please cite:
@article{Li2024.04.15.589470,
title = {{{STEP}}: {{Spatial}} Transcriptomics Embedding Procedure for Multi-Scale Biological Heterogeneities Revelation in Multiple Samples},
author = {Li, Lounan and Li, Zhong and Li, Yuanyuan and Yin, Xiao-ming and Xu, Xiaojiang},
year = {2024},
journal = {bioRxiv : the preprint server for biology},
eprint = {https://www.biorxiv.org/content/early/2024/04/20/2024.04.15.589470.full.pdf},
publisher = {Cold Spring Harbor Laboratory},
doi = {10.1101/2024.04.15.589470},
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file step_kit-0.2.8.tar.gz
.
File metadata
- Download URL: step_kit-0.2.8.tar.gz
- Upload date:
- Size: 85.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.15 Linux/6.6.51
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0b653cf53fbc0dcddf19458d4ae5a04294cd64924b50f093b192151e24ff0980 |
|
MD5 | c58bf2c8f6f3399caabd727f73e7aa7c |
|
BLAKE2b-256 | 5d84e9ce176e94751ff7e301eb519778a019b4d22cd72fa7ca0c3a19be88aff2 |
File details
Details for the file step_kit-0.2.8-py3-none-any.whl
.
File metadata
- Download URL: step_kit-0.2.8-py3-none-any.whl
- Upload date:
- Size: 99.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.15 Linux/6.6.51
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d6e8dfc1bb35aafbc342829cbabe6cd5affc6ba8595bf1270fda1ee59456c0c9 |
|
MD5 | e6c1cf4aec25602f7678c5116873f98a |
|
BLAKE2b-256 | 9b8f846c075cfa445afa964e5190af96c67a71e75f613f8c7ace5450969d6a8b |