15#ifndef dealii_cgal_point_conversion_h
16#define dealii_cgal_point_conversion_h
22#ifdef DEAL_II_WITH_CGAL
24# include <CGAL/version.h>
25# if CGAL_VERSION_MAJOR >= 6
26# include <CGAL/Installation/internal/disable_deprecation_warnings_and_errors.h>
28# include <CGAL/Cartesian.h>
29# include <CGAL/Exact_predicates_exact_constructions_kernel.h>
30# include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
31# include <CGAL/Simple_cartesian.h>
45 template <
typename CGALPo
intType,
int dim>
47 dealii_point_to_cgal_point(const ::Point<dim> &p);
57 template <
int dim,
typename CGALPo
intType>
59 cgal_point_to_dealii_point(
const CGALPointType &p);
65 template <
typename CGALPo
intType,
int dim>
67 dealii_point_to_cgal_point(const ::Point<dim> &p)
69 constexpr int cdim = CGALPointType::Ambient_dimension::value;
70 static_assert(dim <= cdim,
"Only dim <= cdim supported");
71 if constexpr (cdim == 1)
72 return CGALPointType(p[0]);
73 else if constexpr (cdim == 2)
74 return CGALPointType(p[0], dim > 1 ? p[1] : 0);
75 else if constexpr (cdim == 3)
76 return CGALPointType(p[0], dim > 1 ? p[1] : 0, dim > 2 ? p[2] : 0);
79 return CGALPointType();
84 template <
int dim,
typename CGALPo
intType>
86 cgal_point_to_dealii_point(
const CGALPointType &p)
88 constexpr int cdim = CGALPointType::Ambient_dimension::value;
89 if constexpr (dim == 1)
90 return ::Point<dim>(CGAL::to_double(p.x()));
91 else if constexpr (dim == 2)
92 return ::Point<dim>(CGAL::to_double(p.x()),
93 cdim > 1 ? CGAL::to_double(p.y()) : 0);
94 else if constexpr (dim == 3)
95 return ::Point<dim>(CGAL::to_double(p.x()),
96 cdim > 1 ? CGAL::to_double(p.y()) : 0,
97 cdim > 2 ? CGAL::to_double(p.z()) : 0);
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define DEAL_II_NOT_IMPLEMENTED()