This is yet another Ray Tracing in One Weekend clone, but this time using CUDA instead of C++. CUDA can be used to speed up the code. For example, on my machine, the C++ code renders the test image in 90 seconds. The CUDA accelerated code renders the image in about 7 seconds.
Initial coding started in May, 2018 and was posted to the NVIDIA Developer blog November 5, 2018: https://devblogs.nvidia.com/accelerated-ray-tracing-cuda/
Peter Shirley has written a few ebooks about Ray Tracing. You can find out more at http://in1weekend.blogspot.com/2016/01/ray-tracing-in-one-weekend.html Note that as of April, 2018 the books are pay what you wish and 50% of the proceeds go towards not-for-profit programming education organizations. They are also available for $3 each on Amazon as a Kindle download.
This repository contains code for converting the first ray tracer ebook "Ray Tracing in one Weekend" from C++ to CUDA. By changing to CUDA, depending on your CPU and GPU you can see speedups of 10x or more!
Before coding the ray tracer in CUDA, I recommend that you code the ray tracer in C++, first. You should understand the concepts presented in a serial language well, then translate this knowledge to CUDA. In fact, since CUDA uses C++, much of your code can be reused.
The canonical C++ code from Peter Shirley is at https://github.com/petershirley/raytracinginoneweekend. I am basing this on https://github.com/pfranz/raytracinginoneweekend which has each chapter as a separate git branch. This is very handy for checking out the code at each chapter.
Here are links to the git branch for each Chapter. If you look at the README.md you'll see some hints about what needed to be done. See the Makefile for the standard targets. Note that you'll want to adjust the GENCODE_FLAGS in the CUDA Makefiles for your specific graphics card architecture.
The master branch has the code as Peter Shirley presented it in C++. I added a Makefile so you can make out.jpg
and compare the runtime to CUDA. To build variants that use CUDA, check out one of these branches. E.g. git checkout ch01_output_cuda
- Chapter 1 - Basic Output:
git checkout ch01_output_cuda
- Chapter 2 - Vectors:
git checkout ch02_vec3_cuda
- Chapter 3 - Rays:
git checkout ch03_rays_cuda
- Chapter 4 - Spheres:
git checkout ch04_sphere_cuda
- Chapter 5 - Normals:
git checkout ch05_normals_cuda
- Chapter 6 - Antialiasing:
git checkout ch06_antialiasing_cuda
- Chapter 7 - Diffuse:
git checkout ch07_diffuse_cuda
- Chapter 8 - Metal:
git checkout ch08_metal_cuda
- Chapter 9 - Dielectrics:
git checkout ch09_dielectrics_cuda
- Chapter 10 - Camera:
git checkout ch10_camera_cuda
- Chapter 11 - Defocus Blur:
git checkout ch11_defocus_blur_cuda
- Chapter 12 - Where Next:
git checkout ch12_where_next_cuda
Basic process (after Chapter 3) was:
# checkout original code & create a cuda branch
git checkout origin/chyy_yyy
git checkout chyy_yyy
git branch -m chyy_yyy_cuda
git mv main.cc main.cu
<checkin>
# grab previous chapters code as a starting point
cp chapterxx/* .
# edit & fix code
# checkin code
# save current code for next chapter
mkdir chapteryy
cp * chapteryy