Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J....

57
Stereo vision Many slides adapted from Steve Seitz

Transcript of Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J....

Page 1: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Stereo vision

Many slides adapted from Steve Seitz

Page 2: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

What is stereo vision?• Generic problem formulation: given several images of

the same object or scene, compute a representation of its 3D shape

Page 3: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

What is stereo vision?• Generic problem formulation: given several images of

the same object or scene, compute a representation of its 3D shape

• “Images of the same object or scene”• Arbitrary number of images (from two to thousands)• Arbitrary camera positions (isolated cameras or video sequence)• Cameras can be calibrated or uncalibrated

• “Representation of 3D shape”• Depth maps• Meshes• Point clouds• Patch clouds• Volumetric models• Layered models

Page 4: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

What is stereo vision?• Generic problem formulation: given several images of

the same object or scene, compute a representation of its 3D shape

Page 5: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

What is stereo vision?• Narrower formulation: given a calibrated binocular

stereo pair, fuse it to produce a depth imageimage 1 image 2

Dense depth map

Page 6: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

What is stereo vision?• Narrower formulation: given a calibrated binocular

stereo pair, fuse it to produce a depth image• Humans can do it

Stereograms: Invented by Sir Charles Wheatstone, 1838

Page 7: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

What is stereo vision?• Narrower formulation: given a calibrated binocular

stereo pair, fuse it to produce a depth image• Humans can do it

Autostereograms: www.magiceye.com

Page 8: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

What is stereo vision?• Narrower formulation: given a calibrated binocular

stereo pair, fuse it to produce a depth image• Humans can do it

Autostereograms: www.magiceye.com

Page 9: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Application of stereo: Robotic exploration

Nomad robot searches for meteorites in Antartica

Real-time stereo on Mars

Page 10: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Application: View Interpolation

Right Image

Page 11: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Left Image

Application: View Interpolation

Page 12: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Application: View Interpolation

Disparity

Page 13: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Application: View Interpolation

Page 14: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Basic stereo matching algorithm

• For each pixel in the first image• Find corresponding epipolar line in the right image• Examine all pixels on the epipolar line and pick the best match• Triangulate the matches to get depth information

• Simplest case: epipolar lines are scanlines• When does this happen?

Page 15: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Simplest Case: Parallel images• Image planes of cameras

are parallel to each other and to the baseline

• Camera centers are at same height

• Focal lengths are the same

Page 16: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Simplest Case: Parallel images• Image planes of cameras

are parallel to each other and to the baseline

• Camera centers are at same height

• Focal lengths are the same• Then, epipolar lines fall

along the horizontal scan lines of the images

Page 17: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Essential matrix for parallel images

RtExExT ][,0 ×==′

⎥⎥⎥

⎢⎢⎢

⎡−== ×

0000

000][

TTRtE

R = I t = (T, 0, 0)

Epipolar constraint:

⎥⎥⎥

⎢⎢⎢

−−

−=×

00

0][

xy

xz

yz

aaaa

aaa

t

x

x’

Page 18: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Essential matrix for parallel images

RtExExT ][,0 ×==′

⎥⎥⎥

⎢⎢⎢

⎡−== ×

0000

000][

TTRtE

Epipolar constraint:

( ) ( ) vTTvvTTvuv

u

TTvu ′==

⎟⎟⎟

⎜⎜⎜

′−=

⎟⎟⎟

⎜⎜⎜

⎛′′

⎥⎥⎥

⎢⎢⎢

⎡− 0

010

10000

0001

R = I t = (T, 0, 0)

The y-coordinates of corresponding points are the same!

t

x

x’

Page 19: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Depth from disparity

f

x x’

BaselineB

z

O O’

X

f

zfBxxdisparity ⋅

=′−=

Disparity is inversely proportional to depth!

Page 20: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Stereo image rectification

Page 21: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Stereo image rectification

• reproject image planes onto a commonplane parallel to the line between optical centers

• pixel motion is horizontal after this transformation• two homographies (3x3 transform), one for each

input image reprojectionC. Loop and Z. Zhang. Computing Rectifying Homographies for Stereo Vision. IEEE Conf. Computer Vision and Pattern Recognition, 1999.

Page 22: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Rectification example

Page 23: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Basic stereo matching algorithm

• If necessary, rectify the two stereo images to transform epipolar lines into scanlines

• For each pixel x in the first image• Find corresponding epipolar scanline in the right image• Examine all pixels on the scanline and pick the best match x’• Compute disparity x-x’ and set depth(x) = 1/(x-x’)

Page 24: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Correspondence problem

Multiple matching hypotheses satisfy the epipolarconstraint, but which one is correct?

Page 25: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Correspondence problem• Let’s make some assumptions to simplify the

matching problem• The baseline is relatively small (compared to the depth of

scene points)• Then most scene points are visible in both views• Also, matching regions are similar in appearance

Page 26: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Correspondence problem• Let’s make some assumptions to simplify the

matching problem• The baseline is relatively small (compared to the depth of

scene points)• Then most scene points are visible in both views• Also, matching regions are similar in appearance

• Additional constraints• Uniqueness• Ordering • Continuity

Page 27: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Matching cost

disparity

Left Right

scanline

Correspondence search with similarity constraint

• Slide a window along the right scanline and compare contents of that window with the reference window in the left image

• Matching cost: SSD or normalized correlation

Page 28: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Left Right

scanline

Correspondence search with similarity constraint

SSD

Page 29: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Left Right

scanline

Correspondence search with similarity constraint

Norm. corr

Page 30: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Effect of window size

• Smaller window+ More detail– More noise

• Larger window+ Smoother disparity maps– Less detail

W = 3 W = 20

Page 31: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

The similarity constraint

• Corresponding regions in two images should be similar in appearance

• …and non-corresponding regions should be different• When will the similarity constraint fail?

Page 32: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Limitations of similarity constraint

Textureless surfaces Occlusions, repetition

Non-Lambertian surfaces, specularities

Page 33: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Results with window search

Window-based matching Ground truth

Data

Page 34: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Better methods exist...

Graph cuts Ground truth

For the latest and greatest: http://www.middlebury.edu/stereo/

Y. Boykov, O. Veksler, and R. Zabih, Fast Approximate Energy Minimization via Graph Cuts, PAMI 2001

Page 35: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

How can we improve window-based matching?• The similarity constraint is local (each reference

window is matched independently)• Need to enforce non-local correspondence

constraints

Page 36: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Non-local constraints• Uniqueness

• For any point in one image, there should be at most one matching point in the other image

Page 37: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Non-local constraints• Uniqueness

• For any point in one image, there should be at most one matching point in the other image

• Ordering• Corresponding points should be in the same order in both

views

Page 38: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Non-local constraints• Uniqueness

• For any point in one image, there should be at most one matching point in the other image

• Ordering• Corresponding points should be in the same order in both

views

Ordering constraint doesn’t hold

Page 39: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Non-local constraints• Uniqueness

• For any point in one image, there should be at most one matching point in the other image

• Ordering• Corresponding points should be in the same order in both

views

• Smoothness• We expect disparity values to change slowly (for the most

part)

Page 40: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Scanline stereo• Try to coherently match pixels on the entire scanline• Different scanlines are still optimized independently

Left image Right image

Page 41: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

“Shortest paths” for scan-line stereoLeft image

Right image

Can be implemented with dynamic programmingOhta & Kanade ’85, Cox et al. ‘96

leftS

rightS

correspondence

q

p

Left

oc

clus

ion

t

Rightocclusion

s

occlC

occlC

II ′

corrC

Slide credit: Y. Boykov

Page 42: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Coherent stereo on 2D grid• Scanline stereo generates streaking artifacts

• Can’t use dynamic programming to find spatially coherent disparities/ correspondences on a 2D grid

Page 43: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Stereo matching as energy minimization

MAP estimate of disparity image D: )()|,(),|( 2121 DPDIIPIIDP ∝

I1 I2 D

W1(i) W2(i+D(i)) D(i)

)(),,( smooth21data DEDIIEE βα +=

)(log)|,(log),|(log 2121 DPDIIPIIDP −−∝−

( )∑ −=ji

jDiDE,neighbors

smooth )()(ρ( )221data ))(()(∑ +−=i

iDiWiWE

Page 44: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Stereo matching as energy minimization

I1 I2 D

• Energy functions of this form can be minimized using graph cuts

Y. Boykov, O. Veksler, and R. Zabih, Fast Approximate Energy Minimization via Graph Cuts, PAMI 2001

W1(i) W2(i+D(i)) D(i)

)(),,( smooth21data DEDIIEE βα +=

( )∑ −=ji

jDiDE,neighbors

smooth )()(ρ( )221data ))(()(∑ +−=i

iDiWiWE

Page 45: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

The role of the baseline

Small baseline: large depth errorLarge baseline: difficult search problem

Large BaselineSmall Baseline

Source: S. Seitz

Page 46: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Problem for wide baselines: Foreshortening

• Matching with fixed-size windows will fail!• Possible solution: adaptively vary window size• Another solution: model-based stereo

Page 47: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Model-based stereo

Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH 1996.

Page 48: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Model-based stereo

key image offset image

Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH 1996.

Page 49: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Model-based stereo

key image warped offset image

displacement map

Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH 1996.

Page 50: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Active stereo with structured light

• Project “structured” light patterns onto the object• simplifies the correspondence problem• Allows us to use only one camera

camera

projector

L. Zhang, B. Curless, and S. M. Seitz. Rapid Shape Acquisition Using Color Structured Light and Multi-pass Dynamic Programming. 3DPVT 2002

Page 51: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Active stereo with structured light

L. Zhang, B. Curless, and S. M. Seitz. Rapid Shape Acquisition Using Color Structured Light and Multi-pass Dynamic Programming. 3DPVT 2002

Page 52: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Laser scanning

Optical triangulation• Project a single stripe of laser light• Scan it across the surface of the object• This is a very precise version of structured light scanning

Direction of travel

Object

CCD

CCD image plane

LaserCylindrical lens

Laser sheet

Digital Michelangelo Projecthttp://graphics.stanford.edu/projects/mich/

Source: S. Seitz

Page 53: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Laser scanned models

The Digital Michelangelo Project, Levoy et al.

Source: S. Seitz

Page 54: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Laser scanned models

The Digital Michelangelo Project, Levoy et al.

Source: S. Seitz

Page 55: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Laser scanned models

The Digital Michelangelo Project, Levoy et al.

Source: S. Seitz

Page 56: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Laser scanned models

The Digital Michelangelo Project, Levoy et al.

Source: S. Seitz

Page 57: Stereo vision - Computer Sciencelazebnik/research/spring08/lec12...Paul E. Debevec, Camillo J. Taylor, and Jitendra Malik. Modeling and Rendering Architecture from Photographs. SIGGRAPH

Laser scanned models

The Digital Michelangelo Project, Levoy et al.

Source: S. Seitz