Merge branch 'fix_parallel_surfaceopt' into 'master'

fix parallel surface optimization

See merge request jschoeberl/netgen!476
This commit is contained in:
Joachim Schöberl 2022-02-15 19:18:22 +00:00
commit cf8a6639a3
3 changed files with 521 additions and 610 deletions

View File

@ -983,8 +983,10 @@ namespace netgen
RegionTimer reg(timer_opt2d); RegionTimer reg(timer_opt2d);
auto meshopt = MeshOptimize2d(mesh); auto meshopt = MeshOptimize2d(mesh);
for(auto i : Range(mparam.optsteps2d)) for(auto i : Range(mparam.optsteps2d))
for(auto k : Range(mesh.GetNFD()))
{ {
PrintMessage(3, "Optimization step ", i); PrintMessage(3, "Optimization step ", i);
meshopt.SetFaceIndex(k+1);
int innerstep = 0; int innerstep = 0;
for(auto optstep : mparam.optimize2d) for(auto optstep : mparam.optimize2d)
{ {

View File

@ -394,6 +394,7 @@ namespace netgen
return 0.0; return 0.0;
double loch = mesh.GetH (mesh[pi1]); double loch = mesh.GetH (mesh[pi1]);
int faceindex = -1;
for (SurfaceElementIndex sei2 : elementsonnode[pi1]) for (SurfaceElementIndex sei2 : elementsonnode[pi1])
{ {
@ -403,13 +404,8 @@ namespace netgen
if (el2[0] == pi2 || el2[1] == pi2 || el2[2] == pi2) if (el2[0] == pi2 || el2[1] == pi2 || el2[2] == pi2)
{ {
faceindex = el2.GetIndex();
hasbothpi.Append (sei2); hasbothpi.Append (sei2);
nv = Cross (Vec3d (mesh[el2[0]], mesh[el2[1]]),
Vec3d (mesh[el2[0]], mesh[el2[2]]));
}
else
{
hasonepi.Append (sei2);
} }
} }
@ -417,7 +413,7 @@ namespace netgen
return 0.0; return 0.0;
nv = normals[pi1]; nv = normals[pi2];
for (SurfaceElementIndex sei2 : elementsonnode[pi2]) for (SurfaceElementIndex sei2 : elementsonnode[pi2])
@ -476,7 +472,14 @@ namespace netgen
for (int l = 0; l < 3; l++) for (int l = 0; l < 3; l++)
{ {
if ( (normals[el[l]] * nv) < 0.5) auto normal = normals[el[l]];
if(fixed[el[l]])
{
// point possibly on edge -> multiple normal vectors (for each surface), need to calculate it to be sure
const int surfnr = mesh.GetFaceDescriptor (el.GetIndex()).SurfNr();
normal = mesh.GetGeometry()->GetNormal (surfnr, mesh[el[l]], &el.GeomInfo()[l]);
}
if ( ( normal * nv) < 0.5)
bad2 += 1e10; bad2 += 1e10;
} }
@ -532,10 +535,10 @@ namespace netgen
{ {
const Element2d & el1p = mesh[sei]; const Element2d & el1p = mesh[sei];
if (el1p.IsDeleted()) continue; if (el1p.IsDeleted()) continue;
if(el1p.GetIndex() != faceindex) continue;
for (int l = 0; l < el1p.GetNP(); l++) for (int l = 0; l < el1p.GetNP(); l++)
if (el1p[l] == pi1) if (el1p[l] == pi1)
// gi = el1p.GeomInfoPi (l+1);
gi = el1p.GeomInfo()[l]; gi = el1p.GeomInfo()[l];
break; break;
} }

File diff suppressed because it is too large Load Diff