Skip to main content

SimSpace: a comprehensive in-silico spatial omics data simulation framework

Project description

SimSpace

Docs PyPI

SimSpace is a Python framework for simulating spatial omics data with realistic cellular distributions and tissue organization. Designed for benchmarking spatial analysis methods, SimSpace enables generation of synthetic datasets that preserve spatial autocorrelation, cell-cell interactions, and spatial proximities using a Markov Random Field (MRF) model.

SimSpace Workflow

📦 Installation

To install the latest version of SimSpace, we recommend using conda to setup the environment:

git clone https://github.com/TianxiaoNYU/simspace.git
  • Create a conda environment for simspace
cd simspace
conda env create -f environment.yml
conda activate simspace
  • Install simspace from PyPi
pip install simspace

🧬 Optional: Setting Up the R Environment for Omics Simulation

SimSpace supports external omics profile simulation via R-based tools, including scDesign3, SRTsim, and splatter. These tools are optional but recommended if you want to simulate gene expression profiles in addition to spatial patterns.

To enable this functionality, please install the required R packages manually in your system R environment:

Steps:

  1. Ensure that R (version 4.4 or compatible) is installed on your system. You can download it from CRAN.
  2. Open an R session and install the required packages:
if (!require("devtools", quietly = TRUE))
    install.packages("devtools")
devtools::install_github("SONGDONGYUAN1994/scDesign3")
devtools::install_github("xzhoulab/SRTsim")
if (!require("devtools", quietly = TRUE))
    install.packages("BiocManager")
BiocManager::install(c("splatter"))

Once installed, SimSpace will automatically use these tools when relevant R-based simulations are requested.

📖 Documentation

Full documentation for SimSpace is available at:

➡️ simspace.readthedocs.io

The documentation includes:

  • Installation instructions (Python + optional R setup)
  • Tutorials (reference-free & reference-based simulation)
  • API reference for all modules and functions

📘 Tutorials

To get started with SimSpace, we provide detailed tutorials covering both reference-based and reference-free simulation modes.

  • Step-by-step tutorials can be found in tutorials.md
  • Executable notebook examples are located in the examples/ directory

These resources walk through how to configure and run simulations as well as visualize outputs.

To reproduce the figures in the manuscript, one can find the scripts at examples/figures.ipynb.

🚀 Quick Start

Here’s a basic example to simulate a 2D tissue with 3 spatial niches and 8 cell types:

from simspace import util, spatial

# Define simulation parameters
params = util.generate_random_parameters(
    n_group=3,
    n_state=8,
    seed=42)

# Run simulation
sim = util.sim_from_params(
    params,
    shape=(50, 50),    # shape of the simulation grid
    custom_neighbor=spatial.generate_offsets(3, 'manhattan'),
    seed=42
)

# Visualize
sim.plot()

# Check and save the simulated spatial data
sim.meta.head()
# sim.meta.to_csv('simspace.csv')

🙋‍♀️ About

Developed by Tianxiao Zhao at NYU Grossman School of Medicine. Should you have any questions, please contact Tianxiao Zhao at Tianxiao.Zhao@nyulangone.org

🔗 References

If you use SimSpace in your work, please cite the work on BioRxiv: Zhao T, Zhang K, Hollenberg M, Zhou W, Fenyo D. SimSpace: a comprehensive in-silico spatial omics data simulation framework. bioRxiv. 2025:2025.07.18.665587.

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

simspace-0.2.5.tar.gz (168.9 kB view details)

Uploaded Source

Built Distribution

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

simspace-0.2.5-py3-none-any.whl (172.8 kB view details)

Uploaded Python 3

File details

Details for the file simspace-0.2.5.tar.gz.

File metadata

  • Download URL: simspace-0.2.5.tar.gz
  • Upload date:
  • Size: 168.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for simspace-0.2.5.tar.gz
Algorithm Hash digest
SHA256 e2ea52515aeb0c9aa14c6e47f30441e1325af37fc51e1b6f9d3a954bd0e7b03f
MD5 ad486adcd8b4e0411d77df8b86b062ec
BLAKE2b-256 4994c2e8a24061afbf835c2c89f7dd7c87db26b5c9bd7b6db6d751b3669a64fc

See more details on using hashes here.

File details

Details for the file simspace-0.2.5-py3-none-any.whl.

File metadata

  • Download URL: simspace-0.2.5-py3-none-any.whl
  • Upload date:
  • Size: 172.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for simspace-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 81cff7381fd6640b392955de03348b396052f5aa91fee52eb89adb65a5ee9a98
MD5 c92db5b29f348db5b9c6aadf1ba80a93
BLAKE2b-256 d5a7af3c772e9247ba1c236f66cc6eb7c95c2e2a6bab78e21f12c951aebedc2a

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