In this project, I implemented image alignment using two metrics: Sum of Squared Differences (SSD) and Normalized Cross-Correlation (NCC).
The goal was to align images based on these metrics and improve alignment using a coarse-to-fine pyramid approach.
2. Methodology
The initial steps were as follows:
Preprocessing: Read in the image file as double and seperate the RGB channels.
Aligning: (a) Align the Green and Red channels to the Blue channel using either SSD (squared Euclidean distance)
or NCC (normalized dot product) as the score metric.
(b) Iteratively search in a ±15×15 window for the displacement with the best score.
(c) Shift the channel with that displacement.
Colorizing: Stack the shifted Green and Red channels and stack them on top of the Blue channel.
Finishing: Save the colored image file and display it for visual inspection.
Some improvements made:
For Preprocessing: Crop the borders of the images to elimate irrelevant black and white edges.
For Aligning: Implement a pyramid approach by downsampling to handle large images efficiently.
For Colorizing: Change the base channel from Blue to Green for better reference.
3. Results
3.1 Naive Implementation Results
3.1 Optimized Implementation Results
4. Conclusion
In conclusion, the image alignment was successfully implemented using both SSD and NCC metrics. The coarse-to-fine pyramid approach
provided a significant speedup for large images. Cropping the images helped in eliminating border artifacts that could affect the alignment process.
And aligning to different channels avoided the interference of emir's blue clothes.