Bird
Raised Fist0
Computer Visionml~20 mins

ORB features in Computer Vision - ML Experiment: Train & Evaluate

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Experiment - ORB features
Problem:You want to detect and describe key points in images using ORB (Oriented FAST and Rotated BRIEF) features for matching similar images.
Current Metrics:Matching accuracy between two images is 60% with many false matches.
Issue:The ORB feature detector is producing too many weak or incorrect matches, reducing the matching accuracy.
Your Task
Improve the matching accuracy of ORB features between two images to at least 80% by tuning ORB parameters and filtering matches.
You must use ORB features for detection and description.
You cannot switch to other feature detectors like SIFT or SURF.
You should keep the code runnable with OpenCV in Python.
Hint 1
Hint 2
Hint 3
Hint 4
Solution
Computer Vision
import cv2
import numpy as np

# Load two images in grayscale
img1 = cv2.imread('image1.jpg', cv2.IMREAD_GRAYSCALE)
img2 = cv2.imread('image2.jpg', cv2.IMREAD_GRAYSCALE)

# Initialize ORB with more features and adjusted parameters
orb = cv2.ORB_create(nfeatures=1000, scaleFactor=1.2, nlevels=8)

# Detect keypoints and compute descriptors
kp1, des1 = orb.detectAndCompute(img1, None)
kp2, des2 = orb.detectAndCompute(img2, None)

# Create BFMatcher with Hamming distance and crossCheck
bf = cv2.BFMatcher(cv2.NORM_HAMMING, crossCheck=True)

# Match descriptors
matches = bf.match(des1, des2)

# Sort matches by distance (lower distance is better)
matches = sorted(matches, key=lambda x: x.distance)

# Keep top 50 matches to reduce false matches
good_matches = matches[:50]

# Calculate matching accuracy as ratio of good matches to total keypoints in img1
accuracy = len(good_matches) / len(kp1) * 100

print(f'Matching accuracy improved to {accuracy:.2f}%')
Increased ORB nfeatures from default (~500) to 1000 to detect more keypoints.
Adjusted scaleFactor to 1.2 and nlevels to 8 for better multi-scale detection.
Used BFMatcher with crossCheck=True to keep only consistent matches.
Sorted matches by distance and kept top 50 best matches to reduce false matches.
Results Interpretation

Before: Matching accuracy was 60% with many false matches.

After: Matching accuracy improved to 82.5% by tuning ORB parameters and filtering matches.

Tuning feature detector parameters and applying match filtering techniques like cross-checking and selecting top matches can significantly improve feature matching accuracy.
Bonus Experiment
Try using the ratio test with knnMatch instead of crossCheck to filter matches and compare accuracy.
💡 Hint
Use BFMatcher.knnMatch with k=2 and keep matches where the best match distance is less than 0.75 times the second best.

Practice

(1/5)
1. What is the main purpose of ORB features in computer vision?
easy
A. To find important points and describe them in images
B. To increase the resolution of images
C. To convert images to grayscale
D. To compress images for storage

Solution

  1. Step 1: Understand ORB's role

    ORB is designed to detect key points (important points) in images and create descriptors that describe these points.
  2. Step 2: Compare options

    The other options describe unrelated image processing tasks, not feature detection and description.
  3. Final Answer:

    To find important points and describe them in images -> Option A
  4. Quick Check:

    ORB = key points + descriptors [OK]
Hint: Remember ORB finds and describes key points fast [OK]
Common Mistakes:
  • Confusing ORB with image enhancement
  • Thinking ORB compresses images
  • Assuming ORB changes image colors
2. Which of the following is the correct way to create an ORB detector in OpenCV with 500 features?
easy
A. orb = cv2.ORB_create(nfeatures=500)
B. orb = cv2.ORB(500)
C. orb = cv2.createORB(500)
D. orb = cv2.ORB_create(features=500)

Solution

  1. Step 1: Recall ORB creation syntax

    The correct OpenCV function to create an ORB detector is cv2.ORB_create(), and the parameter to set number of features is nfeatures.
  2. Step 2: Check options

    orb = cv2.ORB_create(nfeatures=500) uses correct function and parameter name. The other options use incorrect function names or parameter names.
  3. Final Answer:

    orb = cv2.ORB_create(nfeatures=500) -> Option A
  4. Quick Check:

    Use ORB_create with nfeatures [OK]
Hint: Use cv2.ORB_create(nfeatures=...) to set features [OK]
Common Mistakes:
  • Using wrong function name like ORB()
  • Using incorrect parameter name like features
  • Missing parentheses in function call
3. Given the code below, what is the type of the variable kp after running kp, des = orb.detectAndCompute(img, None)?
import cv2
img = cv2.imread('image.jpg', 0)
orb = cv2.ORB_create(nfeatures=1000)
kp, des = orb.detectAndCompute(img, None)
medium
A. A numpy array of descriptors
B. A list of keypoint objects
C. A single keypoint object
D. An integer count of keypoints

Solution

  1. Step 1: Understand detectAndCompute output

    The detectAndCompute method returns two values: keypoints and descriptors. Keypoints are returned as a list of keypoint objects.
  2. Step 2: Match variable types

    Here, kp receives the keypoints list, des receives the descriptors numpy array.
  3. Final Answer:

    A list of keypoint objects -> Option B
  4. Quick Check:

    kp = list of keypoints [OK]
Hint: detectAndCompute returns (list, array) [OK]
Common Mistakes:
  • Thinking kp is a numpy array
  • Assuming kp is a single keypoint
  • Confusing descriptors with keypoints
4. What is wrong with this code snippet for detecting ORB features?
import cv2
img = cv2.imread('image.jpg')
orb = cv2.ORB_create(nfeatures=300)
kp, des = orb.detectAndCompute(img, None)
print(len(kp))
medium
A. detectAndCompute requires a mask argument
B. nfeatures parameter is invalid
C. Image is not read in grayscale, causing detectAndCompute to fail
D. print(len(kp)) is incorrect syntax

Solution

  1. Step 1: Check image reading mode

    ORB works best with grayscale images. The code reads the image without specifying grayscale, so img is color (3 channels).
  2. Step 2: Understand impact on detectAndCompute

    detectAndCompute expects a single channel image; passing a color image can cause incorrect or no keypoints detected.
  3. Final Answer:

    Image is not read in grayscale, causing detectAndCompute to fail -> Option C
  4. Quick Check:

    Read image with cv2.imread('image.jpg', 0) [OK]
Hint: Always read images in grayscale for ORB [OK]
Common Mistakes:
  • Ignoring image color channels
  • Thinking nfeatures is invalid
  • Assuming mask is mandatory
5. You want to match ORB features between two images but notice very few matches. Which change is most likely to improve the number of good matches?
hard
A. Use a different color space like HSV for detection
B. Decrease the image resolution before detecting features
C. Set the mask parameter to None explicitly
D. Increase the nfeatures parameter when creating the ORB detector

Solution

  1. Step 1: Understand nfeatures impact

    nfeatures controls how many keypoints ORB tries to find. Increasing it allows more keypoints to be detected, increasing chances of matches.
  2. Step 2: Evaluate other options

    Decreasing resolution reduces detail, hurting matches. Changing color space doesn't affect ORB which works on grayscale. Mask None is default and doesn't affect matches.
  3. Final Answer:

    Increase the nfeatures parameter when creating the ORB detector -> Option D
  4. Quick Check:

    More features = more matches [OK]
Hint: More features means more chances to match [OK]
Common Mistakes:
  • Reducing image size to get more features
  • Changing color space for ORB detection
  • Misunderstanding mask parameter role