Expand description
grisubal algorithm description & implementation
This module contain all code used to implement our grid submersion algorithm, or grisubal for short.
This algorithm builds the mesh of a geometry by overlapping a grid over it and intersecting the grid with the geometry. It is inspired by the approach described in this research note.
§Assumptions / Hypotheses
Boundaries are consistently oriented, i.e.:
- normals of segments making up a boundary all point outward / inward, no mix,
- boundaries are closed,
- if there are nested boundaries, their orientation are consistent one with the other; this is an extension of the first condition.
§Algorithm
The steps followed by the algorithm are detailed in the user guide. The following is a summary.
§Pre-processing
- Compute characteristics of a grid covering the entire geometry, avoiding exact intersection between the grid’s segments and the geometry’s vertices.
- Remove “redundant” Points of Interest to avoid duplicated vertices.
- Check for obvious orientation issues (open geometry & orientation per boundary).
§Main kernel
- Compute intersection vertices between the geometry’s segments and the grid.
- Insert given intersections into the grid.
- Build new edge data by searching through the original segments.
- Insert new edges into the map. Mark darts on each side of the edge with the
Boundary
attribute.
§Post-processing clip
Depending on the specified argument, one side (or the other) of the boundary can be clipped.
This is specified using the Clip
enum; The following steps describe the operation for
Clip::Left
:
- Fetch all darts marked as
Boundary::Left
during the last step of the main kernel. - Use these darts’ faces as starting point for a coloring algorithm. The search is done using a BFS and only consider adjacent faces if the adjacent dart isn’t marked as a boundary. This step is also used to check for orientation inconsistencies, most importantly orientation across distinct boundaries.
- Delete all darts making up the marked faces.
The Boundary
attribute is then removed from the map before return.
Enums§
- Post-processing clip operation.
- Enum used to model potential errors of the
grisubal
kernel.
Functions§
- Main algorithm call function.