Lecture 28: Photometric Stereo CS4670/5760: Computer Vision Kavita Bala Lecture 28: Photometric Stereo Thanks to Scott Wehrwein
Announcements PA 3 due at 1pm on Monday PA 4 out on Monday HW 2 out on weekend Next week: MVS, sFM
Last Time: Two-View Stereo
Last Time: Two-View Stereo Key Idea: use feature motion to understand shape
Today: Photometric Stereo Key Idea: use pixel brightness to understand shape
Today: Photometric Stereo Key Idea: use pixel brightness to understand shape
Photometric Stereo What results can you get? Input (1 of 12) Normals (RGB colormap) Normals (vectors) Shaded 3D rendering Textured 3D rendering
Modeling Image Formation Now we need to reason about: How light interacts with the scene How a pixel value is related to light energy in the world Track a “ray” of light all the way from light source to the sensor
Directional Lighting Key property: all rays are parallel Equivalent to an infinitely distant point source
Lambertian Reflectance Image intensity Surface normal Light direction Image intensity cos(angle between N and L)
Materials - Three Forms Ideal diffuse (Lambertian) There are several types of surfaces that are assumed to make up the world. Ideal diffuse. It is similar to the diffuse emitter in that it emits all incident light equally in all outgoing directions. When light hits the surface it is reflected uniformly anywhere in the hemisphere above the surface. Ideal specular (perfect mirrors). Light is reflected exactly in the mirror direction of the incoming light. A perfect mirror is such a surface. Directional diffuse (almost all materials in the world). Incoming light is reflected into the hemisphere to different extents. If the object is more glossy then more of the incoming energy reflects close to the mirror direction. If it is more diffuse then the reflection is more uniform. Ideal specular Directional diffuse © Kavita Bala, Computer Science, Cornell University
Reflectance—Three Forms Why spheres?! Ideal diffuse (Lambertian) Ideal specular Directional diffuse © Kavita Bala, Computer Science, Cornell University
Ideal Diffuse Reflection Characteristic of multiple scattering materials An idealization but reasonable for matte surfaces Basis of most radiosity methods © Kavita Bala, Computer Science, Cornell University
© Kavita Bala, Computer Science, Cornell University Ideal Diffuse Lambert’s Law © Kavita Bala, Computer Science, Cornell University
Ideal Specular Reflection Calculated from Fresnel’s equations Exact for polished surfaces Basis of early ray-tracing methods © Kavita Bala, Computer Science, Cornell University
Lambertian Reflectance Reflected energy is proportional to cosine of angle between L and N (incoming) Measured intensity is viewpoint-independent (outgoing)
Lambertian Reflectance: Incoming Reflected energy is proportional to cosine of angle between L and N
Lambertian Reflectance: Incoming Reflected energy is proportional to cosine of angle between L and N
Lambertian Reflectance: Incoming Reflected energy is proportional to cosine of angle between L and N Light hitting surface is proportional to the cosine
Lambertian Reflectance: Outgoing Radiance (what we see) is viewpoint-independent
Lambertian Reflectance: Outgoing Radiance (what the eye sees) is viewpoint-independent Emission rate of photons: B0 cos theta Radiance: (Photons/second)/(area steradian) Looking down get B0/dA Looking at angle get B0 cos theta/(dA cos theta)
Lambertian Reflectance: Outgoing Measured intensity is viewpoint-independent
Lambertian Reflectance: Outgoing Measured intensity is viewpoint-independent A cos (q) Radiance (what eye sees)
Image Formation Model: Final Diffuse albedo: what fraction of incoming light is reflected? Introduce scale factor Light intensity: how much light is arriving? Compensate with camera exposure (global scale factor) Camera response function Assume pixel value is linearly proportional to incoming energy (perform radiometric calibration if not)
A Single Image: Shape from Shading Assume is 1 for now. What can we measure from one image? is the angle between N and L Add assumptions: A few known normals (e.g. silhouettes) Smoothness of normals In practice, SFS doesn’t work very well: assumptions are too restrictive, too much ambiguity in nontrivial scenes.
Multiple Images: Photometric Stereo N V Write this as a matrix equation:
Solving the Equations 28
Solving the Equations When is L nonsingular (invertible)? >= 3 light directions are linearly independent, or: All light direction vectors cannot lie in a plane. What if we have more than one pixel? Stack them all into one big system. 29
More than Three Lights Solve using least squares (normal equations): Equivalently use SVD Given G, solve for N and as before. Or equivalently use the SVD
More than one pixel Previously: I = N L * 1 x # images 1 x 3
More than one pixel Stack all pixels into one system: Solve as before. p x # images p x 3 3 x # images I = N L *
Depth Map from Normal Map We now have a surface normal, but how do we get depth? Assume a smooth surface V1 V2 orthographic projection N Get a similar equation for V2 Each normal gives us two linear constraints on z compute z values by solving a matrix equation 33
Determining Light Directions Trick: Place a mirror ball in the scene. The location of the highlight is determined by the light source direction. 34
Real-World HDR Lighting Environments Funston Beach Eucalyptus Grove Grace Cathedral Uffizi Gallery Lighting Environments from the Light Probe Image Gallery: http://www.debevec.org/Probes/ © Kavita Bala, Computer Science, Cornell University
© Kavita Bala, Computer Science, Cornell University Mirrored Sphere © Kavita Bala, Computer Science, Cornell University
© Kavita Bala, Computer Science, Cornell University
Acquiring the Light Probe © Kavita Bala, Computer Science, Cornell University
Assembling the Light Probe © Kavita Bala, Computer Science, Cornell University
Extreme HDR Image Series Focal length in terms of pupil diameter. 4 times pupil diameter.f/16 gets Less light. 1 sec f/4 1/4 sec f/4 1/30 sec f/4 1/30 sec f/16 1/250 sec f/16 1/1000 sec f/16 1/8000 sec f/16 © Kavita Bala, Computer Science, Cornell University
Extreme HDR Image Series sun closeup 1 sec f/4 1/4 sec f/4 1/30 sec f/4 1/30 sec f/16 1/250 sec f/16 1/1000 sec f/16 1/8000 sec f/16 only image that does not saturate! © Kavita Bala, Computer Science, Cornell University
© Kavita Bala, Computer Science, Cornell University HDRI Sky Probe © Kavita Bala, Computer Science, Cornell University
Determining Light Directions For a perfect mirror, the light is reflected across N: So the light source direction is given by: 43
Determining Light Directions For a sphere with highlight at point H: R = direction of the camera from C = Compute N: 44
from Athos Georghiades Results from Athos Georghiades 45
Normals (RGB colormap) Results Input (1 of 12) Normals (RGB colormap) Normals (vectors) Shaded 3D rendering Textured 3D rendering
Questions?