PAL15429 Computation of the mesh, based on "014.brep" via Tetrahedron(NETGEN), is failed.
fix for G7.py
This commit is contained in:
parent
ad29df2ead
commit
8130763e3a
@ -178,6 +178,9 @@ bool NETGENPlugin_NETGEN_3D::Compute(SMESH_Mesh& aMesh,
|
|||||||
list< const SMDS_MeshElement* > triangles;
|
list< const SMDS_MeshElement* > triangles;
|
||||||
list< bool > isReversed; // orientation of triangles
|
list< bool > isReversed; // orientation of triangles
|
||||||
|
|
||||||
|
TopAbs_ShapeEnum mainType = aMesh.GetShapeToMesh().ShapeType();
|
||||||
|
bool checkReverse = ( mainType == TopAbs_COMPOUND || mainType == TopAbs_COMPSOLID );
|
||||||
|
|
||||||
// for the degeneraged edge: ignore all but one node on it;
|
// for the degeneraged edge: ignore all but one node on it;
|
||||||
// map storing ids of degen edges and vertices and their netgen id:
|
// map storing ids of degen edges and vertices and their netgen id:
|
||||||
map< int, int* > degenShapeIdToPtrNgId;
|
map< int, int* > degenShapeIdToPtrNgId;
|
||||||
@ -193,7 +196,11 @@ bool NETGENPlugin_NETGEN_3D::Compute(SMESH_Mesh& aMesh,
|
|||||||
const SMESHDS_SubMesh * aSubMeshDSFace = meshDS->MeshElements( aShapeFace );
|
const SMESHDS_SubMesh * aSubMeshDSFace = meshDS->MeshElements( aShapeFace );
|
||||||
if ( aSubMeshDSFace )
|
if ( aSubMeshDSFace )
|
||||||
{
|
{
|
||||||
bool isRev = SMESH_Algo::IsReversedSubMesh( TopoDS::Face(aShapeFace), meshDS );
|
bool isRev = false;
|
||||||
|
if ( checkReverse && helper.NbAncestors(aShapeFace, aMesh, aShape.ShapeType()) > 1 )
|
||||||
|
// IsReversedSubMesh() can work wrong on strongly curved faces,
|
||||||
|
// so we use it as less as possible
|
||||||
|
isRev = SMESH_Algo::IsReversedSubMesh( TopoDS::Face(aShapeFace), meshDS );
|
||||||
|
|
||||||
SMDS_ElemIteratorPtr iteratorElem = aSubMeshDSFace->GetElements();
|
SMDS_ElemIteratorPtr iteratorElem = aSubMeshDSFace->GetElements();
|
||||||
while ( iteratorElem->more() ) // loop on elements on a face
|
while ( iteratorElem->more() ) // loop on elements on a face
|
||||||
@ -332,8 +339,10 @@ bool NETGENPlugin_NETGEN_3D::Compute(SMESH_Mesh& aMesh,
|
|||||||
(Netgen_triangle[0] != Netgen_triangle[1] &&
|
(Netgen_triangle[0] != Netgen_triangle[1] &&
|
||||||
Netgen_triangle[0] != Netgen_triangle[2] &&
|
Netgen_triangle[0] != Netgen_triangle[2] &&
|
||||||
Netgen_triangle[2] != Netgen_triangle[1] ))
|
Netgen_triangle[2] != Netgen_triangle[1] ))
|
||||||
|
{
|
||||||
Ng_AddSurfaceElement(Netgen_mesh, NG_TRIG, Netgen_triangle);
|
Ng_AddSurfaceElement(Netgen_mesh, NG_TRIG, Netgen_triangle);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// -------------------------
|
// -------------------------
|
||||||
// Generate the volume mesh
|
// Generate the volume mesh
|
||||||
|
Loading…
Reference in New Issue
Block a user