top of page
data:image/s3,"s3://crabby-images/7693d/7693d45eaf8ca60a3a9dc5743260c4eec56a840b" alt="test_cap_back.PNG"
data:image/s3,"s3://crabby-images/bc7b6/bc7b6ae6c2aee34cce2900e34d408e19efb608ea" alt="Parallel Lines"
data:image/s3,"s3://crabby-images/6d229/6d229e9201908c034210a9a643c298a2c244bf2d" alt="Montaña"
data:image/s3,"s3://crabby-images/2d281/2d28156cea49d38816165f457a646481aa5249a9" alt="Elegante fondo abstracto"
SPACE PARTITIONING
Class
CS350
Instructor
Eder Beldad
Languages
C++ and OpenGL
About
In this class, we learned how acceleration structures and optimizations for graphics work, so we created a framework to implement these structures and to implement the collision detection algorithm GJK. The implemented structures were Bounding Volume Hierarchy, Octrees, and KD Trees.
Bounding Volume Hierarchy
For this structure, we developed three approaches that vary according to how the bounding volumes of the objects of the scenes are analyzed, the approaches are top-down, bottom-up and insertion.
​
data:image/s3,"s3://crabby-images/85a83/85a830a0c01ceaaf84c5c28fc437f4e30edc332b" alt="BVH.gif"
Octrees
For making the Octrees implementation as fast as possible, we used bitfields to analyze which were the children of each node that were activated. Also, we combined the Octree with the usage of frustum culling to make it even faster.
KD Trees
Being KD Trees one of the most used structures for Raytracing, we had to implement one to be able to perform ray-casting against the triangles of the objects in a scene in a very fast way.
data:image/s3,"s3://crabby-images/88eb5/88eb50b34d69b75c401f072a6a36427f5177497e" alt="Kdtree.PNG"
GJK
In physics simulation, one of the hardest challenges is to be able to compute complex polygons collisions cheaply. Gilbert-Johnson-Kerti collision detection algorithm takes advantage of the Voronoi Region to compute them without expensive computational cost.
data:image/s3,"s3://crabby-images/4ed25/4ed258ff465cbc3f58e20cd7f2ea79baa24c06c2" alt="GJK.gif"
bottom of page