{ } Raw JSON

bundles / scipy latest / scipy / ndimage / _morphology / black_tophat

function

scipy.ndimage._morphology:black_tophat

source: /scipy/ndimage/_morphology.py :1902

Signature

def   black_tophat ( input size = None footprint = None structure = None output = None mode = reflect cval = 0.0 origin = 0 * axes = None )

Summary

Multidimensional black tophat filter.

Parameters

input : array_like

Input.

size : tuple of ints, optional

Shape of a flat and full structuring element used for the filter. Optional if footprint or structure is provided.

footprint : array of ints, optional

Positions of non-infinite elements of a flat structuring element used for the black tophat filter.

structure : array of ints, optional

Structuring element used for the filter. structure may be a non-flat structuring element. The structure array applies offsets to the pixels in a neighborhood (the offset is additive during dilation and subtractive during erosion)

output : array, optional

An array used for storing the output of the filter may be provided.

mode : {'reflect', 'constant', 'nearest', 'mirror', 'wrap'}, optional

The mode parameter determines how the array borders are handled, where cval is the value when mode is equal to 'constant'. Default is 'reflect'

cval : scalar, optional

Value to fill past edges of input if mode is 'constant'. Default is 0.0.

origin : scalar, optional

The origin parameter controls the placement of the filter. Default 0

axes : tuple of int or None

The axes over which to apply the filter. If None, input is filtered along all axes. If an origin tuple is provided, its length must match the number of axes.

Returns

black_tophat : ndarray

Result of the filter of input with structure.

Notes

Array API Standard Support

black_tophat has experimental support for Python Array API Standard compatible backends in addition to NumPy. Please consider testing these features by setting an environment variable SCIPY_ARRAY_API=1 and providing CuPy, PyTorch, JAX, or Dask arrays as array arguments. The following combinations of backend and device (or other capability) are supported.

====================  ====================  ====================
Library               CPU                   GPU
====================  ====================  ====================
NumPy                 ✅                     n/a                 
CuPy                  n/a                   ✅                   
PyTorch               ✅                     ⛔                   
JAX                   ⚠️ no JIT
Dask                  ⚠️ computes graph     n/a                 
====================  ====================  ====================

See dev-arrayapi for more information.

Examples

Change dark peak to bright peak and subtract background.
from scipy.ndimage import generate_binary_structure, black_tophat
import numpy as np
square = generate_binary_structure(rank=2, connectivity=3)
dark_on_gray = np.array([[7, 6, 6, 6, 7],
                         [6, 5, 4, 5, 6],
                         [6, 4, 0, 4, 6],
                         [6, 5, 4, 5, 6],
                         [7, 6, 6, 6, 7]])
black_tophat(input=dark_on_gray, structure=square)

See also

grey_closing
grey_opening
white_tophat

Aliases

  • scipy.ndimage.black_tophat