mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-26 04:40:34 +05:00
Merge branch 'fix_parallel_surfaceopt' into 'master'
fix parallel surface optimization See merge request jschoeberl/netgen!476
This commit is contained in:
commit
cf8a6639a3
@ -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)
|
||||||
{
|
{
|
||||||
|
@ -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
Loading…
Reference in New Issue
Block a user