From 6db1c2d831274b687fc94576eb48dde70de62a17 Mon Sep 17 00:00:00 2001 From: Joachim Schoeberl Date: Sun, 24 Sep 2023 11:26:53 +0200 Subject: [PATCH] more (pyramid) cases --- libsrc/meshing/classifyhpel.hpp | 67 ++++++++++++++++++++++++++------- libsrc/meshing/hpref_tet.hpp | 3 +- libsrc/meshing/hprefinement.cpp | 14 +++---- 3 files changed, 60 insertions(+), 24 deletions(-) diff --git a/libsrc/meshing/classifyhpel.hpp b/libsrc/meshing/classifyhpel.hpp index ab2fca7b..6d5b7294 100644 --- a/libsrc/meshing/classifyhpel.hpp +++ b/libsrc/meshing/classifyhpel.hpp @@ -20,7 +20,7 @@ HPREF_ELEMENT_TYPE ClassifyTet(HPRefElement & el, INDEX_2_HASHTABLE & edges if (debug < 4) debug = 0; - *testout << "new el" << endl; + // *testout << "new el" << endl; for (int j = 0; j < 4; j++) for (int k = 0; k < 4; k++) @@ -209,9 +209,9 @@ HPREF_ELEMENT_TYPE ClassifyTet(HPRefElement & el, INDEX_2_HASHTABLE & edges bool se5 = isedge5 || (isfedge5 && !isface[0] && !isface[2]); bool se6 = isedge6 || (isfedge6 && !isface[0] && !isface[1]); - *testout << "sp = " << sp1 << sp2 << sp3 << sp4 << endl; - *testout << "se = " << se1 << se2 << se3 << se4 << se5 << se6 << endl; - *testout << "sf = " << isface[0] << isface[1] << isface[2] << isface[3] << endl; + // *testout << "sp = " << sp1 << sp2 << sp3 << sp4 << endl; + // *testout << "se = " << se1 << se2 << se3 << se4 << se5 << se6 << endl; + // *testout << "sf = " << isface[0] << isface[1] << isface[2] << isface[3] << endl; switch (isface[0]+isface[1]+isface[2]+isface[3]) @@ -943,7 +943,7 @@ HPREF_ELEMENT_TYPE ClassifyTrig(HPRefElement & el, INDEX_2_HASHTABLE & edge if(cornerpoint.Test(el.PNum(p[k]))) point_sing[p[k]-1] = 3; - *testout << "point_sing = " << point_sing[0] << point_sing[1] << point_sing[2] << endl; + // *testout << "point_sing = " << point_sing[0] << point_sing[1] << point_sing[2] << endl; if(edge_sing[0] + edge_sing[1] + edge_sing[2] == 0) { @@ -1007,7 +1007,7 @@ HPREF_ELEMENT_TYPE ClassifyTrig(HPRefElement & el, INDEX_2_HASHTABLE & edge if(type!=HP_NONE) break; } - *testout << "type = " << type << endl; + // *testout << "type = " << type << endl; for(int k=0;k<3;k++) el[k] = pnums[k]; /*if(type != HP_NONE) @@ -1291,7 +1291,7 @@ HPREF_ELEMENT_TYPE ClassifyQuad(HPRefElement & el, INDEX_2_HASHTABLE & edge int ep1(-1), ep2(-1), ep3(-1), ep4(-1), cp1(-1), cp2(-1), cp3(-1), cp4(-1); int isedge1, isedge2, isedge3, isedge4; - *testout << "edges = " << edges << endl; + // *testout << "edges = " << edges << endl; for (int j = 1; j <= 4; j++) { @@ -1753,9 +1753,10 @@ HPREF_ELEMENT_TYPE ClassifyHex7 (HPRefElement & el, INDEX_2_HASHTABLE & edg // const ELEMENT_FACE * elfaces = MeshTopology::GetFaces1 (HEX); // const ELEMENT_EDGE * eledges = MeshTopology::GetEdges1 (HEX); - INDEX_3 fbot = { el.pnums[0], el.pnums[1], el.pnums[2] }; + INDEX_4 fbot4 = { el.pnums[0], el.pnums[1], el.pnums[2], el.pnums[3] }; INDEX_3 ftop = { el.pnums[4], el.pnums[5], el.pnums[6] }; - fbot.Sort(); + fbot4.Sort(); + INDEX_3 fbot = { fbot4[0], fbot4[1], fbot4[2] }; ftop.Sort(); bool singbot = faces.Used(fbot); @@ -1822,6 +1823,11 @@ HPREF_ELEMENT_TYPE ClassifyPyramid(HPRefElement & el, INDEX_2_HASHTABLE & e NgBitArray & cornerpoint, NgBitArray & edgepoint, INDEX_3_HASHTABLE & faces, INDEX_2_HASHTABLE & face_edges, INDEX_2_HASHTABLE & surf_edges, NgArray & facepoint) { + // *testout << "classify pyramid, pnums = "; + // for (int i = 0; i < 5; i++) *testout << el.pnums[i] << " "; + // *testout << endl; + + HPREF_ELEMENT_TYPE type = HP_NONE; // implementation only for HP_PYRAMID @@ -1844,6 +1850,7 @@ HPREF_ELEMENT_TYPE ClassifyPyramid(HPRefElement & el, INDEX_2_HASHTABLE & e for(int m=0;m<4 && type == HP_NONE;m++) { + *testout << "m = " << m << endl; int p[5] = {m%4, m%4+1, m%4+2, m%4+3, 4}; for(int l=0;l<5;l++) @@ -1874,12 +1881,27 @@ HPREF_ELEMENT_TYPE ClassifyPyramid(HPRefElement & el, INDEX_2_HASHTABLE & e for (int k=0;k<5;k++) { - INDEX_3 i3; - INDEX_4 i4 = INDEX_4(el.pnums[p[elfaces[k][0]-1]], el.pnums[p[elfaces[k][1]-1]], el.pnums[p[elfaces[k][2]-1]], + INDEX_3 i3; + /* + INDEX_4 i4 = INDEX_4(el.pnums[p[elfaces[k][0]-1]], el.pnums[p[elfaces[k][1]-1]], el.pnums[p[elfaces[k][2]-1]], el.pnums[p[elfaces[k][3]-1]]); i4.Sort(); i3 = INDEX_3(i4.I1(), i4.I2(), i4.I3()); - + */ + if (k < 4) + { + i3 = INDEX_3(el.pnums[p[elfaces[k][0]-1]], el.pnums[p[elfaces[k][1]-1]], el.pnums[p[elfaces[k][2]-1]]); + i3.Sort(); + } + else + { + INDEX_4 i4 = INDEX_4(el.pnums[p[elfaces[k][0]-1]], el.pnums[p[elfaces[k][1]-1]], el.pnums[p[elfaces[k][2]-1]], + el.pnums[p[elfaces[k][3]-1]]); + i4.Sort(); + i3 = INDEX_3(i4.I1(), i4.I2(), i4.I3()); + } + + if (faces.Used (i3)) { @@ -1889,7 +1911,19 @@ HPREF_ELEMENT_TYPE ClassifyPyramid(HPRefElement & el, INDEX_2_HASHTABLE & e } sface +=face_sing[k]; } - + + *testout << "point_sing: "; + for (int k = 0; k < 5; k++) *testout << point_sing[k] << " "; + *testout << endl; + + *testout << "edge_sing: "; + for (int k = 0; k < 4; k++) *testout << edge_sing[k] << " "; + *testout << endl; + + *testout << "face_sing: "; + for (int k = 0; k < 5; k++) *testout << face_sing[k] << " "; + *testout << endl; + if(!sface && !spoint && !sedge) return(HP_PYRAMID); if(!sface && !sedge && point_sing[p[0]] == spoint) @@ -1900,7 +1934,12 @@ HPREF_ELEMENT_TYPE ClassifyPyramid(HPRefElement & el, INDEX_2_HASHTABLE & e type = HP_PYRAMID_EDGES; if(sface && sface == face_sing[0] && spoint == point_sing[4] + 2) - type = HP_PYRAMID_1FB_0E_1VA; + { + if (point_sing[4] == 1) + type = HP_PYRAMID_1FB_0E_0V; + else + type = HP_PYRAMID_1FB_0E_1VA; + } if(type != HP_NONE) diff --git a/libsrc/meshing/hpref_tet.hpp b/libsrc/meshing/hpref_tet.hpp index ae805ae2..06bc7728 100644 --- a/libsrc/meshing/hpref_tet.hpp +++ b/libsrc/meshing/hpref_tet.hpp @@ -3644,8 +3644,7 @@ HPRefStruct reftet_1f_1ea_3v El(HP_TET_1F_0E_0V, { E41, E43, E42, F423 }), El(HP_TET_1F_0E_1VA, { E41, V4, E42, E43 }), - // El(HP_PYRAMID_1FB_0E_0V, { E24, E23, F213, F214, F234 }), // TODO - El(HP_PYRAMID, { E24, E23, F213, F214, F234 }), + El(HP_PYRAMID_1FB_0E_0V, { E24, E23, F213, F214, F234 }), // needs check El(HP_PYRAMID_1FB_0E_1VA, { E23, E24, F214, F213, V2 }), El(HP_TET_1E_1VA, { V2, E21, F214, F213 }), } diff --git a/libsrc/meshing/hprefinement.cpp b/libsrc/meshing/hprefinement.cpp index b8fef9fc..1fae823f 100644 --- a/libsrc/meshing/hprefinement.cpp +++ b/libsrc/meshing/hprefinement.cpp @@ -1763,6 +1763,7 @@ bool CheckSingularities(Mesh & mesh, INDEX_2_HASHTABLE & edges, INDEX_2_HAS i3 = INDEX_3(i4.I1(), i4.I2(), i4.I3()); } faces.Set (i3, domnr); + *testout << "set face " << i3 << ", domnr = " << domnr << endl; for (int j = 0; j < el.GetNP(); j++) { @@ -1774,9 +1775,9 @@ bool CheckSingularities(Mesh & mesh, INDEX_2_HASHTABLE & edges, INDEX_2_HAS } } - (*testout) << "singular edges = " << edges << endl; - (*testout) << "singular faces = " << faces << endl; - (*testout) << "singular faces_edges = " << face_edges << endl; + // (*testout) << "singular edges = " << edges << endl; + // (*testout) << "singular faces = " << faces << endl; + // (*testout) << "singular faces_edges = " << face_edges << endl; } else { @@ -1901,7 +1902,8 @@ bool CheckSingularities(Mesh & mesh, INDEX_2_HASHTABLE & edges, INDEX_2_HAS bool sing = CheckSingularities(mesh, edges, edgepoint_dom, cornerpoint, edgepoint, faces, face_edges, - surf_edges, facepoint, levels, act_ref); + surf_edges, facepoint, levels, act_ref); + if (act_ref == 1 && split == SPLIT_ALFELD) sing = true; if(sing==0) return(sing); @@ -1915,8 +1917,6 @@ bool CheckSingularities(Mesh & mesh, INDEX_2_HASHTABLE & edges, INDEX_2_HAS for( int i = 0; i & edges, INDEX_2_HAS { hpel.type = ClassifyPyramid(hpel, edges, edgepoint_dom, cornerpoint, edgepoint, faces, face_edges, surf_edges, facepoint); - - cout << " ** Pyramid classified " << hpel.type << endl; break; } default: