Shadows. Shadows. Thanks to: Frédo Durand and Seth Teller MIT. Realism Depth cue



Similar documents
Image Processing and Computer Graphics. Rendering Pipeline. Matthias Teschner. Computer Science Department University of Freiburg

A Short Introduction to Computer Graphics

INTRODUCTION TO RENDERING TECHNIQUES

Introduction to Computer Graphics

Lezione 4: Grafica 3D*(II)

GUI GRAPHICS AND USER INTERFACES. Welcome to GUI! Mechanics. Mihail Gaianu 26/02/2014 1

Computer Animation: Art, Science and Criticism

Computer Applications in Textile Engineering. Computer Applications in Textile Engineering

Monash University Clayton s School of Information Technology CSE3313 Computer Graphics Sample Exam Questions 2007

Computer Graphics. Introduction. Computer graphics. What is computer graphics? Yung-Yu Chuang

Deferred Shading & Screen Space Effects

COMP175: Computer Graphics. Lecture 1 Introduction and Display Technologies

Shader Model 3.0. Ashu Rege. NVIDIA Developer Technology Group

Making natural looking Volumetric Clouds In Blender 2.48a

SkillsUSA 2014 Contest Projects 3-D Visualization and Animation

Using Photorealistic RenderMan for High-Quality Direct Volume Rendering

Image Synthesis. Transparency. computer graphics & visualization

Advanced Rendering for Engineering & Styling

Instructor. Goals. Image Synthesis Examples. Applications. Computer Graphics. Why Study 3D Computer Graphics?

Computer Graphics Global Illumination (2): Monte-Carlo Ray Tracing and Photon Mapping. Lecture 15 Taku Komura

Computer Graphics Hardware An Overview

Introduction to GPGPU. Tiziano Diamanti

OpenGL Performance Tuning

So, you want to make a photo-realistic rendering of the Earth from orbit, eh? And you want it to look just like what astronauts see from the shuttle

Consolidated Visualization of Enormous 3D Scan Point Clouds with Scanopy

Specular reflection. Dielectrics and Distribution in Ray Tracing. Snell s Law. Ray tracing dielectrics

Water Flow in. Alex Vlachos, Valve July 28, 2010

NVPRO-PIPELINE A RESEARCH RENDERING PIPELINE MARKUS TAVENRATH MATAVENRATH@NVIDIA.COM SENIOR DEVELOPER TECHNOLOGY ENGINEER, NVIDIA

CSE 564: Visualization. GPU Programming (First Steps) GPU Generations. Klaus Mueller. Computer Science Department Stony Brook University

Lecture Notes, CEng 477

Thea Omni Light. Thea Spot Light. Light setup & Optimization

Recent Advances and Future Trends in Graphics Hardware. Michael Doggett Architect November 23, 2005

Introduction Week 1, Lecture 1

The Evolution of Computer Graphics. SVP, Content & Technology, NVIDIA

Cartoon-Looking Rendering of 3D-Scenes

Course Overview. CSCI 480 Computer Graphics Lecture 1. Administrative Issues Modeling Animation Rendering OpenGL Programming [Angel Ch.

3D Math Overview and 3D Graphics Foundations

Scan-Line Fill. Scan-Line Algorithm. Sort by scan line Fill each span vertex order generated by vertex list

Dynamic Resolution Rendering

Optimizing AAA Games for Mobile Platforms

The Car Tutorial Part 1 Creating a Racing Game for Unity

Computer Graphics. Anders Hast

Multivariate data visualization using shadow

Methodology for Lecture. Review of Last Demo

How To Teach Computer Graphics

Maya 2014 Still Life Part 1 Texturing & Lighting

CUBE-MAP DATA STRUCTURE FOR INTERACTIVE GLOBAL ILLUMINATION COMPUTATION IN DYNAMIC DIFFUSE ENVIRONMENTS

Materials in NX Render

Cork Education and Training Board. Programme Module for. 3 Dimensional Computer Graphics. Leading to. Level 5 FETAC

OpenGL Insights. Edited by. Patrick Cozzi and Christophe Riccio

Chapter 10. Bidirectional Path Tracing

Modern Graphics Engine Design. Sim Dietrich NVIDIA Corporation

Basic Problem: Map a 3D object to a 2D display surface. Analogy - Taking a snapshot with a camera

Volume Rendering on Mobile Devices. Mika Pesonen

GPU(Graphics Processing Unit) with a Focus on Nvidia GeForce 6 Series. By: Binesh Tuladhar Clay Smith

Advanced Visual Effects with Direct3D

Graphical displays are generally of two types: vector displays and raster displays. Vector displays

Lighting & Rendering in Maya: Lights and Shadows

Comp 410/510. Computer Graphics Spring Introduction to Graphics Systems

Introduction to Computer Graphics. Reading: Angel ch.1 or Hill Ch1.

One Step Closer to a Fully Realistic 3D World on the Consumer PC A White Paper on the 3dfx T-Buffer

CSE168 Computer Graphics II, Rendering. Spring 2006 Matthias Zwicker

Otis Photo Lab Inkjet Printing Demo

CS130 - Intro to computer graphics. Dr. Victor B. Zordan vbz@cs.ucr.edu Objectives

Color correction in 3D environments Nicholas Blackhawk

COMP-557: Fundamentals of Computer Graphics McGill University, Fall 2010

Dhiren Bhatia Carnegie Mellon University

GPU Christmas Tree Rendering. Evan Hart

Realtime 3D Computer Graphics Virtual Reality

Visualization and Feature Extraction, FLOW Spring School 2016 Prof. Dr. Tino Weinkauf. Flow Visualization. Image-Based Methods (integration-based)

Blender addons ESRI Shapefile import/export and georeferenced raster import

B2.53-R3: COMPUTER GRAPHICS. NOTE: 1. There are TWO PARTS in this Module/Paper. PART ONE contains FOUR questions and PART TWO contains FIVE questions.

Teaching Introductory Computer Graphics Via Ray Tracing

A Proposal for OpenEXR Color Management

Beginning Android 4. Games Development. Mario Zechner. Robert Green

REAL-TIME IMAGE BASED LIGHTING FOR OUTDOOR AUGMENTED REALITY UNDER DYNAMICALLY CHANGING ILLUMINATION CONDITIONS

DATA VISUALIZATION OF THE GRAPHICS PIPELINE: TRACKING STATE WITH THE STATEVIEWER

CASTING CURVED SHADOWS ON CURVED SURFACES. Lance Williams Computer Graphics Lab New York Institute of Technology Old Westbury, New York 11568

Path Tracing. Michael Doggett Department of Computer Science Lund university Michael Doggett

Computer Graphics CS 543 Lecture 12 (Part 1) Curves. Prof Emmanuel Agu. Computer Science Dept. Worcester Polytechnic Institute (WPI)

Silverlight for Windows Embedded Graphics and Rendering Pipeline 1

Adding Animation With Cinema 4D XL

Procedural Shaders: A Feature Animation Perspective

Interactive Computer Graphics

IT 386: 3D Modeling and Animation. Review Sheet. Notes from Professor Nersesian s IT 386: 3D Modeling and Animation course

Autodesk Revit Architecture 2011 Professional Massmodeling Rendering Video Tutorial

Path Tracing Overview

Introduction to Computer Graphics. Jürgen P. Schulze, Ph.D. University of California, San Diego Fall Quarter 2012

PRODUCT LIFECYCLE MANAGEMENT COMPETENCY CENTRE RENDERING. PLMCC, JSS Academy of Technical Education, Noida Rendering 1 of 16

Writing Applications for the GPU Using the RapidMind Development Platform

Certificate Courses in Animation

Our One-Year 3D Animation Program is a comprehensive training in 3D using Alias

ADVANCED THEORIES FOR CG LIGHTING

GPUs Under the Hood. Prof. Aaron Lanterman School of Electrical and Computer Engineering Georgia Institute of Technology

Compositing a 3D character over video footage in Maya Jean-Marc Gauthier, Spring 2008

2: Introducing image synthesis. Some orientation how did we get here? Graphics system architecture Overview of OpenGL / GLU / GLUT

An introduction to Global Illumination. Tomas Akenine-Möller Department of Computer Engineering Chalmers University of Technology

Optimizing Unity Games for Mobile Platforms. Angelo Theodorou Software Engineer Unite 2013, 28 th -30 th August

How To Make A Texture Map Work Better On A Computer Graphics Card (Or Mac)

Transcription:

Shadows Thanks to: Frédo Durand and Seth Teller MIT 1 Shadows Realism Depth cue 2 1

Shadows as depth cue 3 Spatial relationship between objects Michael McCool Univ of Waterloo 4 2

Spatial relationship between objects Michael McCool Univ of Waterloo 5 Spatial relationship between objects Michael McCool Univ of Waterloo 6 3

Spatial relationship between objects Michael McCool Univ of Waterloo 7 Spatial relationship between objects Michael McCool Univ of Waterloo 8 4

Shadows add visual acuity without with 9 Shadows and art Shadows as the origin of painting People painted by tracing the shadows onto the canvas/wall 10 5

Duality shadow-view A point is lit if it is visible from the light source Shadow computation very similar to view computation 11 Shadow ray Ray from visible point to light source If blocked, discard light contribution One shadow ray per light Optimization? Stop after first intersection (don t worry about tmin) Test latest obstacle first 12 6

Ray-casting shadows 13 Local vs. Global Illumination Core OpenGL uses local illumination model Light sources used: distant, point, spot Pros: Fast calculation of pixel color using Phong, only needs Position & direction of light source Material properties (diffuse, specular, ambient coeff) Light settings (intensity, fall-off, color) but no info about other objects in the scene! Each primitive can be processed independently of others Cons: Good looking images need global effects Reflected light (e.g. environment mapping) Shadows 14 7

Global: Shadows A point is in shadow if the light got blocked between the light source and point Light Source Viewer Occluder Point is in shadow Point is lit Need mask that contains information about blocked / non blocked pixels 15 Fake methods Still (not so) commonly used in games Images from TombRaider. Eidos Interactive. Shadows are simple, hand-drawn polygons No global effect but better than no shadow at all 16 8

Shadow Quality: Blobs 17 Overview Projected Shadows Shadow map Image-precision, texture mapping 18 9

Planar Projection Render a ground-plane Render an object Then render the object again, but this time Projected onto the plane Without light, so that the shadow is black Half transparent (using blending), to avoid completely dark shadows Avoid multiple darkening on one spot by using ordinary z-buffer checks 19 Projected Geometry [Blinn88] Me and my fake shadow Shadows for selected large receiver polygons Ground plane Walls 20 10

11 21 Projected Geometry Example: xz plane at y=0 y y y z z y z y y y x x y x v l v l v l p v l v l v l p 22 Projected Geometry Transformation as 4 by 4 matrix 1 0 1 0 0 0 0 0 0 0 0 0 z y x y y z x y v v v l l l l l p

Projected Geometry General case: receiver polygon in plane E E : n x d 0 d n l p l ( v l ) n v l 4x4 matrix 23 Projected Geometry Basic algorithm Render scene (full lighting) For each receiver polygon Compute projection matrix M Mult with actual transformation (modelview) Render selected (occluder) geometry Darken/Black 24 12

Planar Shadows Shadow is projected into the plane of the floor. 25 Constructing a Shadow Matrix groundplane = N x N y N z D void shadowmatrix(glfloat shadowmat[4][4], GLfloat groundplane[4], GLfloat lightpos[4]) { GLfloat dot; /* Find dot product between light position vector and ground plane normal. */ dot = groundplane[x] * lightpos[x] + groundplane[y] * lightpos[y] + groundplane[z] * lightpos[z] + groundplane[w] * lightpos[w]; shadowmat[0][0] = dot - lightpos[x] * groundplane[x]; shadowmat[1][0] = 0.f - lightpos[x] * groundplane[y]; shadowmat[2][0] = 0.f - lightpos[x] * groundplane[z]; shadowmat[3][0] = 0.f - lightpos[x] * groundplane[d]; shadowmat[0][1] = 0.f - lightpos[y] * groundplane[x]; shadowmat[1][1] = dot - lightpos[y] * groundplane[y]; shadowmat[2][1] = 0.f - lightpos[y] * groundplane[z]; shadowmat[3][1] = 0.f - lightpos[y] * groundplane[d]; shadowmat[0][2] = 0.f - lightpos[z] * groundplane[x]; shadowmat[1][2] = 0.f - lightpos[z] * groundplane[y]; shadowmat[2][2] = dot - lightpos[z] * groundplane[z]; shadowmat[3][2] = 0.f - lightpos[z] * groundplane[d]; shadowmat[0][3] = 0.f - lightpos[w] * groundplane[x]; shadowmat[1][3] = 0.f - lightpos[w] * groundplane[y]; shadowmat[2][3] = 0.f - lightpos[w] * groundplane[z]; shadowmat[3][3] = dot - lightpos[w] * groundplane[d]; } 26 13

How to add shadows? Can be done in two ways: 1 st method: Full illumination + darkening FB = DiffuseTex0 * ( Light0 + Light1 + Light2 ) if pixel is in shadow (with respect to Light0) FB = FB * 0.5 This is wrong since the contribution of Light1,2 etc. is also affected! 27 How to add shadows? 2 nd & correct method: Use mask for each light FB = DiffuseTex0 * ( Light0 * Mask0 + Light1 * Mask1 + Light2 * Mask2 ) Mask values 0 if pixel is in shadow (with respect to Light X) 1 if pixel is lit by Light X 0 1 for pixels on shadow edge (soft shadow edge) Accumulation of (Light0 * Mask0) + can be done using additive blending 28 14

How to add shadows? Algorithm Render scene with ambient illumination only For each light source Render scene with illumination from this light only Scale illumination by shadow mask Add up contribution to frame buffer Expensive but nearly correct! Speed-Up Use more lights & masks in one pass Masks stored as textures Apply masks & sum up using fragment shaders 29 How to Render the Shadow /* Render 50% black shadow color on top of whatever the floor appearance is. */ gl.enable(gl.blend); gl.blendfunc(gl_src_alpha, GL_ONE_MINUS_SRC_ALPHA); Draw with color (0.0, 0.0, 0.0, 0.5); //Force the 50% black. // use pass-through shaders assigning color in fragment program /* Project the shadow. */ PushMatrix(); // whatever matrix functions you use MultMatrixf((GLfloat *) floorshadow); drawdinosaur(); PopMatrix(); // whatever matrix functions you use 30 15

Not Quite So Easy (1) Without stencil to avoid double blending of the shadow pixels: Notice darks spots on the planar shadow. Solution: Clear stencil to zero. Draw floor with stencil of one. Draw shadow if stencil is one. If shadow s stencil test passes, set stencil to two. No double blending. 31 Not Quite So Easy (2) There s still another problem even if using stencil to avoid double blending. depth buffer Z fighting artifacts Shadow fights with depth values from the floor plane. Use polygon offset to raise shadow polygons slightly in Z. 32 16

Not Quite so Easy (3) Good. Bad. Notice right image s reflection falls off the floor! Same problem with Shadows! 33 Planar Projection Fast Can be done with a matrix operation Easy Just use the Modelview transform Very unrealistic Just planar shadows 34 17

Projected Geometry Problems Z-Fighting Use bias when rendering shadow polygons Use stencil buffer (no depth test) Bounded receiver polygon? Use stencil buffer (restrict drawing to receiver area) Shadow polygon overlap? Use stencil count (only the first pixel gets through) 35 Fake shadows using textures Separate occluder and receiver Compute b/w image of obstacle from light Use projective textures Image from light source BW image of obstacle Final image Figure from Moller & haines Real Time Rendering 36 18

Fake shadows using textures Limitations? Image from light source BW image of obstacle Final image Figure from Moller & haines Real Time Rendering 37 Shadow maps Use texture mapping but using depth 2 passes (at least) Compute shadow map from light source Store depth buffer (shadow map) Compute final image Look up the shadow map to know if points are in shadow Figure from Foley et al. Computer Graphics Principles and Practice 38 19

Shadow map look up We have a 3D point x,y,z How do we look up the shadow map? (x,y,z) Figure from Foley et al. Computer Graphics Principles and Practice 39 Shadow map look up We have a 3D point x,y,z How do we look up the shadow map? Use the 4x4 camera matrix from the light source We get (x,y,z ) Test: ShadowMap(x,y )<z (x,y,z ) (x,y,z) Figure from Foley et al. Computer Graphics Principles and Practice 40 20

Shadow maps In Renderman (High-end production software) 41 Shadow maps Can be done in hardware Using hardware texture mapping Texture coordinates u,v,w generated using 4x4 matrix Modern hardware permits tests on texture values 42 21

Introducing Another Technique: Shadow Mapping Image-space shadow determination Lance Williams published the basic idea in 1978 By coincidence, same year Jim Blinn invented bump mapping (a great vintage year for graphics) Completely image-space algorithm means no knowledge of scene s geometry is required must deal with aliasing artifacts Well known software rendering technique Pixar s RenderMan uses the algorithm Basic shadowing technique for Toy Story, etc. 43 Shadow Mapping References Important SIGGRAPH papers Lance Williams, Casting Curved Shadows on Curved Surfaces, SIGGRAPH 78 William Reeves, David Salesin, and Robert Cook (Pixar), Rendering antialiased shadows with depth maps, SIGGRAPH 87 Mark Segal, et. al. (SGI), Fast Shadows and Lighting Effects Using Texture Mapping, SIGGRAPH 92 44 22

The Shadow Mapping Concept (1) Depth testing from the light s point-of-view Two pass algorithm First, render depth buffer from the light s pointof-view the result is a depth map or shadow map essentially a 2D function indicating the depth of the closest pixels to the light This depth map is used in the second pass 45 The Shadow Mapping Concept (2) Shadow determination with the depth map Second, render scene from the eye s point-of-view For each rasterized fragment determine fragment s XYZ position relative to the light this light position should be setup to match the frustum used to create the depth map compare the depth value at light position XY in the depth map to fragment s light position Z 46 23

The Shadow Mapping Concept (3) The Shadow Map Comparison Two values A = Z value from depth map at fragment s light XY position B = Z value of fragment s XYZ light position If B is greater than A, then there must be something closer to the light than the fragment then the fragment is shadowed If A and B are approximately equal, the fragment is lit 47 Shadow Mapping with a Picture in 2D (1) The A < B shadowed fragment case depth map image plane light source depth map Z = A eye position eye view image plane, a.k.a. the frame buffer fragment s light Z = B 48 24

Shadow Mapping with a Picture in 2D (2) The A B unshadowed fragment case depth map image plane light source depth map Z = A eye position fragment s light Z = B eye view image plane, a.k.a. the frame buffer 49 Shadow Mapping with a Picture in 2D (3) Note image precision mismatch! The depth map could be at a different resolution from the framebuffer This mismatch can lead to artifacts 50 25

Visualizing the Shadow Mapping Technique (1) A fairly complex scene with shadows the point light source 51 Visualizing the Shadow Mapping Technique (2) Compare with and without shadows with shadows without shadows 52 26

Visualizing the Shadow Mapping Technique (3) The scene from the light s point-of-view FYI: from the eye s point-of-view again 53 Visualizing the Shadow Mapping Technique (4) The depth buffer from the light s point-of-view FYI: from the light s point-of-view again 54 27

Visualizing the Shadow Mapping Technique (5) Projecting the depth map onto the eye s view FYI: depth map for light s point-of-view again 55 Visualizing the Shadow Mapping Technique (6) Projecting light s planar distance onto eye s view 56 28

Visualizing the Shadow Mapping Technique (6) Comparing light distance to light depth map Green is where the light planar distance and the light depth map are approximatel y equal Non-green is where shadows should be 57 Visualizing the Shadow Mapping Technique (7) Scene with shadows Notice how specular highlights never appear in shadows Notice how curved surfaces cast shadows on each other 58 29

Shadow Quality: Shadow Maps 59 OpenGL Shadow Mapping Two simple steps: 1. Create the shadow map Render from the light s point of view, save the depth buffer into a texture 2. Render the scene In the fragment shader, use the shadow map to test for visibility 60 30

OpenGL Shadow Mapping Create the texture object GLuint FramebufferName = 0; glgenframebuffers(1, &FramebufferName); glbindframebuffer(gl_framebuffer, FramebufferName); // Depth texture. Slower than a depth buffer, but you can sample it later in your shader GLuint depthtexture; glgentextures(1, &depthtexture); glbindtexture(gl_texture_2d, depthtexture); glteximage2d(gl_texture_2d, 0,GL_DEPTH_COMPONENT16, 1024, 1024, 0,GL_DEPTH_COMPONENT, GL_FLOAT, 0); gltexparameteri(gl_texture_2d, GL_TEXTURE_MAG_FILTER, GL_NEAREST); gltexparameteri(gl_texture_2d, GL_TEXTURE_MIN_FILTER, GL_NEAREST); gltexparameteri(gl_texture_2d, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); gltexparameteri(gl_texture_2d, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); glframebuffertexture(gl_framebuffer, GL_DEPTH_ATTACHMENT, depthtexture, 0); gldrawbuffer(gl_none); // No color buffer is drawn to. // Always check that our framebuffer is ok if(glcheckframebufferstatus(gl_framebuffer)!= GL_FRAMEBUFFER_COMPLETE) return false; 61 OpenGL Shadow Mapping Light s point of view glm::vec3 lightpos(5, 20, 20); glm::mat4 depthprojectionmatrix = glm::perspective<float>(45.0f, 1.0f, 2.0f, 50.0f); glm::mat4 depthviewmatrix = glm::lookat(lightpos, lightpos-lightinvdir glm::mat4 depthmodelmatrix = glm::mat4(1.0); glm::mat4 depthmvp = depthprojectionmatrix * depthviewmatrix * depthmodelmatrix; // Send our transformation to the currently bound shader, // in the "MVP" uniform gluniformmatrix4fv(depthmatrixid, 1, GL_FALSE, &depthmvp[0][0]) 62 31

OpenGL Shadow Mapping Light s point of view Vertex Shader: #version 330 core // Input vertex data, different for all executions of this shader. layout(location = 0) in vec3 vertexposition_modelspace; // Values that stay constant for the whole mesh. uniform mat4 depthmvp; void main(){ gl_position = depthmvp * vec4(vertexposition_modelspace,1); } Fragment Shader: #version 330 core // Ouput data layout(location = 0) out float fragmentdepth; void main(){ // Not really needed, OpenGL does it anyway fragmentdepth = gl_fragcoord.z; } 63 OpenGL Shadow Mapping Result 64 32

OpenGL Shadow Mapping Use the Shadow Map: Vertex Shader: // Output position of the vertex, in clip space : MVP * position gl_position = MVP * vec4(vertexposition_modelspace,1); // Same, but with the light's view matrix ShadowCoord = DepthBiasMVP * vec4(vertexposition_modelspace,1); // scale and bias: [-1 1] range to [0 1] glm::mat4 biasmatrix( 0.5, 0.0, 0.0, 0.5, 0.0, 0.5, 0.0, 0.5, 0.0, 0.0, 0.5, 0.5, 0.0, 0.0, 0.0, 1.0); glm::mat4 depthbiasmvp = biasmatrix*depthmvp; Fragment Shader: float visibility = 1.0; // Need to do perspective divide: // if done by your own shader code: //if ( texture( shadowmap, (ShadowCoord.xy/ShadowCoord.w) ).z < (ShadowCoord.z-bias)/ShadowCoord.w ) // // but there is a built-in GLSL function since this is common: if ( textureproj( shadowmap, ShadowCoord.xyw ).z < (ShadowCoord.z-bias)/ShadowCoord.w ) { visibility = 0.5; } color = // Ambient : simulates indirect lighting MaterialAmbientColor + // Diffuse : "color" of the object visibility * MaterialDiffuseColor * LightColor * LightPower * costheta+ // Specular : reflective highlight, like a mirror visibility * MaterialSpecularColor * LightColor * LightPower * pow(cosalpha,5); 65 OpenGL Shadow Mapping Result 66 33

OpenGL Shadow Mapping float bias = 0.005; float visibility = 1.0; if ( texture2d( shadowmap, ShadowCoord.xy ).z < ShadowCoord.z-bias){ visibility = 0.5; } Result: 67 OpenGL Shadow Mapping Bias based on slope: float bias = 0.005*tan(acos(cosTheta)); // costheta is dot( n,l ), clamped between 0 and 1 bias = clamp(bias, 0,0.01); 68 34

OpenGL Shadow Mapping Use solid objects: 69 Problems with shadow maps? Field of view Bias Aliasing 70 35

Field of view problem What if point to shadow is outside field of view of shadow map? Use cubical shadow map Use only spot lights! 71 Problems with shadow maps? Field of view Bias Aliasing 72 36

The bias nightmare For a point visible from the light source ShadowMap(x,y )z Avoid erroneous self shadowing 73 The bias nightmare Shadow ray casting Start the ray at hit+light*epsilon Add bias to avoid degeneracy Yet another instance of geometric robustness hit+epsilon*light hit 74 37

Bias for shadow maps ShadowMap(x,y )+bias < z Choosing the good bias value can be very tricky 75 Construct Light View Depth Map Realizing the theory in practice Constructing the depth map use existing hardware depth buffer use glpolygonoffset to bias depth value read back the depth buffer contents (bind to a texture) Depth map used as a 2D texture 76 38

Justification for glpolygonoffset When Constructing Shadow Maps Depth buffer contains window space depth values Post-perspective divide means non-linear distribution glpolygonoffset is guaranteed to be a window space offset Doing a clip space gltranslatef is not sufficient Common shadow mapping implementation mistake Actual bias in depth buffer units will vary over the frustum No way to account for slope of polygon 77 Sampling a Polygon s Depth at Pixel Centers (1) Consider a polygon covering pixels in 2D Polygon X Z Pixel centers 78 39

Sampling a Polygon s Depth at Pixel Centers (2) Consider a 2 nd grid for the polygon covering pixels in 2D X Z 79 Sampling a Polygon s Depth at Pixel Centers (3) How Z changes with respect to X X Z z/x 80 40

Why You Need glpolygonoffset s Slope Say pixel center is re-sampled to another grid For example, the shadow map texture s grid! The re-sampled depth could be off by +/-0.5 z/x and +/-0.5 z/y The maximum absolute error would be 0.5 z/x + 0.5 z/y max( z/x, z/y ) This assumes the two grids have pixel footprint area ratios of 1.0 Otherwise, we might need to scale by the ratio Exactly what polygon offset s slope depth bias does 81 Depth Map Bias Issues How much polygon offset bias depends Too little bias, everything begins to shadow Just right Too much bias, shadow starts too far back 82 41

Selecting the Depth Map Bias Not that hard Usually the following works well glpolygonoffset(scale = 1.1, bias = 4.0) Usually better to error on the side of too much bias adjust to suit the shadow issues in your scene Depends somewhat on shadow map precision more precision requires less of a bias When the shadow map is being magnified, a larger scale is often required 83 Problems with shadow maps? Field of view Bias Aliasing 84 42

Shadow map aliasing Undersampling of shadow map Reprojection aliasing 85 Alaising Finite shadow map resolution Result: pixelized shadows 86 43

Shadow maps In Renderman (High-end production software) 87 Shadow map filtering (PCF) Does not work! Filtering depth is not meaningful 88 44

Percentage closer filtering Filter the result of the test But makes the bias issue more tricky 89 Percentage closer filtering 5x5 samples Nice antialiased shadow Using a bigger filter produces fake soft shadows But makes the bias issue more tricky 90 45

Shadows in production Often use shadow maps Ray casting as fallback in case of robustness issues 91 Movie Time! 92 46

Alaising Bad aliasing cases: Large Scenes High resolution shadow map required Close-ups to shadow boundaries Zoom in Shadow stretches along the receiver 93 Aliasing Duelling frusta Light shines opposite to viewing direction 94 47

Aliasing Duelling frusta Resolution mismatch 95 Aliasing Miner s headlamp Similar frusta Similar sampling One shadowmap pixel for image pixel 96 48

Pros and Cons + general everything that can be rendered can cast and receive a shadow works together with vertex programs + fast full hardware support (almost) no overhead for static scenes two passes needed for dynamic scenes + robust + easy to implement - aliasing 97 Questions? 98 49