CellPose Counter
Cell/nuclei counter using cellpose models
A Napari plugin for cell/nuclei counting from a region or interest using cellpose models.
Installation¶
Option 1: via pip (or pip alternatives like uv):
Below is a minimally working example of setting up a new virtual environment and installing the counter module with uv on Unix based systems.
uv venv # create virtual environment in .venv
source .venv/bin/activate
uv pip install "napari[all]" cellpose-counter
Option 2: via Docker/Podman. The provide Dockerfile can be used to install Napari and the counter plugin along with a preconfigured Xpra server using the napari-xpra image. Below is an example of building the image and running the application with GPU support.
podman build -t cellpose-counter .
podman run -it -d \
-p 9876:9876 \
-e XPRA_START="python3 -m napari -w cellpose-counter" \
--device nvidia.com/gpu=all
Then, navigate to http://localhost:9876
to view the application in a virtual
machine.
Note: There is a known issue installing the plugin directly from Napari. Please see this issue for more updates.
GPU Acceleration¶
To enable GPU acceleration, you will need a CUDA capable GPU along with the CUDA toolkit and cudNN library.
For instructions on installing cuda toolkit and cudNN, see:
Once these are installed, update the pytorch package by first uninstalling torch (if already instsalled).
uv pip uninstall torch
Then install a torch version that is compatible with your CUDA version. For example,
uv pip install torch --index-url https://download.pytorch.org/whl/cu118
After installation, you can verify in an interactive python console with:
import torch
torch.cuda.is_available()
Usage¶
To open Napari with the cellpose counter loaded, run napari -w cellpose-counter
.
A dock widget will be open on the right side of the Napari interface. There you can view options for restoring images (using the cellpose denoise module), and counting cells/nuclei in a region of interest (ROI).
A few important notes:
- Images in TIFF or CZI file formats may be used.
- Images must be grayscale or single channel. RGB images may be loaded, but
should be split. You can do this by right clicking on the image and select
split rgb
orsplit stack
. - ROIs can be drawn using the shape layer tools. Only a single ROI can be drawn per shape layer (otherwise only the first draw ROI will be used).
- ROIs should be square or rectangular. You can draw ROIs as polygons or other shapes, but a bounding box will be made from these shapes anyway.
- For long running processes such as image restoration or counting, it may seem like Napari is not doing anything. Notifications are shown in the viewer to display import information and a small activity indicator can be seen in the bottom right hand corner. If this indicator is spinning, then work is being done even if it doesn't look like it.
- In case of a large number of uncounted nuclei, consider modifying the
segmentation parameters, or use the
Continue Counting
option to re-run the segmentation on uncounted nuclei.
Updating¶
-
via Napari plugin manager. Select cellpose-counter plugin and update button.
-
via pip (or uv, ..., etc.)
uv pip install cellpose-counter --upgrade
Contributing¶
All contributions are welcome. Please submit an issue for feedback or bugs.
Citations¶
This plugin is built on top of the Cellpose segmentation and denoising models. If you use this plugin, please cite the following paper:
@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}
}
License¶
Version:
- 0.1.8
Last updated:
- 10 December 2024
First released:
- 21 November 2024
License:
- Copyright (c) 2024, Szablowski Lab All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * Neither the name of copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Supported data:
- Information not submitted
Plugin type:
GitHub activity:
- Stars: 0
- Forks: 0
- Issues + PRs: 0