From 27a6d291875de453591af3bbb8ded7764b7b2ab4 Mon Sep 17 00:00:00 2001 From: Christopher Lackner Date: Wed, 20 Apr 2022 17:18:44 +0200 Subject: [PATCH] fix occ closesurfaces ending in a larger plane --- libsrc/meshing/basegeom.cpp | 36 ++++++++++++++++++++++++++++++++---- libsrc/meshing/basegeom.hpp | 1 + 2 files changed, 33 insertions(+), 4 deletions(-) diff --git a/libsrc/meshing/basegeom.cpp b/libsrc/meshing/basegeom.cpp index a340ccb6..586d351f 100644 --- a/libsrc/meshing/basegeom.cpp +++ b/libsrc/meshing/basegeom.cpp @@ -107,6 +107,35 @@ namespace netgen return true; } + bool GeometryFace :: IsConnectingCloseSurfaces() const + { + std::map verts; + for(const auto& edge : edges) + { + verts[&edge->GetStartVertex()] = false; + verts[&edge->GetEndVertex()] = false; + } + for(const auto& [v, is_mapped] : verts) + { + if(is_mapped) + continue; + for(const auto& v_ident : v->identifications) + { + const auto& other = v_ident.to == v ? v_ident.from : v_ident.to; + if(v_ident.type == Identifications::CLOSESURFACES && + verts.count(other)) + { + verts[v] = true; + verts[other] = true; + } + } + } + for(auto& [v, is_mapped] : verts) + if(!is_mapped) + return false; + return true; + } + void GeometryFace :: RestrictHTrig(Mesh& mesh, const PointGeomInfo& gi0, const PointGeomInfo& gi1, @@ -761,7 +790,6 @@ namespace netgen if(face.primary == &face) { // check if this face connects two identified closesurfaces - bool is_connecting_closesurfaces = false; auto & idents = mesh.GetIdentifications(); std::set relevant_edges; auto segments = face.GetBoundary(mesh); @@ -786,6 +814,7 @@ namespace netgen Transformation<3> trafo; + if(face.IsConnectingCloseSurfaces()) for(const auto &s : segments) { auto edgenr = s.edgenr-1; @@ -793,6 +822,7 @@ namespace netgen ShapeIdentification *edge_mapping; // have edgenr first time, search for closesurface identification + if(mapped_edges[edgenr] == UNINITIALIZED) { mapped_edges[edgenr] = NOT_MAPPED; @@ -805,7 +835,6 @@ namespace netgen { trafo = edge_ident.trafo; mapped_edges[edgenr] = edge_ident.to->nr; - is_connecting_closesurfaces = true; break; } } @@ -826,8 +855,7 @@ namespace netgen mesh.AddSurfaceElement(sel); } } - - if(!is_connecting_closesurfaces) + else if(MeshFace(mesh, mparam, k, glob2loc)) n_failed_faces++; } diff --git a/libsrc/meshing/basegeom.hpp b/libsrc/meshing/basegeom.hpp index 36c923c4..228ecfad 100644 --- a/libsrc/meshing/basegeom.hpp +++ b/libsrc/meshing/basegeom.hpp @@ -158,6 +158,7 @@ namespace netgen } virtual bool IsMappedShape( const GeometryShape & other, const Transformation<3> & trafo, double tolerance ) const override; + virtual bool IsConnectingCloseSurfaces() const; protected: void RestrictHTrig(Mesh& mesh,