Operators |
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 mean_n and rank_n, or edge-preserving filters like guided_filter and bilateral_filter, which additionally use guidance images). Please note that some filters have both possibilities and more information is given in the specific operator reference.
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 | ||||
|
|
|
mean_image(S) | ||||
|
|
|
1 | 1 | binomial_filter, gauss_filter, smooth_image |
anisotropic_diffusion(E)[2] | ||||
|
|
|
805|2568 | bilateral_filter, guided_filter |
guided_filter(E)[2,3] | ||||
|
|
|
13 | 62 | bilateral_filter, anisotropic_diffusion, median_image |
bilateral_filter(E)[3] | ||||
|
|
|
16 | 54 | guided_filter, anisotropic_diffusion, median_image |
isotropic_diffusion(E)[2] | ||||
|
|
|
11 | 51 |
sigma_image | ||||
|
|
|
10 | 33 | anisotropic_diffusion, rank_image |
midrange_image | ||||
|
|
|
3 | 11 | sigma_image |
median_image(E) | ||||
|
|
|
3 | 4 | median_rect, rank_image, rank_rect |
median_rect(C) | ||||
|
|
|
2 | 3 | median_image, rank_rect, rank_image |
median_separate(C) | ||||
|
|
|
7 | 24 | median_image |
median_weighted | ||||
|
|
|
14 | 47 | median_image, trimmed_mean, sigma_image |
rank_image(E) | ||||
|
|
|
3 | 15 | rank_rect, median_image, median_rect |
eliminate_min_max | ||||
|
|
|
11 | 42 |
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 Image itself).
Video images composed of two half images can have systematic errors. In such a case, the operator fill_interlace can help.
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: info_smooth, which returns information related to the different filters used by the operator 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.
Operators |