napari plugin for blob detection in images
A napari plugin for blob detection.
It’s best to create a new python environment to try the plugin:
conda create -n napari-blob-detection python=3.9
Activate the environment:
conda activate napari-blob-detection
You will need to install napari and JupyterLab or Jupyter Notebook (if you want to test the examples)
pip install napari[all]
pip install jupyterlab
You can then install napari-blob-detection
via pip:
pip install git+https://github.com/adrtsc/napari-blob-detection.git
To try the example jupyter notebooks do the following:
git clone https://github.com/adrtsc/napari-blob-detection
cd napari-blob-detection/examples/
Start JupyterLab
jupyter lab
If you want to use the plugin with your own data, it is important that you convert your image into a 4D (t, z, y, x) array before adding it as image layer to napari. Otherwise the plugin will struggle. Often you either have to expand the dimensions of your array or rearrange the dimensions:
For example, if your image is a 2D array:
import numpy as np
from skimage import io
import napari
# read your image
img = io.imread('path/to/img')
# add t and z dimensions
img = np.expand_dims(img, (0, 1))
# create napari viewer and add the image
viewer = napari.Viewer()
viewer.add_image(img)
In case you have a 4D array but the dimensions are not in the correct order, numpy.transpose() is helpfull to rearrange them.
import numpy as np
# here is a 4D array that has the wrong order of dimensions (y, x, t, z)
img = np.empty([100, 100, 1, 10]) # img.shape is (100, 100, 1, 10)
# the following line will reorder the dimensions to (t, z, y, x)
rearranged_img = np.transpose(img, (2, 3, 0, 1)) # rearranged_img.shape is (1, 10, 100, 100)
To use the blob detection widget, open napari and go to “Plugins -> napari-blob-detection -> blob_detection”. This will dock the blob detection widget to the napari viewer.
You can choose which detector you would like to use in the detector drop-down. Currently, the ones available are:
The available parameters will change depending on the detector you choose. Please refer to the official implementation of the functions for details on the parameters. Once you are ready to test the parameters, click on “Detect blobs” and the plugin will create a napari points layer with the detected blobs.
After using the blob detection widget you can use the filter widget to filter the blobs by some feature measurements. To open the filter widget go to “Plugins -> napari-blob-detection -> filter_widget”. This will dock the filter widget to the napari viewer. The filter widget will initially look like this:
Make sure that you choose the right image layer and the right points layer and then click on initialize filter. The plugin will now measure some features of the blobs present in the points layer. A new button “add filter” and an interface to save the filtered blobs will appear.
Clicking on “add filter” will add a subwidget to filter the blobs by one feature value.
It may be that the slider of is squished on your screen. In that case, drag the widget window to the left to make it larger:
Dragging the slider will now filter out blob that are either below the threshold (min) or above the threshold (max). To remove the filter again, you can click “delete”. You can add multiple filters that will all be applied to the blobs if you want to filter by multiple features:
To save the filtered blobs and their feature measurements click on “Select file”, and choose a filename ending with .csv. Then click on “save results”.
Sometimes it can be tricky to find the right parameters for blob detection or the right filters and thresholds to use. In those cases, it can help to use the selection widget. This widget allows you to annotate coordinates manually as true positive (TP) blobs and false positive (FP) blobs. Under the hood, the widget will train a support vector machine to then classify the initially detected blobs into TP and FP blobs. For this to work nicely, it is important that the intially detected blobs contain all the TP blobs that are present in the image (which means they will also contain a lot of FP blobs).
Before you can start you need the following things in napari:
To add another points layer click on this button in your layer list:
To open the selection widget go to “Plugins -> napari-blob-detection -> selection_widget”. This will dock the selection widget to the napari viewer.
Now make sure to set all the layers correctly:
Then click on “initialize layers”. Now you can make annotations on your annotation points layer. You can switch between the “foreground” and “background” class to annotate TP and FP coordinates. The size of the annotations is set automatically based on the size of the blobs in your points layer.
Once you are done adding annotations click the following buttons (in this order!):
After clicking “apply classifier” a new points layer will be generated that will only contain the blobs that were classified as TP blobs.
If you are doing blob detection on 2DT or 3DT images, you may want to track the blobs over time. This is possible with this widget. This widget is an interface to the Trackpy link function. To add the widget, go to “Plugins -> napari-blob-detection -> tracking_widget”. This will dock the widget to the napari viewer.
clicking on “track blobs” will try to track the blobs over time and adds a tracks layer to the napari viewer with the results.
This napari plugin was generated with Cookiecutter using @napari’s cookiecutter-napari-plugin template.
Contributions are very welcome. Tests can be run with tox, please ensure the coverage at least stays the same before you submit a pull request.
Distributed under the terms of the BSD-3 license, “napari-blob-detection” is free and open source software
If you encounter any problems, please file an issue along with a detailed description.