mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-05 22:30:33 +05:00
0020843: EDF 1374 : SMESH Projection 2D + Extrusion 3D issue
* Modify for the case of quasi quadrilateral side face
This commit is contained in:
parent
5e181bb5c5
commit
2ef5167c0a
@ -214,6 +214,94 @@ namespace {
|
|||||||
|
|
||||||
return gp_Ax2( O, Z, X);
|
return gp_Ax2( O, Z, X);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Removes submeshes meshed with regular grid from given list
|
||||||
|
* \retval int - nb of removed submeshes
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
int removeQuasiQuads(list< SMESH_subMesh* >& notQuadSubMesh)
|
||||||
|
{
|
||||||
|
int oldNbSM = notQuadSubMesh.size();
|
||||||
|
SMESHDS_Mesh* mesh = notQuadSubMesh.front()->GetFather()->GetMeshDS();
|
||||||
|
list< SMESH_subMesh* >::iterator smIt = notQuadSubMesh.begin();
|
||||||
|
#define __NEXT_SM { ++smIt; continue; }
|
||||||
|
while ( smIt != notQuadSubMesh.end() )
|
||||||
|
{
|
||||||
|
SMESH_subMesh* faceSm = *smIt;
|
||||||
|
SMESHDS_SubMesh* faceSmDS = faceSm->GetSubMeshDS();
|
||||||
|
int nbQuads = faceSmDS->NbElements();
|
||||||
|
if ( nbQuads == 0 ) __NEXT_SM;
|
||||||
|
|
||||||
|
// get oredered edges
|
||||||
|
list< TopoDS_Edge > orderedEdges;
|
||||||
|
list< int > nbEdgesInWires;
|
||||||
|
TopoDS_Vertex V000;
|
||||||
|
int nbWires = SMESH_Block::GetOrderedEdges( TopoDS::Face( faceSm->GetSubShape() ),
|
||||||
|
V000, orderedEdges, nbEdgesInWires );
|
||||||
|
if ( nbWires != 1 || nbEdgesInWires.front() <= 4 )
|
||||||
|
__NEXT_SM;
|
||||||
|
|
||||||
|
// get nb of segements on edges
|
||||||
|
list<int> nbSegOnEdge;
|
||||||
|
list< TopoDS_Edge >::iterator edge = orderedEdges.begin();
|
||||||
|
for ( ; edge != orderedEdges.end(); ++edge )
|
||||||
|
{
|
||||||
|
if ( SMESHDS_SubMesh* edgeSmDS = mesh->MeshElements( *edge ))
|
||||||
|
nbSegOnEdge.push_back( edgeSmDS->NbElements() );
|
||||||
|
else
|
||||||
|
nbSegOnEdge.push_back(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// unite nbSegOnEdge of continues edges
|
||||||
|
int nbEdges = nbEdgesInWires.front();
|
||||||
|
list<int>::iterator nbSegIt = nbSegOnEdge.begin();
|
||||||
|
for ( edge = orderedEdges.begin(); edge != orderedEdges.end(); )
|
||||||
|
{
|
||||||
|
const TopoDS_Edge& e1 = *edge++;
|
||||||
|
const TopoDS_Edge& e2 = ( edge == orderedEdges.end() ? orderedEdges.front() : *edge );
|
||||||
|
if ( SMESH_Algo::IsContinuous( e1, e2 ))
|
||||||
|
{
|
||||||
|
// common vertex of continues edges must be shared by two 2D mesh elems of geom face
|
||||||
|
TopoDS_Vertex vCommon = TopExp::LastVertex( e1, true );
|
||||||
|
const SMDS_MeshNode* vNode = SMESH_Algo::VertexNode( vCommon, mesh );
|
||||||
|
int nbF = 0;
|
||||||
|
if ( vNode )
|
||||||
|
{
|
||||||
|
SMDS_ElemIteratorPtr fIt = vNode->GetInverseElementIterator(SMDSAbs_Face);
|
||||||
|
while ( fIt->more() )
|
||||||
|
nbF += faceSmDS->Contains( fIt->next() );
|
||||||
|
}
|
||||||
|
list<int>::iterator nbSegIt1 = nbSegIt++;
|
||||||
|
if ( !vNode || nbF == 2 ) // !vNode - two edges can be meshed as one
|
||||||
|
{
|
||||||
|
// unite
|
||||||
|
if ( nbSegIt == nbSegOnEdge.end() ) nbSegIt = nbSegOnEdge.begin();
|
||||||
|
*nbSegIt += *nbSegIt1;
|
||||||
|
nbSegOnEdge.erase( nbSegIt1 );
|
||||||
|
--nbEdges;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
++nbSegIt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
vector<int> nbSegVec( nbSegOnEdge.begin(), nbSegOnEdge.end());
|
||||||
|
if ( nbSegVec.size() == 4 &&
|
||||||
|
nbSegVec[0] == nbSegVec[2] &&
|
||||||
|
nbSegVec[1] == nbSegVec[3] &&
|
||||||
|
nbSegVec[0] * nbSegVec[1] == nbQuads
|
||||||
|
)
|
||||||
|
smIt = notQuadSubMesh.erase( smIt );
|
||||||
|
else
|
||||||
|
__NEXT_SM;
|
||||||
|
}
|
||||||
|
|
||||||
|
return oldNbSM - notQuadSubMesh.size();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
@ -320,7 +408,7 @@ bool StdMeshers_Prism_3D::Compute(SMESH_Mesh& theMesh, const TopoDS_Shape& theSh
|
|||||||
// Projections on the top and bottom faces are taken from nodes existing
|
// Projections on the top and bottom faces are taken from nodes existing
|
||||||
// on these faces; find correspondence between bottom and top nodes
|
// on these faces; find correspondence between bottom and top nodes
|
||||||
myBotToColumnMap.clear();
|
myBotToColumnMap.clear();
|
||||||
if ( !assocOrProjBottom2Top() ) // it also fill myBotToColumnMap
|
if ( !assocOrProjBottom2Top() ) // it also fills myBotToColumnMap
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
||||||
@ -763,19 +851,8 @@ bool StdMeshers_Prism_3D::assocOrProjBottom2Top()
|
|||||||
const SMDS_MeshNode* topNode = bN_tN->second;
|
const SMDS_MeshNode* topNode = bN_tN->second;
|
||||||
if ( botNode->GetPosition()->GetTypeOfPosition() != SMDS_TOP_FACE )
|
if ( botNode->GetPosition()->GetTypeOfPosition() != SMDS_TOP_FACE )
|
||||||
continue; // wall columns are contained in myBlock
|
continue; // wall columns are contained in myBlock
|
||||||
// compute bottom node params
|
|
||||||
TNode bN( botNode );
|
|
||||||
// if ( zSize > 2 ) {
|
|
||||||
// gp_XYZ paramHint(-1,-1,-1);
|
|
||||||
// if ( prevTNode.IsNeighbor( bN ))
|
|
||||||
// paramHint = prevTNode.GetParams();
|
|
||||||
// if ( !myBlock.ComputeParameters( bN.GetCoords(), bN.ChangeParams(),
|
|
||||||
// ID_BOT_FACE, paramHint ))
|
|
||||||
// return error(TCom("Can't compute normalized parameters for node ")
|
|
||||||
// << botNode->GetID() << " on the face #"<< botSM->GetId() );
|
|
||||||
// prevTNode = bN;
|
|
||||||
// }
|
|
||||||
// create node column
|
// create node column
|
||||||
|
TNode bN( botNode );
|
||||||
TNode2ColumnMap::iterator bN_col =
|
TNode2ColumnMap::iterator bN_col =
|
||||||
myBotToColumnMap.insert( make_pair ( bN, TNodeColumn() )).first;
|
myBotToColumnMap.insert( make_pair ( bN, TNodeColumn() )).first;
|
||||||
TNodeColumn & column = bN_col->second;
|
TNodeColumn & column = bN_col->second;
|
||||||
@ -1078,7 +1155,7 @@ bool StdMeshers_PrismAsBlock::Init(SMESH_MesherHelper* helper,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
// Analyse faces mesh and topology: choose the bottom submesh.
|
// Analyse mesh and topology of faces: choose the bottom submesh.
|
||||||
// If there are not quadrangle geom faces, they are top and bottom ones.
|
// If there are not quadrangle geom faces, they are top and bottom ones.
|
||||||
// Not quadrangle geom faces must be only on top and bottom.
|
// Not quadrangle geom faces must be only on top and bottom.
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
@ -1091,14 +1168,24 @@ bool StdMeshers_PrismAsBlock::Init(SMESH_MesherHelper* helper,
|
|||||||
bool hasNotQuad = ( nbNotQuad || nbNotQuadMeshed );
|
bool hasNotQuad = ( nbNotQuad || nbNotQuadMeshed );
|
||||||
|
|
||||||
// detect bad cases
|
// detect bad cases
|
||||||
if ( nbNotQuad > 0 && nbNotQuad != 2 )
|
|
||||||
return error(COMPERR_BAD_SHAPE,
|
|
||||||
TCom("More than 2 not quadrilateral faces: ")
|
|
||||||
<<nbNotQuad);
|
|
||||||
if ( nbNotQuadMeshed > 2 )
|
if ( nbNotQuadMeshed > 2 )
|
||||||
|
{
|
||||||
return error(COMPERR_BAD_INPUT_MESH,
|
return error(COMPERR_BAD_INPUT_MESH,
|
||||||
TCom("More than 2 faces with not quadrangle elements: ")
|
TCom("More than 2 faces with not quadrangle elements: ")
|
||||||
<<nbNotQuadMeshed);
|
<<nbNotQuadMeshed);
|
||||||
|
}
|
||||||
|
int nbQuasiQuads = 0;
|
||||||
|
if ( nbNotQuad > 0 && nbNotQuad != 2 )
|
||||||
|
{
|
||||||
|
// Issue 0020843 - one of side faces is quasi-quadrilateral.
|
||||||
|
// Remove from notQuadGeomSubMesh faces meshed with regular grid
|
||||||
|
nbQuasiQuads = removeQuasiQuads( notQuadGeomSubMesh );
|
||||||
|
nbNotQuad -= nbQuasiQuads;
|
||||||
|
if ( nbNotQuad > 0 && nbNotQuad != 2 )
|
||||||
|
return error(COMPERR_BAD_SHAPE,
|
||||||
|
TCom("More than 2 not quadrilateral faces: ")
|
||||||
|
<<nbNotQuad);
|
||||||
|
}
|
||||||
|
|
||||||
// get found submeshes
|
// get found submeshes
|
||||||
if ( hasNotQuad )
|
if ( hasNotQuad )
|
||||||
|
Loading…
Reference in New Issue
Block a user