mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 14:10:34 +05:00
Interpolate growth vectors only with OCC geometry
This commit is contained in:
parent
3a86103392
commit
bcedbfd189
@ -180,11 +180,85 @@ namespace netgen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void InterpolateSurfaceGrowthVectors(const Mesh & mesh, const BoundaryLayerParameters& blp, int fd_old, FlatArray<Vec<3>, PointIndex> growthvectors)
|
||||||
|
{
|
||||||
|
// interpolate growth vectors at inner surface points from surrounding edge points
|
||||||
|
Array<Point<2>, PointIndex> delaunay_points(mesh.GetNP());
|
||||||
|
Array<int, PointIndex> p2face(mesh.GetNP());
|
||||||
|
p2face = 0;
|
||||||
|
|
||||||
|
Array<SurfaceElementIndex> surface_els;
|
||||||
|
Array<PointIndex> edge_points;
|
||||||
|
Array<PointIndex> surface_points;
|
||||||
|
for(auto facei : Range(1, fd_old+1))
|
||||||
|
{
|
||||||
|
if(!blp.surfid.Contains(facei))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
p2face = 0;
|
||||||
|
|
||||||
|
edge_points.SetSize(0);
|
||||||
|
surface_points.SetSize(0);
|
||||||
|
surface_els.SetSize(0);
|
||||||
|
mesh.GetSurfaceElementsOfFace (facei, surface_els);
|
||||||
|
Box<2> bbox ( Box<2>::EMPTY_BOX );
|
||||||
|
for(auto sei : surface_els)
|
||||||
|
{
|
||||||
|
const auto & sel = mesh[sei];
|
||||||
|
for (auto i : Range(sel.GetNP()))
|
||||||
|
{
|
||||||
|
auto pi = sel[i];
|
||||||
|
if(p2face[pi] != 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
p2face[pi] = facei;
|
||||||
|
|
||||||
|
if(mesh[pi].Type() <= EDGEPOINT)
|
||||||
|
edge_points.Append(pi);
|
||||||
|
else
|
||||||
|
surface_points.Append(pi);
|
||||||
|
|
||||||
|
auto & gi = sel.GeomInfo()[i];
|
||||||
|
// TODO: project to plane if u,v not available?
|
||||||
|
delaunay_points[pi] = {gi.u, gi.v};
|
||||||
|
bbox.Add(delaunay_points[pi]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(surface_points.Size()==0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
DelaunayMesh dmesh( delaunay_points, bbox );
|
||||||
|
|
||||||
|
for(auto pi : edge_points)
|
||||||
|
{
|
||||||
|
p2face[pi] = 0;
|
||||||
|
dmesh.AddPoint(pi);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::map<PointIndex, double> weights;
|
||||||
|
for(auto pi : surface_points)
|
||||||
|
{
|
||||||
|
dmesh.AddPoint(pi, &weights);
|
||||||
|
auto & v = growthvectors[pi];
|
||||||
|
for(auto & [pi_other, weight] : weights)
|
||||||
|
v += weight * growthvectors[pi_other];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void GenerateBoundaryLayer(Mesh& mesh, const BoundaryLayerParameters& blp)
|
void GenerateBoundaryLayer(Mesh& mesh, const BoundaryLayerParameters& blp)
|
||||||
{
|
{
|
||||||
static Timer timer("Create Boundarylayers");
|
static Timer timer("Create Boundarylayers");
|
||||||
RegionTimer regt(timer);
|
RegionTimer regt(timer);
|
||||||
|
|
||||||
|
bool interpolate_growth_vectors = false;
|
||||||
|
if(mesh.GetGeometry())
|
||||||
|
interpolate_growth_vectors = mesh.GetGeometry()->GetGeomType() == Mesh::GEOM_OCC;
|
||||||
|
|
||||||
int max_edge_nr = -1;
|
int max_edge_nr = -1;
|
||||||
for(const auto& seg : mesh.LineSegments())
|
for(const auto& seg : mesh.LineSegments())
|
||||||
if(seg.edgenr > max_edge_nr)
|
if(seg.edgenr > max_edge_nr)
|
||||||
@ -263,7 +337,7 @@ namespace netgen
|
|||||||
{
|
{
|
||||||
for(auto pi : sel.PNums())
|
for(auto pi : sel.PNums())
|
||||||
{
|
{
|
||||||
if(mesh[pi].Type() >= SURFACEPOINT)
|
if(interpolate_growth_vectors && mesh[pi].Type() >= SURFACEPOINT)
|
||||||
continue;
|
continue;
|
||||||
auto & np = growthvectors[pi];
|
auto & np = growthvectors[pi];
|
||||||
if(np.Length() == 0) { np = n; continue; }
|
if(np.Length() == 0) { np = n; continue; }
|
||||||
@ -358,7 +432,7 @@ namespace netgen
|
|||||||
for(auto i : Range(sel.PNums()))
|
for(auto i : Range(sel.PNums()))
|
||||||
{
|
{
|
||||||
auto pi = sel.PNums()[i];
|
auto pi = sel.PNums()[i];
|
||||||
if(mesh[pi].Type() >= SURFACEPOINT)
|
if(interpolate_growth_vectors && mesh[pi].Type() >= SURFACEPOINT)
|
||||||
continue;
|
continue;
|
||||||
if(growthvectors[pi].Length2() == 0.)
|
if(growthvectors[pi].Length2() == 0.)
|
||||||
continue;
|
continue;
|
||||||
@ -401,17 +475,11 @@ namespace netgen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Array<Point<2>, PointIndex> delaunay_points(mesh.GetNP());
|
|
||||||
Array<int, PointIndex> p2face(mesh.GetNP());
|
|
||||||
p2face = 0;
|
|
||||||
|
|
||||||
// interpolate tangential component of growth vector along edge
|
// interpolate tangential component of growth vector along edge
|
||||||
|
if(interpolate_growth_vectors)
|
||||||
for(auto edgenr : Range(max_edge_nr))
|
for(auto edgenr : Range(max_edge_nr))
|
||||||
{
|
{
|
||||||
if(!moved_edges[edgenr+1]) continue;
|
if(!moved_edges[edgenr+1]) continue;
|
||||||
// can only interpolate on geometry edges
|
|
||||||
if(!mesh.GetGeometry())
|
|
||||||
break;
|
|
||||||
const auto& geo = *mesh.GetGeometry();
|
const auto& geo = *mesh.GetGeometry();
|
||||||
if(edgenr >= geo.GetNEdges())
|
if(edgenr >= geo.GetNEdges())
|
||||||
continue;
|
continue;
|
||||||
@ -472,68 +540,8 @@ namespace netgen
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// interpolate growth vectors at inner surface points from surrounding edge points
|
if(interpolate_growth_vectors)
|
||||||
Array<SurfaceElementIndex> surface_els;
|
InterpolateSurfaceGrowthVectors(mesh, blp, fd_old, growthvectors);
|
||||||
Array<PointIndex> edge_points;
|
|
||||||
Array<PointIndex> surface_points;
|
|
||||||
for(auto facei : Range(1, fd_old+1))
|
|
||||||
{
|
|
||||||
if(!blp.surfid.Contains(facei))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
p2face = 0;
|
|
||||||
|
|
||||||
edge_points.SetSize(0);
|
|
||||||
surface_points.SetSize(0);
|
|
||||||
surface_els.SetSize(0);
|
|
||||||
mesh.GetSurfaceElementsOfFace (facei, surface_els);
|
|
||||||
Box<2> bbox ( Box<2>::EMPTY_BOX );
|
|
||||||
for(auto sei : surface_els)
|
|
||||||
{
|
|
||||||
const auto & sel = mesh[sei];
|
|
||||||
for (auto i : Range(sel.GetNP()))
|
|
||||||
{
|
|
||||||
auto pi = sel[i];
|
|
||||||
if(p2face[pi] != 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
p2face[pi] = facei;
|
|
||||||
|
|
||||||
if(mesh[pi].Type() <= EDGEPOINT)
|
|
||||||
edge_points.Append(pi);
|
|
||||||
else
|
|
||||||
surface_points.Append(pi);
|
|
||||||
|
|
||||||
auto & gi = sel.GeomInfo()[i];
|
|
||||||
// TODO: project to plane if u,v not available?
|
|
||||||
delaunay_points[pi] = {gi.u, gi.v};
|
|
||||||
bbox.Add(delaunay_points[pi]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(surface_points.Size()==0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
DelaunayMesh dmesh( delaunay_points, bbox );
|
|
||||||
|
|
||||||
for(auto pi : edge_points)
|
|
||||||
{
|
|
||||||
p2face[pi] = 0;
|
|
||||||
dmesh.AddPoint(pi);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::map<PointIndex, double> weights;
|
|
||||||
for(auto pi : surface_points)
|
|
||||||
{
|
|
||||||
dmesh.AddPoint(pi, &weights);
|
|
||||||
auto & v = growthvectors[pi];
|
|
||||||
for(auto & [pi_other, weight] : weights)
|
|
||||||
v += weight * growthvectors[pi_other];
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// insert new points
|
// insert new points
|
||||||
for (PointIndex pi = 1; pi <= np; pi++)
|
for (PointIndex pi = 1; pi <= np; pi++)
|
||||||
|
@ -6,9 +6,6 @@
|
|||||||
|
|
||||||
namespace netgen
|
namespace netgen
|
||||||
{
|
{
|
||||||
using ngcore::INT;
|
|
||||||
|
|
||||||
|
|
||||||
void DelaunayTrig::CalcCenter (FlatArray<Point<2>, PointIndex> points)
|
void DelaunayTrig::CalcCenter (FlatArray<Point<2>, PointIndex> points)
|
||||||
{
|
{
|
||||||
Point<2> p1 = points[pnums[0]];
|
Point<2> p1 = points[pnums[0]];
|
||||||
|
@ -2,6 +2,8 @@
|
|||||||
|
|
||||||
namespace netgen
|
namespace netgen
|
||||||
{
|
{
|
||||||
|
using ngcore::INT;
|
||||||
|
|
||||||
static inline Point<2> P2( Point<3> p )
|
static inline Point<2> P2( Point<3> p )
|
||||||
{
|
{
|
||||||
return {p[0], p[1]};
|
return {p[0], p[1]};
|
||||||
|
Loading…
Reference in New Issue
Block a user