Project 4

IMAGE WARPING and MOSAICING

Part A

Shoot the Pictures

Part A of this assignment consist of two tasks. The first part is about performing rectification of images. I used three different images capturing different shapes (two different rectangular shapes and one quadratic) The pictures were also taken from different angles. The images used for rectification are shown below:

picture
Quadratic picture.
remarkable
Picture of a Remarkable with rectangular shape.
drawing
Picture of a drawing of a smileyface with rectangular shape.

The second part of part A is about blending images into a mosaic. For this part, I used two images of the front of the International House to create one mosaic, two images of the side of the International House to create another mosaic, and two images of Hilgard Hall on campus to create a third mosaic. When taking the images, it is important that the center of projection are the same for all images that are blended into the same mosaic. Also, the images in this task should overlap by 40% to 70%. The images used for the mosaic are shown below:

picture
Picture 1 of the front of International House.
remarkable
Picture 2 of the front of International House.
drawing
Picture 1 of the side of International House.
drawing
Picture 2 of the side of International House.
drawing
Picture 1 of Hilgard Hall.
drawing
Picture 2 of Hilgard Hall.

Recover Homographies

Rectification involves warping an image that contains a known shape, such as a rectangle, which may appear distorted when projected onto a 2D image. The goal is to map this distorted shape back onto a reference frame where it is correctly aligned, for example, mapping the corners of a distorted rectangle to the points [0,0], [1,0], [1,1], [0,1] which define a square or rectangle. This process is achieved using homography, a transformation that relates the distorted shape in the image to the reference shape. To apply homography, we need to compute the homography matrix by solving a set of equations based on point correspondences between the distorted shape and the reference frame. The homography matrix allows us to warp the image so that the shape appears undistorted and aligned as expected. The set of equations are shown here:

\[ \begin{bmatrix} wx' \\ wy' \\ w \end{bmatrix} = \begin{bmatrix} a & b & c \\ d & e & f \\ g & h & i \end{bmatrix} \begin{bmatrix} x \\ y \\ 1 \end{bmatrix} \]

we can set 𝑖=1 because homographies are defined up to a scale, meaning the transformation remains valid if the entire matrix is scaled by a constant factor. By setting 𝑖=1, we normalize the matrix, reducing the degrees of freedom from 9 to 8. That means we need 8 equations to solve the equations and obtain the matrix. To get these 8 equations, we can manually click on 4 corresponding points on the two images we are using. This yields 8 equaitons since each point contains one x and one y value. However, with only 4 points, the system becomes very sensitive to noise. It is therefore better to use more than 4 points, which yields an overdetermined system. In such cases, we cannot solve the system exactly, but we can find an approximate solution using least squares optimization, which is what I did.

Warp the Images

With the homography matrix, we can now warp an image onto another image plane. To do this I used inverse warping, where I mapped from the new image plane we are warping onto back to the original image using the inverse of the homography matrix. I then used bilinear interpolation when pixels where mapped between pixels in the original image. To perform the inverse warping we first need to make an empty image, and then we need to know which size the image is going to get. This is done by warping the corners of the original image onto the other image plane.

Image Rectification

When we have the image warping funcition, we can test it by performing image rectification. To do this we need to know the actual shape of the rectangulars, and then use this shape as the image plane we are warping the images onto. This was done on the three images shown above. The results are shown below:

picture
Quadratic picture rectified.
remarkable
Remarkable rectified.
drawing
Drawing rectified.

The result was good, as we can see that all three images unnderwent a correct "rectification". However we can also see from the drawing that the interpolation is not perfect, as the smileeyface is not completely recovered. However, since the lines on the smileyface is very thin, I think this is acceptable.

Blend the images into a mosaic

Now that we have confirmed that the homography work as it should, and that it is possible to war an image onto another image plane, it is time to blend images into a mosaic. This was done on the two images of the front of the International House, the two images of the side of the International House, and the Hilgard Hall. Since the images overlap by 40%-70%, we need to blend the images where they intersect. I did this by finding the intersection of the two images, and then make a mask that linearly increases from left to right on the intersected area. This means that the left side of the intersection is 100% the first image, and the right side is 100% the second image. The results are shown below:

picture
Mosaic of the front of International House.
remarkable
The bledning mask that was used to blend the two images of the front of International House
drawing
Mosaic of the side of International House.
drawing
The blending mask that was used to blend the two images of the side of International Houses.
drawing
Mosaic of the Hilgard Hall.
drawing
The blending mask that was used to blend the two images of the Hilgard Hall.

The results were good, and I thought it was really cool and satisfying to see that the mosic looks so smooth.

Part B

Part B of the assignment is about creating the same mosaics as in part A, but this time do everything automatically. This means that we have to make a program that automatically finds matching features in the two images, and uses these features to perform the homography transformation. This process is split into 6 smaller steps:

Part B, step 1:

The first part of feature matchin is about doing corner detection. We want to find corners and use them as features as they are easy to match between images. I used the Harris corner detector to find corners in the images by utilizing the functions that were provided in the assignement. The resulting Harris corners for the images of the Hilgard Hall are shown below:

drawing
Front of the Hilgard Hall with the Harris corners marked.
drawing
Front of the Hilgard Hall with the Harris corners marked.

Ideally, we would want to have features that are spread apart from each other. Features that are close provide redundant information, and are proun to the same noise. To reduce the amount of features in a way that makes sure the features are spread apart, we can use Adaptive Non-Maximal Suppression (ANMS). ANMS iteratively searches through all the neighbours for all the feature-points, and then removes the points that are not at least a factor of c times as strong of a corner as its strongest neighbour. I used a c-value of 0.9, as reccomended by the paper. For each iterate, the radius increases, until we are left with the desired amount of features, in this case 100. The remaining corners after ANMS are shown below:

drawing
Front of the Hilgard Hall with the remaining Harris corners after ANMS.
drawing
Side of the Hilgard Hall with the remaining Harris corners after ANMS.

Part B, step 2:

To be able to match features from the two pictures, we need to store some information about the features. The information we choose to store is a 8x8 patches of nearby pixels. Each of the pixels are 5 pixels away from each other, which means we are effectively storing a 40x40 patch of nearby pixels. Since we are now sampling the image, we need to make sure that we avoid Aliasing by complying with the Nyquist-Shannon sampling theorem. This means that we need to make sure that the sampling rate is at least twice the highest frequency in the image. This is done by using a Gaussian filter with a sigma value given by the following formula:

Nyquist Cutoff = 1 / (2 × Sampling Frequency)

σ = 1 / (2 × π × Nyquist Cutoff)

and then do the sampling on the blurred image.

Part B, step 3:

Now that we have a description for each feature, it is time to match the features. For each feature, we look at the distance between the feature's description and all the feature descriptions in the other image. We then collect the closest and the second closest features, and calculate the ratio between the two distances. All features that have a ratio below a certian threshold (I used 0.5) are considered a match. The matching features are shown below:

drawing
Matching features in the two images of the Hilgard Hall.

Part B, step 4:

Altough this trick helped with removing outliers, we still have some outliers left. To remove the final outliers, we use an algorithm called RANSAC. RANSAC iteratively selects four random matches, and creates an homography transformation based on those four matches. It then performs an homography transformation of one image onto the other, and looks at the distance between the remaining featurs. All the features that are within the distance of a certain threshold (I used 5), are considered inliers for this specific transformation. After a certain number of iterations (I used 1000), we extract the outliers that are counted as an inlier the most times. I saved the 12 best inliers. The inliers for the Hilgard Hall are shown below:

drawing
Remaning matches after running the RANSAC algorithm on the Hilgard Hall.

Part B, step 5:

Now that we are left with features that all match, it is time to perform the warping to create the MOSAIC's. This is done in the same way as in part A, but this time we use the automatically extracted features instead of manually extracted features. The results are shown below, with the manually and automatically stiched images side by side:

picture
Mosaic of the Hilgard Hall, features extracted manually.
remarkable
Mosaic of the Hilgard Hall, features extracted automatically.
drawing
Mosaic of the front of International House, features extracted manually.
drawing
Mosaic of the front of International House, features extracted automatically.
drawing
Mosaic of the side of International House, features extracted manually.
drawing
Mosaic of the side of International House, features extracted automatically.

The resulting mosaics were almost identical, but the image of the International House from the side is slightly less blurry on the automatic mosiac. This mean that the automatic feature extraction was just as good, and even a little better than the manual feature extraction. Awesome!

What did I learn?

I generally learned a lot in this assignment, and I thought it was both very interesting and satisfying, as the results were really good. If I were to pick one thing that was the coolest to learn, I would say the RANSAC algorithm. The algorithm is very intuitive, but distinguishes from many other algorithms/methods used in this assignment and course in general, because it is not theoretically possible to prove that it is going to work. If someone would have suggested this algorithm to me without showing any results, I would be unsure wheter it would actually work good or not, because you select random points to use as base for homography, meaning that some of the iterations are going to count "bad" inliers. However, the algortihm worked really well!