Skip to main content

computer vision for image-based phenotyping of single cells

Project description

VisCy

Python package index PyPI monthly downloads Total downloads GitHub contributors GitHub Repo stars GitHub forks SPEC 0 — Minimum Supported Dependencies DOI

VisCy (blend of vision and cyto) is a deep learning pipeline for training and deploying computer vision models for image-based phenotyping at single-cell resolution.

This repository provides a pipeline for the following.

  • Image translation
    • Robust virtual staining of landmark organelles with Cytoland
  • Image representation learning
    • Self-supervised learning of the cell state and organelle phenotypes with DynaCLR
  • Semantic segmentation
    • Supervised learning of of cell state (e.g. state of infection)

Note: VisCy is under active development. While we strive to maintain stability, the main branch may occasionally be updated with backward-incompatible changes which are subsequently shipped in releases following semantic versioning. Please choose a stable release from PyPI for production use.

Cytoland (Robust Virtual Staining)

Demo Open in Spaces

Try the 2D virtual staining demo of cell nuclei and membrane from label-free images on Hugging Face.

Virtual Staining App Demo

Cytoland @ Virtual Cells Platform

Cytoland models are accessible via the Chan Zuckerberg Initiative's Virtual Cells Platform. Notebooks are available as pre-rendered pages or on Colab:

Tutorials

  • Virtual staining exercise: Notebook illustrating how to use VisCy to train, predict and evaluate the VSCyto2D model. This notebook was developed for the DL@MBL2024 course and uses UNeXt2 architecture.

  • Image translation demo: Fluorescence images can be predicted from label-free images. Can we predict label-free image from fluorescence? Find out using this notebook.

  • Training Virtual Staining Models via CLI: Instructions for how to train and run inference on VisCy's virtual staining models (VSCyto3D, VSCyto2D and VSNeuromast).

Gallery

Below are some examples of virtually stained images (click to play videos). See the full gallery here.

VSCyto3D VSNeuromast VSCyto2D
HEK293T Neuromast A549

References

The Cytoland models and training protocols are reported in our recent paper on robust virtual staining in Nature Machine Intelligence.

This package evolved from the TensorFlow version of virtual staining pipeline, which we reported in this paper in 2020 in eLife.

Liu, Hirata-Miyasaki et al., 2025

  @article{liu_robust_2025,
      title = {Robust virtual staining of landmark organelles with {Cytoland}},
      copyright = {2025 The Author(s)},
      issn = {2522-5839},
      url = {https://www.nature.com/articles/s42256-025-01046-2},
      doi = {10.1038/s42256-025-01046-2},
      abstract = {Correlative live-cell imaging of landmark organelles—such as nuclei, nucleoli, cell membranes, nuclear envelope and lipid droplets—is critical for systems cell biology and drug discovery. However, achieving this with molecular labels alone remains challenging. Virtual staining of multiple organelles and cell states from label-free images with deep neural networks is an emerging solution. Virtual staining frees the light spectrum for imaging molecular sensors, photomanipulation or other tasks. Current methods for virtual staining of landmark organelles often fail in the presence of nuisance variations in imaging, culture conditions and cell types. Here we address this with Cytoland, a collection of models for robust virtual staining of landmark organelles across diverse imaging parameters, cell states and types. These models were trained with self-supervised and supervised pre-training using a flexible convolutional architecture (UNeXt2) and augmentations inspired by image formation of light microscopes. Cytoland models enable virtual staining of nuclei and membranes across multiple cell types—including human cell lines, zebrafish neuromasts, induced pluripotent stem cells (iPSCs) and iPSC-derived neurons—under a range of imaging conditions. We assess models using intensity, segmentation and application-specific measurements obtained from virtually and experimentally stained nuclei and membranes. These models rescue missing labels, correct non-uniform labelling and mitigate photobleaching. We share multiple pre-trained models, open-source software (VisCy) for training, inference and deployment, and the datasets.},
      language = {en},
      urldate = {2025-06-23},
      journal = {Nature Machine Intelligence},
      author = {Liu, Ziwen and Hirata-Miyasaki, Eduardo and Pradeep, Soorya and Rahm, Johanna V. and Foley, Christian and Chandler, Talon and Ivanov, Ivan E. and Woosley, Hunter O. and Lee, See-Chi and Khadka, Sudip and Lao, Tiger and Balasubramanian, Akilandeswari and Marreiros, Rita and Liu, Chad and Januel, Camille and Leonetti, Manuel D. and Aviner, Ranen and Arias, Carolina and Jacobo, Adrian and Mehta, Shalin B.},
      month = jun,
      year = {2025},
      note = {Publisher: Nature Publishing Group},
      pages = {1--15},
      }
  
Guo, Yeh, Folkesson et al., 2020

  @article {10.7554/eLife.55502,
      article_type = {journal},
      title = {Revealing architectural order with quantitative label-free imaging and deep learning},
      author = {Guo, Syuan-Ming and Yeh, Li-Hao and Folkesson, Jenny and Ivanov, Ivan E and Krishnan, Anitha P and Keefe, Matthew G and Hashemi, Ezzat and Shin, David and Chhun, Bryant B and Cho, Nathan H and Leonetti, Manuel D and Han, May H and Nowakowski, Tomasz J and Mehta, Shalin B},
      editor = {Forstmann, Birte and Malhotra, Vivek and Van Valen, David},
      volume = 9,
      year = 2020,
      month = {jul},
      pub_date = {2020-07-27},
      pages = {e55502},
      citation = {eLife 2020;9:e55502},
      doi = {10.7554/eLife.55502},
      url = {https://doi.org/10.7554/eLife.55502},
      keywords = {label-free imaging, inverse algorithms, deep learning, human tissue, polarization, phase},
      journal = {eLife},
      issn = {2050-084X},
      publisher = {eLife Sciences Publications, Ltd},
      }
  

Library of Virtual Staining (VS) Models

The robust virtual staining models (i.e VSCyto2D, VSCyto3D, VSNeuromast), and fine-tuned models can be found here

DynaCLR (Embedding Cell Dynamics via Contrastive Learning of Representations)

DynaCLR is a self-supervised method for learning robust and temporally-regularized representations of cell and organelle dynamics from time-lapse microscopy using contrastive learning. It supports diverse downstream biological tasks -- including cell state classification with efficient human annotations, knowledge distillation across fluorescence and label-free imaging channels, and alignment of cell state dynamics.

Preprint

DynaCLR on arXiv:

DynaCLR schematic

Demo

  • DynaCLR demos

  • Example test dataset, model checkpoint, and predictions can be found here.

  • See tutorial on exploration of learned embeddings with napari-iohub here.

Installation

  1. We recommend using a new Conda/virtual environment.

    conda create --name viscy python=3.11
    # OR specify a custom path since the dependencies are large:
    # conda create --prefix /path/to/conda/envs/viscy python=3.11
    
  2. Install a released version of VisCy from PyPI:

    pip install viscy
    

    If evaluating virtually stained images for segmentation tasks, install additional dependencies:

    pip install "viscy[metrics]"
    

    Visualizing the model architecture requires visual dependencies:

    pip install "viscy[visual]"
    
  3. Verify installation by accessing the CLI help message:

    viscy --help
    

For development installation, see the contributing guide.

Additional Notes

The pipeline is built using the PyTorch Lightning framework. The iohub library is used for reading and writing data in OME-Zarr format.

The full functionality is tested on Linux x86_64 with NVIDIA Ampere/Hopper GPUs (CUDA 12.6). Some features (e.g. mixed precision and distributed training) may not be available with other setups, see PyTorch documentation for details.

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

viscy-0.4.1.tar.gz (22.4 MB view details)

Uploaded Source

Built Distribution

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

viscy-0.4.1-py3-none-any.whl (739.2 kB view details)

Uploaded Python 3

File details

Details for the file viscy-0.4.1.tar.gz.

File metadata

  • Download URL: viscy-0.4.1.tar.gz
  • Upload date:
  • Size: 22.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.14 {"installer":{"name":"uv","version":"0.9.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Rocky Linux","version":"8.10","id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for viscy-0.4.1.tar.gz
Algorithm Hash digest
SHA256 594aebe8764b77bbc93430f685a0d20591f80c326ce90baba4f59c40322302cf
MD5 c51e04311a01a0c250402f98d2ae8cf8
BLAKE2b-256 2a2341862a71f12f251025145d3f1d2367fbb7eb927653a158c9b66edb5b4512

See more details on using hashes here.

File details

Details for the file viscy-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: viscy-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 739.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.14 {"installer":{"name":"uv","version":"0.9.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Rocky Linux","version":"8.10","id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for viscy-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7851b2086ac33137835c0ee24e08a3e35accb3c3863232482297038446e0a0ab
MD5 6a124be967fb9c7c181547a4d12af875
BLAKE2b-256 f1251ed11efe765e559d1f5dcf764378331321d71f45c548ad051e1bbb413b9c

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