Counting bright objects in images#
A common use case for image processing in the biology context is counting blobs of high signal intensity surrounded by a low intensity background. Thresholding is the method of choice in this scenario. We demonstrate it with Otsu’s thresholding method (Otsu et al., IEEE Transactions on Systems, Man, and Cybernetics, Vol. 9 (1), 1979)
import pyclesperanto_prototype as cle
from skimage.io import imread, imsave, imshow
import matplotlib
import numpy as np
# initialize GPU
cle.select_device("GTX")
<Apple M1 Max on Platform: Apple (2 refs)>
# load data
image = imread('../../data/blobs.tif')
print("Loaded image size: " + str(image.shape))
cle.imshow(image)
Loaded image size: (254, 256)
data:image/s3,"s3://crabby-images/05019/050192b23532899a5e923e1fc580ce912c188c03" alt="../_images/39bb1efc7e4e7ed858ad16ff06fac347caaf3300a9103cd5efac0920807efe82.png"
We just setup a simple image processing workflow that leads to a label image.
# process the image
blurred = cle.gaussian_blur(image, sigma_x=1, sigma_y=1)
binary = cle.threshold_otsu(blurred)
labeled = cle.connected_components_labeling_box(binary)
# show result
cle.imshow(labeled, labels=True)
data:image/s3,"s3://crabby-images/5bf01/5bf0157a41ba763fe3ee81cde60208abe2ccf14a" alt="../_images/43678164c62301bcfa638dcf0a18910a51069f864934221e5c948dc8f0789d67.png"
The maximum intensity in a label image corresponds to the number of objects.
num_labels = cle.maximum_of_all_pixels(labeled)
print("Number of objects in the image: " + str(num_labels))
Number of objects in the image: 62.0
Exercise#
Remove the labels that touch the image border and count the objects again.