uniform refinement for quads

This commit is contained in:
Joachim Schoeberl 2021-04-18 17:53:16 +02:00
parent e860cf188b
commit 9033de843b

View File

@ -77,6 +77,32 @@ namespace netgen
} }
break; break;
} }
case QUAD:
{
static int betw[5][3] =
{ { 0, 1, 4 },
{ 1, 2, 5 },
{ 2, 3, 6 },
{ 0, 3, 7 },
{ 0, 2, 8 } }; // one diagonal of the quad. should change later to mid-point of edge mid-points
for (int j = 0; j < 5; j++)
{
auto i2 = PointIndices<2>::Sort(el[betw[j][0]],el[betw[j][1]]);
if (j == 4)
{
auto i2a = PointIndices<2>::Sort(el[0], el[2]);
auto i2b = PointIndices<2>::Sort(el[1], el[3]);
i2 = i2a[0] < i2b[0] ? i2a : i2b;
}
if (!between.Used(i2))
{
between.Set (i2, 0);
parents.Append(i2);
}
}
break;
}
default: default:
throw NgException ("currently refinement for quad-elements is not supported"); throw NgException ("currently refinement for quad-elements is not supported");
} }
@ -125,7 +151,7 @@ namespace netgen
between.Set (parents[i], mesh.GetNV()+i+PointIndex::BASE); between.Set (parents[i], mesh.GetNV()+i+PointIndex::BASE);
mesh.mlbetweennodes[mesh.GetNV()+i+PointIndex::BASE] = parents[i]; mesh.mlbetweennodes[mesh.GetNV()+i+PointIndex::BASE] = parents[i];
} }
mesh.SetNP(mesh.GetNV() + parents.Size()); mesh.SetNP(mesh.GetNV() + parents.Size());
NgArray<bool, PointIndex::BASE> pointset(mesh.GetNP()); NgArray<bool, PointIndex::BASE> pointset(mesh.GetNP());
pointset = false; pointset = false;
@ -281,70 +307,76 @@ namespace netgen
case QUAD6: case QUAD6:
case QUAD8: case QUAD8:
{ {
NgArrayMem<PointIndex,9> pnums(9); PointIndex pnums[9];
NgArrayMem<PointGeomInfo,9> pgis(9); PointGeomInfo pgis[9];
static int betw[5][3] = static int betw[5][3] =
{ { 1, 2, 5 }, { { 0, 1, 4 },
{ 1, 2, 5 },
{ 2, 3, 6 }, { 2, 3, 6 },
{ 3, 4, 7 }, { 0, 3, 7 },
{ 1, 4, 8 }, { 0, 2, 8 } };
{ 5, 7, 9 } };
for (int j = 0; j < 4; j++)
for (int j = 1; j <= 4; j++)
{ {
pnums.Elem(j) = el.PNum(j); pnums[j] = el[j];
pgis.Elem(j) = el.GeomInfoPi(j); pgis[j] = el.GeomInfoPi(j+1);
} }
for (int j = 0; j < 5; j++) for (int j = 0; j < 5; j++)
{ {
int pi1 = pnums.Elem(betw[j][0]); int pi1 = pnums[betw[j][0]];
int pi2 = pnums.Elem(betw[j][1]); int pi2 = pnums[betw[j][1]];
INDEX_2 i2 (pi1, pi2); INDEX_2 i2 (pi1, pi2);
i2.Sort(); i2.Sort();
if (j == 4)
{
auto i2a = PointIndices<2>::Sort(el[0], el[2]);
auto i2b = PointIndices<2>::Sort(el[1], el[3]);
i2 = i2a[0] < i2b[0] ? i2a : i2b;
}
if (between.Used(i2)) Point<3> pb;
{ PointGeomInfo pgi;
pnums.Elem(5+j) = between.Get(i2); geo.PointBetween(mesh.Point (pi1), mesh.Point (pi2), 0.5,
pgis.Elem(5+j) = surfgi.Get(pnums.Elem(4+j)); mesh.GetFaceDescriptor(el.GetIndex ()).SurfNr(),
} el.GeomInfoPi (betw[j][0]+1 ),
else el.GeomInfoPi (betw[j][1]+1 ),
{ pb, pgi);
Point<3> pb;
geo.PointBetween(mesh.Point (pi1),
mesh.Point (pi2), 0.5,
mesh.GetFaceDescriptor(el.GetIndex ()).SurfNr(),
el.GeomInfoPi (betw[j][0]),
el.GeomInfoPi (betw[j][1]),
pb, pgis.Elem(5+j));
pnums.Elem(5+j) = mesh.AddPoint (pb); pgis[4+j] = pgi;
PointIndex pinew = between.Get(i2);
pnums[4+j] = pinew;
between.Set (i2, pnums.Get(5+j)); if (!pointset[pinew])
{
if (surfgi.Size() < pnums.Elem(5+j)) pointset[pinew] = true;
surfgi.SetSize (pnums.Elem(5+j)); mesh.Point(pinew) = pb;
surfgi.Elem(pnums.Elem(5+j)) = pgis.Elem(5+j); }
}
} if (surfgi.Size() < pnums[4+j])
surfgi.SetSize (pnums[4+j]);
surfgi.Elem(pnums[4+j]) = pgis[4+j];
}
static int reftab[4][4] = static int reftab[4][4] =
{ {
{ 1, 5, 9, 8 }, { 0, 4, 8, 7 },
{ 5, 2, 6, 9 }, { 4, 1, 5, 8 },
{ 8, 9, 7, 4 }, { 7, 8, 6, 3 },
{ 9, 6, 3, 7 } }; { 8, 5, 2, 6 } };
int ind = el.GetIndex(); int ind = el.GetIndex();
for (int j = 0; j < 4; j++) for (int j = 0; j < 4; j++)
{ {
Element2d nel(QUAD); Element2d nel(QUAD);
for (int k = 1; k <= 4; k++) for (int k = 0; k < 4; k++)
{ {
nel.PNum(k) = pnums.Get(reftab[j][k-1]); nel[k] = pnums[reftab[j][k]];
nel.GeomInfoPi(k) = pgis.Get(reftab[j][k-1]); nel.GeomInfoPi(k+1) = pgis[reftab[j][k]];
} }
nel.SetIndex(ind); nel.SetIndex(ind);