mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-26 21:00:34 +05:00
make number of vertices per level available
This commit is contained in:
parent
ed135fc61e
commit
20abe6ec37
@ -284,7 +284,8 @@ namespace netgen
|
||||
|
||||
int GetDimension() const;
|
||||
int GetNLevels() const;
|
||||
|
||||
size_t GetNVLevel (int level) const;
|
||||
|
||||
int GetNElements (int dim) const;
|
||||
int GetNNodes (int nt) const;
|
||||
|
||||
|
@ -1724,7 +1724,9 @@ void Ng_SetSurfaceElementOrders (int enr, int ox, int oy)
|
||||
|
||||
int Ng_GetNLevels ()
|
||||
{
|
||||
return (mesh) ? mesh->mglevels : 0;
|
||||
if (!mesh) return 0;
|
||||
return max(size_t(1), mesh -> level_nv.Size());
|
||||
// return (mesh) ? mesh->mglevels : 0;
|
||||
}
|
||||
|
||||
|
||||
|
@ -130,7 +130,15 @@ namespace netgen
|
||||
|
||||
int Ngx_Mesh :: GetNLevels() const
|
||||
{
|
||||
return mesh -> mglevels;
|
||||
return max(size_t(1), mesh -> level_nv.Size());
|
||||
}
|
||||
|
||||
size_t Ngx_Mesh :: GetNVLevel(int level) const
|
||||
{
|
||||
if (level >= mesh->level_nv.Size())
|
||||
return mesh->GetNV();
|
||||
else
|
||||
return mesh->level_nv[level];
|
||||
}
|
||||
|
||||
int Ngx_Mesh :: GetNElements (int dim) const
|
||||
|
@ -2755,14 +2755,15 @@ namespace netgen
|
||||
inf.close();
|
||||
}
|
||||
|
||||
|
||||
|
||||
if (mesh.mglevels == 1 || idmaps.Size() > 0)
|
||||
BisectTetsCopyMesh(mesh, NULL, opt, idmaps, refelementinfofileread);
|
||||
|
||||
|
||||
mesh.ComputeNVertices();
|
||||
|
||||
|
||||
// if (mesh.mglevels == 1 || idmaps.Size() > 0)
|
||||
if (mesh.level_nv.Size() == 0) // || idmaps.Size() ????
|
||||
{
|
||||
BisectTetsCopyMesh(mesh, NULL, opt, idmaps, refelementinfofileread);
|
||||
mesh.level_nv.Append (mesh.GetNV());
|
||||
}
|
||||
|
||||
int np = mesh.GetNV();
|
||||
mesh.SetNP(np);
|
||||
|
||||
@ -2773,7 +2774,7 @@ namespace netgen
|
||||
// int initnp = np;
|
||||
// int maxsteps = 3;
|
||||
|
||||
mesh.mglevels++;
|
||||
// mesh.mglevels++;
|
||||
|
||||
/*
|
||||
if (opt.refinementfilename || opt.usemarkedelements)
|
||||
@ -3807,7 +3808,8 @@ namespace netgen
|
||||
// write multilevel hierarchy to mesh:
|
||||
np = mesh.GetNP();
|
||||
mesh.mlbetweennodes.SetSize(np);
|
||||
if (mesh.mglevels <= 2)
|
||||
// if (mesh.mglevels <= 2)
|
||||
if (mesh.level_nv.Size() <= 1)
|
||||
{
|
||||
PrintMessage(4,"RESETTING mlbetweennodes");
|
||||
for (int i = 1; i <= np; i++)
|
||||
@ -3817,6 +3819,9 @@ namespace netgen
|
||||
}
|
||||
}
|
||||
|
||||
mesh.level_nv.Append (np);
|
||||
|
||||
|
||||
/*
|
||||
for (i = 1; i <= cutedges.GetNBags(); i++)
|
||||
for (j = 1; j <= cutedges.GetBagSize(i); j++)
|
||||
@ -3982,11 +3987,12 @@ namespace netgen
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
// Check/Repair
|
||||
|
||||
static bool repaired_once;
|
||||
if(mesh.mglevels == 1)
|
||||
// if(mesh.mglevels == 1)
|
||||
if(mesh.level_nv.Size() == 1)
|
||||
repaired_once = false;
|
||||
|
||||
//mesh.Save("before.vol");
|
||||
|
@ -20,7 +20,7 @@ namespace netgen
|
||||
segmentht = NULL;
|
||||
|
||||
lochfunc = NULL;
|
||||
mglevels = 1;
|
||||
// mglevels = 1;
|
||||
elementsearchtree = NULL;
|
||||
elementsearchtreets = NextTimeStamp();
|
||||
majortimestamp = timestamp = NextTimeStamp();
|
||||
|
@ -175,7 +175,9 @@ namespace netgen
|
||||
|
||||
|
||||
/// number of refinement levels
|
||||
int mglevels;
|
||||
// int mglevels;
|
||||
// number of vertices on each refinement level:
|
||||
NgArray<size_t> level_nv;
|
||||
/// refinement hierarchy
|
||||
NgArray<PointIndices<2>,PointIndex::BASE> mlbetweennodes;
|
||||
/// parent element of volume element
|
||||
|
@ -690,7 +690,7 @@ namespace netgen
|
||||
case 'j': mesh3d.ImproveMeshJacobian(mp); break;
|
||||
}
|
||||
}
|
||||
mesh3d.mglevels = 1;
|
||||
// mesh3d.mglevels = 1;
|
||||
MeshQuality3d (mesh3d);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user