From e26f0f38f4d1aeb3d9528ec884618dba175ab953 Mon Sep 17 00:00:00 2001 From: Matthias Hochsteger Date: Fri, 10 Jan 2020 17:58:37 +0100 Subject: [PATCH] Handle triangles correctly in BuildEdgeList() --- libsrc/meshing/improve2.hpp | 27 +++++++++++++++++++++------ 1 file changed, 21 insertions(+), 6 deletions(-) diff --git a/libsrc/meshing/improve2.hpp b/libsrc/meshing/improve2.hpp index 08172818..139bbb65 100644 --- a/libsrc/meshing/improve2.hpp +++ b/libsrc/meshing/improve2.hpp @@ -26,13 +26,28 @@ void BuildEdgeList( const Mesh & mesh, const Table & element const auto & elem = mesh[ei]; if (elem.IsDeleted()) continue; - for (int j = 0; j < 6; j++) + static_assert(is_same_v||is_same_v, "Invalid type for TINDEX"); + if constexpr(is_same_v) { - PointIndex pi0 = elem[tetedges[j][0]]; - PointIndex pi1 = elem[tetedges[j][1]]; - if (pi1 < pi0) Swap(pi0, pi1); - if(pi0==pi) - local_edges.Append(std::make_tuple(pi0, pi1)); + for (int j = 0; j < 3; j++) + { + PointIndex pi0 = elem[j]; + PointIndex pi1 = elem[(j+1)%3]; + if (pi1 < pi0) Swap(pi0, pi1); + if(pi0==pi) + local_edges.Append(std::make_tuple(pi0, pi1)); + } + } + else if constexpr(is_same_v) + { + for (int j = 0; j < 6; j++) + { + PointIndex pi0 = elem[tetedges[j][0]]; + PointIndex pi1 = elem[tetedges[j][1]]; + if (pi1 < pi0) Swap(pi0, pi1); + if(pi0==pi) + local_edges.Append(std::make_tuple(pi0, pi1)); + } } } QuickSort(local_edges);