scPortrait – image-based single cell analysis at scale in Python#
scPortrait is a scalable toolkit to analyse single-cell image datasets. This Python implementation efficiently segments individual cells, generates single-cell datasets and provides tools for the efficient deep learning classification of their phenotypes for downstream applications.

Installation#
Check out the installation instructions here. You can validate your installation by running one of the example notebooks here.
Getting Started#
You can check out our worfklow overview or our `in-depth tutorial<http://127.0.0.1:5500/docs/_build/html/pages/notebooks/_notebook_workflow_walkthrough.html>`_ to get started with scPortrait. For more detailed information on the package, checkout the more detailed guides here. You can find a collection of example projects which run on datasets provided within scPortrait to help you get started with here. If you encounter issues feel free to open up a git issue.
Citing our Work#
scPortrait was developed by Sophia Mädler and Niklas Schmacke in the labs of Matthias Mann, Veit Hornung and Fabian Theis in 2024 and is actively being developed. If you are interested in contributing please reach out to the developers.
If you use our code please cite the following manuscript:
SPARCS, a platform for genome-scale CRISPR screening for spatial cellular phenotypes Niklas Arndt Schmacke, Sophia Clara Maedler, Georg Wallmann, Andreas Metousis, Marleen Berouti, Hartmann Harz, Heinrich Leonhardt, Matthias Mann, Veit Hornung bioRxiv 2023.06.01.542416; doi: https://doi.org/10.1101/2023.06.01.542416
Contributing#
We are excited for people to adapt and extend scPortrait to their needs. If you are interested in contributing to scPortrait, please reach out to the developers or open a pull request on our GitHub repository.
Documentation#
Ecosystem
Code Examples
Module API
- pipeline
- project
Project
Project.config
Project.nuc_seg_name
Project.cyto_seg_name
Project.sdata_path
Project.filehander
Project.DEFAULT_IMAGE_DTYPE
Project.DEFAULT_SEGMENTATION_DTYPE
Project.DEFAULT_SINGLE_CELL_IMAGE_DTYPE
Project.sdata
Project.update_featurization_f()
Project.print_project_status()
Project.view_sdata()
Project.plot_input_image()
Project.plot_he_image()
Project.plot_segmentation_masks()
Project.load_input_from_array()
Project.load_input_from_tif_files()
Project.load_input_from_omezarr()
Project.load_input_from_dask()
Project.load_input_from_sdata()
Project.complete_segmentation()
Project.extract()
Project.select()
- segmentation
- segmentation workflows
WGASegmentation
ShardedWGASegmentation
DAPISegmentation
ShardedDAPISegmentation
DAPISegmentationCellpose
ShardedDAPISegmentationCellpose
CytosolSegmentationCellpose
ShardedCytosolSegmentationCellpose
CytosolOnlySegmentationCellpose
ShardedCytosolOnlySegmentationCellpose
CytosolSegmentationDownsamplingCellpose
ShardedCytosolSegmentationDownsamplingCellpose
CytosolOnlySegmentationDownsamplingCellpose
ShardedCytosolOnlySegmentationDownsamplingCellpose
- extraction
- Featurization
- selection
- processing
- images
- masks
MatchNucleusCytosolIds
MatchNucleusCytosolIds.filtering_threshold
MatchNucleusCytosolIds.downsample
MatchNucleusCytosolIds.downsampling_factor
MatchNucleusCytosolIds.erosion_dilation
MatchNucleusCytosolIds.smoothing_kernel_size
MatchNucleusCytosolIds.nucleus_mask
MatchNucleusCytosolIds.cytosol_mask
MatchNucleusCytosolIds.nuclei_discard_list
MatchNucleusCytosolIds.cytosol_discard_list
MatchNucleusCytosolIds.nucleus_lookup_dict
MatchNucleusCytosolIds.load_masks()
MatchNucleusCytosolIds.update_cytosol_mask()
MatchNucleusCytosolIds.update_masks()
MatchNucleusCytosolIds.match_nucleus_id()
MatchNucleusCytosolIds.initialize_lookup_table()
MatchNucleusCytosolIds.count_cytosol_occurances()
MatchNucleusCytosolIds.check_for_unassigned_cytosols()
MatchNucleusCytosolIds.identify_multinucleated_cells()
MatchNucleusCytosolIds.cleanup_filtering_lists()
MatchNucleusCytosolIds.cleanup_lookup_dictionary()
MatchNucleusCytosolIds.generate_lookup_table()
MatchNucleusCytosolIds.filter()
MatchNucleusCytosolIds.get_lookup_table()
MatchNucleusCytosolIds.filter()
SizeFilter
- plotting
- io
- tools