Top Banner
3/30/15 1 Introduction to Grouping: The Hough Transform CS 510 Lecture #18 March 30, 2015 Recall - Hierarchy of Features (e.g. Szeliski’s book) • Edges • Corners • Chains Line segments Parameterized curves • Regions Surface patches Closed Polygons 3/30/15 2 CS 510, Image Computa4on, ©Ross Beveridge & Bruce Draper
10

Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

Jan 23, 2021

Download

Documents

dariahiddleston
Welcome message from author
This document is posted to help you gain knowledge. Please leave a comment to let me know what you think about it! Share it to your friends and learn new things together.
Transcript
Page 1: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

1  

Introduction to Grouping: The Hough Transform

CS 510 Lecture #18

March 30, 2015

Recall - Hierarchy of Features (e.g. Szeliski’s book)

•  Edges •  Corners •  Chains •  Line segments •  Parameterized curves •  Regions •  Surface patches •  Closed Polygons

3/30/15   2  CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper  

Page 2: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

2  

Hierarchical Feature Extraction •  Most features are extracted by combining a

small set of primitive features (edges, corners, regions) – Grouping: which pixels should group? – Model Fitting: what structure describes group?

•  Simple example: The Hough Transform – Groups points into lines –  (patented in 1962)

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   3  

Hough Transform: Grouping •  The idea of the Hough transform is that a change in

representation converts a point grouping problem into a peak detection problem.

•  Standard line representations: –  y = mx + b -- compact, but problems with vertical

lines –  (x0, y0) + t(x1, y1) -- your raytracer used this form, but

it is highly redundant (4 free parameters) –  ax + by + c = 0 -- Bresenham’s uses this form. Still

redundant (3 free parameters) •  How else might you represent a line?

3/30/15   4  CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper  

Page 3: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

3  

Hough Grouping (cont.) •  Represent infinite lines as (φ,ρ):

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   5  

ρ

φ

Hough Grouping (III) •  Why? This representation is:

–  Small: only two free parameters (like y=mx+b) –  Finite in all parameters : 0 <= ρ< √(row2+col2), 0 <= φ

< 2π –  Unique: only one representation per line

•  General Idea: –  Hough space (φ,ρ) represents all possible lines –  Next step - use discrete Hough space –  Let every point “vote for” any line is might belong to.

3/30/15   6  CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper  

Page 4: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

4  

•  Every edge has a location and position, so it can be part of only one (infinitely extended) line.

•  Co-linear edges map to one bucket in Hough space.

Hough Grouping: Directed Edges

φ

ρ

3/30/15   7  CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper  

Hough Grouping: Edges •  Reduces line grouping to peak detection

– Each edge votes for a bucket (line) –  # of votes equates to support

•  The # of participating edges. – Position of bucket provides the φ, ρ parameters

•  Problem: if “true” line parameters are on the boundary of a bucket, supporting data may be split

•  Solution: smooth the histogram (Hough image) before selecting peaks.

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   8  

Page 5: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

5  

Basic Hough – Infinite Lines •  The Hough Transform in pure form … •  Does not return end-points •  Instead, it returns a rho and theta pairs.

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   9  

Example 1

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   10  

Page 6: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

6  

Example 2

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   11  

Example 3

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   12  

Page 7: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

7  

Hough Fitting

•  After finding the peaks in the Hough Transform - still two potential problems: – Resolution limited by bucket size. –  Infinite lines, not line segments

•  Both of these problems can be fixed, –  If you kept a linked list of edges (not just #) – Of course, this is more expensive...

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   13  

Hough Fitting (II) •  Sort your edges

–  rotate edge points according to ρ – sort them by (rotated) x coordinate

•  Look for gaps – have the user provide a “max gap” threshold –  if two edges (in the sorted list) are more than

max gap apart, break the line into segments –  if there are enough edges in a given segment,

fit a straight line to the points

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   14  

Page 8: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

8  

Open CV Hough Version 2

•  Second Hough algorithm in OpenCV •  Returns segments – based on work below

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   15  

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   16  

Page 9: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

9  

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   17  

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   18  

Page 10: Introduction to Grouping: The Hough Transformcs510/yr2015sp/more... · Hough Transform: Grouping • The idea of the Hough transform is that a change in representation converts a

3/30/15  

10  

Building Example

3/30/15   CS  510,  Image  Computa4on,  ©Ross  Beveridge  &  Bruce  Draper   19  

hGp://docs.opencv.org/modules/imgproc/doc/feature_detec4on.html