domainwise meshing and optimization enabled

This commit is contained in:
Christopher Lackner 2016-12-02 14:59:59 +01:00
parent e31cc7dfa1
commit 0d36c69c25
4 changed files with 25 additions and 8 deletions

View File

@ -18,6 +18,7 @@ namespace netgen
point is inner point. point is inner point.
*/ */
void MeshOptimize3d :: CombineImprove (Mesh & mesh, void MeshOptimize3d :: CombineImprove (Mesh & mesh,
OPTIMIZEGOAL goal) OPTIMIZEGOAL goal)
{ {
@ -41,6 +42,8 @@ void MeshOptimize3d :: CombineImprove (Mesh & mesh,
double totalbad = 0; double totalbad = 0;
for (ElementIndex ei = 0; ei < ne; ei++) for (ElementIndex ei = 0; ei < ne; ei++)
{ {
if(mesh.GetDimension()==3 && mp.only3D_domain_nr && mp.only3D_domain_nr != mesh.VolumeElement(ei).GetIndex())
continue;
double elerr = CalcBad (mesh.Points(), mesh[ei], 0); double elerr = CalcBad (mesh.Points(), mesh[ei], 0);
totalbad += elerr; totalbad += elerr;
elerrs[ei] = elerr; elerrs[ei] = elerr;
@ -55,6 +58,7 @@ void MeshOptimize3d :: CombineImprove (Mesh & mesh,
for (ElementIndex ei = 0; ei < ne; ei++) for (ElementIndex ei = 0; ei < ne; ei++)
if (!mesh[ei].IsDeleted()) if (!mesh[ei].IsDeleted())
if(!(mesh.GetDimension()==3 && mp.only3D_domain_nr && mp.only3D_domain_nr != mesh.VolumeElement(ei).GetIndex()))
for (int j = 0; j < mesh[ei].GetNP(); j++) for (int j = 0; j < mesh[ei].GetNP(); j++)
elementsonnode.Add (mesh[ei][j], ei); elementsonnode.Add (mesh[ei][j], ei);
@ -64,6 +68,8 @@ void MeshOptimize3d :: CombineImprove (Mesh & mesh,
for (ElementIndex ei = 0; ei < ne; ei++) for (ElementIndex ei = 0; ei < ne; ei++)
{ {
if(mesh.GetDimension()==3 && mp.only3D_domain_nr && mp.only3D_domain_nr != mesh.VolumeElement(ei).GetIndex())
continue;
if (multithread.terminate) if (multithread.terminate)
break; break;
@ -238,6 +244,7 @@ void MeshOptimize3d :: CombineImprove (Mesh & mesh,
totalbad = 0; totalbad = 0;
for (ElementIndex ei = 0; ei < mesh.GetNE(); ei++) for (ElementIndex ei = 0; ei < mesh.GetNE(); ei++)
if(!(mesh.GetDimension()==3 && mp.only3D_domain_nr && mp.only3D_domain_nr != mesh.VolumeElement(ei).GetIndex()))
totalbad += CalcBad (mesh.Points(), mesh[ei], 0); totalbad += CalcBad (mesh.Points(), mesh[ei], 0);
if (goal == OPT_QUALITY) if (goal == OPT_QUALITY)
@ -247,6 +254,7 @@ void MeshOptimize3d :: CombineImprove (Mesh & mesh,
int cntill = 0; int cntill = 0;
for (ElementIndex ei = 0; ei < ne; ei++) for (ElementIndex ei = 0; ei < ne; ei++)
if(!(mesh.GetDimension()==3 && mp.only3D_domain_nr && mp.only3D_domain_nr != mesh.VolumeElement(ei).GetIndex()))
if (!mesh.LegalTet (mesh[ei])) if (!mesh.LegalTet (mesh[ei]))
cntill++; cntill++;

View File

@ -32,6 +32,8 @@ namespace netgen
int nonconsist = 0; int nonconsist = 0;
for (int k = 1; k <= mesh3d.GetNDomains(); k++) for (int k = 1; k <= mesh3d.GetNDomains(); k++)
{ {
if(mp.only3D_domain_nr && mp.only3D_domain_nr !=k)
continue;
PrintMessage (3, "Check subdomain ", k, " / ", mesh3d.GetNDomains()); PrintMessage (3, "Check subdomain ", k, " / ", mesh3d.GetNDomains());
mesh3d.FindOpenElements(k); mesh3d.FindOpenElements(k);
@ -63,6 +65,8 @@ namespace netgen
for (int k = 1; k <= mesh3d.GetNDomains(); k++) for (int k = 1; k <= mesh3d.GetNDomains(); k++)
{ {
if(mp.only3D_domain_nr && mp.only3D_domain_nr !=k)
continue;
if (multithread.terminate) if (multithread.terminate)
break; break;

View File

@ -1111,6 +1111,8 @@ namespace netgen
bool check_impossible = 0; bool check_impossible = 0;
int only3D_domain_nr = -1;
/// ///
int secondorder = 0; int secondorder = 0;
/// high order element curvature /// high order element curvature

View File

@ -590,18 +590,21 @@ DLL_HEADER void ExportNetgenMeshing(py::module &m)
py::class_<MP> (m, "MeshingParameters") py::class_<MP> (m, "MeshingParameters")
.def(py::init<>()) .def(py::init<>())
.def("__init__", .def("__init__",
[](MP *instance, double maxh, bool quad_dominated, int optsteps2d, int optsteps3d) [](MP *instance, double maxh, bool quad_dominated, int optsteps2d, int optsteps3d,
int only3D_domain)
{ {
new (instance) MeshingParameters; new (instance) MeshingParameters;
instance->maxh = maxh; instance->maxh = maxh;
instance->quad = int(quad_dominated); instance->quad = int(quad_dominated);
instance->optsteps2d = optsteps2d; instance->optsteps2d = optsteps2d;
instance->optsteps3d = optsteps3d; instance->optsteps3d = optsteps3d;
instance->only3D_domain_nr = only3D_domain;
}, },
py::arg("maxh")=1000, py::arg("maxh")=1000,
py::arg("quad_dominated")=false, py::arg("quad_dominated")=false,
py::arg("optsteps2d") = 3, py::arg("optsteps2d") = 3,
py::arg("optsteps3d") = 3 py::arg("optsteps3d") = 3,
py::arg("only3D_domain") = 0
, ,
"create meshing parameters" "create meshing parameters"
) )