Fun with Frequencies and Filters

Vishnu Suresh

CS 180: Computer Vision and Computational Photography

Overview

This project explores the multifarious ways of utilizing image filters and image frequency bands to come up with unique and interesting results. These include Edge Detection using Derivative of Gaussian (DoG) Filters, hybridizing images so that what you view changes as a function of your distance from the image, image sharpening, and multi-resolution blending. The power of these methods enables us to put creative ideas into picture! (You might see a Wimbledon Champion you've never heard of before!)

This webpage will go through each of these methods in great detail showing all the images (intermediary and results) involved.

Finite Difference Operator

In this section, we work on the image of a cameraman. I use two finite difference operators namely [1 -1] and [1 -1].T to compute the partial derivatives with respect to x and y respectively. This is done through convolution by using the scipy.convolve2d function with mode = same. Once I have these convolved images, I combine them using np.sqrt(dx_deriv ** 2 + dy_deriv ** 2) and I create an edge image by binarizing the gradient magnitude image by empirically picking the correct threshold.

Project Image 1
The Camerman
Project Image 1
Partial Derivative wrt. x
Project Image 2
Partial Derivative wrt. y
Project Image 3
Edge Map (Threshold = 29)

Derivate of Gaussian (DoG) Filters

Since the partial derivative images were rather noisy, I first apply a gaussian kernel on the original image through convolution. Once the original image, I repeat the same finite-difference-operator process above. Here are the results:

Project Image 1
Partial Derivative wrt. x on Gaussian Blurred Image
Project Image 2
Partial Derivative wrt. y on Gaussian Blurred Image
Project Image 3
COmbined Image: Edge Map (Threshold = 29)

What differences do I see? In the case of the Gaussian kernel filter, there are little to no unneccessary artifacts on the image. This would allow us to arrive at a better quality edge map.

DoG in one convolution operation

Instead of first applying the Gaussian kernel on our original image and then convolving them with Dx and Dy finite finite-difference-operators, I can use a single convolution operation. I first convolve the Gaussian kernel with Dx and Dy.

Project Image 1
Gaussian Kernel
Project Image 2
Gaussian Kernel convolved with Dx
Project Image 3
Gaussian Kernel convolved with Dy

Now I apply these kernels on the original unblurred image to get their "smoothened" partial derivatives with respect to x and y. Once I have these images, I combine them using np.sqrt(dx_deriv ** 2 + dy_deriv ** 2) to get the gradient magnitude image.

As can be seen, because of commutativity of how convolution operations are applied, we get the same result as before.

Project Image 1
Partial Derivative wrt. x on Original Image using Gaussian Kernel convolved with Dx
Project Image 2
Partial Derivative wrt. y on Original Image using Gaussian Kernel convolved with Dy
Project Image 3
Combined Image

COmparison of the final images through both methods. Images are very similar.

Project Image 1
Result through multiple convolution operations
Project Image 2
Result through single DoG convolution operations

Image Sharpening

In order to sharpen an image target, the image is convolved with a gaussian kernel in order to filter out higher frequencies, resulting in a blurred image blurred. The high-frequency details are then calculated through details = target - blurred, which removes all lower frequency features from the original image. These details are then emphasized in the final image through result = target + alpha * details where alpha is a constant sharpening factor. The value of alpha is picked through experimentation.

Just like how the we know that the Gaussian Kernel can be used as the convolution operator for low-pass image filtering, I also derived the high pass convolution operator (called the unsharp mask filter) which gives you the higher frequencies of the image. Unsharp mask filter = (1 + alpha) * identity - alpha * gauss2d. Doesn't matter how one computes the high frequency images - either directly or through the unmask shape filter, both methods resilt in the exact same image.

Below, is an illustration of the image sharpening process of the given image of the Taj Mahal and a personally selected image of 20-time Tennis Grand-Slam Champion Roger Federer

Sharpening the Taj

edge map image
Original Taj Mahal Image
Before edge detection
Gaussian Blurred Taj Mahal
After edge detection
High Frequency Taj Mahal
Project Image 1
Sharpened Taj Mahal

Sharpening the GOAT

edge map image
Original Roger Federer Image
Project Image 1
Sharpened Roger Federer

Blurring and Re-Sharpening the GOAT

To test out how good the image sharpening process enhances the quality of an image, let's compare the quality of the original Roger Federer and the Roger Federer image that's first gaussian blurred and then sharpened.

edge map image
Original Roger Federer Image
Before edge detection
Gaussian Blurred and re-sharpened Roger Federer

THE VERDICT: When comparing the original and the blurred-> sharpened versions of the RF images, they are similar, the original image does have more information in the image and is of better quality but the blurred and sharpened image does a good job of getting close.

Hybrid Images

The goal of this part of the assignment is to create hybrid images using the approach described in the SIGGRAPH 2006 paper by Oliva, Torralba, and Schyns. Hybrid images are static images that change in interpretation as a function of the viewing distance. The basic idea is that high frequency tends to dominate perception when it is available, but, at a distance, only the low frequency (smooth) part of the signal can be seen. By blending the high frequency portion of one image with the low-frequency portion of another, you get a hybrid image that leads to different interpretations at different distances.

The algorithm for generating hybrid images is as follows: we first align two images of our choice using the given interactive alignment script. Once we have the two images, we decide which one we want to see up close (High Frequency dominating) and which one we want to see from afar (Low Frequency Dominating). We compute the low frequency filtered and the high frequency filtered images and add them. This gives them the hybrid image. For the purposes of this project, before passing the images to the specific frequency filters, I grey-scaled them (i.e. consisting of only channel). Therefore, even the output was grey-scaled.

Let's go this through this process in detail with the given nutmeg and derek images.

Nutmeg and Derek Hybridization in Detail

Project Image 1
Aligned Nutmeg (aligned on eye position)
Project Image 2
Aligned Derek (aligned on eye position)
Project Image 3
Low Frequency Derek
Project Image 3
High Frequency Nutmeg
Project Image 1
Hybrid Nutmeg-Derek

Roger Federer and Rafael Nadal Hybridization

edge map image
Original Roger Federer Image
Before edge detection
Original Rafael Nadal Image
After edge detection
Hybrid Roger Nadal (Aligned on ears and grey-scaled)

Albert Einstein and Marilyn Monroe Hybridization

edge map image
Original Albert Einstein Image
Before edge detection
Original Marilyn Monroe Image
After edge detection
Hybrid Albert Monroe (Aligned on eyes and grey-scaled)

Let's do a detailed fourier space freqeuncy analysis of the Albert Einstein and Marilyn Monroe Intermediary and Final Images

Project Image 1
Log-magnitude Fourier Transform of original grey-scaled Albert Einstein
Project Image 2
Log-magnitude Fourier Transform of original grey-scaled Marylin Monroe
Project Image 3
Log-magnitude Fourier Transform of grey-scaled low-pass filtered Albert Einstein
Project Image 3
Log-magnitude Fourier Transform of grey-scaled high-pass filtered Marylin Monroe
Project Image 1
Log-magnitude Fourier Transform of grey-scaled hybrid Albert Monroe

Gaussian and Laplacian Stacks

A Gaussian Stack is an array of images, all of the same dimension with downsampling, where each successive image is a gaussian kernel filter convolved result of the previous image.

A Laplacian Stack is again an array of images, all of the same dimension with downsampling, where an image i is obtained by subtracting the (i+1)th image of the Gaussian stack from the ith image. This means each image in this new Laplacian Stack represents different frequency bands of the original image. Below are levels 0, 3, and 6 of the laplacian stacks of the given apple and orange images. 0 => Highest Frequency Band and 6 => Lowest Frequency Band. Please note: During the blending process in the next section, the laplacian stack will also contain the lowest frequency/most blurred image from the gaussian stack as well. This ensures that if we collapse the stack, we retrieve the original image.

Project Image 1
Apple Laplacian Stack Level 0
Project Image 2
Orange Laplacian Stack Level 0
Project Image 1
Apple Laplacian Stack Level 3
Project Image 2
Orange Laplacian Stack Level 3
Project Image 1
Apple Laplacian Stack Level 6
Project Image 2
Orange Laplacian Stack Level 6

Multi-Resolution Image Blending

Now comes the most exciting section of this project. We use the laplacian stacks to blend the image of the apple and the orange to present the oraple. There will also be another fascinating never before seen Tennis Champion reveal.

This is how the process works: we generate a mask (could be a simple horizontal 0-1 mask or a more complicated irregular mask) and create a gaussian stack for it. Now using the mask gaussian stack and the laplacian stacks of the input images, we perform a process illustrated in the image below.

Project Image 1
Blending Process Slide from Lecture. We add all the l_{k}s to arrive at the final blended image.

The Oraple

Project Image 1
Horizontal Mask
Project Image 2
Oraple

The Evolution of a new Wimbledon Champion!

This process blends my face with the image of Roger Federer winning the 2017 Gentlemen's Wimbledon Singles Championship. The process is the almost the same as above. The only difference is that I first align both the images and make them the same dimension, before creating the irregular mask, the gaussian and the laplacian stacks.

Project Image 1
RF Original
Project Image 2
VS Original

Here are the Laplacian Stacks of these images.

Project Image 1
RF Laplacian Stack Level 0
Project Image 2
VS Laplacian Stack Level 0
Project Image 1
RF Laplacian Stack Level 3
Project Image 2
VS Laplacian Stack Level 3
Project Image 1
RF Laplacian Stack Level 6
Project Image 2
VS Laplacian Stack Level 6
Project Image 1
Circular Mask
Project Image 1
The Newest Gentlemen's Wimbledon Singles Champion