mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-11 21:50:34 +05:00
uniform refinement for quads
This commit is contained in:
parent
e860cf188b
commit
9033de843b
@ -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);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user