kirsch_ampkirsch_ampKirschAmpKirschAmpkirsch_amp (Operator)

Name

kirsch_ampkirsch_ampKirschAmpKirschAmpkirsch_amp — Detect edges (amplitude) using the Kirsch operator.

Signature

kirsch_amp(Image : ImageEdgeAmp : : )

Herror kirsch_amp(const Hobject Image, Hobject* ImageEdgeAmp)

Herror T_kirsch_amp(const Hobject Image, Hobject* ImageEdgeAmp)

void KirschAmp(const HObject& Image, HObject* ImageEdgeAmp)

HImage HImage::KirschAmp() const

static void HOperatorSet.KirschAmp(HObject image, out HObject imageEdgeAmp)

HImage HImage.KirschAmp()

def kirsch_amp(image: HObject) -> HObject

Description

kirsch_ampkirsch_ampKirschAmpKirschAmpkirsch_amp calculates an approximation of the first derivative of the image data and is used as an edge detector. The filter is based on the following filter masks: -3 -3 5 -3 5 5 5 5 5 5 5 -3 -3 0 5 -3 0 5 -3 0 -3 5 0 -3 -3 -3 5 -3 -3 -3 -3 -3 -3 -3 -3 -3 5 -3 -3 -3 -3 -3 -3 -3 -3 -3 -3 -3 5 0 -3 5 0 -3 -3 0 -3 -3 0 5 5 -3 -3 5 5 -3 5 5 5 -3 5 5 The result image contains the maximum response of all masks.

Attention

Note that filter operators may return unexpected results if an image with a reduced domain is used as input. Please refer to the chapter Filters.

Execution Information

Parameters

ImageImageImageimageimage (input_object)  (multichannel-)image(-array) objectHImageHObjectHObjectHobject (byte / int2 / uint2)

Input image.

ImageEdgeAmpImageEdgeAmpImageEdgeAmpimageEdgeAmpimage_edge_amp (output_object)  image(-array) objectHImageHObjectHObjectHobject * (byte / int2 / uint2)

Edge amplitude (gradient magnitude) image.

Example (HDevelop)

read_image(Image,'fabrik')
kirsch_amp(Image,Kirsch_amp)
threshold(Kirsch_amp,Edges,128,255)

Example (C)

read_image(&Image,"fabrik");
kirsch_amp(Image,&Kirsch_amp);
threshold(Kirsch_amp,&Edges,128,255);

Example (HDevelop)

read_image(Image,'fabrik')
kirsch_amp(Image,Kirsch_amp)
threshold(Kirsch_amp,Edges,128,255)

Example (HDevelop)

read_image(Image,'fabrik')
kirsch_amp(Image,Kirsch_amp)
threshold(Kirsch_amp,Edges,128,255)

Result

kirsch_ampkirsch_ampKirschAmpKirschAmpkirsch_amp always returns 2 ( H_MSG_TRUE) . If the input is empty the behavior can be set via set_system('no_object_result',<Result>)set_system("no_object_result",<Result>)SetSystem("no_object_result",<Result>)SetSystem("no_object_result",<Result>)set_system("no_object_result",<Result>). If necessary, an exception is raised.

Possible Predecessors

binomial_filterbinomial_filterBinomialFilterBinomialFilterbinomial_filter, gauss_filtergauss_filterGaussFilterGaussFiltergauss_filter, sigma_imagesigma_imageSigmaImageSigmaImagesigma_image, median_imagemedian_imageMedianImageMedianImagemedian_image, smooth_imagesmooth_imageSmoothImageSmoothImagesmooth_image

Alternatives

sobel_ampsobel_ampSobelAmpSobelAmpsobel_amp, frei_ampfrei_ampFreiAmpFreiAmpfrei_amp, prewitt_ampprewitt_ampPrewittAmpPrewittAmpprewitt_amp, robinson_amprobinson_ampRobinsonAmpRobinsonAmprobinson_amp, robertsrobertsRobertsRobertsroberts

See also

bandpass_imagebandpass_imageBandpassImageBandpassImagebandpass_image, laplace_of_gausslaplace_of_gaussLaplaceOfGaussLaplaceOfGausslaplace_of_gauss

Module

Foundation