gen_std_bandpassgen_std_bandpassGenStdBandpassGenStdBandpassgen_std_bandpass (Operator)
Name
gen_std_bandpassgen_std_bandpassGenStdBandpassGenStdBandpassgen_std_bandpass
— Generate a bandpass filter with Gaussian or sinusoidal shape.
Signature
Herror gen_std_bandpass(Hobject* ImageFilter, double Frequency, double Sigma, const char* Type, const char* Norm, const char* Mode, const Hlong Width, const Hlong Height)
Herror T_gen_std_bandpass(Hobject* ImageFilter, const Htuple Frequency, const Htuple Sigma, const Htuple Type, const Htuple Norm, const Htuple Mode, const Htuple Width, const Htuple Height)
void GenStdBandpass(HObject* ImageFilter, const HTuple& Frequency, const HTuple& Sigma, const HTuple& Type, const HTuple& Norm, const HTuple& Mode, const HTuple& Width, const HTuple& Height)
void HImage::GenStdBandpass(double Frequency, double Sigma, const HString& Type, const HString& Norm, const HString& Mode, Hlong Width, Hlong Height)
void HImage::GenStdBandpass(double Frequency, double Sigma, const char* Type, const char* Norm, const char* Mode, Hlong Width, Hlong Height)
void HImage::GenStdBandpass(double Frequency, double Sigma, const wchar_t* Type, const wchar_t* Norm, const wchar_t* Mode, Hlong Width, Hlong Height)
(Windows only)
static void HOperatorSet.GenStdBandpass(out HObject imageFilter, HTuple frequency, HTuple sigma, HTuple type, HTuple norm, HTuple mode, HTuple width, HTuple height)
void HImage.GenStdBandpass(double frequency, double sigma, string type, string norm, string mode, int width, int height)
Description
gen_std_bandpassgen_std_bandpassGenStdBandpassGenStdBandpassGenStdBandpassgen_std_bandpass
generates a rotationally invariant bandpass
filter with the response being determined by the parameters
FrequencyFrequencyFrequencyFrequencyfrequencyfrequency
and SigmaSigmaSigmaSigmasigmasigma
: FrequencyFrequencyFrequencyFrequencyfrequencyfrequency
determines
the location of the maximum response with respect to the DC term,
while SigmaSigmaSigmaSigmasigmasigma
determines the width of the frequency band that
passes the filter. FrequencyFrequencyFrequencyFrequencyfrequencyfrequency
and SigmaSigmaSigmaSigmasigmasigma
are
specified as a fraction of the maximum (horizontal and vertical)
frequency that can be represented in an image of size WidthWidthWidthWidthwidthwidth
x HeightHeightHeightHeightheightheight
. FrequencyFrequencyFrequencyFrequencyfrequencyfrequency
should lie
between 0 and 1. For TypeTypeTypeTypetypetype
= 'gauss'"gauss""gauss""gauss""gauss""gauss", a Gaussian
response is generated with SigmaSigmaSigmaSigmasigmasigma
being the standard
deviation. For TypeTypeTypeTypetypetype
= 'sin'"sin""sin""sin""sin""sin", a sine function is
generated with the maximum at FrequencyFrequencyFrequencyFrequencyfrequencyfrequency
and the extent
SigmaSigmaSigmaSigmasigmasigma
. To achieve a maximum overall efficiency of the
filtering operation, the parameter NormNormNormNormnormnorm
can be used to
specify the normalization factor of the filter. If
fft_genericfft_genericFftGenericFftGenericFftGenericfft_generic
and NormNormNormNormnormnorm
= 'n'"n""n""n""n""n" is used the
normalization in the FFT can be avoided. ModeModeModeModemodemode
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_genericFftGenericFftGenericFftGenericfft_generic
is used, 'dc_edge'"dc_edge""dc_edge""dc_edge""dc_edge""dc_edge" can be used to gain
efficiency. If fft_imagefft_imageFftImageFftImageFftImagefft_image
and fft_image_invfft_image_invFftImageInvFftImageInvFftImageInvfft_image_inv
are used
for filtering, NormNormNormNormnormnorm
= 'none'"none""none""none""none""none" and ModeModeModeModemodemode
= 'dc_center'"dc_center""dc_center""dc_center""dc_center""dc_center" must be used. If rft_genericrft_genericRftGenericRftGenericRftGenericrft_generic
is
used, ModeModeModeModemodemode
= 'rft'"rft""rft""rft""rft""rft" must be used.
Execution Information
- Multithreading type: reentrant (runs in parallel with non-exclusive operators).
- Multithreading scope: global (may be called from any thread).
- Processed without parallelization.
Parameters
ImageFilterImageFilterImageFilterImageFilterimageFilterimage_filter
(output_object) image →
objectHImageHObjectHImageHobject * (real)
Bandpass filter as image in the frequency domain.
FrequencyFrequencyFrequencyFrequencyfrequencyfrequency
(input_control) real →
HTuplefloatHTupleHtuple (real) (double) (double) (double)
Distance of the filter's maximum from the DC term.
Default value: 0.1
Suggested values: 0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0
Restriction: Frequency >= 0
SigmaSigmaSigmaSigmasigmasigma
(input_control) real →
HTuplefloatHTupleHtuple (real) (double) (double) (double)
Bandwidth of the filter (standard deviation).
Default value: 0.01
Suggested values: 0.002, 0.005, 0.01, 0.02, 0.05, 0.1, 0.2, 0.3, 0.4, 0.5, 0.7, 1.0
Restriction: Sigma >= 0
TypeTypeTypeTypetypetype
(input_control) string →
HTuplestrHTupleHtuple (string) (string) (HString) (char*)
Filter type.
Default value:
'sin'
"sin"
"sin"
"sin"
"sin"
"sin"
List of values: 'gauss'"gauss""gauss""gauss""gauss""gauss", 'sin'"sin""sin""sin""sin""sin"
NormNormNormNormnormnorm
(input_control) string →
HTuplestrHTupleHtuple (string) (string) (HString) (char*)
Normalizing factor of the filter.
Default value:
'none'
"none"
"none"
"none"
"none"
"none"
List of values: 'n'"n""n""n""n""n", 'none'"none""none""none""none""none"
ModeModeModeModemodemode
(input_control) string →
HTuplestrHTupleHtuple (string) (string) (HString) (char*)
Location of the DC term in the frequency domain.
Default value:
'dc_center'
"dc_center"
"dc_center"
"dc_center"
"dc_center"
"dc_center"
List of values: 'dc_center'"dc_center""dc_center""dc_center""dc_center""dc_center", 'dc_edge'"dc_edge""dc_edge""dc_edge""dc_edge""dc_edge", 'rft'"rft""rft""rft""rft""rft"
WidthWidthWidthWidthwidthwidth
(input_control) integer →
HTupleintHTupleHtuple (integer) (int / long) (Hlong) (Hlong)
Width of the image (filter).
Default value: 512
Suggested values: 128, 160, 192, 256, 320, 384, 512, 640, 768, 1024, 2048, 4096, 8192
HeightHeightHeightHeightheightheight
(input_control) integer →
HTupleintHTupleHtuple (integer) (int / long) (Hlong) (Hlong)
Height of the image (filter).
Default value: 512
Suggested values: 120, 128, 144, 240, 256, 288, 480, 512, 576, 1024, 2048, 4096, 8192
Result
gen_std_bandpassgen_std_bandpassGenStdBandpassGenStdBandpassGenStdBandpassgen_std_bandpass
returns TRUE if all parameters are correct.
If necessary, an exception is raised.
Possible Predecessors
fft_imagefft_imageFftImageFftImageFftImagefft_image
,
fft_genericfft_genericFftGenericFftGenericFftGenericfft_generic
,
rft_genericrft_genericRftGenericRftGenericRftGenericrft_generic
Possible Successors
convol_fftconvol_fftConvolFftConvolFftConvolFftconvol_fft
Alternatives
gen_sin_bandpassgen_sin_bandpassGenSinBandpassGenSinBandpassGenSinBandpassgen_sin_bandpass
See also
fft_image_invfft_image_invFftImageInvFftImageInvFftImageInvfft_image_inv
,
gen_gauss_filtergen_gauss_filterGenGaussFilterGenGaussFilterGenGaussFiltergen_gauss_filter
,
gen_mean_filtergen_mean_filterGenMeanFilterGenMeanFilterGenMeanFiltergen_mean_filter
,
gen_derivative_filtergen_derivative_filterGenDerivativeFilterGenDerivativeFilterGenDerivativeFiltergen_derivative_filter
,
gen_bandpassgen_bandpassGenBandpassGenBandpassGenBandpassgen_bandpass
,
gen_bandfiltergen_bandfilterGenBandfilterGenBandfilterGenBandfiltergen_bandfilter
,
gen_highpassgen_highpassGenHighpassGenHighpassGenHighpassgen_highpass
,
gen_lowpassgen_lowpassGenLowpassGenLowpassGenLowpassgen_lowpass
Module
Foundation