In this assignment, you will be implementing SDF operators on various primitives and use a ray marcher to render them. Ray marching is a technique for rendering implicit surfaces where the ray-primitive intersection equation cannot be solved analytically.
Warning: this assignment diverges significantly from marching cubes, so switching options midway can be costly for your time and effort.
We have provided a preview scene, and a toggle for the ray marcher rendering. When you correctly implement the ray marcher, the image should match the preview scene containing the simple geometry. Your ray marching calculation should be performed in the fragment shader.
The ray marcher should generate a ray direction, and march through the scene using the distances computed from sphere tracing.
Note: Your scene won't be rendered until you have implemented the SDFs for primitives below.
- Generate Rays (15 pts): for each fragment inside the fragment shader, compute a ray direction for the ray marcher
- Sphere Tracing (10 pts): compute the nearest distance from the scene SDFs and update the ray marching's step size.
These are simple primitives with well-defined SDFs. We encourage trying other SDFs not listed here, they are interesting!
- Sphere (3pts)
- Box (3pts)
- Cone (3pts)
- Torus (3pts)
- Cylinder (3pts)
To create constructive geometry, and interesting shapes (such as holes, bumps, etc.), implement the following operators to combine your primitive SDFs.
- Intersection (2pts)
- Subtraction (3pts)
- Union (2pts)
- Transformation (8pts)
- translation and scaling
Compute the normals to use for shading your surface.
- Read Chapter 13 of Morgan McGuire's notes
Implement a simple Lambert material. Additional materials can earn extra points.
- intersection, subtraction, union, transformation (20pts)
Use time as an input to some of your functions to animate your scene!
- Implement SDF for Mandelbulb (10pts)
- You need to implement naive raymarching (not sphere tracing) to get this to work
- Lighting effects
- Soft shadowing using secondary rays (5pts)
- Ambient occlusion (10pts)
- Additional materials besides Lambert. (5pts each)
- Additional SDFs besides the listed primitive. (5pts each)
http://graphics.cs.williams.edu/courses/cs371/f14/reading/implicit.pdf
- Update
README.md
to contain a solid description of your project - Publish your project to gh-pages.
npm run deploy
. It should now be visible at http://username.github.io/repo-name - Create a pull request to this repository, and in the comment, include a link to your published project.
- Submit the link to your pull request on Canvas.
npm run build
- Add and commit all changes
npm run deploy
- If you're having problems with assets not linking correctly, make sure you wrap you're filepaths in
require()
. This will make the bundler package and your static assets as well. So, instead ofloadTexture('./images/thing.bmp')
, doloadTexture(require('./images/thing.bmp'))
.