Skip to content

Commit

Permalink
mesh.parentelement with correct types
Browse files Browse the repository at this point in the history
  • Loading branch information
JSchoeberl committed Jan 4, 2025
1 parent 9bc0273 commit 63cb566
Show file tree
Hide file tree
Showing 6 changed files with 34 additions and 31 deletions.
6 changes: 3 additions & 3 deletions libsrc/interface/nginterface.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1749,12 +1749,12 @@ int Ng_GetParentElement (int ei)
if (mesh->GetDimension() == 3)
{
if (ei <= mesh->mlparentelement.Size())
return mesh->mlparentelement.Get(ei);
return mesh->mlparentelement[ei-1]+1;
}
else
{
if (ei <= mesh->mlparentsurfaceelement.Size())
return mesh->mlparentsurfaceelement.Get(ei);
return mesh->mlparentsurfaceelement[ei-1]+1;
}
return 0;
}
Expand All @@ -1765,7 +1765,7 @@ int Ng_GetParentSElement (int ei)
if (mesh->GetDimension() == 3)
{
if (ei <= mesh->mlparentsurfaceelement.Size())
return mesh->mlparentsurfaceelement.Get(ei);
return mesh->mlparentsurfaceelement[ei-1]+1;
}
else
{
Expand Down
28 changes: 13 additions & 15 deletions libsrc/interface/nginterface_v2.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -725,34 +725,32 @@ namespace netgen

int Ngx_Mesh :: GetParentElement (int ei) const
{
ei++;
if (mesh->GetDimension() == 3)
if (mesh->GetDimension() == 3)
{
if (ei <= mesh->mlparentelement.Size())
return mesh->mlparentelement.Get(ei)-1;
if (ei < mesh->mlparentelement.Size())
return mesh->mlparentelement[ei];
}
else
else
{
if (ei <= mesh->mlparentsurfaceelement.Size())
return mesh->mlparentsurfaceelement.Get(ei)-1;
if (ei < mesh->mlparentsurfaceelement.Size())
return mesh->mlparentsurfaceelement[ei];
}
return -1;
return -1;
}


int Ngx_Mesh :: GetParentSElement (int ei) const
{
ei++;
if (mesh->GetDimension() == 3)
if (mesh->GetDimension() == 3)
{
if (ei <= mesh->mlparentsurfaceelement.Size())
return mesh->mlparentsurfaceelement.Get(ei)-1;
if (ei < mesh->mlparentsurfaceelement.Size())
return mesh->mlparentsurfaceelement[ei];
}
else
else
{
return -1;
return -1;
}
return -1;
return -1;
}

int Ngx_Mesh :: GetNIdentifications () const
Expand Down
15 changes: 9 additions & 6 deletions libsrc/meshing/bisect.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2203,11 +2203,14 @@ namespace netgen


mesh.mlparentelement.SetSize(ne);
for (int i = 1; i <= ne; i++)
mesh.mlparentelement.Elem(i) = 0;
// for (int i = 1; i <= ne; i++)
// mesh.mlparentelement.Elem(i) = 0;
mesh.mlparentelement = ElementIndex::INVALID;

mesh.mlparentsurfaceelement.SetSize(nse);
for (int i = 1; i <= nse; i++)
mesh.mlparentsurfaceelement.Elem(i) = 0;
// for (int i = 1; i <= nse; i++)
// mesh.mlparentsurfaceelement.Elem(i) = 0;
mesh.mlparentsurfaceelement = SurfaceElementIndex::INVALID;

if (printmessage_importance>0)
{
Expand Down Expand Up @@ -3361,7 +3364,7 @@ namespace netgen

mtets[ei] = newtet1;
mtets.Append (newtet2);
mesh.mlparentelement.Append (ei-IndexBASE<ElementIndex>()+1);
mesh.mlparentelement.Append (ei);
}
NgProfiler::StopTimer (timer_bisecttet);
(*opt.tracer)("bisecttet", true);
Expand Down Expand Up @@ -3508,7 +3511,7 @@ namespace netgen

mtris[i] = newtri1;
mtris.Append (newtri2);
mesh.mlparentsurfaceelement.Append (i+1);
mesh.mlparentsurfaceelement.Append (i);
}

NgProfiler::StopTimer (timer_bisecttrig);
Expand Down
4 changes: 2 additions & 2 deletions libsrc/meshing/meshclass.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -224,9 +224,9 @@ namespace netgen
/// refinement hierarchy
Array<PointIndices<2>,PointIndex> mlbetweennodes;
/// parent element of volume element
NgArray<int> mlparentelement;
Array<ElementIndex, ElementIndex> mlparentelement;
/// parent element of surface element
NgArray<int> mlparentsurfaceelement;
Array<SurfaceElementIndex, SurfaceElementIndex> mlparentsurfaceelement;



Expand Down
4 changes: 2 additions & 2 deletions libsrc/meshing/parallelmesh.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -959,8 +959,8 @@ namespace netgen
self.opensegments = NgArray<Segment>(0);
self.numvertices = 0;
self.mlbetweennodes = Array<PointIndices<2>,PointIndex> (0);
self.mlparentelement = NgArray<int>(0);
self.mlparentsurfaceelement = NgArray<int>(0);
self.mlparentelement = Array<ElementIndex, ElementIndex>(0);
self.mlparentsurfaceelement = Array<SurfaceElementIndex, SurfaceElementIndex>(0);
self.curvedelems = make_unique<CurvedElements> (self);
self.clusters = make_unique<AnisotropicClusters> (self);
self.ident = make_unique<Identifications> (self);
Expand Down
8 changes: 5 additions & 3 deletions libsrc/meshing/python_mesh.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -961,11 +961,13 @@ DLL_HEADER void ExportNetgenMeshing(py::module &m)
);
})
.def_property_readonly("parentelements", [](Mesh & self) {
return FlatArray<int>(self.mlparentelement.Size(), &self.mlparentelement[0]);
// return FlatArray<int>(self.mlparentelement.Size(), &self.mlparentelement[0]);
return FlatArray(self.mlparentelement);
}, py::keep_alive<0,1>())
.def_property_readonly("parentsurfaceelements", [](Mesh & self) {
return FlatArray<int>(self.mlparentsurfaceelement.Size(),
&self.mlparentsurfaceelement[0]);
// return FlatArray<int>(self.mlparentsurfaceelement.Size(),
// &self.mlparentsurfaceelement[0]);
return FlatArray(self.mlparentsurfaceelement);
}, py::keep_alive<0,1>())
.def_property_readonly("macromesh", [](Mesh & self) {
auto coarsemesh = make_shared<Mesh>();
Expand Down

0 comments on commit 63cb566

Please sign in to comment.