Image Binarization#
When binarizing an image, we produce an image that has only two values: True and False. Often, images are also called if they contain the value 0
, e.g. for background, and any other value for foreground.
import numpy as np
from skimage import data
from skimage.io import imread
from skimage.filters import threshold_otsu
import matplotlib.pyplot as plt
We use this example image of nuclei.
image_nuclei = imread('data/mitosis_mod.tif')
plt.imshow(image_nuclei, cmap='gray')
plt.colorbar()
<matplotlib.colorbar.Colorbar at 0x7f168ed67820>
data:image/s3,"s3://crabby-images/9c00e/9c00e1857b4d074f7d7a28546ab6dadc0e4e5330" alt="../_images/5ee4f2e0b4d2c791d4e3df838aab7c7c2e301d6adef7d5ebc897580b7be1bc56.png"
Image Thesholding#
The most common binarization technique is thresholding. We apply a threshold to determine which pixel lie above a certain pixel intensity and which are below.
image_binary = image_nuclei > 125
plt.imshow(image_binary, cmap='gray')
plt.colorbar()
<matplotlib.colorbar.Colorbar at 0x7f168ebac490>
data:image/s3,"s3://crabby-images/07070/07070318630e2bb8ce40caeca9f027212e72ebb7" alt="../_images/4e9b0ae786a40c641e780a20775b946497b6fe237a6d2e2515a18c673f6fdde9.png"
As choosing a manual threshold introduces human bias, it might be better to apply an automated thresholding algorithm such as Otsu’s method.
threshold = threshold_otsu(image_nuclei)
threshold
77
image_otsu_binary = image_nuclei > threshold
plt.imshow(image_otsu_binary, cmap='gray')
plt.colorbar()
<matplotlib.colorbar.Colorbar at 0x7f168ecd78e0>
data:image/s3,"s3://crabby-images/b2096/b20964c6e3e6c569ff06d3a3fc3a74240e9e6873" alt="../_images/a022a28994ebba3c453db8cc001c0cc9125f746d2a20fd32c2007570d814b3ac.png"