Perspective Shadow Maps Marc Stamminger REVES/INRIA, Sophia-Antipolis, France now at: Bauhaus-Universität, Weimar, Germany George Drettakis REVES/INRIA, Sophia-Antipolis, France
Generate shadow n Hard shadows algorithms-Which are binary. For example, shadow volumes,depth buffer,ray tracing n Soft shadows algorithms-Also display the penumbra area around the central umbra shadow. For example, radiosity
Generate shadow Ray TracingRadiosity
Generate shadow n Kevin Weiler and Peter Atherton, Siggraph ‘1977 –Hidden Surface Removal Using Polygon Area Sorting n Franklin C., Siggraph ‘1977 –Shadow Algorithms for Computer Graphics
Traditional Shadow Maps n Williams, Siggraph ‘1978 –render scene from light source –shadowing by depth comparison
Adaptive shadow maps n T.Lokovic E.Vearch, Siggraph ‘2000 –Deep Shadow Maps n Randima F. Sebastian F. Kavita B., Siggraph ‘2001 –Adaptive Shadow Maps –Replace the flat ahsdow map with an adaptive,hierarchical representation.
Adaptive shadow maps n drawback: By using multiple shadow maps,several rendering passes are required,and due to the more involved data structures,the methods no longer map to hardware.
Adaptive shadow maps
Introduction n Method used to generate shadows: 1.clipping 2.shadow volumes n These methods often suffer from robustness problems due to the geometric computations required,and may also involve a significant rendering overhead. n Such algorithms are usually a preprocess,and are thus best suited to static scenes.
Introduction n The paper by Lance Williams (Casting Curved Shadows on Curved Surfaces) “ Shadow map “
Shadow Maps n The algorithm 1.The depth values for the objects closest to the source are stored to the depth map for each point. 2.As each point is generated into the obsevers view,it is transformed into the light source’s coordinate system and tested for visibility.
Result
shadow map aliasing View frustum is for obsever Light frustum is for light source
shadow map aliasing N N
N α α L/2 dsds rsrs 1
shadow map aliasing dsds rsrs (L/2) * cos α 1
shadow map aliasing N d L/2 β β 1 rsrs
shadow map aliasing
For an orthogonal view, d is proportional to d s* r s. For directional light sources,d is only dependent of d s /r i. If d>di, shadow map aliasing happens.
shadow map aliasing n r s /r i is not close to a constant. n cos β /cosα become large. When the light rays are almost parallel to a surface. Situations
shadow map aliasing n prone to aliasing when zooming into shadow boundaries single shadow map pixel
shadow map aliasing n perspective aliasing parallel light okayaliased okay
shadow map aliasing n perspective aliasing –smooth transition aliased oversampled
shadow map aliasing n projection aliasing parallel light
shadow map aliasing n projection aliasing –very local aliased oversampled
Perspective shadow maps Step 1. Mapping the scene to post-perspective space. 2. Generating a standard shadow map by rendering a view from the transformed light source to the unit cube.
perspective transformation World space Observer f n (Camera distance)
perspective transformation post-perspective world space
perspective shadow map n standard shadow map n perspective shadow map shadow map image
perspective shadow map n standard shadow map n perspective shadow map aliased oversampled
perspective shadow map n shadow map in post-perspective space n just another shadow map projection n reduces perspective aliasing n regeneration per frame necessary
parallel light transformation post-perspective world space
parallel light transformation 1. Directional light sources can be considered as point lights at infinity plane. 2. The infinity plane is at: z=(f + n) / (f - n) 3. A directional light source from behind is mapped to a “inverted” point light source. 4. A directional light parallel to the image plane remains at infinity.
point light transformation post-perspective world space frontback
point light transformation n Point light on the plane through the view point which is perpendicular to the view direction,become directional.
discussion n best case: –parallel light in post-perspective space –no new perspective distortion post-perspective world space
discussion n non-optimal case: –point light close to frustum n worst case: –becomes uniform shadow map post-perspective world space
discussion A common problem in shadow maps is the bias necessary to avoid self-occlusion or surface acne. This problem is increased for perspective shadow maps,because objects are scaled non-uniformly.
Including all objects Casting Shadows The shadow map must contain all objects within that frustum plus all potential occluders outside the frustum that can cast a shadow onto any visible object.
shadow map window n geometric method to include all necessary objects
Including all objects Casting Shadows In World Space
Including all objects Casting Shadows In Post-perspective Space
Including all objects Casting Shadows n When a line intersects the camera plane, where the intersection point is mapped to infinity. n Moving the center of projection back, so that we are behind the furthermost point which can cast a shadow into the view frustum. n This camera point displacement is only for the shadow map generation, not for rendering the image.
Point Rendering n Point Rendering is particularly well suited for natural objects. n For the generation of uniform shadow maps point rendering loses most of its benefits. n Perspective Shadow Map fits nicely with the point rendering.
results
n first implementation on an Xbox game developer kit courtesy of Thatcher Ulrich
results
No shadowsUniform shadow map
results Perspective shadow map
conclusion n perspective shadow maps –shadow map in post-perspective space –just another shadow map matrix –non-uniform shadow map resolution –needs recomputation per frame –minimal overhead for dynamic scenes
報告完畢