Median filter
Last updated
Last updated
Next on our plate, we have actual smoothing algorithms. Previously, we have been discussing blurring, which does fall under the moniker of smoothing. However, when one refers to "smoothing" filters, it is assumed that it relates to taking a pixelated image and smoothing certain noisy parts of it out to make it clearer and less noisy. This is in contrast to blurring, which tends to "smooth" the entire image almost uniformly. Now, let's delve into the median filter.
The mathematical median is a function that derives the midpoint value of a sorted set of odd length. If the length is even, we instead take the average of the two middlemost values. Mathematically speaking, here is what it would look like:
Here is the pseudo-code representation
So, the median filter works similarly to the previously discussed functions; we loop through each pixel and take an area specified by the kernel dimensions. From this neighbourhood of pixels, we extract the median and assign the current pixel to it. Let's take a look at the implementation.
The median filter is implemented at src/smoothing/median.c
I will be the first to admit this code isn't the cleanest. Let's break down what we are doing.
We loop through each pixel of the image (more specifically each channel)
We have an array called pixelArray
where we will store all the values which fall within the kernel
The loop assigns the pixels to this pixelArray
, we then apply a function calculate_median
The returned value is assigned to the current pixel
The implementation for the calculate_median
varies, our implementation does a bubble sort and returns the median.
The median filter is known for its slow performance, the primary bottleneck is the calculation of the median, where we have to sort through all the neighbouring pixels. On doing some performance benchmarks on my machine (11th Gen Intel i3-1115G4 (4) @ 2.995GHz
)
The time complexity here is abysmal which is why we need the Bilateral filter which we will discuss next.