1 / 28

Ray Tracing, Part 2

Christian Lauterbach COMP 770, 2/16/2009. Ray Tracing, Part 2. Overview. Acceleration structures Spatial hierarchies Object hierarchies Interactive Ray Tracing techniques Ray packets Optimized hierarchy construction. Last lecture. Ray Tracing For each pixel: generate ray

marly
Download Presentation

Ray Tracing, Part 2

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Christian Lauterbach COMP 770, 2/16/2009 Ray Tracing, Part 2

  2. Overview • Acceleration structures • Spatial hierarchies • Object hierarchies • Interactive Ray Tracing techniques • Ray packets • Optimized hierarchy construction

  3. Last lecture • Ray Tracing • For each pixel: generate ray • For each primitive: • Does ray hit primitive? • Yes: Test depth / write color • That means linear time complexity in number of primitives!

  4. Acceleration structures • Goal: fast search operation for ray that returns all intersecting primitives • Then test only against those • Operation should take sub-linear time • In practice: conservative superset

  5. Acceleration structures • Broad classification: • Spatial hierarchies • Grids • Octrees • Kd-trees, BSP trees • Object hierarchies • Bounding volume hierarchies • Spatial kd-trees

  6. Spatial hierarchies: grids • Regular subdivision of space into cells • Cells almost always cubes • Each object is referenced in each cell it overlaps • Nested grids also possible • Ray tracing with the grid: • Find entry cell of ray • For each cell: • Intersect with all objects in cell. If hit, terminate. • Otherwise, walk to next cell ray can hit

  7. Spatial hierarchies: kd-trees • Binary tree of space subdivisions • Each is axis-aligned plane x y y

  8. Spatial hierarchies: kd-trees • Traversing a kd-tree: recursive • Start at root node • For current node: • If inner node: • Find intersection of ray with plane • If ray intersects both children, recurse onnear side, then far side • Otherwise, recurse on side it intersects • If leaf node: • Intersect with all object. If hit, terminate.

  9. RT with the kd-tree (2) what can the ray possibly hit? ray 1 ray 2 ray 3 split plane 'near' node 'far' node

  10. RT with the kd-tree (3) three cases: hitpoint above split: far node only hitpoint below split: near node only otherwise: near, then far 'above' and 'below' rather vague use distance t along ray ray = origin + t *direction

  11. RT with the kd-tree (4) when does the ray intersect? split plane t_min t_split t_max 'near' node 'far' node

  12. Kd-tree traversal • Simple and fast implementation • In practice: using stack, not recursion • Very quick intersection test (couple FLOPS + tests) • Overall: logarithmic complexity for each ray

  13. Object hierarchies: BVHs • Different approach: subdivide objects, not space • Hierarchical clustering of objects • Each cluster represented by bounding volume • Binary tree • Each parent node fully contains children

  14. Bounding volumes • Practically anything can be bounding volume • Just need ray intersection method • Typical choices: • Spheres • Axis-aligned bounding boxes (AABBs) • Oriented bounding boxes (OBBs) • k-DOPs • Trade-off between intersection speed and how closely the BV encloses the geometry

  15. BVH traversal • Recursive algorithm: • Start with root node • For current node: • Does ray intersect node’s BV? If no, return • Is inner node? • Yes, recurse on children • Is leaf node? • Intersect with object(s) in node, store intersection results • Note: can’t return after first intersection!

  16. Choosing a structure • There is no ‘best’ acceleration structure • All have pros and cons • Grid:+ fast construction- bad for high local detail (teapot/stadium)

  17. Choosing a structure • There is no ‘best’ acceleration structure • All have pros and cons • kd-tree:+ fast traversal- expensive build, only static scenes

  18. Choosing a structure • There is no ‘best’ acceleration structure • All have pros and cons • BVH:+ can be updated for dynamic scenes- traversal more expensive than kd-tree

  19. Overview • Acceleration structures • Spatial hierarchies • Object hierarchies • Interactive Ray Tracing techniques • Ray packets • Optimized hierarchy construction

  20. Ray Packets • Often have large set of rays close together • Idea:trace rays in coherent groups (ray packets) Viewer Screen

  21. Ray coherence • How does this change tracing? • Traversal and object intersectionwork on group of rays at a time • Also generate secondary (shadow, …) rays in packets • General idea: • If one ray intersects, all are intersected

  22. BVH traversal • Recursive algorithm: • Start with root node • For current node: • Does ray intersect node’s BV? If no, return • Is inner node? • Yes, recurse on children • Is leaf node? • Intersect ray with all object(s) in node, store intersection results

  23. BVH packet traversal • Recursive algorithm: • Start with root node • For current node: • Does any ray intersect node’s BV? If no, return • Is inner node? • Yes, recurse on children • Is leaf node? • Intersect all rays with all object(s) in node,store intersection results

  24. Ray packet advantages • Why does this make things faster? • Less memory bandwidth: nodes/objects only loaded once for rays in packet • Allows data parallel processing! • Current CPUs: e.g. Intel SSE • All GPUs • Disadvantage: • Rays can be intersected with objects/nodes they would never hit!

  25. Data parallelism • Essentially vector operations (SIMD) • Operations work on all elements in parallel v1 v2 v3 v4 v5 v6 v7 v8 v1 v2 v3 v4 v5 v6 v7 v8 + w1 w2 w3 w4 w5 w6 w7 w8 = v1+w1 v2+w2 v3+w3 v4+w4 v5+w5 v6+w6 v7+w7 v8+w8

  26. Data parallelism • Vector operations usually as fast as a single scalar operation • Intel SSE: 4-wide vectors • GPUs: 8-32 wide • Cell: 4-wide • Vector processors: up to 64,000!

  27. SIMD ray processing • Can use SIMD units to parallelize for rays • Each vector has one component from one ray • Thus, can process small group at same speed as one ray! ray1 ray2 ray3 ray4 ray5 ray6 ray7 ray8 trii trii trii trii trii trii trii trii trii 

  28. Optimized hierarchy construction • The way the hierarchy is constructed has high impact on traversal performance

More Related