20#ifdef DEAL_II_WITH_OPENCASCADE
26# include <IGESControl_Controller.hxx>
27# include <IGESControl_Reader.hxx>
28# include <IGESControl_Writer.hxx>
29# include <STEPControl_Controller.hxx>
30# include <STEPControl_Reader.hxx>
31# include <STEPControl_Writer.hxx>
32# include <TopExp_Explorer.hxx>
34# include <TopoDS_Edge.hxx>
35# include <TopoDS_Face.hxx>
36# include <TopoDS_Shape.hxx>
40# if DEAL_II_OPENCASCADE_VERSION_GTE(7, 0, 0)
41# include <Standard_Transient.hxx>
43# include <Handle_Standard_Transient.hxx>
46# include <BRepAdaptor_Curve.hxx>
47# if DEAL_II_OPENCASCADE_VERSION_GTE(7, 6, 0)
48# include <BRepAlgoAPI_Section.hxx>
50# include <BRepAdaptor_HCompCurve.hxx>
51# include <BRepAdaptor_HCurve.hxx>
52# include <BRepAlgo_Section.hxx>
54# include <BRepAdaptor_Surface.hxx>
55# include <BRepBndLib.hxx>
56# include <BRepBuilderAPI_MakeEdge.hxx>
57# include <BRepBuilderAPI_Sewing.hxx>
58# include <BRepBuilderAPI_Transform.hxx>
59# include <BRepMesh_IncrementalMesh.hxx>
60# include <BRepTools.hxx>
61# include <BRep_Builder.hxx>
62# include <GCPnts_AbscissaPoint.hxx>
63# include <GeomAPI_Interpolate.hxx>
64# include <GeomAPI_ProjectPointOnCurve.hxx>
65# include <GeomAPI_ProjectPointOnSurf.hxx>
66# include <GeomConvert_CompCurveToBSplineCurve.hxx>
67# include <GeomLProp_SLProps.hxx>
68# include <Geom_BoundedCurve.hxx>
69# include <Geom_Plane.hxx>
70# include <IntCurvesFace_ShapeIntersector.hxx>
71# include <Poly_Triangulation.hxx>
72# include <ShapeAnalysis_Surface.hxx>
73# include <StlAPI_Reader.hxx>
74# include <StlAPI_Writer.hxx>
75# include <TColStd_HSequenceOfTransient.hxx>
76# include <TColStd_SequenceOfTransient.hxx>
77# include <TColgp_HArray1OfPnt.hxx>
78# include <TopLoc_Location.hxx>
91 std::tuple<unsigned int, unsigned int, unsigned int>
95 unsigned int n_faces = 0,
n_edges = 0, n_vertices = 0;
96 for (exp.Init(shape,
TopAbs_FACE); exp.More(); exp.Next(), ++n_faces)
100 for (exp.Init(shape,
TopAbs_VERTEX); exp.More(); exp.Next(), ++n_vertices)
102 return std::tuple<unsigned int, unsigned int, unsigned int>(n_faces,
109 std::vector<TopoDS_Face> & faces,
110 std::vector<TopoDS_Edge> &
edges,
111 std::vector<TopoDS_Vertex> &
vertices)
118 for (exp.Init(shape,
TopAbs_FACE); exp.More(); exp.Next())
122 for (exp.Init(shape,
TopAbs_EDGE); exp.More(); exp.Next())
124 edges.push_back(TopoDS::Edge(exp.Current()));
128 vertices.push_back(TopoDS::Vertex(exp.Current()));
135 std::vector<TopoDS_Compound> &
compounds,
137 std::vector<TopoDS_Solid> &
solids,
138 std::vector<TopoDS_Shell> &
shells,
139 std::vector<TopoDS_Wire> &
wires)
156 for (exp.Init(shape,
TopAbs_SOLID); exp.More(); exp.Next())
160 for (exp.Init(shape,
TopAbs_SHELL); exp.More(); exp.Next())
164 for (exp.Init(shape,
TopAbs_WIRE); exp.More(); exp.Next())
170 template <
int spacedim>
177 return gp_Pnt(p[0], 0, 0);
179 return gp_Pnt(p[0], p[1], 0);
181 return gp_Pnt(p[0], p[1], p[2]);
187 template <
int spacedim>
197 "Cannot convert OpenCASCADE point to 1d if p.Y() != 0."));
200 "Cannot convert OpenCASCADE point to 1d if p.Z() != 0."));
205 "Cannot convert OpenCASCADE point to 2d if p.Z() != 0."));
219 const double tolerance)
221 const double rel_tol =
223 if (direction.norm() > 0.0)
224 return (
p1 * direction <
p2 * direction - rel_tol);
226 for (
int d = dim; d >= 0; --d)
227 if (
p1[d] <
p2[d] - rel_tol)
229 else if (
p2[d] <
p1[d] - rel_tol)
264 return trans.Shape();
301 std::vector<TopoDS_Vertex>
vertices;
302 std::vector<TopoDS_Edge>
edges;
303 std::vector<TopoDS_Face> faces;
306 std::none_of(faces.begin(), faces.end(), [&
Loc](
const TopoDS_Face &face) {
307 Handle(Poly_Triangulation) theTriangulation =
308 BRep_Tool::Triangulation(face, Loc);
309 return theTriangulation.IsNull();
335# if DEAL_II_OPENCASCADE_VERSION_GTE(6, 9, 0)
340# if !DEAL_II_OPENCASCADE_VERSION_GTE(7, 2, 0)
381 return trans.Shape();
392 ExcMessage(
"Failed to add shape to STEP controller."));
397 ExcMessage(
"Failed to write translated shape to STEP file."));
403 double tolerance = 0.0;
405 std::vector<TopoDS_Face> faces;
406 std::vector<TopoDS_Edge>
edges;
407 std::vector<TopoDS_Vertex>
vertices;
417 for (
const auto &face : faces)
433# if DEAL_II_OPENCASCADE_VERSION_GTE(7, 6, 0)
479 if (
added[i] ==
false)
501 ExcMessage(
"Joining some of the Edges failed."));
514 const double tolerance)
521 dim > 1 ? direction[1] : 0,
522 dim > 2 ? direction[2] : 0));
540 for (
int i = 0; i <
Inters.NbPnt(); ++i)
560 const double tolerance)
564 if (direction * direction > 0)
569 return OpenCASCADE::point_compare(p1,
579 for (
unsigned int vertex = 0; vertex < n_vertices; ++vertex)
588 ExcMessage(
"Interpolated bspline generation failed"));
598 template <
int spacedim>
599 std::vector<TopoDS_Edge>
607 std::map<unsigned int, std::pair<unsigned int, unsigned int>>
vert_to_faces;
608 std::map<unsigned int, std::pair<unsigned int, unsigned int>>
face_to_verts;
612 unsigned int face_index;
614 for (
const auto &cell :
triangulation.active_cell_iterators())
616 if (cell->face(f)->at_boundary())
619 face_index = cell->face(f)->index();
620 const unsigned int v0 = cell->face(f)->vertex_index(0);
621 const unsigned int v1 = cell->face(f)->vertex_index(1);
627 const auto verts = mapping.get_vertices(cell);
629 f, 0,
true,
false,
false)];
631 f, 1,
true,
false,
false)];
690 if (f.second ==
false)
692 face_index = f.first;
705 const double tolerance)
713# ifdef DEAL_II_HAVE_CXX17
716 unsigned int counter = 0;
777 u =
Proj.LowerDistanceParameter();
784 return std::tuple<Point<dim>,
TopoDS_Shape, double,
double>(
793 const double tolerance)
797 return std::get<0>(
ref);
803 const double tolerance)
815 std::tuple<unsigned int, unsigned int, unsigned int>
numbers =
822 "Could not find normal: the shape containing the closest point has 0 faces."));
826 "Could not find normal: the shape containing the closest point has more than 1 face."));
869 ExcMessage(
"Curvature is not well defined!"));
893 template <
int spacedim>
899 const double u0 =
surf.FirstUParameter();
900 const double u1 =
surf.LastUParameter();
901 const double v0 =
surf.FirstVParameter();
902 const double v1 =
surf.LastVParameter();
904 std::vector<CellData<2>> cells;
905 std::vector<Point<spacedim>>
vertices;
914 for (
unsigned int i = 0; i < 4; ++i)
915 cell.vertices[i] = i;
917 cells.push_back(cell);
921# include "utilities.inst"
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
static ::ExceptionBase & ExcNotImplemented()
#define Assert(cond, exc)
static ::ExceptionBase & ExcUnsupportedShape()
static ::ExceptionBase & ExcMessage(std::string arg1)
#define AssertThrow(cond, exc)
TopoDS_Edge interpolation_curve(std::vector< Point< dim > > &curve_points, const Tensor< 1, dim > &direction=Tensor< 1, dim >(), const bool closed=false, const double tolerance=1e-7)
std::tuple< Point< 3 >, Tensor< 1, 3 >, double, double > push_forward_and_differential_forms(const TopoDS_Face &face, const double u, const double v, const double tolerance=1e-7)
void extract_compound_shapes(const TopoDS_Shape &shape, std::vector< TopoDS_Compound > &compounds, std::vector< TopoDS_CompSolid > &compsolids, std::vector< TopoDS_Solid > &solids, std::vector< TopoDS_Shell > &shells, std::vector< TopoDS_Wire > &wires)
Point< dim > push_forward(const TopoDS_Shape &in_shape, const double u, const double v)
std::tuple< unsigned int, unsigned int, unsigned int > count_elements(const TopoDS_Shape &shape)
void write_STEP(const TopoDS_Shape &shape, const std::string &filename)
std::tuple< Point< 3 >, Tensor< 1, 3 >, double, double > closest_point_and_differential_forms(const TopoDS_Shape &in_shape, const Point< 3 > &origin, const double tolerance=1e-7)
void extract_geometrical_shapes(const TopoDS_Shape &shape, std::vector< TopoDS_Face > &faces, std::vector< TopoDS_Edge > &edges, std::vector< TopoDS_Vertex > &vertices)
TopoDS_Edge join_edges(const TopoDS_Shape &in_shape, const double tolerance=1e-7)
TopoDS_Shape read_STEP(const std::string &filename, const double scale_factor=1e-3)
bool point_compare(const Point< dim > &p1, const Point< dim > &p2, const Tensor< 1, dim > &direction=Tensor< 1, dim >(), const double tolerance=1e-10)
Point< spacedim > point(const gp_Pnt &p, const double tolerance=1e-10)
Point< dim > closest_point(const TopoDS_Shape &in_shape, const Point< dim > &origin, const double tolerance=1e-7)
std::tuple< Point< dim >, TopoDS_Shape, double, double > project_point_and_pull_back(const TopoDS_Shape &in_shape, const Point< dim > &origin, const double tolerance=1e-7)
Point< dim > line_intersection(const TopoDS_Shape &in_shape, const Point< dim > &origin, const Tensor< 1, dim > &direction, const double tolerance=1e-7)
void write_STL(const TopoDS_Shape &shape, const std::string &filename, const double deflection, const bool sew_different_faces=false, const double sewer_tolerance=1e-6, const bool is_relative=false, const double angular_deflection=0.5, const bool in_parallel=false)
void create_triangulation(const TopoDS_Face &face, Triangulation< 2, spacedim > &tria)
TopoDS_Shape read_STL(const std::string &filename)
TopoDS_Shape intersect_plane(const TopoDS_Shape &in_shape, const double c_x, const double c_y, const double c_z, const double c, const double tolerance=1e-7)
std::vector< TopoDS_Edge > create_curves_from_triangulation_boundary(const Triangulation< 2, spacedim > &triangulation, const Mapping< 2, spacedim > &mapping=StaticMappingQ1< 2, spacedim >::mapping)
double get_shape_tolerance(const TopoDS_Shape &shape)
void write_IGES(const TopoDS_Shape &shape, const std::string &filename)
TopoDS_Shape read_IGES(const std::string &filename, const double scale_factor=1e-3)
::VectorizedArray< Number, width > max(const ::VectorizedArray< Number, width > &, const ::VectorizedArray< Number, width > &)
::VectorizedArray< Number, width > abs(const ::VectorizedArray< Number, width > &)
const ::parallel::distributed::Triangulation< dim, spacedim > * triangulation
static unsigned int face_to_cell_vertices(const unsigned int face, const unsigned int vertex, const bool face_orientation=true, const bool face_flip=false, const bool face_rotation=false)
static std_cxx20::ranges::iota_view< unsigned int, unsigned int > face_indices()
const ::Triangulation< dim, spacedim > & tria