Files
scikit-image/skimage/morphology/binary.py
T
Johannes Schönberger f8d34e8bf9 Deprecate out parameter
2013-10-11 19:05:18 +02:00

165 lines
4.8 KiB
Python

import warnings
import numpy as np
from scipy import ndimage
def _convolve(image, selem, out, cval):
# determine the smallest integer dtype which does not overflow
selem = selem != 0
selem_sum = np.sum(selem)
if selem_sum < 2 ** 8:
out_dtype = np.uint8
else:
out_dtype = np.intp
if out is None:
out = np.zeros_like(image, dtype=out_dtype)
else:
warnings.warn('Parameter `out` is deprecated and it does not equal '
'the output image if the sum of the structuring element '
'overflows the dtype of `out`.')
iinfo = np.iinfo(out.dtype)
if iinfo.max - iinfo.min < selem_sum:
raise ValueError('Sum of structuring (=%d) element results in '
'overflow for dtype of `out`. You must raise the '
'bit-depth.')
conv = ndimage.convolve(image > 0, selem, output=out,
mode='constant', cval=cval)
if conv is not None:
out = conv
return out, selem_sum
def binary_erosion(image, selem, out=None):
"""Return fast binary morphological erosion of an image.
This function returns the same result as greyscale erosion but performs
faster for binary images.
Morphological erosion sets a pixel at (i,j) to the minimum over all pixels
in the neighborhood centered at (i,j). Erosion shrinks bright regions and
enlarges dark regions.
Parameters
----------
image : ndarray
Image array.
selem : ndarray
The neighborhood expressed as a 2-D array of 1's and 0's.
out : ndarray
The array to store the result of the morphology. If None is
passed, a new array will be allocated.
Returns
-------
eroded : bool array
The result of the morphological erosion.
"""
out, selem_sum = _convolve(image, selem, out, 1)
return np.array(np.equal(out, selem_sum, out=out), dtype=np.bool,
copy=False)
def binary_dilation(image, selem, out=None):
"""Return fast binary morphological dilation of an image.
This function returns the same result as greyscale dilation but performs
faster for binary images.
Morphological dilation sets a pixel at (i,j) to the maximum over all pixels
in the neighborhood centered at (i,j). Dilation enlarges bright regions
and shrinks dark regions.
Parameters
----------
image : ndarray
Image array.
selem : ndarray
The neighborhood expressed as a 2-D array of 1's and 0's.
out : ndarray
The array to store the result of the morphology. If None, is
passed, a new array will be allocated.
Returns
-------
dilated : bool array
The result of the morphological dilation.
"""
out, _ = _convolve(image, selem, out, 0)
return np.array(np.not_equal(out, 0, out=out), dtype=np.bool, copy=False)
def binary_opening(image, selem, out=None):
"""Return fast binary morphological opening of an image.
This function returns the same result as greyscale opening but performs
faster for binary images.
The morphological opening on an image is defined as an erosion followed by
a dilation. Opening can remove small bright spots (i.e. "salt") and connect
small dark cracks. This tends to "open" up (dark) gaps between (bright)
features.
Parameters
----------
image : ndarray
Image array.
selem : ndarray
The neighborhood expressed as a 2-D array of 1's and 0's.
out : ndarray
The array to store the result of the morphology. If None
is passed, a new array will be allocated.
Returns
-------
opening : bool array
The result of the morphological opening.
"""
eroded = binary_erosion(image, selem)
out = binary_dilation(eroded, selem, out=out)
return out
def binary_closing(image, selem, out=None):
"""Return fast binary morphological closing of an image.
This function returns the same result as greyscale closing but performs
faster for binary images.
The morphological closing on an image is defined as a dilation followed by
an erosion. Closing can remove small dark spots (i.e. "pepper") and connect
small bright cracks. This tends to "close" up (dark) gaps between (bright)
features.
Parameters
----------
image : ndarray
Image array.
selem : ndarray
The neighborhood expressed as a 2-D array of 1's and 0's.
out : ndarray
The array to store the result of the morphology. If None,
is passed, a new array will be allocated.
Returns
-------
closing : bool array
The result of the morphological closing.
"""
dilated = binary_dilation(image, selem)
out = binary_erosion(dilated, selem, out=out)
return out