This flashcard is just one of a free flashcard set. See all flashcards!
95
What problems are addressed by the Extended Marching Cubes algorithm? How does it solve them?
Problems of Marching Cubes
Solution: Directed Distances
instead of an iso-value, store three directed distances for every vertex: exact distance to the surface crossing along every cube edge
Solution: Feature Detection / Sampling / Reconstruction
Feature Detection
based on the gradient values at the edge intersections, compute normal vectors:
data:image/s3,"s3://crabby-images/773dc/773dc6224f7c40905338bda50ab52f2563e23fa4" alt=""
find the two normal vectors
which span the largest angle
data:image/s3,"s3://crabby-images/77092/77092fd2fe530dd3cc3665dd8fcd936a89fc6dce" alt=""
data:image/s3,"s3://crabby-images/0cee8/0cee831bfbc5eefe96e247097490e8529c09853a" alt=""
find the normal
which forms the smallest angle to the orthogonal direction data:image/s3,"s3://crabby-images/c87ea/c87ea73493764e2a530ab276e23f39e972dd9fc4" alt=""
data:image/s3,"s3://crabby-images/d1a12/d1a12474015df0094f92590b74b626fe34dbadda" alt=""
data:image/s3,"s3://crabby-images/0967e/0967ee10b6b6dd3b4c8cd9a06cfe3595bef8a2d0" alt=""
If
, we have detected a feature.
If additionally
, the current feature is a corner feature (two large opening angles). Otherwise, it is an edge feature (one large opening angle).
Feature Sampling
Find intersection point of tangent planes:
data:image/s3,"s3://crabby-images/2458e/2458e1ccc35f8315fd7a62fc91006b9f04ee9dbc" alt=""
data:image/s3,"s3://crabby-images/631b7/631b7aa702e644adfa332cf9b81f717e537e1904" alt=""
This might not have a unique solution:
Over-determined: No common intersection point. Find least-squares solution (closest to all planes).
Under-determined: Infinitely many intersection points. Find least-norm solution (closest to voxel center).
Solve using SVD:
data:image/s3,"s3://crabby-images/43f0a/43f0acb296eb1cdece47fd014e41f5ce4e0731b0" alt=""
data:image/s3,"s3://crabby-images/141d3/141d3399756124d676235ebba129faee16309cb9" alt=""
data:image/s3,"s3://crabby-images/7affd/7affd90b1b5fdf852c30f6115e9a5dabf2811de9" alt=""
data:image/s3,"s3://crabby-images/5b2a0/5b2a0b397a2aa1137f99834abf672a9ac22503b7" alt=""
Feature Reconstruction
Look up cell configuration from Marching Cubes table. If in a feature cell, insert feature vertex at computed position and connect with a triangle fan. Flip edges so they align with feature edges.
- edge intersections are computed using linear interpolation (inaccurate)
- assumes smooth isosurface: sharp features within cells are lost (aliasing problem)
Solution: Directed Distances
instead of an iso-value, store three directed distances for every vertex: exact distance to the surface crossing along every cube edge
Solution: Feature Detection / Sampling / Reconstruction
Feature Detection
based on the gradient values at the edge intersections, compute normal vectors:
data:image/s3,"s3://crabby-images/773dc/773dc6224f7c40905338bda50ab52f2563e23fa4" alt=""
find the two normal vectors
data:image/s3,"s3://crabby-images/934be/934be146f37aeb365782b10cff33ee5efcb99971" alt=""
data:image/s3,"s3://crabby-images/77092/77092fd2fe530dd3cc3665dd8fcd936a89fc6dce" alt=""
data:image/s3,"s3://crabby-images/0cee8/0cee831bfbc5eefe96e247097490e8529c09853a" alt=""
find the normal
data:image/s3,"s3://crabby-images/724ba/724bad11c3e3fbbdbcedcddd683d7b23046be225" alt=""
data:image/s3,"s3://crabby-images/c87ea/c87ea73493764e2a530ab276e23f39e972dd9fc4" alt=""
data:image/s3,"s3://crabby-images/d1a12/d1a12474015df0094f92590b74b626fe34dbadda" alt=""
data:image/s3,"s3://crabby-images/0967e/0967ee10b6b6dd3b4c8cd9a06cfe3595bef8a2d0" alt=""
If
data:image/s3,"s3://crabby-images/df061/df0611e63ff38de67f87cb6c354159c0d7ec0c22" alt=""
If additionally
data:image/s3,"s3://crabby-images/53e16/53e165a98807a23a81c5fc814af79aa5feb4d29b" alt=""
Feature Sampling
Find intersection point of tangent planes:
data:image/s3,"s3://crabby-images/2458e/2458e1ccc35f8315fd7a62fc91006b9f04ee9dbc" alt=""
data:image/s3,"s3://crabby-images/631b7/631b7aa702e644adfa332cf9b81f717e537e1904" alt=""
This might not have a unique solution:
Over-determined: No common intersection point. Find least-squares solution (closest to all planes).
Under-determined: Infinitely many intersection points. Find least-norm solution (closest to voxel center).
Solve using SVD:
data:image/s3,"s3://crabby-images/43f0a/43f0acb296eb1cdece47fd014e41f5ce4e0731b0" alt=""
data:image/s3,"s3://crabby-images/141d3/141d3399756124d676235ebba129faee16309cb9" alt=""
data:image/s3,"s3://crabby-images/7affd/7affd90b1b5fdf852c30f6115e9a5dabf2811de9" alt=""
data:image/s3,"s3://crabby-images/5b2a0/5b2a0b397a2aa1137f99834abf672a9ac22503b7" alt=""
Feature Reconstruction
Look up cell configuration from Marching Cubes table. If in a feature cell, insert feature vertex at computed position and connect with a triangle fan. Flip edges so they align with feature edges.
data:image/s3,"s3://crabby-images/c64c7/c64c7f61abb9e2d96a6c69beff1bd79eb8bfc4e8" alt=""
Flashcard info:
Author: janisborn
Main topic: Informatik
Topic: Computergrafik
School / Univ.: RWTH Aachen
City: Aachen
Published: 18.05.2022