Hacker News new | past | comments | ask | show | jobs | submit login

I found this part not well covered in the article too. But to your question, ray tracing starts fromt the camera. Typically you define the direction of a ray for each pixel, and that ray will bounce around to calculate a final color, and that color will be rendered as the color for that pixel.

My assumption is that the shared scene and shaders might play a role here, although the direction of the rays will still vary.




A big part of raytracing is checking which objects are intersected by ray. When you have two cameras very near one another, most rays for second camera will intersect the same objects as corresponding rays on first camera.


If I recall correctly, this would not matter too much in practice.

The reason for this is that while the primary rays are a coherent bundle, the secondary rays are all over the place. Essentially, as soon as you hit the first object, it bounces in a random direction all over the scene. And for every primary ray, you might end up spawning a dozen secondary rays.

I believe this is also the reason dedicated raytracing hardware is needed for GPUs. While a coherent bundle is fairly trivial to parallelize, incoherent rays are going to absolutely wreck your SIMD performance. You really want dedicated hardware to properly manage this, for example by doing BVH traversal and collecting all secondary rays that hit the same object for a single mostly-coherent render pass.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: