20#ifdef DEAL_II_WITH_CGAL
24# include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
25# include <CGAL/Labeled_mesh_domain_3.h>
26# include <CGAL/Mesh_triangulation_3.h>
41 const Function<3> &dealii_implicit_function,
42 const CGALWrappers::AdditionalData<dim> &data,
43 const Point<3> &interior_point,
44 const double &outer_ball_radius)
46# ifdef DEAL_II_WITH_CGAL
49 "The implicit function must have exactly one component."));
50 Assert(dealii_implicit_function.
value(interior_point) < 0,
52 "The implicit function must be negative at the interior point."));
53 Assert(outer_ball_radius > 0,
54 ExcMessage(
"The outer ball radius must be positive."));
56 ExcMessage(
"The triangulation must be empty."));
58 if constexpr (dim == 3)
60 using K = CGAL::Exact_predicates_inexact_constructions_kernel;
61 using NumberType = K::FT;
62 using Point_3 = K::Point_3;
63 using Sphere_3 = K::Sphere_3;
65 using Mesh_domain = CGAL::Labeled_mesh_domain_3<K>;
67 CGAL::Mesh_triangulation_3<Mesh_domain,
70 using C3t3 = CGAL::Mesh_complex_3_in_triangulation_3<Tr, int, int>;
71 using Mesh_criteria = CGAL::Mesh_criteria_3<Tr>;
74 auto cgal_implicit_function = [&](
const Point_3 &p) {
76 dealii_implicit_function.
value(Point<3>(p.x(), p.y(), p.z())));
79 Mesh_domain domain = Mesh_domain::create_implicit_mesh_domain(
80 cgal_implicit_function,
82 Point_3(interior_point[0], interior_point[1], interior_point[2]),
83 outer_ball_radius * outer_ball_radius));
85 Mesh_criteria criteria(CGAL::parameters::facet_size = data.
facet_size,
87 CGAL::parameters::facet_distance =
89 CGAL::parameters::cell_radius_edge_ratio =
91 CGAL::parameters::cell_size = data.
cell_size);
93 auto cgal_triangulation = CGAL::make_mesh_3<C3t3>(domain, criteria);
94 CGALWrappers::cgal_triangulation_to_dealii_triangulation(
95 cgal_triangulation, tria);
97 else if constexpr (dim == 2)
100 using Tr = CGAL::Surface_mesh_default_triangulation_3;
101 using C2t3 = CGAL::Complex_2_in_triangulation_3<Tr>;
102 using GT = Tr::Geom_traits;
103 using Sphere_3 = GT::Sphere_3;
104 using Point_3 = GT::Point_3;
106 using Function = FT (*)(Point_3);
107 using Surface_3 = CGAL::Implicit_surface_3<GT, Function>;
111 auto cgal_implicit_function = [&](
const Point_3 &p) {
113 dealii_implicit_function.
value(Point<3>(p.x(), p.y(), p.z())));
116 Surface_3 surface(cgal_implicit_function,
117 Sphere_3(Point_3(interior_point[0],
120 outer_ball_radius * outer_ball_radius));
126 CGAL::Surface_mesh_default_criteria_3<Tr> criteria(data.angular_bound,
128 data.distance_bound);
129 CGAL::make_surface_mesh(c2t3,
132 CGAL::Non_manifold_tag());
133 CGAL::facets_in_complex_2_to_triangle_mesh(c2t3, mesh);
134 CGALWrappers::cgal_surface_mesh_to_dealii_triangulation(mesh, tria);
144 (void)dealii_implicit_function;
146 (void)interior_point;
147 (void)outer_ball_radius;
157 Triangulation<3> &vol_tria,
158 const CGALWrappers::AdditionalData<3> &data)
160# ifdef DEAL_II_WITH_CGAL
164 "The input triangulation cannot be empty when calling this function."));
168 "The output triangulation must be empty when calling this function."));
169 using K = CGAL::Exact_predicates_inexact_constructions_kernel;
170 using Point_3 = K::Point_3;
173 CGAL::Polyhedral_mesh_domain_with_features_3<
K,
174 CGAL::Surface_mesh<Point_3>>;
175 using Tr = CGAL::Mesh_triangulation_3<Mesh_domain,
178 using Mesh_criteria = CGAL::Mesh_criteria_3<Tr>;
180 CGAL::Mesh_complex_3_in_triangulation_3<Tr,
181 Mesh_domain::Corner_index,
182 Mesh_domain::Curve_index>;
184 CGAL::Surface_mesh<Point_3> mesh;
194 CGAL::Polygon_mesh_processing::triangulate_faces(mesh);
195 CGAL::Polygon_mesh_processing::stitch_borders(mesh);
196 Mesh_domain domain(mesh);
197 domain.detect_features();
198 Mesh_criteria criteria(CGAL::parameters::facet_size = data.
facet_size,
200 CGAL::parameters::facet_distance =
202 CGAL::parameters::cell_radius_edge_ratio =
204 CGAL::parameters::cell_size = data.
cell_size);
205 const auto cgal_triangulation = CGAL::make_mesh_3<C3t3>(domain, criteria);
206 CGALWrappers::cgal_triangulation_to_dealii_triangulation(cgal_triangulation,
221# include "grid/grid_generator_cgal.inst"
const unsigned int n_components
virtual RangeNumberType value(const Point< dim > &p, const unsigned int component=0) const
unsigned int n_active_cells() const
unsigned int n_cells() const
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define Assert(cond, exc)
static ::ExceptionBase & ExcImpossibleInDim(int arg1)
static ::ExceptionBase & ExcMessage(std::string arg1)
#define AssertThrow(cond, exc)
void dealii_tria_to_cgal_surface_mesh(const ::Triangulation< dim, spacedim > &triangulation, CGAL::Surface_mesh< CGALPointType > &mesh)
CGAL::Sequential_tag ConcurrencyTag
CGAL::Exact_predicates_exact_constructions_kernel_with_sqrt K
CGAL::Surface_mesh< K_exact::Point_3 > Surface_mesh
void surface_mesh_to_volumetric_mesh(const Triangulation< 2, 3 > &surface_tria, Triangulation< 3 > &vol_tria, const CGALWrappers::AdditionalData< 3 > &data=CGALWrappers::AdditionalData< 3 >{})
void implicit_function(Triangulation< dim, 3 > &tria, const Function< 3 > &implicit_function, const CGALWrappers::AdditionalData< dim > &data=CGALWrappers::AdditionalData< dim >{}, const Point< 3 > &interior_point=Point< 3 >(), const double &outer_ball_radius=1.0)
double cell_radius_edge_ratio