Binary Image Skeletonization#
This notebook demonstrates basic binary image skeletonization using Python libraries.
Introduction#
Skeletonization reduces binary objects in an image to their essential lines, preserving the structure and connectivity, allowing for further analysis of the shapes and structures.
# Import necessary libraries
import matplotlib.pyplot as plt
from skimage import data, filters, morphology, color
Load and preprocess the image#
We’ll use a sample image from skimage.data
and convert it to binary form for demonstration.
# Load sample image
image = data.horse() # Sample binary image
# Apply threshold to convert to binary image
binary_image = image < filters.threshold_otsu(image)
# Plot original and binary images
fig, ax = plt.subplots(1, 2, figsize=(8, 4))
ax[0].imshow(image, cmap='gray')
ax[0].set_title('Original Image')
ax[1].imshow(binary_image, cmap='gray')
ax[1].set_title('Binary Image')
plt.show()
<__array_function__ internals>:180: RuntimeWarning: Converting input from bool to <class 'numpy.uint8'> for compatibility.
data:image/s3,"s3://crabby-images/5a591/5a591184e47deef9c8b34b42c720e605b2062e03" alt="../_images/bc41a558da818413e26e5bcc7585faddd25b2b979e7336dec5309e3202246d51.png"
Perform Skeletonization#
We’ll use the skeletonize
function from skimage.morphology
to perform skeletonization on the binary image.
# Perform skeletonization
skeleton = morphology.skeletonize(binary_image)
# Plot skeletonized image
plt.figure(figsize=(4, 4))
plt.imshow(skeleton, cmap='gray')
plt.title('Skeletonized Image')
plt.show()
data:image/s3,"s3://crabby-images/fc8f4/fc8f473f0186e725bbb2794be46fe890e7ec32d1" alt="../_images/31d59b1ba498f8d159d55340ce42e2acbc71493530d27e05dcf5e32e9f0e9893.png"