.. DO NOT EDIT. .. THIS FILE WAS AUTOMATICALLY GENERATED BY SPHINX-GALLERY. .. TO MAKE CHANGES, EDIT THE SOURCE PYTHON FILE: .. "auto_examples/segmentation/plot_expand_labels.py" .. LINE NUMBERS ARE GIVEN BELOW. .. only:: html .. note:: :class: sphx-glr-download-link-note :ref:`Go to the end ` to download the full example code or to run this example in your browser via Binder .. rst-class:: sphx-glr-example-title .. _sphx_glr_auto_examples_segmentation_plot_expand_labels.py: ========================================== Expand segmentation labels without overlap ========================================== Given several connected components represented by a label image, these connected components can be expanded into background regions using :py:func:`skimage.segmentation.expand_labels`. In contrast to :py:func:`skimage.morphology.dilation` this method will not let connected components expand into neighboring connected components with lower label number. .. GENERATED FROM PYTHON SOURCE LINES 13-62 .. image-sg:: /auto_examples/segmentation/images/sphx_glr_plot_expand_labels_001.png :alt: Original, Sobel+Watershed, Expanded labels :srcset: /auto_examples/segmentation/images/sphx_glr_plot_expand_labels_001.png :class: sphx-glr-single-img .. code-block:: default import matplotlib.pyplot as plt import numpy as np from skimage import data from skimage.color import label2rgb from skimage.filters import sobel from skimage.measure import label from skimage.segmentation import expand_labels, watershed coins = data.coins() # Make segmentation using edge-detection and watershed. edges = sobel(coins) # Identify some background and foreground pixels from the intensity values. # These pixels are used as seeds for watershed. markers = np.zeros_like(coins) foreground, background = 1, 2 markers[coins < 30.0] = background markers[coins > 150.0] = foreground ws = watershed(edges, markers) seg1 = label(ws == foreground) expanded = expand_labels(seg1, distance=10) # Show the segmentations. fig, axes = plt.subplots( nrows=1, ncols=3, figsize=(9, 5), sharex=True, sharey=True, ) axes[0].imshow(coins, cmap="Greys_r") axes[0].set_title("Original") color1 = label2rgb(seg1, image=coins, bg_label=0) axes[1].imshow(color1) axes[1].set_title("Sobel+Watershed") color2 = label2rgb(expanded, image=coins, bg_label=0) axes[2].imshow(color2) axes[2].set_title("Expanded labels") for a in axes: a.axis("off") fig.tight_layout() plt.show() .. rst-class:: sphx-glr-timing **Total running time of the script:** (0 minutes 0.879 seconds) .. _sphx_glr_download_auto_examples_segmentation_plot_expand_labels.py: .. only:: html .. container:: sphx-glr-footer sphx-glr-footer-example .. container:: binder-badge .. image:: images/binder_badge_logo.svg :target: https://mybinder.org/v2/gh/scikit-image/scikit-image/v0.22.x?filepath=notebooks/auto_examples/segmentation/plot_expand_labels.ipynb :alt: Launch binder :width: 150 px .. container:: sphx-glr-download sphx-glr-download-python :download:`Download Python source code: plot_expand_labels.py ` .. container:: sphx-glr-download sphx-glr-download-jupyter :download:`Download Jupyter notebook: plot_expand_labels.ipynb ` .. only:: html .. rst-class:: sphx-glr-signature `Gallery generated by Sphinx-Gallery `_