This chapter contains operators for smoothing filters. Further information about filtering can be found at the introduction to the chapter Filters.
Smoothing operators are filters that help to suppress noise in an image. For this purpose it is assumed, that in the undisturbed or true image the gray value of a given data point does not completely differ from its surroundings, ideally even varies only little. Thus, to suppress noise, it can be useful to replace the measured gray value with an estimate based on surrounding data points. Such an estimate can be done in different ways, so HALCON provides different smoothing operators.
The operators differ in speed and suitability for different kinds of noise.
Information like the complexity (runtime dependence on the image size)
is, if available, given in the operator reference.
While most operators treat a single image,
some can process depending images
(e.g., multichannel filters like
and mean_n
,
or edge-preserving filters like rank_n
and
guided_filter
, which additionally use guidance images).
Please note that some filters have both possibilities and more information
is given in the specific operator reference.
bilateral_filter
These smoothing filters apply their smoothing function on each channel of the input image separately and return a smoothed image with the same number of channels. In the following table we list implemented variants of smoothing filters for a single image with random noise and apply them for three different variants of random noise. The images in the table shall give an idea of the operators capability, but please note that the smoothed images highly depend on the input parameters and the individual image for every operator. For comparison, the different noisy images without filtering are given in the first row of the table. The undisturbed image without noise is shown in the following figure ((1) the full image as well as (2) its part by means of which possible effects on edges and remains from Salt & Pepper noise are visualized more clearly).
| ||||
(1) Undisturbed image, (2) part of the image chosen for the visualization of the filter capabilities |
We marked filters recommended due to their special suitability concerning speed (S), edge-preservation (E), or a compromise between these two (C). The numbers in square brackets refer to further information that is given in a list below the table.
White Noise | Gaussian Noise | Salt & Pepper Noise | Time[1] | Alternatives |
---|---|---|---|---|
noisy image | ||||
|
|
|
(E)[2] | ||||
|
|
|
805|2568 |
,
|
(E)[2,3] | ||||
|
|
|
13 | 62 |
,
,
|
(E)[3] | ||||
|
|
|
16 | 54 |
, ,
|
(E)[2] | ||||
|
|
|
11 | 51 |
| ||||
|
|
|
10 | 33 |
,
|
| ||||
|
|
|
3 | 11 |
|
(E) | ||||
|
|
|
3 | 4 |
, ,
|
(C) | ||||
|
|
|
2 | 3 |
, ,
|
(C) | ||||
|
|
|
7 | 24 |
|
| ||||
|
|
|
14 | 47 |
, ,
|
(E) | ||||
|
|
|
2 | 8 |
, ,
|
(E) | ||||
|
|
|
3 | 15 |
, ,
|
| ||||
|
|
|
11 | 42 |
Further information related to the numbers in square brackets used in the table above:
The numbers in the column 'Time' are indications about the time the operator uses to process an image. The numbers are obtained from averaging over multiple runs on the three different noise images and given in arbitrary units. Note also that the runtime of an operator depends on many factors, not at least on the used parameters and the image size. For each filter, the first number is for an image of size 800x600, the second for an image of size 1497x1160. The shown images are parts of the smaller image with parameters reasonable to us (we do not claim to have found the parameters resulting neither necessarily in the best image smoothing nor the smallest runtime). Even if two filters have the same parameter name as input, we did not necessarily use the same parameter value for both of them. Therefore, these numbers are to be understood as an indicator only.
This operator can be used iteratively.
This operator uses a guidance image
(which can be the
itself).
Image
Video images composed of two half images can have systematic errors.
In such a case, the operator
can help.
fill_interlace
These smoothing filters take an image with multiple channels as input and return a single channel (gray value) image. In HALCON, the following filters of this group are implemented:
In addition to the smoothing filters, this chapter contains the following
operator:
, which returns information related to the different
filters used by the operator info_smooth
.
smooth_image
In the following, the most important terms that are used in the context of smoothing filters are described:
Smoothing means to apply a filter function on the given data to capture the main data patterns while removing noise.
Random noise is a stationary variation of brightness or color information by a small random amount for every pixel with an assumed mean of 0 over the total image.
Systematic noise is predictable noise, caused, e.g., by the specific setup used to acquire the images.
anisotropic_diffusion
bilateral_filter
binomial_filter
eliminate_min_max
eliminate_sp
fill_interlace
gauss_filter
guided_filter
info_smooth
smooth_image
.isotropic_diffusion
mean_image
mean_image_shape
mean_n
mean_sp
median_image
median_rect
median_separate
median_weighted
midrange_image
rank_image
rank_n
rank_rect
sigma_image
smooth_image
trimmed_mean