interest points
play

Interest Points Computer Vision Jia-Bin Huang, Virginia Tech Many - PowerPoint PPT Presentation

Interest Points Computer Vision Jia-Bin Huang, Virginia Tech Many slides from N Snavely, K. Grauman & Leibe, and D. Hoiem Administrative Stuffs HW 1 posted, due 11:59 PM Sept 25 Submission through Canvas Frequently Asked


  1. Scale invariant detection Suppose you’re looking for corners Key idea: find scale that gives local maximum of f • in both position and scale • One definition of f : the Harris operator

  2. Automatic Scale Selection ′ ′ σ = σ f ( I ( x , )) f ( I ( x , ))   i i i i 1 m 1 m How to find corresponding patch sizes? K. Grauman, B. Leibe

  3. Automatic Scale Selection • Function responses for increasing scale (scale signature) ′ σ σ f ( I ( x , )) f ( I ( x , ))  i i i  i 1 m 1 m K. Grauman, B. Leibe

  4. Automatic Scale Selection • Function responses for increasing scale (scale signature) ′ σ σ f ( I ( x , )) f ( I ( x , ))  i i i  i 1 m 1 m K. Grauman, B. Leibe

  5. Automatic Scale Selection • Function responses for increasing scale (scale signature) ′ σ σ f ( I ( x , )) f ( I ( x , ))  i i i  i 1 m 1 m K. Grauman, B. Leibe

  6. Automatic Scale Selection • Function responses for increasing scale (scale signature) ′ σ σ f ( I ( x , )) f ( I ( x , ))  i i i  i 1 m 1 m K. Grauman, B. Leibe

  7. Automatic Scale Selection • Function responses for increasing scale (scale signature) ′ σ σ f ( I ( x , )) f ( I ( x , ))  i i i  i 1 m 1 m K. Grauman, B. Leibe

  8. Automatic Scale Selection • Function responses for increasing scale (scale signature) ′ σ ′ σ f ( I ( x , )) f ( I ( x , )) i  i i  i 1 m 1 m K. Grauman, B. Leibe

  9. Implementation • Instead of computing f for larger and larger windows, we can implement using a fixed window size with a Gaussian pyramid (sometimes need to create in- between levels, e.g. a ¾-size image)

  10. What Is A Useful Signature Function? • Difference-of-Gaussian = “blob” detector K. Grauman, B. Leibe

  11. Difference-of-Gaussian (DoG) = - K. Grauman, B. Leibe

  12. DoG – Efficient Computation • Computation in Gaussian scale pyramid Sampling with step σ 4 =2 σ σ σ 1 σ = 2 4 Original image σ K. Grauman, B. Leibe

  13. Find local maxima in position-scale space of Difference-of-Gaussian σ 5 σ 4 σ + σ L ( ) L ( ) σ 3 xx yy σ 2 ⇒ List st o of (x, x, y y, , s) σ K. Grauman, B. Leibe

  14. Results: Difference-of-Gaussian K. Grauman, B. Leibe

  15. Orientation Normalization [Lowe, SIFT, 1999] • Compute orientation histogram • Select dominant orientation • Normalize: rotate to fixed orientation 2 π 0 T. Tuytelaars, B. Leibe

  16. Maximally Stable Extremal Regions [Matas ‘02] • Based on Watershed segmentation algorithm • Select regions that stay stable over a large parameter range K. Grauman, B. Leibe

  17. Example Results: MSER 73 K. Grauman, B. Leibe

  18. Available at a web site near you… • For most local feature detectors, executables are available online: – http://www.robots.ox.ac.uk/~vgg/research/affine – http://www.cs.ubc.ca/~lowe/keypoints/ – http://www.vision.ee.ethz.ch/~surf K. Grauman, B. Leibe

  19. Two minutes break

  20. Local Descriptors • The ideal descriptor should be – Robust – Distinctive – Compact – Efficient • Most available descriptors focus on edge/gradient information – Capture texture information – Color rarely used K. Grauman, B. Leibe

  21. Scale Invariant Feature Transform Basic idea: • Take 16x16 square window around detected feature • Compute edge orientation (angle of the gradient - 90 ° ) for each pixel • Throw out weak edges (threshold gradient magnitude) • Create histogram of surviving edge orientations 2 π 0 angle histogram Adapted from slide by David Lowe

  22. SIFT descriptor Full version • Divide the 16x16 window into a 4x4 grid of cells (2x2 case shown below) • Compute an orientation histogram for each cell • 16 cells * 8 orientations = 128 dimensional descriptor Adapted from slide by David Lowe

  23. Local Descriptors: SIFT Descriptor Histogram of oriented gradients • Captures important texture information • Robust to small translations / affine deformations [Lowe, ICCV 1999] K. Grauman, B. Leibe

  24. Details of Lowe’s SIFT algorithm • Run DoG detector – Find maxima in location/scale space – Remove edge points • Find all major orientations – Bin orientations into 36 bin histogram • Weight by gradient magnitude • Weight by distance to center (Gaussian-weighted mean) – Return orientations within 0.8 of peak • Use parabola for better orientation fit • For each (x,y,scale,orientation), create descriptor: – Sample 16x16 gradient mag. and rel. orientation – Bin 4x4 samples into 4x4 histograms – Threshold values to max of 0.2, divide by L2 norm – Final descriptor: 4x4x8 normalized histograms Lowe IJCV 2004

  25. SIFT Example sift 868 SIFT features

  26. Feature matching Given a feature in I 1 , how to find the best match in I 2 ? 1. Define distance function that compares two descriptors 2. Test all the features in I 2 , find the one with min distance

  27. Feature distance How to define the difference between two features f 1 , f 2 ? • Simple approach: L 2 distance, ||f 1 - f 2 || • can give good scores to ambiguous (incorrect) matches f 1 f 2 I 1 I 2

  28. Feature distance How to define the difference between two features f 1 , f 2 ? • Better approach: ratio distance = ||f 1 - f 2 || / || f 1 - f 2 ’ || • f 2 is best SSD match to f 1 in I 2 f 2 ’ is 2 nd best SSD match to f 1 in I 2 • • gives large values for ambiguous matches ' f 1 f 2 f 2 I 1 I 2

  29. Feature matching example 51 matches

  30. Feature matching example 58 matches

  31. Evaluating the results How can we measure the performance of a feature matcher? 50 75 200 feature distance

  32. True/false positives How can we measure the performance of a feature matcher? 50 true match 75 200 false match feature distance The distance threshold affects performance • True positives = # of detected matches that are correct • Suppose we want to maximize these—how to choose threshold? • False positives = # of detected matches that are incorrect • Suppose we want to minimize these—how to choose threshold?

  33. Evaluating the results How can we measure the performance of a feature matcher? 1 0.7 true # true positives positive # correctly matched features (positives) rate “recall” 0 1 0.1 false positive rate # false positives # incorrectly matched features (negatives) 1 - “precision”

  34. Evaluating the results How can we measure the performance of a feature matcher? ROC curve (“Receiver Operator Characteristic”) 1 0.7 true # true positives positive # correctly matched features (positives) rate “recall” 0 1 0.1 false positive rate # false positives # incorrectly matched features (negatives) 1 - “precision”

  35. Matching SIFT Descriptors • Nearest neighbor (Euclidean distance) • Threshold ratio of nearest to 2 nd nearest descriptor Lowe IJCV 2004

  36. SIFT Repeatability Lowe IJCV 2004

  37. SIFT Repeatability

  38. SIFT Repeatability Lowe IJCV 2004

  39. Local Descriptors: SURF • Fast approximation of SIFT idea  Efficient computation by 2D box filters & integral images ⇒ 6 times faster than SIFT  Equivalent quality for object identification • GPU implementation available Feature extraction @ 200Hz Many other efficient descriptors  are also available (detector + descriptor, 640×480 img) http://www.vision.ee.ethz.ch/~surf  [Bay, ECCV’06], [Cornelis, CVGPU’08] K. Grauman, B. Leibe

  40. Local Descriptors: Shape Context Count the number of points inside each bin, e.g.: Count = 4 ... Count = 10 Log-polar binning: more precision for nearby points, more flexibility for farther points. Belongie & Malik, ICCV 2001 K. Grauman, B. Leibe

  41. Local Descriptors: Geometric Blur Compute edges at four orientations Extract a patch in each channel ~ Apply spatially varying blur and sub-sample Example descriptor (Idealized signal) Berg & Malik, CVPR 2001 K. Grauman, B. Leibe

  42. Choosing a detector • What do you want it for? – Precise localization in x-y: Harris – Good localization in scale: Difference of Gaussian – Flexible region shape: MSER • Best choice often application dependent – Harris-/Hessian-Laplace/DoG work well for many natural categories – MSER works well for buildings and printed things • Why choose? – Get more points with more detectors • There have been extensive evaluations/comparisons – [Mikolajczyk et al., IJCV’05, PAMI’05] – All detectors/descriptors shown here work well

  43. Comparison of Keypoint Detectors Tuytelaars Mikolajczyk 2008

  44. Choosing a descriptor • Again, need not stick to one • For object instance recognition or stitching, SIFT or variant is a good choice

Recommend


More recommend