mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-11 21:50:34 +05:00
fix edge interpolation of growthvectors in boundarylayer
(now without geometry)
This commit is contained in:
parent
c4b679ec5a
commit
2ffd3b6589
@ -373,6 +373,7 @@ namespace netgen
|
|||||||
}
|
}
|
||||||
|
|
||||||
const auto & p2sel = mesh.CreatePoint2SurfaceElementTable();
|
const auto & p2sel = mesh.CreatePoint2SurfaceElementTable();
|
||||||
|
Array<Vec<3>, PointIndex> edge_tangents(np);
|
||||||
|
|
||||||
for(auto pi : mesh.Points().Range())
|
for(auto pi : mesh.Points().Range())
|
||||||
{
|
{
|
||||||
@ -413,6 +414,7 @@ namespace netgen
|
|||||||
auto npnp = np * np;
|
auto npnp = np * np;
|
||||||
auto nn = n * n;
|
auto nn = n * n;
|
||||||
if(nn-npn*npn/npnp == 0) { np = n; continue; }
|
if(nn-npn*npn/npnp == 0) { np = n; continue; }
|
||||||
|
edge_tangents[pi] = Cross(np, n).Normalize();
|
||||||
np += (nn - npn)/(nn - npn*npn/npnp) * (n - npn/npnp * np);
|
np += (nn - npn)/(nn - npn*npn/npnp) * (n - npn/npnp * np);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -552,12 +554,14 @@ namespace netgen
|
|||||||
// build sorted list of edge
|
// build sorted list of edge
|
||||||
Array<PointIndex> points;
|
Array<PointIndex> points;
|
||||||
// find first vertex on edge
|
// find first vertex on edge
|
||||||
|
double edge_len = 0.;
|
||||||
for(const auto& seg : segments)
|
for(const auto& seg : segments)
|
||||||
{
|
{
|
||||||
if(seg.edgenr-1 == edgenr && mesh[seg[0]].Type() == FIXEDPOINT)
|
if(seg.edgenr-1 == edgenr && mesh[seg[0]].Type() == FIXEDPOINT)
|
||||||
{
|
{
|
||||||
points.Append(seg[0]);
|
points.Append(seg[0]);
|
||||||
points.Append(seg[1]);
|
points.Append(seg[1]);
|
||||||
|
edge_len += (mesh[seg[1]] - mesh[seg[0]]).Length();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -571,6 +575,7 @@ namespace netgen
|
|||||||
continue;
|
continue;
|
||||||
if(seg[0] == points.Last() && points[points.Size()-2] !=seg[1])
|
if(seg[0] == points.Last() && points[points.Size()-2] !=seg[1])
|
||||||
{
|
{
|
||||||
|
edge_len += (mesh[points.Last()] - mesh[seg[1]]).Length();
|
||||||
points.Append(seg[1]);
|
points.Append(seg[1]);
|
||||||
point_found = true;
|
point_found = true;
|
||||||
break;
|
break;
|
||||||
@ -583,28 +588,17 @@ namespace netgen
|
|||||||
}
|
}
|
||||||
|
|
||||||
// tangential part of growth vectors
|
// tangential part of growth vectors
|
||||||
EdgePointGeomInfo gi;
|
auto gt1 = growthvectors[points[0]];
|
||||||
Point<3> p = mesh[points[0]];
|
auto gt2 = growthvectors[points.Last()];
|
||||||
const auto& edge = geo.GetEdge(edgenr);
|
|
||||||
edge.ProjectPoint(p, &gi);
|
|
||||||
auto tau1 = gi.dist;
|
|
||||||
auto t1 = edge.GetTangent(tau1);
|
|
||||||
t1 *= 1./t1.Length();
|
|
||||||
p = mesh[points.Last()];
|
|
||||||
edge.ProjectPoint(p, &gi);
|
|
||||||
auto tau2 = gi.dist;
|
|
||||||
auto t2 = edge.GetTangent(gi.dist);
|
|
||||||
t2 *= 1./t2.Length();
|
|
||||||
auto gt1 = (growthvectors[points[0]] * t1) * t1;
|
|
||||||
auto gt2 = (growthvectors[points.Last()] * t2) * t2;
|
|
||||||
|
|
||||||
|
double len = 0.;
|
||||||
for(size_t i = 1; i < points.Size()-1; i++)
|
for(size_t i = 1; i < points.Size()-1; i++)
|
||||||
{
|
{
|
||||||
auto pi = points[i];
|
auto pi = points[i];
|
||||||
p = mesh[pi];
|
len += (mesh[pi] - mesh[points[i-1]]).Length();
|
||||||
edge.ProjectPoint(p, &gi);
|
auto t = edge_tangents[pi];
|
||||||
auto tau = gi.dist;
|
auto lam = len/edge_len;
|
||||||
auto interpol = (1-fabs(tau-tau1)) * gt1 + (1-fabs(tau-tau2))*gt2;
|
auto interpol = (1-lam) * (gt1 * t) * t + lam * (gt2 * t) * t;
|
||||||
growthvectors[pi] += interpol;
|
growthvectors[pi] += interpol;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user