This flashcard is just one of a free flashcard set. See all flashcards!
27
How are Progressive Meshes generated, stored and reconstructed? How can we do Selective Refinement?
Original mesh: data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
Incremental Decimation applies a series of decimation operators:
data:image/s3,"s3://crabby-images/a5045/a5045c3746cf141eb459f8bcbc6eee077bcb422a" alt=""
By reversing these operators, we can reconstruct
from the decimated mesh data:image/s3,"s3://crabby-images/b8cd0/b8cd0c5466514d285da4b6c17174080cb11350ad" alt=""
data:image/s3,"s3://crabby-images/7ab74/7ab74f07401a6b36dbc438a63a964e7d19f1d428" alt=""
In order to make a Halfedge Collapse operator
reversible, we need to store:
Thus, each operator is stored as
data:image/s3,"s3://crabby-images/6a056/6a0566db12c49cf15e152d3111254dd9b474b2f6" alt=""
Selective Refinement
If we want to undo an operator
data:image/s3,"s3://crabby-images/6a056/6a0566db12c49cf15e152d3111254dd9b474b2f6" alt=""
the problem might be that one of the opposite vertices
or
does not exist:
In order to solve this problem, we store the refined mesh as a binary forest where the leaf nodes are the unrefined vertices and each inner node corresponds to a decimation operator.
During decimation, we remember from which original vertices our mesh started out. Initially, we store at every triangle corner a pointer to the incident vertex. As we decimate the mesh, these triangle corner labels remain intact. When we store an operator, instead of storing
,
as the vertices in the decimated mesh, we store the values stored in the respective triangle corners.
If we want to refine at a vertex
, we find the two opposite vertices
,
in the currently refined mesh by walking up the binary forest of operators until we find vertices that have already been instantiated.
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
Incremental Decimation applies a series of decimation operators:
data:image/s3,"s3://crabby-images/a5045/a5045c3746cf141eb459f8bcbc6eee077bcb422a" alt=""
By reversing these operators, we can reconstruct
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
data:image/s3,"s3://crabby-images/b8cd0/b8cd0c5466514d285da4b6c17174080cb11350ad" alt=""
data:image/s3,"s3://crabby-images/7ab74/7ab74f07401a6b36dbc438a63a964e7d19f1d428" alt=""
In order to make a Halfedge Collapse operator
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
- Position of the source vertex which was collapsed:
- A pointer to the target vertex towards which
was collapsed:
- Pointers to the two boundary vertices which were adjacent to both
and
before the collapse:
Thus, each operator is stored as
data:image/s3,"s3://crabby-images/6a056/6a0566db12c49cf15e152d3111254dd9b474b2f6" alt=""
Selective Refinement
If we want to undo an operator
data:image/s3,"s3://crabby-images/6a056/6a0566db12c49cf15e152d3111254dd9b474b2f6" alt=""
the problem might be that one of the opposite vertices
data:image/s3,"s3://crabby-images/c17e4/c17e4e5be4e5b959bff8eb32caa25b424ee98edb" alt=""
data:image/s3,"s3://crabby-images/85028/850280873bde023b4a6e666d9f9849bdfcc97f49" alt=""
-
/
might not exist yet if it is still not expanded
-
/
might not exist anymore if it has previously been split
In order to solve this problem, we store the refined mesh as a binary forest where the leaf nodes are the unrefined vertices and each inner node corresponds to a decimation operator.
During decimation, we remember from which original vertices our mesh started out. Initially, we store at every triangle corner a pointer to the incident vertex. As we decimate the mesh, these triangle corner labels remain intact. When we store an operator, instead of storing
data:image/s3,"s3://crabby-images/e614f/e614ff7618866461b127d795f7eb785b8f855994" alt=""
data:image/s3,"s3://crabby-images/cf1a6/cf1a6b8a3f3502693312a15ac18bff41700f86bf" alt=""
If we want to refine at a vertex
data:image/s3,"s3://crabby-images/906d0/906d09f5a3dcaac6ff74229b5fa84afa28259e37" alt=""
data:image/s3,"s3://crabby-images/c17e4/c17e4e5be4e5b959bff8eb32caa25b424ee98edb" alt=""
data:image/s3,"s3://crabby-images/85028/850280873bde023b4a6e666d9f9849bdfcc97f49" alt=""
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