prepare LocalH tree before blockfill sequentially

This commit is contained in:
Matthias Hochsteger 2021-06-16 15:05:58 +02:00
parent 7e344c2247
commit d0edaa57bb
3 changed files with 133 additions and 71 deletions

View File

@ -227,6 +227,26 @@ namespace netgen
} }
} }
void PrepareForBlockFillLocalH(MeshingData & md)
{
static Timer t("PrepareForBlockFillLocalH"); RegionTimer rt(t);
md.meshing = make_unique<Meshing3>(nullptr);
auto & mesh = md.mesh;
mesh.CalcSurfacesOfNode();
mesh.FindOpenElements(md.domain);
for (PointIndex pi : mesh.Points().Range())
md.meshing->AddPoint (mesh[pi], pi);
for (int i = 1; i <= mesh.GetNOpenElements(); i++)
md.meshing->AddBoundaryElement (mesh.OpenElement(i));
if (mesh.HasLocalHFunction())
md.meshing->PrepareBlockFillLocalH(mesh, md.mp);
}
void MeshDomain( MeshingData & md) void MeshDomain( MeshingData & md)
{ {
@ -237,15 +257,7 @@ namespace netgen
if(mp.only3D_domain_nr && mp.only3D_domain_nr != domain) if(mp.only3D_domain_nr && mp.only3D_domain_nr != domain)
return; return;
mesh.CalcSurfacesOfNode();
mesh.FindOpenElements(domain);
md.meshing = make_unique<Meshing3>(nullptr);
for (PointIndex pi : mesh.Points().Range())
md.meshing->AddPoint (mesh[pi], pi);
for (int i = 1; i <= mesh.GetNOpenElements(); i++)
md.meshing->AddBoundaryElement (mesh.OpenElement(i));
if (mp.delaunay && mesh.GetNOpenElements()) if (mp.delaunay && mesh.GetNOpenElements())
@ -261,9 +273,18 @@ namespace netgen
mesh.GetNE(), " elements"); mesh.GetNE(), " elements");
} }
// mesh.Save("before_findopenels.vol"); Box<3> domain_bbox( Box<3>::EMPTY_BOX );
// mesh.CalcSurfacesOfNode();
// mesh.FindOpenElements(domain); for (auto & sel : mesh.SurfaceElements())
{
if (sel.IsDeleted() ) continue;
for (auto pi : sel.PNums())
domain_bbox.Add (mesh[pi]);
}
domain_bbox.Increase (0.01 * domain_bbox.Diam());
mesh.FindOpenElements(domain);
int cntsteps = 0; int cntsteps = 0;
int meshed; int meshed;
@ -273,7 +294,7 @@ namespace netgen
if (multithread.terminate) if (multithread.terminate)
break; break;
mesh.FindOpenElements(); mesh.FindOpenElements(domain);
PrintMessage (5, mesh.GetNOpenElements(), " open faces"); PrintMessage (5, mesh.GetNOpenElements(), " open faces");
GetOpenElements( mesh, domain )->Save("open_"+ToString(cntsteps)+".vol"); GetOpenElements( mesh, domain )->Save("open_"+ToString(cntsteps)+".vol");
cntsteps++; cntsteps++;
@ -289,15 +310,14 @@ namespace netgen
Array<PointIndex, PointIndex> glob2loc(mesh.GetNP()); Array<PointIndex, PointIndex> glob2loc(mesh.GetNP());
glob2loc = PointIndex::INVALID; glob2loc = PointIndex::INVALID;
for (PointIndex pi : mesh.Points().Range())
if (domain_bbox.IsIn (mesh[pi]))
glob2loc[pi] = meshing.AddPoint (mesh[pi], pi);
for (auto sel : mesh.OpenElements() ) for (auto sel : mesh.OpenElements() )
{ {
for(auto & pi : sel.PNums()) for(auto & pi : sel.PNums())
{
if(!glob2loc[pi].IsValid())
glob2loc[pi] = meshing.AddPoint (mesh[pi], pi);
pi = glob2loc[pi]; pi = glob2loc[pi];
}
meshing.AddBoundaryElement (sel); meshing.AddBoundaryElement (sel);
} }
@ -312,7 +332,7 @@ namespace netgen
mesh.CalcSurfacesOfNode(); mesh.CalcSurfacesOfNode();
mesh.FindOpenElements(); mesh.FindOpenElements(domain);
// teterrpow = 2; // teterrpow = 2;
if (mesh.GetNOpenElements() != 0) if (mesh.GetNOpenElements() != 0)
@ -358,7 +378,7 @@ namespace netgen
{ {
PrintMessage (3, "Check subdomain ", domain, " / ", mesh.GetNDomains()); PrintMessage (3, "Check subdomain ", domain, " / ", mesh.GetNDomains());
mesh.FindOpenElements(); mesh.FindOpenElements(domain);
bool res = (mesh.CheckConsistentBoundary() != 0); bool res = (mesh.CheckConsistentBoundary() != 0);
if (res) if (res)
@ -710,14 +730,12 @@ namespace netgen
CloseOpenQuads( md[i] ); CloseOpenQuads( md[i] );
}); });
for(auto & md_ : md)
PrepareForBlockFillLocalH(md_);
ParallelFor( md.Range(), [&](int i) ParallelFor( md.Range(), [&](int i)
{ {
// try { MeshDomain(md[i]);
MeshDomain(md[i]);
// }
// catch( const NgException & e ) {
// md[i].mesh.Save("error_"+ToString(i)+".vol");
// }
}); });
MergeMeshes(mesh3d, md); MergeMeshes(mesh3d, md);

View File

@ -180,6 +180,7 @@ GenerateMesh (Mesh & mesh, const MeshingParameters & mp)
// static int meshing3_timer_d = NgProfiler::CreateTimer ("Meshing3::GenerateMesh d"); // static int meshing3_timer_d = NgProfiler::CreateTimer ("Meshing3::GenerateMesh d");
// NgProfiler::RegionTimer reg (meshing3_timer); // NgProfiler::RegionTimer reg (meshing3_timer);
cout << "start tet meshing with " << adfront->GetNP() << " points and " << adfront->GetNF() << " faces " << endl;
NgArray<Point3d, PointIndex::BASE> locpoints; // local points NgArray<Point3d, PointIndex::BASE> locpoints; // local points
NgArray<MiniElement2d> locfaces; // local faces NgArray<MiniElement2d> locfaces; // local faces
@ -1094,11 +1095,10 @@ static int TestSameSide (const Point3d & p1, const Point3d & p2)
*/ */
void Meshing3 :: PrepareBlockFillLocalH (Mesh & mesh,
void Meshing3 :: BlockFillLocalH (Mesh & mesh,
const MeshingParameters & mp) const MeshingParameters & mp)
{ {
static Timer t("Mesing3::BlockFillLocalH"); RegionTimer reg(t); static Timer t("Mesing3::PrepareBlockFillLocalH"); RegionTimer reg(t);
double filldist = mp.filldist; double filldist = mp.filldist;
@ -1107,10 +1107,90 @@ void Meshing3 :: BlockFillLocalH (Mesh & mesh,
PrintMessage (3, "blockfill local h"); PrintMessage (3, "blockfill local h");
NgArray<Point<3> > npoints;
adfront -> CreateTrees(); adfront -> CreateTrees();
double maxh = 0;
for (int i = 1; i <= adfront->GetNF(); i++)
{
const MiniElement2d & el = adfront->GetFace(i);
for (int j = 1; j <= 3; j++)
{
const Point3d & p1 = adfront->GetPoint (el.PNumMod(j));
const Point3d & p2 = adfront->GetPoint (el.PNumMod(j+1));
double hi = Dist (p1, p2);
if (hi > maxh) maxh = hi;
}
}
if (mp.maxh < maxh) maxh = mp.maxh;
// auto loch_ptr = mesh.LocalHFunction().Copy();
// auto & loch = *loch_ptr;
auto & loch = mesh.LocalHFunction();
bool changed;
static Timer t1("loop1");
t1.Start();
do
{
loch.ClearFlags();
static Timer tbox("adfront-bbox");
tbox.Start();
for (int i = 1; i <= adfront->GetNF(); i++)
{
const MiniElement2d & el = adfront->GetFace(i);
Box<3> bbox (adfront->GetPoint (el[0]));
bbox.Add (adfront->GetPoint (el[1]));
bbox.Add (adfront->GetPoint (el[2]));
double filld = filldist * bbox.Diam();
bbox.Increase (filld);
loch.CutBoundary (bbox); // .PMin(), bbox.PMax());
}
tbox.Stop();
// locadfront = adfront;
loch.FindInnerBoxes (adfront, NULL);
npoints.SetSize(0);
loch.GetInnerPoints (npoints);
changed = false;
for (int i = 1; i <= npoints.Size(); i++)
{
if (loch.GetH(npoints.Get(i)) > 1.5 * maxh)
{
loch.SetH (npoints.Get(i), maxh);
changed = true;
}
}
}
while (changed);
t1.Stop();
}
void Meshing3 :: BlockFillLocalH (Mesh & mesh,
const MeshingParameters & mp)
{
static Timer t("Mesing3::BlockFillLocalH"); RegionTimer reg(t);
// PrepareBlockFillLocalH(mesh, mp);
double filldist = mp.filldist;
// (*testout) << "blockfill local h" << endl;
// (*testout) << "rel filldist = " << filldist << endl;
PrintMessage (3, "blockfill local h");
Box<3> bbox ( Box<3>::EMPTY_BOX ); Box<3> bbox ( Box<3>::EMPTY_BOX );
double maxh = 0; double maxh = 0;
@ -1144,47 +1224,6 @@ void Meshing3 :: BlockFillLocalH (Mesh & mesh,
if (mp.maxh < maxh) maxh = mp.maxh; if (mp.maxh < maxh) maxh = mp.maxh;
auto loch_ptr = mesh.LocalHFunction().Copy();
auto & loch = *loch_ptr;
bool changed;
do
{
loch.ClearFlags();
for (int i = 1; i <= adfront->GetNF(); i++)
{
const MiniElement2d & el = adfront->GetFace(i);
Box<3> bbox (adfront->GetPoint (el[0]));
bbox.Add (adfront->GetPoint (el[1]));
bbox.Add (adfront->GetPoint (el[2]));
double filld = filldist * bbox.Diam();
bbox.Increase (filld);
loch.CutBoundary (bbox); // .PMin(), bbox.PMax());
}
// locadfront = adfront;
loch.FindInnerBoxes (adfront, NULL);
npoints.SetSize(0);
loch.GetInnerPoints (npoints);
changed = false;
for (int i = 1; i <= npoints.Size(); i++)
{
if (loch.GetH(npoints.Get(i)) > 1.5 * maxh)
{
loch.SetH (npoints.Get(i), maxh);
changed = true;
}
}
}
while (changed);
if (debugparam.slowchecks) if (debugparam.slowchecks)
(*testout) << "Blockfill with points: " << endl; (*testout) << "Blockfill with points: " << endl;
for (int i = 1; i <= npoints.Size(); i++) for (int i = 1; i <= npoints.Size(); i++)
@ -1211,6 +1250,8 @@ void Meshing3 :: BlockFillLocalH (Mesh & mesh,
// find outer points // find outer points
static Timer tloch2("build loch2");
tloch2.Start();
loch2.ClearFlags(); loch2.ClearFlags();
for (int i = 1; i <= adfront->GetNF(); i++) for (int i = 1; i <= adfront->GetNF(); i++)
@ -1248,6 +1289,7 @@ void Meshing3 :: BlockFillLocalH (Mesh & mesh,
// loch2.CutBoundary (pmin, pmax); // loch2.CutBoundary (pmin, pmax);
loch2.CutBoundary (Box<3> (pmin, pmax)); // pmin, pmax); loch2.CutBoundary (Box<3> (pmin, pmax)); // pmin, pmax);
} }
tloch2.Stop();
// locadfront = adfront; // locadfront = adfront;
loch2.FindInnerBoxes (adfront, NULL); loch2.FindInnerBoxes (adfront, NULL);

View File

@ -28,6 +28,7 @@ class Meshing3
NgArray<char*> problems; NgArray<char*> problems;
/// tolerance criterion /// tolerance criterion
double tolfak; double tolfak;
NgArray<Point<3> > npoints;
public: public:
/// ///
Meshing3 (const string & rulefilename); Meshing3 (const string & rulefilename);
@ -63,6 +64,7 @@ public:
/// ///
void BlockFill (Mesh & mesh, double gh); void BlockFill (Mesh & mesh, double gh);
/// ///
void PrepareBlockFillLocalH (Mesh & mesh, const MeshingParameters & mp);
void BlockFillLocalH (Mesh & mesh, const MeshingParameters & mp); void BlockFillLocalH (Mesh & mesh, const MeshingParameters & mp);
/// uses points of adfront, and puts new elements into mesh /// uses points of adfront, and puts new elements into mesh