mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-13 14:40:35 +05:00
tuning and output for uniform refinement
This commit is contained in:
parent
5c22bd08c3
commit
4dad700c87
@ -13,6 +13,8 @@ namespace netgen
|
|||||||
|
|
||||||
void Refinement :: Refine (Mesh & mesh)
|
void Refinement :: Refine (Mesh & mesh)
|
||||||
{
|
{
|
||||||
|
PrintMessage (3, "Refine mesh");
|
||||||
|
|
||||||
// reduce 2nd order
|
// reduce 2nd order
|
||||||
mesh.ComputeNVertices();
|
mesh.ComputeNVertices();
|
||||||
mesh.SetNP(mesh.GetNV());
|
mesh.SetNP(mesh.GetNV());
|
||||||
@ -99,6 +101,8 @@ namespace netgen
|
|||||||
throw NgException ("currently refinement for non-tet elements is not supported");
|
throw NgException ("currently refinement for non-tet elements is not supported");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PrintMessage (5, "have points");
|
||||||
|
|
||||||
Array<int> par_nr(parents.Size());
|
Array<int> par_nr(parents.Size());
|
||||||
for (int i = 0; i < par_nr.Size(); i++)
|
for (int i = 0; i < par_nr.Size(); i++)
|
||||||
@ -115,6 +119,8 @@ namespace netgen
|
|||||||
Array<bool, PointIndex::BASE> pointset(mesh.GetNP());
|
Array<bool, PointIndex::BASE> pointset(mesh.GetNP());
|
||||||
pointset = false;
|
pointset = false;
|
||||||
|
|
||||||
|
PrintMessage (5, "sorting complete");
|
||||||
|
|
||||||
// refine edges
|
// refine edges
|
||||||
Array<EdgePointGeomInfo,PointIndex::BASE> epgi;
|
Array<EdgePointGeomInfo,PointIndex::BASE> epgi;
|
||||||
|
|
||||||
@ -162,7 +168,8 @@ namespace netgen
|
|||||||
mesh.AddSegment (ns2);
|
mesh.AddSegment (ns2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PrintMessage (5, "have 1d elements");
|
||||||
|
|
||||||
// refine surface elements
|
// refine surface elements
|
||||||
Array<PointGeomInfo,PointIndex::BASE> surfgi (8*mesh.GetNP());
|
Array<PointGeomInfo,PointIndex::BASE> surfgi (8*mesh.GetNP());
|
||||||
for (int i = PointIndex::BASE;
|
for (int i = PointIndex::BASE;
|
||||||
@ -342,8 +349,11 @@ namespace netgen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PrintMessage (5, "have 2d elements");
|
||||||
|
|
||||||
// refine volume elements
|
// refine volume elements
|
||||||
int oldne = mesh.GetNE();
|
int oldne = mesh.GetNE();
|
||||||
|
mesh.VolumeElements().SetAllocSize(8*oldne);
|
||||||
for (ElementIndex ei = 0; ei < oldne; ei++)
|
for (ElementIndex ei = 0; ei < oldne; ei++)
|
||||||
{
|
{
|
||||||
const Element & el = mesh.VolumeElement(ei);
|
const Element & el = mesh.VolumeElement(ei);
|
||||||
@ -717,8 +727,10 @@ namespace netgen
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PrintMessage (5, "have 3d elements");
|
||||||
mesh.ComputeNVertices();
|
mesh.ComputeNVertices();
|
||||||
mesh.RebuildSurfaceElementLists();
|
mesh.RebuildSurfaceElementLists();
|
||||||
|
PrintMessage (5, "mesh updates complete");
|
||||||
return;
|
return;
|
||||||
|
|
||||||
int cnttrials = 10;
|
int cnttrials = 10;
|
||||||
|
Loading…
Reference in New Issue
Block a user