You are here: Start » Function Reference » Image » Image Local Transforms » TopHatImage_AnyKernel
Header: | FIL.h |
---|---|
Namespace: | fil |
Module: | FoundationLite |
Performs a morphological white top hat operation on a image using an arbitrary kernel.
Syntax
void fil::TopHatImage_AnyKernel ( const fil::Image& inImage, ftl::Optional<const fil::Region&> inRoi, ftl::Optional<const fil::Region&> inSourceRoi, ftl::Optional<fil::Pixel> inBorderColor, const fil::Region& inKernel, ftl::Optional<const fil::Location&> inKernelAnchor, fil::Image& outImage )
Parameters
Name | Type | Default | Description | |
---|---|---|---|---|
![]() |
inImage | const Image& | Input image | |
![]() |
inRoi | Optional<const Region&> | NIL | Range of outImage pixels to be computed |
![]() |
inSourceRoi | Optional<const Region&> | NIL | Range of inImage pixels to be considered in computations |
![]() |
inBorderColor | Optional<Pixel> | NIL | Color of the imaginary pixels outside the image boundaries |
![]() |
inKernel | const Region& | Kernel shape | |
![]() |
inKernelAnchor | Optional<const Location&> | NIL | A location within inKernel, defining its center |
![]() |
outImage | Image& | Output image |
In-place Processing
This function supports in-place data processing - you can pass the same reference to inImage and outImage
Read more about In-place Computation.
Description
Extracts from image small objects that are brighter than surroundings. Uses user-defined kernel.
Is performed by running consecutively two filters. OpenImage_AnyKernel to get the image without small objects and SubtractFromImage to remove everything but them.
Examples
![]() |
![]() |
Top Hat used to remove bigger objects. Source image on the left and result on the right.
Hardware Acceleration
This operation is optimized for SSE2 technology for pixels of types: all formats (when inSourceRoi = NIL and inBorderColor = NIL).
This operation is optimized for NEON technology for pixels of types: all formats (when inSourceRoi = NIL and inBorderColor = NIL).
This operation supports automatic parallelization for multicore and multiprocessor systems.
Errors
List of possible exceptions:
Error type | Description |
---|---|
DomainError | Region exceeds an input image in TopHatImage_AnyKernel. |