Using StarDist in napari with GPU-support in Windows (2025)#

Stefan Hahmann, January 20th 2025

Note: This is an update of a previous Blogpost.

3D segmentation using deep learning is computationally costly, it might be necessary from a practical perspective to do it on computers with powerful graphics processing units (GPUs). One option is to do this in the cloud via Google Colab and for that it is recommended to take a look at ZeroCostDeepLearning4Microscopy. If you would like to run everything on your own Windows computer, you can follow the instructions provided here.

The StarDist developers Uwe Schmidt and Martin Weigert recently released a napari plugin named stardist-napari. This puts 3D nuclei segmentation using StarDist into the hands of end-users. You can see it in action in this Youtube video.

Under the hood StarDist uses Tensorflow, CUDA and cuDNN. As installation of these is not trivial, I took some notes while setting up a Windows computer with these recently (i.e. January 2025) and share the steps here. If you know tricks or short-cuts, please get in touch and share them!

See also:

Overview#

Before you start, you will need administrative privileges on your computer. If you don’t have them, please contact your IT department.

In the following procedure, we will install

  • CUDA 11.2.0

  • CUDNN 8.1.0.77 for CUDA 11.2

  • tensorflow-gpu 2.10.0

  • stardist 0.8.5

  • napari 0.5.5

  • stardist-napari 2024.8.6.1

CUDA installation#

To install CUDA, download this file from the website and install them in this order. Follow the instructions. This may take a while.

  • cuda_11.2.0_460.89_win10.exe

Note: There is a newer version of CUDA available (>=12), but it is not compatible with the current version of tensorflow-gpu. Thus, we need to stick to CUDA 11.2.0. For more information see Install tensorflow.

There is a table, which shows the compatibility of different versions of CUDA and tensorflow-gpu.

tensorflow-gpu-table.png

cuDNN Library installation#

For downloading the cuDNN library you need an NVidia developer account. Sign up and download CUDNN from this page:

cudnn_download.png

Installation of cuDNN basically means unzipping the archive you downloaded and navigating into it. You can then copy these files:

Into the installation directory of CUDA, e.g. C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v11.2:

At that point, you may need administrator privileges to click on Continue in this dialog:

After CUDA and cuDNN have been installed, it may make sense to restart the computer.

Checking CUDA and cuDNN installation#

If the installation worked correctly, you will find some entries in the Environment Variables of your computer. To read them, click the Start Menu and enter “enviro”. When the Windows Search suggests “Edit Environment Variables” hit enter:

A dialog will open, click on “Edit Environment Variables”:

In the upcoming dialog, two entries should exist and point to the path were you just installed CUDNN:

If these entries don’t exist, you can enter them by hand. However, it is recommended to go back and install CUDA and cuDNN again.

Installing Mamba, Python and Tensorflow#

In order to make Tensorflow use the GPU, we need to install tensorflow libraries. As there are some conflicts between different versions of CUDA, Tensorflow, Python and others, I recommend installing specifically the versions, I’m using here: If you don’t have conda installed yet, I recommend installing miniforge. The installer can be downloaded here. This blog post contains an installation instruction.

Assuming miniforge is set up, we start by creating a new environment and specifically installing python 3.10, cudutoolkit 11.2 and cudnn 8.1.0:

mamba create --name napari-stardist-gpu python=3.10 cudatoolkit=11.2 cudnn=8.1.0

Afterwards, you can activate this environment:

conda activate napari-stardist-gpu

We install tensorflow and more precisely, its GPU version:

pip install tensorflow-gpu==2.10.0

To check if tensorflow is installed correctly and uses the GPU, we start a python console

python

and enter:

import tensorflow as tf
print("Num GPUs Available: ", len(tf.config.list_physical_devices('GPU')))

The output should be some technical details ending with something like:

Num GPUs Available:  1

You can also ask for more details, by entering:

from tensorflow.python.client import device_lib 
print(device_lib.list_local_devices())

This will tell you which GPU is available and also some details about your CPU, which could also run tensorflow:

[name: "/device:CPU:0"
device_type: "CPU"
memory_limit: 268435456
locality {
}
incarnation: 6777841064378058334
, name: "/device:GPU:0"
device_type: "GPU"
memory_limit: 3040739328
locality {
  bus_id: 1
  links {
  }
}
incarnation: 317304344239135289
physical_device_desc: "device: 0, name: NVIDIA GeForce RTX 3050 Ti Laptop GPU, pci bus id: 0000:01:00.0, compute capability: 8.6"
]

You can leave the python console by entering quit().

StarDist installation#

To install StarDist, you can use pip:

pip install stardist==0.8.5

Napari + StarDist plugin installation#

Napari can be installed using pip using this command:

pip install napari[all]

You can then start napari from the command line:

napari

For installing the StarDist plugin, click on the menu Plugins > Install/Uninstall packages.... This dialog will open, where you can just search for the plugin and click the Install button next to it:

You then need to restart napari. Afterwards, a new menu entry will show up under Plugins:

Testing the StarDist napari plugin#

For testing the plugin, you can use example data StarDist provides. You can find it in the menu File > Open Samples... > StarDist > Nuclei (3D).

Then you should be able to activate the plugin from the menu Plugins > StarDist : StarDist. As the default-values fit to the example data, you can just click on Run in the bottom right:

To make sure that the installation of the GPU-related software worked, you can check if the GPU is indeed used, by looking at the command line window in the background :

Furthermore, after a moment of waiting the segmented nuclei should show up:

Also use the 3D view on the bottom left:

Last but not least, please keep in mind that training your own model for your own data can be beneficial for segmentation quality. Check out the StarDist website and example notebooks to learn more.