netgen/libsrc/meshing/meshfunc2d.cpp

108 lines
2.6 KiB
C++
Raw Normal View History

2009-01-13 04:40:13 +05:00
#include <mystdlib.h>
#include "meshing.hpp"
namespace netgen
{
2023-09-18 16:58:43 +05:00
DLL_HEADER void Optimize2d (Mesh & mesh, MeshingParameters & mp, int faceindex)
2009-01-13 04:40:13 +05:00
{
2019-06-03 13:42:32 +05:00
static Timer timer("optimize2d"); RegionTimer reg(timer);
2009-01-13 04:40:13 +05:00
mesh.CalcSurfacesOfNode();
bool secondorder = mesh.GetNP() > mesh.GetNV();
if (secondorder)
{
for (SurfaceElementIndex ei = 0; ei < mesh.GetNSE(); ei++)
mesh[ei].SetType(TRIG);
}
mesh.Compress();
bool optimize_swap_separate_faces = false;
if(!mp.quad)
{
bool mixed = false;
ParallelFor( Range(mesh.GetNSE()), [&] (auto i) NETGEN_LAMBDA_INLINE
{
if (mesh[SurfaceElementIndex(i)].GetNP() != 3)
mixed = true;
});
if(mixed)
optimize_swap_separate_faces = true;
}
2023-09-18 16:58:43 +05:00
if(faceindex)
optimize_swap_separate_faces = false;
2014-08-31 18:12:31 +06:00
const char * optstr = mp.optimize2d.c_str();
2009-01-13 04:40:13 +05:00
int optsteps = mp.optsteps2d;
2023-09-18 16:58:43 +05:00
// reset topology
mesh.GetTopology() = MeshTopology(mesh);
2013-02-03 20:40:27 +06:00
for (int i = 1; i <= optsteps; i++)
2009-01-13 04:40:13 +05:00
for (size_t j = 1; j <= strlen(optstr); j++)
{
if (multithread.terminate) break;
2023-09-18 16:58:43 +05:00
MeshOptimize2d meshopt(mesh);
meshopt.SetMetricWeight (mp.elsizeweight);
meshopt.SetFaceIndex(faceindex);
2009-01-13 04:40:13 +05:00
switch (optstr[j-1])
{
case 's':
{ // topological swap
if(optimize_swap_separate_faces)
{
for(auto i : Range(1, mesh.GetNFD()+1))
{
meshopt.SetFaceIndex(i);
meshopt.EdgeSwapping (0);
}
}
else
{
meshopt.EdgeSwapping (0);
}
2009-01-13 04:40:13 +05:00
break;
}
case 'S':
{ // metric swap
if(optimize_swap_separate_faces)
{
for(auto i : Range(1, mesh.GetNFD()+1))
{
meshopt.SetFaceIndex(i);
meshopt.EdgeSwapping (1);
}
}
else
{
meshopt.EdgeSwapping (1);
}
2009-01-13 04:40:13 +05:00
break;
}
case 'm':
{
meshopt.ImproveMesh(mp);
2009-01-13 04:40:13 +05:00
break;
}
case 'c':
{
meshopt.CombineImprove();
2009-01-13 04:40:13 +05:00
break;
}
default:
cerr << "Optimization code " << optstr[j-1] << " not defined" << endl;
}
}
2020-01-09 03:27:59 +05:00
mesh.Compress(); // better: compress in individual steps, if necessary
if (secondorder)
{
mesh.GetGeometry()->GetRefinement().MakeSecondOrder(mesh);
}
2009-01-13 04:40:13 +05:00
}
}