Multi-scale feature analysis of spatial transcriptomics
Project description
SpatialZoomer: multi-scale feature analysis of spatial transcriptomics
The Python implementation of SpatialZoomer, a scalable toolkit for multi-scale spatial feature analysis of single-cell resolution spatial transcriptomics via spectral graph signal processing.
Introduction
SpatialZoomer is a toolkit that enables the multi-scale analysis of spatial transcriptomics data. By modeling gene expression as signals on spatial graphs and applying spectral graph signal processing, the toolkit efficiently extracts multi-scale spatial features and identifies biologically meaningful structures. It can automatically identify “critical” scales by partitioning the cross-scale similarity map.
Functions
-
Zoom-capable analysis across spatial scales
Automatically identifies spatial structures ranging from cell, niche, to domain level across critical scales. -
Identification of spatial context-dependent subtypes
As spatial scale increases, cells incorporate broader spatial context and gradually resolve into subclusters influenced by their microenvironments. -
Revealing complex tissue architecture
The extracted multi-scale features can be used to dissect the complex spatial organization.
Advantages
- High computational efficiency with low memory usage
- Fast runtime for high-resolution datasets
- Capable of processing > 1 million cells on desktops
- No GPU required
Demos
Explore SpatialZoomer's multi-scale results across four datasets on our interactive demo site:
Explore SpatialZoomer's multi-scale results by sliding the across four datasets on our interactive demo site:
System Requirements
SpatialZoomer is lightweight and can be executed on laptops, desktops or servers. We tested it on the four machines:
| Device | OS | CPU | RAM |
|---|---|---|---|
| Laptop | Windows 11 | AMD Ryzen 7 8845H, 3.8GHz | 32 GB |
| Desktop | Windows 10 | Intel Core i7-12700F, 2.10GHz | 64 GB |
| Server 1 | CentOS 7 | Intel Xeon Gold 6254, 3.10GHz | 251 GB |
| Server 2 | Ubuntu 18.04 | Intel Xeon E5-2630 v3, 2.40GHz | 251 GB |
-
Most datasets can be processed within 1 hour to generate multi-scale results (10+ scales).
-
The Xenium Prime Ovarian Cancer dataset (>1.1M cells, 5K genes) exceeds memory limit on a 32 GB laptop.
-
The Xenium Prime Cervical Cancer dataset (≈800K cells, 5K genes) runs successfully on a 32 GB machine within ~4 hours.
-
Figure 1: Peak memory usage across devices (add image link here)
-
Figure 2: Total runtime across datasets (add image link here)
This package requires only a standard computer with enough RAM to support the in-memory operations with GPU-free.
设备与运行结果: 32G台式机因为内存爆炸运行不了1,10+万细胞、5K基因的Xenium Prime Ovarian cancer样本,其余样本都可以运行,包括801,131细胞、5K基因的Xenium Prime Cervical cancer样本,能在4h内获得10+个重要尺度下的结果。其余机器均能快速运行所有样本。
在四个机器上的时间和内存(图片展示) 大部分样本能够在1h内获得10余个尺度的多尺度结果 图1(内存) 图2(时间),后续给地址
Installation
3.9以上环境 conda create -n spatialzoomer python=3.10 -y conda activate spatialzoomer conda install -c conda-forge pyarrow pip install SpatialZoomer==1.0.0
Requires Python ≥ 3.9
We recommend using conda:
# Create and activate virtual environment
conda create -n spatialzoomer python=3.10 -y
conda activate spatialzoomer
# Install dependencies
conda install -c conda-forge pyarrow
# Install SpatialZoomer
pip install SpatialZoomer==1.0.0
Tutorials
Tutorial 1: Multi-scale analysis 针对空间转录组数据,自动选取重要尺度,并提计算每个尺度下的空间结构 (github跳转地址).ipynb 以CosMx mouse brain为例 .ipynb 以Xenium V1 lung cancer为例 .ipynb 以Xenium V1 ovarian cancer 为例
Tutorial 2: Identify spatial context dependent clusters 随着尺度增大,细胞融入更多的context信息,逐渐分离为亚群 .ipynb 以Xenium V1 lung cancer为例 .ipynb 以Xenium V1 ovarian cancer 为例
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file spatialzoomerpy-0.0.1.tar.gz.
File metadata
- Download URL: spatialzoomerpy-0.0.1.tar.gz
- Upload date:
- Size: 46.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b279eac48b508d187f43053a58884bdf4f2dd1a4c80ea757b2c70286e24d42c4
|
|
| MD5 |
e0781fa62a3b27c96bc6780bb35b8f3c
|
|
| BLAKE2b-256 |
3ad84279b33dcf6df0e4b4d2c9cb7cfbf65a0aae54be0d329c815b3c19e3ab7c
|
File details
Details for the file spatialzoomerpy-0.0.1-py3-none-any.whl.
File metadata
- Download URL: spatialzoomerpy-0.0.1-py3-none-any.whl
- Upload date:
- Size: 50.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
23ff77bf92d310c514745d017e08494c7600887aa0a74b22c69803b4c6d82d29
|
|
| MD5 |
e87c3657caacdd7d29ba774c4457e838
|
|
| BLAKE2b-256 |
a30f14fd37af8c64470f38b810637caca4811351c6b50477451641576a22699b
|