Metal for Ray Tracing Acceleration
Metal for Ray Tracing Acceleration
WWDC 2018
Metal performance Shaders
GPU — accelerated primitives, optimized for iOS and macOS
- Image processing
- Linear algebra
- Machine learning- inference and training (new)
- Ray tracing (new)
Ray Tracing
Tracing a ray’s path as it interacts with a scene
- Rendering
- Audio and physics simulation
- Collision detection
- AI and pathfinding
- Ambient occlusion, refraction, area lights, depth of field, motion blur
- Method of choice for photorealistic, offline rendering
- Significantly more computationally expensive — doing more work to simulate physical effects
data:image/s3,"s3://crabby-images/2e3fd/2e3fdc085c3485e23cf42ed1713207d8ab69bb8c" alt=""
Rasterization
- Projects triangles onto the screen one at a time
- Fast-method of choice for games and real-time applications
- Difficult to model behavior of light
Reflections
- Can be computed accurately with ray tracing
data:image/s3,"s3://crabby-images/7585b/7585be207b8ab78b6d6d43e11fe95e76197db6ed" alt=""
Soft shadows
- Can be computed directly with ray tracing
- Realistic transition from hard to soft shadows
data:image/s3,"s3://crabby-images/dbf4c/dbf4c9affe76fa407f07cdd754759c7f13ac69ed" alt=""
Global illumination
- Naturally modeled with ray tracing
data:image/s3,"s3://crabby-images/c112c/c112c09913fc090ec554b8483b0bc7ba3e9d5d5c" alt=""
Rendering with Ray Tracing
data:image/s3,"s3://crabby-images/cbe24/cbe24a909613f508e90997116a362bba1f2ddc91" alt=""
data:image/s3,"s3://crabby-images/19282/192820dba5a4eb4cf70470d5609d6d2a2c4028be" alt=""
MPSRayIntersector
- Ray intersector accelerates ray/triangle intersection tests on the GPU
- Accepts batches of rays in a Metal buffer
- Returns one intersection per ray
- Encodes into a Metal command buffer
data:image/s3,"s3://crabby-images/daf9e/daf9ee00e1152da39989ad65933fad78d307f9c7" alt=""
data:image/s3,"s3://crabby-images/c0620/c0620cb1f8f3d5afdc5074fb6fb4b828ce37a724" alt=""
Accelerating Ray/Scene Intersection
data:image/s3,"s3://crabby-images/1ced2/1ced209bc0b75f9840f6eadcfde0e58dd1cb6c05" alt=""
Ray Tracing with Metal Performance Shaders
data:image/s3,"s3://crabby-images/340de/340de1bdccc7b85a4fe5de49f473c00af3a55500" alt=""
Primary Rays and Shading
data:image/s3,"s3://crabby-images/0e75e/0e75eca4ec67d8804221b5cae0f837948b95a5df" alt=""
Creating an Intersector
data:image/s3,"s3://crabby-images/f7f5e/f7f5e693c584744a767a2a24ef9bf02fcdcd4585" alt=""
Creating an Acceleration Structure
data:image/s3,"s3://crabby-images/c2377/c2377d7ebbae296e635f712182e3c14df4f8e8f3" alt=""
data:image/s3,"s3://crabby-images/d2a7c/d2a7c94e8e35ca964b4c29ea5c1fe6e5b7315a27" alt=""
data:image/s3,"s3://crabby-images/8400a/8400ada711e910d408680c0ac157a2879adc35ee" alt=""
Generating Primary Rays
data:image/s3,"s3://crabby-images/8c551/8c551bdc8e106ca0718d1837b00e8b77dbce0a84" alt=""
Finding Intersections with the Scene
data:image/s3,"s3://crabby-images/91699/9169939fe5ca6bee4fdd11a952981eab656b0950" alt=""
Shading
data:image/s3,"s3://crabby-images/eb740/eb74077d761d2a3fc3cac4633aa22e43e39018b6" alt=""
data:image/s3,"s3://crabby-images/f561c/f561c572759b97cfb1bf542e6eb43a52db30ae47" alt=""
Shadow Rays
data:image/s3,"s3://crabby-images/3c952/3c9521ffcc46ea1c915f14402c746e619fac622f" alt=""
data:image/s3,"s3://crabby-images/1b931/1b931b43d321da46efefcf6179cbd71b03c06831" alt=""
data:image/s3,"s3://crabby-images/af922/af9224fc940a8b3dbca1df6144f951b2303322cd" alt=""
Shadow Rays vs Primary Rays
- Maximum intersection distance
- Don’t need triangle index or barycentric coordinates
- Propagate color from shading kernel to final kernel
data:image/s3,"s3://crabby-images/c9695/c969589fc85a4667d4c295c50ead81ee1e22ccb9" alt=""
Customizing the Ray Struct
- Ray type is configurable
- Choose what data is provided to the intersector
- Append app — specific data
data:image/s3,"s3://crabby-images/47689/476890b9d637cea2aff1a7dac2a02e100176f30c" alt=""
data:image/s3,"s3://crabby-images/891bc/891bc94f1919a206b68ac861b3c1d2bf79d8d192" alt=""
Finding Shadow Ray Intersections
data:image/s3,"s3://crabby-images/4a390/4a39010f3ccbce4a92349106ab44346e5b2124e8" alt=""
Adding Ray Color to the Image
data:image/s3,"s3://crabby-images/bb703/bb703d6cfce450c8d6586666ba9a878d6d63eea1" alt=""
Secondary Rays
data:image/s3,"s3://crabby-images/34445/3444588e5e1078dcc9655d3ff9b6a93895953a59" alt=""
data:image/s3,"s3://crabby-images/b467e/b467ea424500e2a11c79fb0351e4a40543f6c229" alt=""
data:image/s3,"s3://crabby-images/9bd21/9bd214b46a57b2412c7f61a5e97e32422ed11459" alt=""
Updating Secondary Rays
data:image/s3,"s3://crabby-images/3cc6b/3cc6bdfdaf0470a423b30d71d9971657dc6f2940" alt=""
Demo
Multi-GPU Ray Tracing
- Split work across GPUs
- Copy data between GPUs
- Synchronize execution
Splitting Work Across GPUs
data:image/s3,"s3://crabby-images/8e927/8e927bafafae8fbdf7975129f21dcdce8236aa1d" alt=""
Copying Scene Data
data:image/s3,"s3://crabby-images/6f338/6f3387ad3f4ee9e429f7ec5e54eb9ba0dec8c7cb" alt=""
Creating a Shared CPU Allocation
data:image/s3,"s3://crabby-images/669c0/669c0bd2e5852da5e50135b33dd5a2a235069a5d" alt=""
data:image/s3,"s3://crabby-images/ea93e/ea93e23c10551cc66ab4a0dfe89a17931e5c3191" alt=""
Synchronizing with Metal Events
data:image/s3,"s3://crabby-images/aa380/aa3803f4998e3ce40df3c5b28a8e8546400b18a1" alt=""
Load Balancing 👍
- GPUs can have different performance
- Some regions are more complex to render
- Adjust region sizes to keep GPUs fully utilized
data:image/s3,"s3://crabby-images/b4731/b4731f80d981bc274f93dca82293bcc1159761dc" alt=""
data:image/s3,"s3://crabby-images/f76c2/f76c27f9549b11d5a98cf921910aa362d82c9119" alt=""
data:image/s3,"s3://crabby-images/b7979/b7979447c95fb6f467e6314d58eef2c2e58b51ac" alt=""
Timing GPU Work
data:image/s3,"s3://crabby-images/4db7c/4db7c079a28a97f5600e3ea9dd8018088eaddb8d" alt=""