Joel Shaffer's Marching Cubes
Marching Cube Algorithm Overview
- Read in all the data such that for any given point (x, y, z) there is an associated value
- Iterate over each point and construct a cube
- For the cube at each point check if the associated value is less than the specified ISO value
- If the value is less than the ISO, the cube intersects the surface at that point and a bit mask should be set for the specified vertex
- Now that each vertex is determined as either inside or outside the surface, determine where along the edges the surface intersects
- Edge intersections are determined using a linear interpolation between the points, utilizing the associated data and the ISO level
- Using the triangle table and the vertex bit mask set the coordinates for a triangle
- Calculate a surface normal for each triangle
- Once all triangle data has been determined, send the data to the vertext and fragment shaders for rasterization
My Code
- Aggregate data from 100+ image files into a single data source
- Create a 3D array representing the data
- Perform marching cubes algorithm to determine triangles
- Calculate surface normals for each triangle
- Send triangles and normal data to vertex/fragment shader (Gourad)
- Use keyboard commands (WASD) and mouse (rotation) to move around the model
Triangle / Cube Intersections
data:image/s3,"s3://crabby-images/cc6aa/cc6aab0e53212a0a29e8c10e13f47e18aabcc46d" alt=""
Souce: William E. Lorensen - MARCHING CUBES: A HIGH RESOLUTION 3D SURFACE CONSTRUCTION ALGORITHM
Original Stanford Images
data:image/s3,"s3://crabby-images/3ba78/3ba78ce53d9c548bc631c94b295a0d684298323e" alt=""
Source: Stanford Volume Data Archive
Examples of my volume visualizations
data:image/s3,"s3://crabby-images/e6186/e6186081a99a18e3735c59bb424caf55fd4cd2a9" alt=""
ISO 20 Surface Normals - 6,851,966 Triangles
data:image/s3,"s3://crabby-images/7f002/7f0027f6b0c18848be623a1bd7b7180b03840789" alt=""
ISO 20 Vertex Normals- 6,851,966 Triangles
data:image/s3,"s3://crabby-images/80b26/80b266df1f513c906600d3f3467755144680ab50" alt=""
ISO 80 - 2,617,506 Triangles
data:image/s3,"s3://crabby-images/2f12b/2f12b014aaf0f722017274c927da6fea9866170b" alt=""
ISO 100 - 2,103,652 Triangles
data:image/s3,"s3://crabby-images/2e3c5/2e3c52f3614276675ad4f004af0097fcf3d3b35a" alt=""
Side view of sphere slices
data:image/s3,"s3://crabby-images/0cc77/0cc77c6e70c6fba312acc0d6064ac45dcf6bf211" alt=""
Entire Sphere - 23480 Triangles
data:image/s3,"s3://crabby-images/5cf35/5cf35a5cdd569eb21f617b2905b274f0924008ff" alt=""
Zoomed in Sphere
data:image/s3,"s3://crabby-images/d2c9e/d2c9e4860c64cf71afdaaf8f7c7ed5085d172fd3" alt=""
Individual triangles on Sphere
data:image/s3,"s3://crabby-images/72b52/72b52cd95a039a23a38e60bc8189bc58e262952f" alt=""
Multiple spheres of varying data quality
data:image/s3,"s3://crabby-images/6c9df/6c9dfe6f9bfddcc7e1dc49bb540f9ab48cbb3e8e" alt=""
Curved ladder / planks
References
- Paul Bourke - Polygonising a scalar field - Triangle and Edge tables used from this source - here
- William E. Lorensen - MARCHING CUBES: A HIGH RESOLUTION 3D SURFACE CONSTRUCTION ALGORITHM - here
- Ostfold University College - Marching Cubes - here
- Stanford University Volume Data Archive - CTHead data and MRbrain data - here