From 7bdde3ef852924c5a2cf8632a7b1d0cd5d625ec2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Joachim=20Sch=C3=B6berl?= Date: Sun, 15 May 2016 19:18:27 +0200 Subject: [PATCH] orient tets for fem-tp --- libsrc/csg/genmesh.cpp | 1 + libsrc/meshing/meshclass.cpp | 29 +++++++++++++++++++++++++++++ 2 files changed, 30 insertions(+) diff --git a/libsrc/csg/genmesh.cpp b/libsrc/csg/genmesh.cpp index 5a1ff811..de45e713 100644 --- a/libsrc/csg/genmesh.cpp +++ b/libsrc/csg/genmesh.cpp @@ -843,6 +843,7 @@ namespace netgen #endif } + mesh -> OrderElements(); return TCL_OK; } } diff --git a/libsrc/meshing/meshclass.cpp b/libsrc/meshing/meshclass.cpp index cc160acd..9c06c819 100644 --- a/libsrc/meshing/meshclass.cpp +++ b/libsrc/meshing/meshclass.cpp @@ -3262,6 +3262,35 @@ namespace netgen el.GeomInfoPi(3) = hgi; } } + + for (auto & el : volelements) + if (el.GetType() == TET) + { + // lowest index first ... + int mini = 0; + for (int i = 1; i < 4; i++) + if (el[i] < el[mini]) mini = i; + if (mini != 0) + { // swap 0 with mini, and the other two ... + int i3 = -1, i4 = -1; + for (int i = 1; i < 4; i++) + if (i != mini) + { + i4 = i3; + i3 = i; + } + swap (el[0], el[mini]); + swap (el[i3], el[i4]); + } + + while (el[1] > el[2] || el[1] > el[3]) + { // rotate element to move second index to second position + auto hp = el[1]; + el[1] = el[2]; + el[2] = el[3]; + el[3] = hp; + } + } } int Mesh :: CheckConsistentBoundary () const