The 2D Fourier Analysis
Today we’ll see how a simple approach like the 2D image analysis via Fourier would allows us to discover a lot of information about images.
Introduction
Fourier transformation are a powerful tools that allows us to write a function in its frequency domain as a sum of a number of sinusoids. Its application domain spans along every engineering and science field. Guess what, Computer Vision is one of the fields in which Fourier Analysis is really helpful.
For example whan dealing with noisy images, or when you need to discover patterns inside an image. We’ll see some of such applications.
Pills of background
The Fourier transform in one dimension is defined as follows: let f(x) be a signal belonging to $\mathbf{R}$
\[\begin{aligned} F(\omega)&=\int_{-\infty}^{+\infty}f(x)\,e^{-i\omega x}dx\\ &=R(\omega)+iI(\omega) \end{aligned}\]that can be easily rewritten using the Euler Formula. There exists also the inverse mapping, the so called ‘Fourier antitransform’ (or Inverse Fourier transform)
\[f(x)=\int_{-\infty}^{+\infty}F(\omega)\,e^{i\omega x}d\omega\]the usefulness of such operators lies in the properties they have:
- for every $\omega$ from 0 to $\infty$, $F(\omega)$ maintain both the phase and the amplitude of the input signals
- in the frequency domain we can extract the amplitude (or frequency) and phase plots, that provides us useful informations
2D generalization
The generalization to the 2D domain it’s quite straightforward. Instead of having time signals, we have spatial signals with spatial frequencies and phases. Whatever holds for 1D domain, holds also for 2D domain, but it’s just more complex.
Note that from now on I’ll refer to 2D grayscale images, but the very same argument can be applied to RGB images.
Amplitude and phase plots
using logarithmic scale for the amplitude, we obtain the following 3D plot
where in the left we have the 3D amplitude spectrum of Lena, while in the right the one for bricks wall (note that is a meshgrid).
Just seeing such results we perceive that these plots gather a lot of informations about the image we are dealing with. A way to handle them is the mixing of amplitude and phase plots from 2 different images