Skip to content

Use Cellpose: A Guide

This documentation page is a copy of the GoNuclear-Cellpose README.md file.

This part of the repo concisely shows how to install, train and segment with Cellpose. In other word, it is a record of how Cellpose is used in this paper. Since my experiments show StarDist and PlantSeg have better 3D segmentation performance than Cellpose, this section is complete yet not extensive.

Installation

It is recommended to install this package in an environment managed by conda. We start the guide by installing Mini-conda.

Install Miniconda

First step required to use the pipeline is installing Miniconda. If you already have a working Anaconda setup you can go directly to the next step. Anaconda can be downloaded for all platforms from here. We suggest to use Miniconda, because it is lighter and install fewer unnecessary packages.

To download Miniconda, open a terminal and type:

wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh

Then install by typing:

bash ./Miniconda3-latest-Linux-x86_64.sh

and follow the installation instructions. The Miniconda3-latest-Linux-x86_64.sh file can be safely deleted.

Install cellpose using pip

To create and activate an conda environment for cellpose, then install cellpose in it, run the following commands in the terminal:

conda create --name cellpose python=3.8
conda activate cellpose
pip install cellpose

If you have a nvidia gpu, follow these steps to make use of it:

pip uninstall torch
conda install pytorch==1.12.0 cudatoolkit=11.3 -c pytorch

If you encounter error or need more explanation, go to Cellpose's official instruction.

Segmentation

Although the PlantSeg and StarDist models from this study outperform the Cellpose models I trained. One may find the gold models in BioImage Archive S-BIAD1026, or one of them philosophical-panda at BioImage Model Zoo.

Data Preparation

Cellpose inference only segmenet TIFF images, not HDF5. However, it can take 3D volumes as input.

Segmentation Command

There are two ways of segmenting 3D images with Cellpose:

  • Segment 3D images slice by slice then stitch 2D segmentation results into 3D segmentation results. With this approach, the images doesn't have to be isotropic, as long as the XY planes have similar properties as the training data.

    cellpose \
        --pretrained_model PATH_TO_MODEL \
        --savedir PATH_TO_OUTPUT_DIR \
        --dir PATH_TO_3D_TIFF_FOLDER \
        --diameter 26.5 \
        --verbose \
        --use_gpu \
        --stitch_threshold 0.9 \
        --chan 0 \
        --no_npy \
        --save_tif
    
  • Compute spatial flow of 3D images in all dimensions then segment the images in 3D directly. You may choose to rescale the images to be isotropic before segmentation, or specify the anisotropy to let Cellpose deal with the rescaling. Here I show the later.

    cellpose \
        --pretrained_model PATH_TO_MODEL \
        --savedir PATH_TO_OUTPUT_DIR \
        --dir PATH_TO_3D_TIFF_FOLDER \
        --diameter 26.5 \
        --anisotropy 2.24 \
        --verbose \
        --use_gpu \
        --do_3D \
        --chan 0 \
        --no_npy \
        --save_tif
    

Training

Data Preparation

Cellpose training only takes 2D images as input. To train on 3D images, we first need to split the 3D images into 2D images. Note that 3D images are better to be rescaled for isotropy in the resulting 2D training data.

Training Command

An example training command is shown below, which is used in the paper. The parameters --learning_rate 0.1 and --weight_decay 0.0001 are recommended by the Cellpose official documentation.

cellpose --train --use_gpu \
    --dir PATH_TO_TRAINING_DATA \
    --pretrained_model nuclei \
    --learning_rate 0.1 \
    --weight_decay 0.0001 \
    --mask_filter _masks \
    --verbose

Cellpose Version and Code

See Cellpose's GitHub page for the code. Cellpose v2.0.5 was used for training and inference in this paper.

Cite

If you find the code/models/datasets useful, please cite our paper and Cellpose:

@article{vijayan2024deep,
  title={A deep learning-based toolkit for 3D nuclei segmentation and quantitative analysis in cellular and tissue context},
  author={Vijayan, Athul and Mody, Tejasvinee Atul and Yu, Qin and Wolny, Adrian and Cerrone, Lorenzo and Strauss, Soeren and Tsiantis, Miltos and Smith, Richard S and Hamprecht, Fred A and Kreshuk, Anna and others},
  journal={Development},
  volume={151},
  number={14},
  year={2024},
  publisher={The Company of Biologists}
}

@article{stringer2021cellpose,
  title={Cellpose: a generalist algorithm for cellular segmentation},
  author={Stringer, Carsen and Wang, Tim and Michaelos, Michalis and Pachitariu, Marius},
  journal={Nature methods},
  volume={18},
  number={1},
  pages={100--106},
  year={2021},
  publisher={Nature Publishing Group US New York}
}