Stitching multiple images from surrounding area to generate its unbroken view called as "panorama"
Flow of the approach is as shown in figure below.
I) Keypoints identification Extract features using SIFT: Features that best matches in both the images are obtained using SIFT. The best matched features act as the basis for stitching. Find keypoints and descriptors:The keypoints and descriptors for the images are then extracted to be stitched using SIFT detector.
II) Matching descriptors (Bfmatcher and KNN match) BFmatcher matches the most similar features and knnMatcher with k=2 gives 2 best matches for each descriptor. Some features that may be existing in many places of the image can mislead future operations. So, all the matches are filtered out to obtain the best ones by applying ratio test. Hamming distance is used as a measure of similarity between two feature descriptors.
III) Finding homography Homography is a transformation that maps the points in one image to the corresponding points in the other image. A homography matrix is needed to perform the transformation and requires atleast 4 matches. It utilizes a robust estimation technique called Random Sample Consensus (RANSAC) which produces the right result even in the presence of large number of bad matches.
IV) Warping Once an accurate homography has been calculated, the transformation can be applied to all pixels in one image to map it to the other image. This is done using the warpPerspective function in OpenCV.
V) Triming (Removing undesired portion) Small portion from right of stitched image are trimed and cropped to remove the undesired black portion obtained after stitching.
Intermediate results
Final results