1
0
mirror of https://github.com/NGSolve/netgen.git synced 2025-01-17 00:10:34 +05:00
netgen/libsrc/meshing/hpref_trig.hpp
2024-01-15 22:43:18 +00:00

849 lines
13 KiB
C++

// HP_TRIG
int reftrig_splitedges[][3] =
{
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_newelstypes[] =
{
HP_TRIG,
HP_NONE,
};
int reftrig_newels[][8] =
{
{ 1, 2, 3 },
};
HPRef_Struct reftrig =
{
HP_TRIG,
reftrig_splitedges,
0, 0,
reftrig_newelstypes,
reftrig_newels
};
// HP_TRIG_SINGCORNER
int reftrig_singcorner_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singcorner_newelstypes[] =
{
HP_TRIG_SINGCORNER,
HP_QUAD,
HP_NONE,
};
int reftrig_singcorner_newels[][8] =
{
{ 1, 4, 5 },
{ 2, 3, 5, 4 },
};
HPRef_Struct reftrig_singcorner =
{
HP_TRIG,
reftrig_singcorner_splitedges,
0, 0,
reftrig_singcorner_newelstypes,
reftrig_singcorner_newels
};
/*
// HP_TRIG_SINGCORNER, trigs only
int reftrig_singcorner_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singcorner_newelstypes[] =
{
HP_TRIG_SINGCORNER,
HP_TRIG,
HP_TRIG,
HP_NONE,
};
int reftrig_singcorner_newels[][8] =
{
{ 1, 4, 5 },
{ 4, 2, 5 },
{ 5, 2, 3 },
};
HPRef_Struct reftrig_singcorner =
{
HP_TRIG,
reftrig_singcorner_splitedges,
0, 0,
reftrig_singcorner_newelstypes,
reftrig_singcorner_newels
};
*/
// HP_TRIG_SINGCORNER12
int reftrig_singcorner12_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 1, 6 },
{ 2, 3, 7 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singcorner12_newelstypes[] =
{
HP_TRIG_SINGCORNER,
HP_TRIG_SINGCORNER,
HP_QUAD,
HP_TRIG,
HP_NONE,
};
int reftrig_singcorner12_newels[][8] =
{
{ 1, 4, 5 },
{ 2, 7, 6 },
{ 4, 6, 7, 5 },
{ 5, 7, 3 },
};
HPRef_Struct reftrig_singcorner12 =
{
HP_TRIG,
reftrig_singcorner12_splitedges,
0, 0,
reftrig_singcorner12_newelstypes,
reftrig_singcorner12_newels
};
// HP_TRIG_SINGCORNER123_2D
int reftrig_singcorner123_2D_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 1, 6 },
{ 2, 3, 7 },
{ 3, 1, 8 },
{ 3, 2, 9 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singcorner123_2D_newelstypes[] =
{
HP_TRIG_SINGCORNER,
HP_TRIG_SINGCORNER,
HP_TRIG_SINGCORNER,
HP_QUAD,
HP_QUAD,
HP_NONE,
};
int reftrig_singcorner123_2D_newels[][8] =
{
{ 1, 4, 5 },
{ 2, 7, 6 },
{ 3, 8, 9 },
{ 4, 6, 8, 5 },
{ 6, 7, 9, 8 },
};
HPRef_Struct reftrig_singcorner123_2D =
{
HP_TRIG,
reftrig_singcorner123_2D_splitedges,
0, 0,
reftrig_singcorner123_2D_newelstypes,
reftrig_singcorner123_2D_newels
};
// HP_TRIG_SINGCORNER123
int reftrig_singcorner123_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 1, 6 },
{ 2, 3, 7 },
{ 3, 1, 8 },
{ 3, 2, 9 },
{ 0, 0, 0 }
};
int reftrig_singcorner123_splitfaces[][4] =
{
{ 1, 2, 3, 10 },
{ 2, 3, 1, 11 },
{ 3, 1, 2, 12 },
{ 0, 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singcorner123_newelstypes[] =
{
HP_DUMMY_QUAD_SINGCORNER,
HP_DUMMY_QUAD_SINGCORNER,
HP_DUMMY_QUAD_SINGCORNER,
// HP_TRIG_SINGCORNER,
// HP_TRIG,
// HP_TRIG_SINGCORNER,
// HP_TRIG,
// HP_TRIG_SINGCORNER,
// HP_TRIG,
HP_QUAD,
HP_QUAD,
HP_QUAD,
HP_TRIG,
HP_NONE,
};
int reftrig_singcorner123_newels[][8] =
{
{ 1, 4, 10, 5 },
{ 2, 7, 11, 6 },
{ 3, 8, 12, 9 },
// { 1, 4, 5 },
// { 5, 4, 10 },
// { 2, 7, 6 },
// { 6, 7, 11 },
// { 3, 8, 9 },
// { 8, 12, 9 },
{ 4, 6, 11, 10 },
{ 7, 9, 12, 11 },
{ 8, 5, 10, 12 },
{ 10, 11, 12 },
};
HPRef_Struct reftrig_singcorner123 =
{
HP_TRIG,
reftrig_singcorner123_splitedges,
reftrig_singcorner123_splitfaces,
0,
reftrig_singcorner123_newelstypes,
reftrig_singcorner123_newels
};
// HP_TRIG_SINGEDGE
int reftrig_singedge_splitedges[][3] =
{
{ 2, 3, 4 },
{ 1, 3, 5 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedge_newelstypes[] =
{
HP_TRIG,
HP_QUAD_SINGEDGE,
HP_NONE,
};
int reftrig_singedge_newels[][8] =
{
{ 4, 3, 5 },
{ 1, 2, 4, 5 },
};
HPRef_Struct reftrig_singedge =
{
HP_TRIG,
reftrig_singedge_splitedges,
0, 0,
reftrig_singedge_newelstypes,
reftrig_singedge_newels
};
// HP_TRIG_SINGEDGECORNER1
int reftrig_singedgecorner1_splitedges[][3] =
{
{ 1, 2, 6 },
{ 1, 3, 5 },
{ 2, 3, 4 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedgecorner1_newelstypes[] =
{
HP_TRIG_SINGEDGECORNER1,
HP_QUAD_SINGEDGE,
HP_TRIG,
HP_NONE,
};
int reftrig_singedgecorner1_newels[][8] =
{
{ 1, 6, 5 },
{ 6, 2, 4, 5 },
{ 5, 4, 3 },
};
HPRef_Struct reftrig_singedgecorner1 =
{
HP_TRIG,
reftrig_singedgecorner1_splitedges,
0, 0,
reftrig_singedgecorner1_newelstypes,
reftrig_singedgecorner1_newels
};
// HP_TRIG_SINGEDGECORNER2
int reftrig_singedgecorner2_splitedges[][3] =
{
{ 2, 1, 6 },
{ 1, 3, 5 },
{ 2, 3, 4 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedgecorner2_newelstypes[] =
{
HP_TRIG_SINGEDGECORNER2,
HP_QUAD_SINGEDGE,
HP_TRIG,
HP_NONE,
};
int reftrig_singedgecorner2_newels[][8] =
{
{ 6, 2, 4},
{ 1, 6, 4, 5 },
{ 5, 4, 3 },
};
HPRef_Struct reftrig_singedgecorner2 =
{
HP_TRIG,
reftrig_singedgecorner2_splitedges,
0, 0,
reftrig_singedgecorner2_newelstypes,
reftrig_singedgecorner2_newels
};
// HP_TRIG_SINGEDGECORNER12
int reftrig_singedgecorner12_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 1, 6 },
{ 2, 3, 7 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedgecorner12_newelstypes[] =
{
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_QUAD_SINGEDGE,
HP_TRIG,
HP_NONE,
};
int reftrig_singedgecorner12_newels[][8] =
{
{ 1, 4, 5 },
{ 6, 2, 7 },
{ 4, 6, 7, 5 },
{ 5, 7, 3 },
};
HPRef_Struct reftrig_singedgecorner12 =
{
HP_TRIG,
reftrig_singedgecorner12_splitedges,
0, 0,
reftrig_singedgecorner12_newelstypes,
reftrig_singedgecorner12_newels
};
// HP_TRIG_SINGEDGECORNER3
int reftrig_singedgecorner3_splitedges[][3] =
{
{ 1, 3, 4 },
{ 3, 1, 5 },
{ 2, 3, 6 },
{ 3, 2, 7 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedgecorner3_newelstypes[] =
{
HP_QUAD_SINGEDGE,
HP_QUAD,
HP_TRIG_SINGCORNER,
HP_NONE,
};
int reftrig_singedgecorner3_newels[][8] =
{
{ 1, 2, 6, 4 },
{ 4, 6, 7, 5 },
{ 3, 5, 7 },
};
HPRef_Struct reftrig_singedgecorner3 =
{
HP_TRIG,
reftrig_singedgecorner3_splitedges,
0, 0,
reftrig_singedgecorner3_newelstypes,
reftrig_singedgecorner3_newels
};
// HP_TRIG_SINGEDGECORNER13
int reftrig_singedgecorner13_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 3, 6 },
{ 3, 1, 7 },
{ 3, 2, 8 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedgecorner13_newelstypes[] =
{
HP_TRIG_SINGEDGECORNER1,
HP_QUAD_SINGEDGE,
HP_QUAD,
HP_TRIG_SINGCORNER,
HP_NONE,
};
int reftrig_singedgecorner13_newels[][8] =
{
{ 1, 4, 5 },
{ 4, 2, 6, 5 },
{ 5, 6, 8, 7 },
{ 3, 7, 8 },
};
HPRef_Struct reftrig_singedgecorner13 =
{
HP_TRIG,
reftrig_singedgecorner13_splitedges,
0, 0,
reftrig_singedgecorner13_newelstypes,
reftrig_singedgecorner13_newels
};
// HP_TRIG_SINGEDGECORNER23
int reftrig_singedgecorner23_splitedges[][3] =
{
{ 1, 3, 4 },
{ 2, 1, 5 },
{ 2, 3, 6 },
{ 3, 1, 7 },
{ 3, 2, 8 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedgecorner23_newelstypes[] =
{
HP_TRIG_SINGEDGECORNER2,
HP_QUAD_SINGEDGE,
HP_QUAD,
HP_TRIG_SINGCORNER,
HP_NONE,
};
int reftrig_singedgecorner23_newels[][8] =
{
{ 5, 2, 6 },
{ 1, 5, 6, 4 },
{ 4, 6, 8, 7 },
{ 3, 7, 8 },
};
HPRef_Struct reftrig_singedgecorner23 =
{
HP_TRIG,
reftrig_singedgecorner23_splitedges,
0, 0,
reftrig_singedgecorner23_newelstypes,
reftrig_singedgecorner23_newels
};
// HP_TRIG_SINGEDGECORNER123
int reftrig_singedgecorner123_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 1, 6 },
{ 2, 3, 7 },
{ 3, 1, 8 },
{ 3, 2, 9 },
{ 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedgecorner123_newelstypes[] =
{
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_QUAD_SINGEDGE,
HP_QUAD,
HP_TRIG_SINGCORNER,
HP_NONE,
};
int reftrig_singedgecorner123_newels[][8] =
{
{ 1, 4, 5 },
{ 6, 2, 7 },
{ 4, 6, 7, 5 },
{ 5, 7, 9, 8 },
{ 3, 8, 9 },
};
HPRef_Struct reftrig_singedgecorner123 =
{
HP_TRIG,
reftrig_singedgecorner123_splitedges,
0, 0,
reftrig_singedgecorner123_newelstypes,
reftrig_singedgecorner123_newels
};
// HP_TRIG_SINGEDGES
int reftrig_singedges_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 3, 6 },
{ 3, 2, 7 },
{ 0, 0, 0 }
};
int reftrig_singedges_splitfaces[][4] =
{
{ 1, 2, 3, 8 },
{ 0, 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedges_newelstypes[] =
{
// HP_QUAD_2E,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_QUAD_SINGEDGE,
HP_QUAD_SINGEDGE,
HP_TRIG,
HP_NONE,
};
int reftrig_singedges_newels[][8] =
{
// { 1, 4, 8, 5 },
{ 1, 4, 8 },
{ 5, 1, 8 },
{ 4, 2, 6, 8 },
{ 3, 5, 8, 7 },
{ 6, 7, 8 },
};
HPRef_Struct reftrig_singedges =
{
HP_TRIG,
reftrig_singedges_splitedges,
reftrig_singedges_splitfaces,
0,
reftrig_singedges_newelstypes,
reftrig_singedges_newels
};
// HP_TRIG_SINGEDGES2
int reftrig_singedges2_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 1, 6 },
{ 2, 3, 7 },
{ 3, 2, 8 },
{ 0, 0, 0 }
};
int reftrig_singedges2_splitfaces[][4] =
{
{ 1, 2, 3, 9 },
{ 0, 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedges2_newelstypes[] =
{
// HP_QUAD_2E,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_QUAD_SINGEDGE,
HP_QUAD_SINGEDGE,
HP_TRIG_SINGEDGECORNER2,
HP_TRIG,
HP_NONE,
};
int reftrig_singedges2_newels[][8] =
{
// { 1, 4, 9, 5 },
{ 1, 4, 9 },
{ 5, 1, 9 },
{ 4, 6, 7, 9 },
{ 3, 5, 9, 8 },
{ 6, 2, 7 },
{ 7, 8, 9 },
};
HPRef_Struct reftrig_singedges2 =
{
HP_TRIG,
reftrig_singedges2_splitedges,
reftrig_singedges2_splitfaces,
0,
reftrig_singedges2_newelstypes,
reftrig_singedges2_newels
};
// HP_TRIG_SINGEDGES3
int reftrig_singedges3_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 3, 6 },
{ 3, 1, 7 },
{ 3, 2, 8 },
{ 0, 0, 0 }
};
int reftrig_singedges3_splitfaces[][4] =
{
{ 1, 2, 3, 9 },
{ 0, 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedges3_newelstypes[] =
{
// HP_QUAD_2E,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_QUAD_SINGEDGE,
HP_QUAD_SINGEDGE,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG,
HP_NONE,
};
int reftrig_singedges3_newels[][8] =
{
// { 1, 4, 9, 5 },
{ 1, 4, 9 },
{ 5, 1, 9 },
{ 4, 2, 6, 9 },
{ 7, 5, 9, 8 },
{ 3, 7, 8 },
{ 6, 8, 9 },
};
HPRef_Struct reftrig_singedges3 =
{
HP_TRIG,
reftrig_singedges3_splitedges,
reftrig_singedges3_splitfaces,
0,
reftrig_singedges3_newelstypes,
reftrig_singedges3_newels
};
// HP_TRIG_SINGEDGES23
int reftrig_singedges23_splitedges[][3] =
{
{ 1, 2, 4 },
{ 1, 3, 5 },
{ 2, 1, 6 },
{ 2, 3, 7 },
{ 3, 1, 8 },
{ 3, 2, 9 },
{ 0, 0, 0 }
};
int reftrig_singedges23_splitfaces[][4] =
{
{ 1, 2, 3, 10 },
{ 0, 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_singedges23_newelstypes[] =
{
// HP_QUAD_2E,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_QUAD_SINGEDGE,
HP_QUAD_SINGEDGE,
HP_TRIG_SINGEDGECORNER2,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG,
HP_NONE,
};
int reftrig_singedges23_newels[][8] =
{
// { 1, 4, 10, 5 },
{ 1 , 4, 10 },
{ 5, 1, 10 },
{ 4, 6, 7, 10 },
{ 8, 5, 10, 9 },
{ 6, 2, 7 },
{ 3, 8, 9 },
{ 7, 9, 10 },
};
HPRef_Struct reftrig_singedges23 =
{
HP_TRIG,
reftrig_singedges23_splitedges,
reftrig_singedges23_splitfaces,
0,
reftrig_singedges23_newelstypes,
reftrig_singedges23_newels
};
// HP_TRIG_3SINGEDGES
int reftrig_3singedges_splitedges[][3] =
{
{ 1, 2, 4 },
{ 2, 1, 5 },
{ 2, 3, 6 },
{ 3, 2, 7 },
{ 3, 1, 8 },
{ 1, 3, 9 },
{ 0, 0, 0 }
};
int reftrig_3singedges_splitfaces[][4] =
{
{ 1, 2, 3, 10 },
{ 2, 3, 1, 11 },
{ 3, 1, 2, 12 },
{ 0, 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_3singedges_newelstypes[] =
{
HP_TRIG,
HP_QUAD_SINGEDGE,
HP_QUAD_SINGEDGE,
HP_QUAD_SINGEDGE,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_TRIG_SINGEDGECORNER1,
HP_TRIG_SINGEDGECORNER2,
HP_NONE,
};
int reftrig_3singedges_newels[][8] =
{
{ 10, 11, 12 },
{ 4, 5, 11, 10 },
{ 6, 7, 12, 11 },
{ 8, 9, 10, 12 },
{ 1, 4, 10 },
{ 9, 1, 10 },
{ 2, 6, 11 },
{ 5, 2, 11 },
{ 3, 8, 12 },
{ 7, 3, 12 },
};
HPRef_Struct reftrig_3singedges =
{
HP_TRIG,
reftrig_3singedges_splitedges,
reftrig_3singedges_splitfaces,
0,
reftrig_3singedges_newelstypes,
reftrig_3singedges_newels
};
// HP_TRIG_ALFELD
int reftrig_Alfeld_splitedges[][3] =
{
{ 0, 0, 0 }
};
int reftrig_Alfeld_splitfaces[][4] =
{
{ 1, 2, 3, 4 },
{ 0, 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_Alfeld_newelstypes[] =
{
HP_TRIG, HP_TRIG, HP_TRIG,
HP_NONE,
};
int reftrig_Alfeld_newels[][8] =
{
{ 1, 2, 4 },
{ 2, 3, 4 },
{ 3, 1, 4 },
};
HPRef_Struct reftrig_Alfeld =
{
HP_TRIG,
reftrig_Alfeld_splitedges,
reftrig_Alfeld_splitfaces,
0,
reftrig_Alfeld_newelstypes,
reftrig_Alfeld_newels
};
// HP_TRIG_POWELL
int reftrig_Powell_splitedges[][3] =
{
{ 1, 2, 4 },
{ 2, 3, 5 },
{ 3, 1, 6 },
{ 0, 0, 0 },
};
int reftrig_Powell_splitfaces[][4] =
{
{ 1, 2, 3, 7 },
{ 0, 0, 0, 0 }
};
HPREF_ELEMENT_TYPE reftrig_Powell_newelstypes[] =
{
HP_TRIG, HP_TRIG, HP_TRIG, HP_TRIG, HP_TRIG, HP_TRIG,
HP_NONE,
};
int reftrig_Powell_newels[][8] =
{
{ 1, 4, 7 },
{ 4, 2, 7 },
{ 2, 5, 7 },
{ 5, 3, 7 },
{ 3, 6, 7 },
{ 6, 1, 7 },
};
HPRef_Struct reftrig_Powell =
{
HP_TRIG,
reftrig_Powell_splitedges,
reftrig_Powell_splitfaces,
0,
reftrig_Powell_newelstypes,
reftrig_Powell_newels
};