ImageDev

GrayscaleFillHoles2d

Fills holes in particles of a two-dimensional grayscale image.

Access to parameter description

For an introduction: This algorithm is analogous to the FillHoles2d which is dedicated to the binary case. It fills darks areas that are not connected to the image borders with the maximal gray level surrounding them. This algorithm uses the grayscale reconstruction by erosion algorithm. The marker image used by the reconstruction is generated with gray levels equal to: The thresholdFillingValue parameter sets the maximum gray level from which the bottom of a valley is considered as a hole.



Figure 1. Original image, gray hole fill result (hole level = image maximum)

Reference:
P. Soille, Morphological Image Analysis. Principles and Applications, Second Edition, Springer-Verlag, Berlin, p.208, 2003.

See also

Function Syntax

This function returns outputImage.
// Function prototype
std::shared_ptr< iolink::ImageView > grayscaleFillHoles2d( std::shared_ptr< iolink::ImageView > inputImage, double thresholdFillingValue, GrayscaleFillHoles2d::Neighborhood neighborhood, std::shared_ptr< iolink::ImageView > outputImage = NULL );

Class Syntax

Parameters

Parameter Name Description Type Supported Values Default Value
input
inputImage
The grayscale input image. Image Binary, Label or Grayscale nullptr
input
thresholdFillingValue
The value filling the marker image inside (the gray level under which valleys are filled). The common usage is to set it at the image maximum intensity. Float64 Any value 1
input
neighborhood
The 2D neighborhood configuration for performing erosions of the numerical reconstruction.
CONNECTIVITY_8 The structuring element is a square.
CONNECTIVITY_4 The structuring element is a cross.
Enumeration CONNECTIVITY_8
output
outputImage
The grayscale output image. Its dimensions and type are forced to the same values as the input. Image nullptr

Object Examples

std::shared_ptr< iolink::ImageView > polystyrene = ioformat::readImage( std::string( IMAGEDEVDATA_IMAGES_FOLDER ) + "polystyrene.tif" );

GrayscaleFillHoles2d grayscaleFillHoles2dAlgo;
grayscaleFillHoles2dAlgo.setInputImage( polystyrene );
grayscaleFillHoles2dAlgo.setThresholdFillingValue( 0.0 );
grayscaleFillHoles2dAlgo.setNeighborhood( GrayscaleFillHoles2d::Neighborhood::CONNECTIVITY_8 );
grayscaleFillHoles2dAlgo.execute();

std::cout << "outputImage:" << grayscaleFillHoles2dAlgo.outputImage()->toString();

Function Examples

std::shared_ptr< iolink::ImageView > polystyrene = ioformat::readImage( std::string( IMAGEDEVDATA_IMAGES_FOLDER ) + "polystyrene.tif" );

auto result = grayscaleFillHoles2d( polystyrene, 0.0, GrayscaleFillHoles2d::Neighborhood::CONNECTIVITY_8 );

std::cout << "outputImage:" << result->toString();