HALCON Reference Manual 10.0.2
Table of Contents / Filters / FFT ClassesClassesClasses | | | Operators

gen_derivative_filtergen_derivative_filtergen_derivative_filterGenDerivativeFilterGenDerivativeFilter (Operator)

Name

gen_derivative_filtergen_derivative_filtergen_derivative_filterGenDerivativeFilterGenDerivativeFilter — Generate a derivative filter in the frequency domain.

Signature

gen_derivative_filter( : ImageDerivative : Derivative, Exponent, Norm, Mode, Width, Height : )

Herror gen_derivative_filter(Hobject* ImageDerivative, const char* Derivative, const Hlong Exponent, const char* Norm, const char* Mode, const Hlong Width, const Hlong Height)

Herror T_gen_derivative_filter(Hobject* ImageDerivative, const Htuple Derivative, const Htuple Exponent, const Htuple Norm, const Htuple Mode, const Htuple Width, const Htuple Height)

Herror gen_derivative_filter(Hobject* ImageDerivative, const HTuple& Derivative, const HTuple& Exponent, const HTuple& Norm, const HTuple& Mode, const HTuple& Width, const HTuple& Height)

HImage HImage::GenDerivativeFilter(const HTuple& Derivative, const HTuple& Exponent, const HTuple& Norm, const HTuple& Mode, const HTuple& Width, const HTuple& Height)

void HOperatorSetX.GenDerivativeFilter(
[out] IHUntypedObjectX*ImageDerivative, [in] VARIANT Derivative, [in] VARIANT Exponent, [in] VARIANT Norm, [in] VARIANT Mode, [in] VARIANT Width, [in] VARIANT Height)

void HImageX.GenDerivativeFilter(
[in] BSTR Derivative, [in] Hlong Exponent, [in] BSTR Norm, [in] BSTR Mode, [in] Hlong Width, [in] Hlong Height)

static void HOperatorSet.GenDerivativeFilter(out HObject imageDerivative, HTuple derivative, HTuple exponent, HTuple norm, HTuple mode, HTuple width, HTuple height)

void HImage.GenDerivativeFilter(string derivative, int exponent, string norm, string mode, int width, int height)

Description

gen_derivative_filtergen_derivative_filtergen_derivative_filterGenDerivativeFilterGenDerivativeFilter generates a derivative filter in the frequency domain. The derivative to be computed is determined by DerivativeDerivativeDerivativeDerivativederivative. ExponentExponentExponentExponentexponent specifies the exponent used in the reverse transform. It must be set to the same value that is used in fft_genericfft_genericfft_genericFftGenericFftGeneric. If fft_image_invfft_image_invfft_image_invFftImageInvFftImageInv is used in the reverse transform, ExponentExponentExponentExponentexponent = 1 must be used. However, since the derivative image typically contains negative values, fft_genericfft_genericfft_genericFftGenericFftGeneric should always be used for the reverse transform. To achieve a maximum overall efficiency of the filtering operation, the parameter NormNormNormNormnorm can be used to specify the normalization factor of the filter. If fft_genericfft_genericfft_genericFftGenericFftGeneric and NormNormNormNormnorm = 'n'"n""n""n""n" is used the normalization in the FFT can be avoided. ModeModeModeModemode can be used to determine where the DC term of the filter lies or whether the filter should be used in the real-valued FFT. If fft_genericfft_genericfft_genericFftGenericFftGeneric is used, 'dc_edge'"dc_edge""dc_edge""dc_edge""dc_edge" can be used to gain efficiency. If fft_imagefft_imagefft_imageFftImageFftImage and fft_image_invfft_image_invfft_image_invFftImageInvFftImageInv are used for filtering, NormNormNormNormnorm = 'none'"none""none""none""none" and ModeModeModeModemode = 'dc_center'"dc_center""dc_center""dc_center""dc_center" must be used. If rft_genericrft_genericrft_genericRftGenericRftGeneric is used, ModeModeModeModemode = 'rft'"rft""rft""rft""rft" must be used.

Parallelization

Parameters

ImageDerivativeImageDerivativeImageDerivativeImageDerivativeimageDerivative (output_object)  image objectHImageHImageHImageXHobject * (complex)

Derivative filter as image in the frequency domain.

DerivativeDerivativeDerivativeDerivativederivative (input_control)  string HTupleHTupleVARIANTHtuple (string) (string) (char*) (BSTR) (char*)

Derivative to be computed.

Default value: 'x' "x" "x" "x" "x"

Suggested values: 'x'"x""x""x""x", 'y'"y""y""y""y", 'xx'"xx""xx""xx""xx", 'xy'"xy""xy""xy""xy", 'yy'"yy""yy""yy""yy", 'xxx'"xxx""xxx""xxx""xxx", 'xxy'"xxy""xxy""xxy""xxy", 'xyy'"xyy""xyy""xyy""xyy", 'yyy'"yyy""yyy""yyy""yyy"

ExponentExponentExponentExponentexponent (input_control)  integer HTupleHTupleVARIANTHtuple (integer) (int / long) (Hlong) (Hlong) (Hlong)

Exponent used in the reverse transform.

Default value: 1

Suggested values: -1, 1

NormNormNormNormnorm (input_control)  string HTupleHTupleVARIANTHtuple (string) (string) (char*) (BSTR) (char*)

Normalizing factor of the filter.

Default value: 'none' "none" "none" "none" "none"

List of values: 'none'"none""none""none""none", 'n'"n""n""n""n"

ModeModeModeModemode (input_control)  string HTupleHTupleVARIANTHtuple (string) (string) (char*) (BSTR) (char*)

Location of the DC term in the frequency domain.

Default value: 'dc_center' "dc_center" "dc_center" "dc_center" "dc_center"

List of values: 'dc_center'"dc_center""dc_center""dc_center""dc_center", 'dc_edge'"dc_edge""dc_edge""dc_edge""dc_edge", 'rft'"rft""rft""rft""rft"

WidthWidthWidthWidthwidth (input_control)  integer HTupleHTupleVARIANTHtuple (integer) (int / long) (Hlong) (Hlong) (Hlong)

Width of the image (filter).

Default value: 512

List of values: 128, 160, 192, 256, 320, 384, 512, 640, 768, 1024, 2048, 4096, 8192

HeightHeightHeightHeightheight (input_control)  integer HTupleHTupleVARIANTHtuple (integer) (int / long) (Hlong) (Hlong) (Hlong)

Height of the image (filter).

Default value: 512

List of values: 120, 128, 144, 240, 256, 288, 480, 512, 576, 1024, 2048, 4096, 8192

Example (HDevelop)

* Generate a smoothed derivative filter.
gen_gauss_filter (ImageGauss, Sigma, Sigma, 0, 'n', 'dc_edge', 512, 512)
convert_image_type (ImageGauss, ImageGaussComplex, 'complex')
gen_derivative_filter (ImageDerivX, 'x', 1, 'none', 'dc_edge', 512, 512)
mult_image (ImageGaussComplex, ImageDerivX, ImageDerivXGauss, 1, 0)
* Filter an image with the smoothed derivative filter.
fft_generic (Image, ImageFFT, 'to_freq', -1, 'none', 'dc_edge', 'complex')
convol_fft (ImageFFT, ImageDerivXGauss, Filtered)
fft_generic (Filtered, ImageX, 'from_freq', 1, 'none', 'dc_edge', 'real')

Result

gen_derivative_filtergen_derivative_filtergen_derivative_filterGenDerivativeFilterGenDerivativeFilter returns 2 (H_MSG_TRUE) if all parameters are correct. If necessary, an exception is raised.

Possible Predecessors

fft_imagefft_imagefft_imageFftImageFftImage, fft_genericfft_genericfft_genericFftGenericFftGeneric, rft_genericrft_genericrft_genericRftGenericRftGeneric

Possible Successors

convol_fftconvol_fftconvol_fftConvolFftConvolFft

See also

fft_image_invfft_image_invfft_image_invFftImageInvFftImageInv, gen_gauss_filtergen_gauss_filtergen_gauss_filterGenGaussFilterGenGaussFilter, gen_mean_filtergen_mean_filtergen_mean_filterGenMeanFilterGenMeanFilter, gen_lowpassgen_lowpassgen_lowpassGenLowpassGenLowpass, gen_bandpassgen_bandpassgen_bandpassGenBandpassGenBandpass, gen_bandfiltergen_bandfiltergen_bandfilterGenBandfilterGenBandfilter, gen_highpassgen_highpassgen_highpassGenHighpassGenHighpass

Module

Foundation


Table of Contents / Filters / FFT ClassesClassesClasses | | | Operators
HALCON Reference Manual 10.0.2 Copyright © 1996-2011 MVTec Software GmbH