39#ifndef H_OGF_MESH_COMMANDS_MESH_GROB_VOLUME_COMMANDS_H
40#define H_OGF_MESH_COMMANDS_MESH_GROB_VOLUME_COMMANDS_H
87 bool preprocess=
false,
88 bool merge_coplanar_facets=
false,
90 double max_hole_area=0.01,
93 bool keep_regions=
false,
118 unsigned int nb_points = 30000,
120 bool pyramids =
true,
121 bool border_refine =
false,
122 double border_max_dist = 0.2,
123 double min_normal_cos = 0.5,
124 double max_corner_cos = 0.6
130 enum VoronoiSimplification {
158 VoronoiSimplification simplification = simplify_tet_voro,
159 double angle_threshold = 1e-3,
163 bool tessellate_non_convex =
false,
164 bool generate_ids =
true,
165 bool medial_axis =
false
179 bool save_histo=
false,
201 bool refine_surface =
false,
202 double max_distance = 0.2
223 bool pyramids =
true,
224 double min_normal_cos = 0.5,
225 double max_corner_cos = 0.6
Base class for Commands related with a MeshGrob object.
Commands that manipulate volume meshes.
void Voronoi_meshing(const NewMeshGrobName &voronoi="voronoi", index_t nb_cells=1000, VoronoiSimplification simplification=simplify_tet_voro, double angle_threshold=1e-3, double shrink=0.0, const NewMeshGrobName &points="", bool exact=true, bool tessellate_non_convex=false, bool generate_ids=true, bool medial_axis=false)
Generates a Voronoi mesh from a volume and points.
void compute_borders()
Copies the border of the volume into the surfacic part of the mesh.
void tet_meshing_with_points(const MeshGrobName &points, const NewMeshGrobName &tetrahedra="tetrahedra", bool refine_surface=false, double max_distance=0.2)
Creates a tetrahedral mesh from a closed surface mesh and a pointset, using tetgen....
void volume_mesh_statistics(bool save_histo=false, index_t nb_bins=100)
Computes and displays various statistics for a hex-dominant mesh.
void tet2hex(const NewMeshGrobName &hexdom_name="hexes", bool prisms=true, bool pyramids=true, double min_normal_cos=0.5, double max_corner_cos=0.6)
Converts a tetrahedral mesh into a hexahedral dominant mesh by merging tetrahedra.
void display_volume()
Displays the volume of a mesh.
void remesh_tetrahedra(double quality=0.5)
Extracts the boundary of the zone with tetrahedral cells and remeshes it using Tetgen.
void hex_dominant_meshing(const NewMeshGrobName &hexdom_name="hexes", unsigned int nb_points=30000, bool prisms=true, bool pyramids=true, bool border_refine=false, double border_max_dist=0.2, double min_normal_cos=0.5, double max_corner_cos=0.6)
Fills a closed mesh with hexaedra (+other cells).
MeshGrobVolumeCommands()
MeshGrobVolumeCommands constructor.
~MeshGrobVolumeCommands() override
MeshGrobVolumeCommands destructor.
A template class for strings that need to have a specific type in the GOM system.
Base class for Commands related with a MeshGrob object.
geo_index_t index_t
The type for storing and manipulating indices.
Global Graphite namespace.
Definitions common to all include files in the mesh library.