1 Take Photos
Take two photos of a scene with a camera. The photos should have some overlap between them.
All these pictures are taken with only a planar rotation of the phone with the COF not changing position (the best I can...)
data:image/s3,"s3://crabby-images/a007c/a007ccbbed018300e7fe04d751bd435ed1383ee9" alt="ball_left"
Ball Left
data:image/s3,"s3://crabby-images/56fff/56fffd05413ea5602d487c79436d7876de895f7c" alt="ball_right"
Ball Right
data:image/s3,"s3://crabby-images/1dcc4/1dcc4a52dc03d064ac95859c8d2b0815fc4c24ab" alt="build_left"
Build Left
data:image/s3,"s3://crabby-images/4ac41/4ac41724d4de1f05a5e7fb2f7977d996022bc927" alt="build_right"
Build Right
data:image/s3,"s3://crabby-images/a11bc/a11bc3917c75f0650351a628dfbd26f3e29ba20f" alt="garden_left"
Garden Left
data:image/s3,"s3://crabby-images/8f242/8f242a3436f905e88e1268cd5679ff47321325ec" alt="garden_right"
Garden Right
2 Recover Homography
- Definition: A homography is a transformation that maps points from one plane to another, typically used in image processing for tasks like image alignment and stitching.
- Use Case: The matrix represents a projective transformation, which preserves straight lines but not necessarily angles or lengths.
- Equation: The transformation is defined by eight parameters, computed by solving a system of linear equations using corresponding points from two images.
3 Warp and Rectification
- Use either forward or inverse warping and avoid aliasing during resampling.
- Consider using
scipy.interpolate.griddata
for a vectorized solution. - Predict the bounding box of the resulting image and manage unfilled pixels using an alpha mask.
- Here are some rectification result. With hand-written, known desination size.
Kindle
data:image/s3,"s3://crabby-images/d2e86/d2e865a417d9b8db03486fec42a116877e4f4f93" alt="kindle_rectified"
Kindle Rectified
Cp
data:image/s3,"s3://crabby-images/7e339/7e33941301b6614ad906dfd77836906057b29837" alt="cp_rectified"
Cp Rectified
data:image/s3,"s3://crabby-images/efc9e/efc9e085ed6cae07a2a4440de18430a456bbcc11" alt="cp2"
Cp2
data:image/s3,"s3://crabby-images/39b05/39b052790582f301a9e0a17b14da73a105c8a556" alt="cp2_rectified"
Cp2 Rectified
4 Stitch and Blend
- Blend images into a mosaic using weighted averaging to avoid strong edge artifacts.
- Warp the images so they’re registered and choose to warp into a reference projection or a new one.
- Manage blending by using an alpha channel and consider using a Laplacian pyramid for blending if needed.
- Naive blending would have huge artifects of seaming lines, so we adopt a distance transform with alpha blending.
data:image/s3,"s3://crabby-images/75342/75342ba9acdea886ec6d0d0a380d0af87db22ccf" alt="ball_mask_1"
ball_mask_1
data:image/s3,"s3://crabby-images/e9baf/e9baf3e2231e3507a005f95cddc0b1b3b9deddae" alt="ball_mask_2"
ball_mask_2
data:image/s3,"s3://crabby-images/c1771/c1771258cd2f53da43e044f1eeb07ce7c60da27b" alt="ball_blended"
ball_blended
data:image/s3,"s3://crabby-images/1a37d/1a37d853be9fe95f21236eebe99c783063dbf85d" alt="build_blended"
build_blended
data:image/s3,"s3://crabby-images/00ead/00ead780495dd22a3befdd21d2c9ad4d9adb34eb" alt="garden_blended"
garden_blended
5 Detect Corner Features: Harris Corners
- Use Harris Corner Detector:
- Use the provided
harris.py
to detect corners in the image. - Configure parameters, if needed, to detect sufficient feature points for stitching (default settings may suffice).
- Use the provided
- Overlay Harris Corners:
- After detecting corners, overlay them on the original image to visualize detected points.
- Save this visualization as an image for later comparison.
- Directly Applying the Harris.py would results in the following images, where corners are too many and not very well disctributed.
data:image/s3,"s3://crabby-images/9a8df/9a8dffd115f8b9a72090e8be038255aa456deb05" alt="garden_left_with_harris_corners"
garden_left_with_harris_corners
data:image/s3,"s3://crabby-images/87c8c/87c8c222256985e4b5cd3833c7c3f2eb25212f2d" alt="garden_right_with_harris_corners"
garden_right_with_harris_corners
6 Adaptive Non-Maximal Suppression (ANMS)
- How do we deal with the previous problem?
- Focus on the adaptive non-maximal suppression algorithm to understand how it achieves a uniform distribution of features.
- Implement ANMS:
- For each detected corner, calculate the Harris corner strength.
- Initialize a suppression radius
r = 0
and iteratively increaser
until only a fixed number of feature points remain (as specified in the task, 800 points). - For each feature, find the minimum radius
r_i
such that no other point with significantly higher corner strength lies within radiusr_i
.
- Visualize and Save:
- Overlay the ANMS-selected corners on the original image.
- Save this result to compare with the Harris-only detection result.
data:image/s3,"s3://crabby-images/b1ae7/b1ae7d0e34d5dc0cc1884c3ebe9e0ae0ab041409" alt="garden_left_ANMS"
garden_left_ANMS
data:image/s3,"s3://crabby-images/7c3db/7c3db45209d219eee310f4cf5bab9fa8bcd8853a" alt="garden_right_ANMS"
garden_right_ANMS
7 Extract Feature Descriptors!
- Extract 8x8 Patches (Section 4):
- For each corner detected in Step 2, extract an 8x8 patch of pixels centered on the corner.
- Sample this 8x8 patch from a larger 40x40 region around each feature point to gain spatial context.
- Normalize Descriptors:
- Apply bias/gain normalization to make the descriptor invariant to intensity changes.
- Normalize each descriptor so that the mean intensity is 0 and the standard deviation is 1.
- Skip Rotational Invariance:
- For simplicity, avoid rotation adjustments; just extract axis-aligned patches as specified.
![test_descriptor1[0]](src/7/descriptor.png)
test_descriptor1[0]
8 Feature Matching
- Nearest Neighbot with Lowe's Trick
- For each feature descriptor in image A, find the nearest (most similar) descriptor in image B using Euclidean distance.
- Use the nearest-neighbor ratio test proposed by Lowe:
- Calculate the ratio of the distance to the nearest neighbor to that of the second-nearest neighbor.
- Select matches where this ratio is below a certain threshold (refer to the figure in the paper for threshold estimation).
- Filter Matches:
- Retain only pairs that satisfy the threshold criterion, reducing incorrect matches.
- Save Matched Pairs for Visualization:
- Optionally, overlay lines on an image to indicate the matched feature points between the two images.
data:image/s3,"s3://crabby-images/8bb8a/8bb8adb683b39d3b8dc821ce32a3d48f6dbda7d8" alt="ball_match_features"
ball_match_features
data:image/s3,"s3://crabby-images/3f1a1/3f1a17435e1502ef423671bac26defbf58ba1124" alt="build_match_features"
build_match_features
data:image/s3,"s3://crabby-images/7b97d/7b97d1ecfa6d2b4f65055eb045f5a10ccb884207" alt="garden_match_features"
garden_match_features
9 RANSAC
- Select Four Points for Homography:
- Implement a RANSAC-based approach to find the best homography matrix.
- Randomly select four matched feature pairs, compute the homography, and calculate the transformation matrix.
- Iterate and Select Best Homography:
- Run multiple RANSAC iterations to refine the homography matrix, minimizing re-projection errors.
- Discard outliers to ensure robust homography estimation.
data:image/s3,"s3://crabby-images/a0d7f/a0d7ff106b122cc1758123c9241d1b033119dabc" alt="ball_ransac_matches"
ball_ransac_matches
data:image/s3,"s3://crabby-images/dd580/dd58037604a299c91e20d28fe1bad78b188c6f20" alt="build_ransac_matches"
build_ransac_matches
data:image/s3,"s3://crabby-images/8d2bc/8d2bc0dca84599fdd530d2406a571bf95c760561" alt="garden_ransac_matches"
garden_ransac_matches
10 Final Auto-blending Results
data:image/s3,"s3://crabby-images/c1771/c1771258cd2f53da43e044f1eeb07ce7c60da27b" alt="ball_blended"
ball_blended
data:image/s3,"s3://crabby-images/f9d47/f9d47dc2b34b028f7f0f99cd305c24d801484f3a" alt="ball_auto_blended"
ball_auto_blended
data:image/s3,"s3://crabby-images/1a37d/1a37d853be9fe95f21236eebe99c783063dbf85d" alt="ball_blended"
build_blended
data:image/s3,"s3://crabby-images/4ad1b/4ad1b98b07cb9dc7307921927c8a49a8dffbf197" alt="ball_auto_blended"
build_auto_blended
data:image/s3,"s3://crabby-images/00ead/00ead780495dd22a3befdd21d2c9ad4d9adb34eb" alt="garden_blended"
garden_blended
data:image/s3,"s3://crabby-images/24ca3/24ca3ef1718ff032a1415521dc388cc3261a4a12" alt="garden_auto_blended"
garden_auto_blended