NPAL14335 (EDF 344 SMESH : "ERROR : Iterator not implemented " when loading a script)

1) use GetInverseElementIterator(type) instead of facesIterator
           and edgesIterator()
        2) use set<element,comparator> instead of map<ID,element> to
           have elements sorted by ID
This commit is contained in:
eap 2006-12-29 14:33:32 +00:00
parent 7dad29749c
commit 3103371901
2 changed files with 177 additions and 188 deletions

View File

@ -69,6 +69,7 @@
#include <TopoDS_Face.hxx> #include <TopoDS_Face.hxx>
#include <map> #include <map>
#include <set>
using namespace std; using namespace std;
using namespace SMESH::Controls; using namespace SMESH::Controls;
@ -450,17 +451,16 @@ static bool findTriangles(const SMDS_MeshNode * theNode1,
theTria1 = theTria2 = 0; theTria1 = theTria2 = 0;
set< const SMDS_MeshElement* > emap; set< const SMDS_MeshElement* > emap;
SMDS_ElemIteratorPtr it = theNode1->GetInverseElementIterator(); SMDS_ElemIteratorPtr it = theNode1->GetInverseElementIterator(SMDSAbs_Face);
while (it->more()) { while (it->more()) {
const SMDS_MeshElement* elem = it->next(); const SMDS_MeshElement* elem = it->next();
if ( elem->GetType() == SMDSAbs_Face && elem->NbNodes() == 3 ) if ( elem->NbNodes() == 3 )
emap.insert( elem ); emap.insert( elem );
} }
it = theNode2->GetInverseElementIterator(); it = theNode2->GetInverseElementIterator(SMDSAbs_Face);
while (it->more()) { while (it->more()) {
const SMDS_MeshElement* elem = it->next(); const SMDS_MeshElement* elem = it->next();
if ( elem->GetType() == SMDSAbs_Face && if ( emap.find( elem ) != emap.end() )
emap.find( elem ) != emap.end() )
if ( theTria1 ) { if ( theTria1 ) {
// theTria1 must be element with minimum ID // theTria1 must be element with minimum ID
if( theTria1->GetID() < elem->GetID() ) { if( theTria1->GetID() < elem->GetID() ) {
@ -812,7 +812,7 @@ static double getBadRate (const SMDS_MeshElement* theElem,
// theCrit is used to select a diagonal to cut // theCrit is used to select a diagonal to cut
//======================================================================= //=======================================================================
bool SMESH_MeshEditor::QuadToTri (map<int,const SMDS_MeshElement*> & theElems, bool SMESH_MeshEditor::QuadToTri (TIDSortedElemSet & theElems,
SMESH::Controls::NumericalFunctorPtr theCrit) SMESH::Controls::NumericalFunctorPtr theCrit)
{ {
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
@ -828,9 +828,9 @@ bool SMESH_MeshEditor::QuadToTri (map<int,const SMDS_MeshElement*> & theElems,
Handle(Geom_Surface) surface; Handle(Geom_Surface) surface;
SMESH_MesherHelper helper( *GetMesh() ); SMESH_MesherHelper helper( *GetMesh() );
map<int, const SMDS_MeshElement * >::iterator itElem; TIDSortedElemSet::iterator itElem;
for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) { for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) {
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
if ( !elem || elem->GetType() != SMDSAbs_Face ) if ( !elem || elem->GetType() != SMDSAbs_Face )
continue; continue;
if ( elem->NbNodes() != ( elem->IsQuadratic() ? 8 : 4 )) if ( elem->NbNodes() != ( elem->IsQuadratic() ? 8 : 4 ))
@ -1049,8 +1049,8 @@ void SMESH_MeshEditor::RemoveElemFromGroups (const SMDS_MeshElement* removeelem,
// theCrit is used to select a diagonal to cut // theCrit is used to select a diagonal to cut
//======================================================================= //=======================================================================
bool SMESH_MeshEditor::QuadToTri (std::map<int,const SMDS_MeshElement*> & theElems, bool SMESH_MeshEditor::QuadToTri (TIDSortedElemSet & theElems,
const bool the13Diag) const bool the13Diag)
{ {
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
myLastCreatedNodes.Clear(); myLastCreatedNodes.Clear();
@ -1062,9 +1062,9 @@ bool SMESH_MeshEditor::QuadToTri (std::map<int,const SMDS_MeshElement*> & theEle
Handle(Geom_Surface) surface; Handle(Geom_Surface) surface;
SMESH_MesherHelper helper( *GetMesh() ); SMESH_MesherHelper helper( *GetMesh() );
map<int, const SMDS_MeshElement * >::iterator itElem; TIDSortedElemSet::iterator itElem;
for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) { for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) {
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
if ( !elem || elem->GetType() != SMDSAbs_Face ) if ( !elem || elem->GetType() != SMDSAbs_Face )
continue; continue;
bool isquad = elem->NbNodes()==4 || elem->NbNodes()==8; bool isquad = elem->NbNodes()==4 || elem->NbNodes()==8;
@ -1284,7 +1284,7 @@ class LinkID_Gen {
// fusion is still performed. // fusion is still performed.
//======================================================================= //=======================================================================
bool SMESH_MeshEditor::TriToQuad (map<int,const SMDS_MeshElement*> & theElems, bool SMESH_MeshEditor::TriToQuad (TIDSortedElemSet & theElems,
SMESH::Controls::NumericalFunctorPtr theCrit, SMESH::Controls::NumericalFunctorPtr theCrit,
const double theMaxAngle) const double theMaxAngle)
{ {
@ -1313,9 +1313,9 @@ bool SMESH_MeshEditor::TriToQuad (map<int,const SMDS_MeshElement*> & theEl
map< const SMDS_MeshElement*, set< NLink > > mapEl_setLi; map< const SMDS_MeshElement*, set< NLink > > mapEl_setLi;
map< const SMDS_MeshElement*, set< NLink > >::iterator itEL; map< const SMDS_MeshElement*, set< NLink > >::iterator itEL;
map<int,const SMDS_MeshElement*>::iterator itElem; TIDSortedElemSet::iterator itElem;
for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) { for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) {
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
//if ( !elem || elem->NbNodes() != 3 ) //if ( !elem || elem->NbNodes() != 3 )
// continue; // continue;
if(!elem || elem->GetType() != SMDSAbs_Face ) continue; if(!elem || elem->GetType() != SMDSAbs_Face ) continue;
@ -1897,12 +1897,10 @@ void laplacianSmooth(const SMDS_MeshNode* theNode,
// find surrounding nodes // find surrounding nodes
set< const SMDS_MeshNode* > nodeSet; set< const SMDS_MeshNode* > nodeSet;
SMDS_ElemIteratorPtr elemIt = theNode->GetInverseElementIterator(); SMDS_ElemIteratorPtr elemIt = theNode->GetInverseElementIterator(SMDSAbs_Face);
while ( elemIt->more() ) while ( elemIt->more() )
{ {
const SMDS_MeshElement* elem = elemIt->next(); const SMDS_MeshElement* elem = elemIt->next();
if ( elem->GetType() != SMDSAbs_Face )
continue;
for ( int i = 0; i < elem->NbNodes(); ++i ) { for ( int i = 0; i < elem->NbNodes(); ++i ) {
if ( elem->GetNode( i ) == theNode ) { if ( elem->GetNode( i ) == theNode ) {
@ -1980,12 +1978,10 @@ void centroidalSmooth(const SMDS_MeshNode* theNode,
// compute new XYZ // compute new XYZ
SMDS_ElemIteratorPtr elemIt = theNode->GetInverseElementIterator(); SMDS_ElemIteratorPtr elemIt = theNode->GetInverseElementIterator(SMDSAbs_Face);
while ( elemIt->more() ) while ( elemIt->more() )
{ {
const SMDS_MeshElement* elem = elemIt->next(); const SMDS_MeshElement* elem = elemIt->next();
if ( elem->GetType() != SMDSAbs_Face )
continue;
nbElems++; nbElems++;
gp_XYZ elemCenter(0.,0.,0.); gp_XYZ elemCenter(0.,0.,0.);
@ -2056,12 +2052,12 @@ static bool getClosestUV (Extrema_GenExtPS& projector,
// on edges and boundary nodes are always fixed. // on edges and boundary nodes are always fixed.
//======================================================================= //=======================================================================
void SMESH_MeshEditor::Smooth (map<int,const SMDS_MeshElement*> & theElems, void SMESH_MeshEditor::Smooth (TIDSortedElemSet & theElems,
set<const SMDS_MeshNode*> & theFixedNodes, set<const SMDS_MeshNode*> & theFixedNodes,
const SmoothMethod theSmoothMethod, const SmoothMethod theSmoothMethod,
const int theNbIterations, const int theNbIterations,
double theTgtAspectRatio, double theTgtAspectRatio,
const bool the2D) const bool the2D)
{ {
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
myLastCreatedNodes.Clear(); myLastCreatedNodes.Clear();
@ -2082,15 +2078,15 @@ void SMESH_MeshEditor::Smooth (map<int,const SMDS_MeshElement*> & theElems,
SMDS_FaceIteratorPtr fIt = aMesh->facesIterator(); SMDS_FaceIteratorPtr fIt = aMesh->facesIterator();
while ( fIt->more() ) { while ( fIt->more() ) {
const SMDS_MeshElement* face = fIt->next(); const SMDS_MeshElement* face = fIt->next();
theElems.insert( make_pair(face->GetID(),face) ); theElems.insert( face );
} }
} }
// get all face ids theElems are on // get all face ids theElems are on
set< int > faceIdSet; set< int > faceIdSet;
map<int, const SMDS_MeshElement* >::iterator itElem; TIDSortedElemSet::iterator itElem;
if ( the2D ) if ( the2D )
for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) { for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) {
int fId = FindShape( (*itElem).second ); int fId = FindShape( *itElem );
// check that corresponding submesh exists and a shape is face // check that corresponding submesh exists and a shape is face
if (fId && if (fId &&
faceIdSet.find( fId ) == faceIdSet.end() && faceIdSet.find( fId ) == faceIdSet.end() &&
@ -2153,7 +2149,7 @@ void SMESH_MeshEditor::Smooth (map<int,const SMDS_MeshElement*> & theElems,
if ( faceSubMesh && nbElemOnFace == faceSubMesh->NbElements() ) if ( faceSubMesh && nbElemOnFace == faceSubMesh->NbElements() )
break; // all elements found break; // all elements found
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
if ( !elem || elem->GetType() != SMDSAbs_Face || elem->NbNodes() < 3 || if ( !elem || elem->GetType() != SMDSAbs_Face || elem->NbNodes() < 3 ||
( faceSubMesh && !faceSubMesh->Contains( elem ))) { ( faceSubMesh && !faceSubMesh->Contains( elem ))) {
++itElem; ++itElem;
@ -2183,13 +2179,12 @@ void SMESH_MeshEditor::Smooth (map<int,const SMDS_MeshElement*> & theElems,
{ {
// check if all faces around the node are on faceSubMesh // check if all faces around the node are on faceSubMesh
// because a node on edge may be bound to face // because a node on edge may be bound to face
SMDS_ElemIteratorPtr eIt = node->GetInverseElementIterator(); SMDS_ElemIteratorPtr eIt = node->GetInverseElementIterator(SMDSAbs_Face);
bool all = true; bool all = true;
if ( faceSubMesh ) { if ( faceSubMesh ) {
while ( eIt->more() && all ) { while ( eIt->more() && all ) {
const SMDS_MeshElement* e = eIt->next(); const SMDS_MeshElement* e = eIt->next();
if ( e->GetType() == SMDSAbs_Face ) all = faceSubMesh->Contains( e );
all = faceSubMesh->Contains( e );
} }
} }
if ( all ) if ( all )
@ -2215,10 +2210,10 @@ void SMESH_MeshEditor::Smooth (map<int,const SMDS_MeshElement*> & theElems,
if ( uvMap.find( node ) == uvMap.end() ) if ( uvMap.find( node ) == uvMap.end() )
uvCheckNodes.push_back( node ); uvCheckNodes.push_back( node );
// add nodes of elems sharing node // add nodes of elems sharing node
// SMDS_ElemIteratorPtr eIt = node->GetInverseElementIterator(); // SMDS_ElemIteratorPtr eIt = node->GetInverseElementIterator(SMDSAbs_Face);
// while ( eIt->more() ) { // while ( eIt->more() ) {
// const SMDS_MeshElement* e = eIt->next(); // const SMDS_MeshElement* e = eIt->next();
// if ( e != elem && e->GetType() == SMDSAbs_Face ) { // if ( e != elem ) {
// SMDS_ElemIteratorPtr nIt = e->nodesIterator(); // SMDS_ElemIteratorPtr nIt = e->nodesIterator();
// while ( nIt->more() ) { // while ( nIt->more() ) {
// const SMDS_MeshNode* n = // const SMDS_MeshNode* n =
@ -2397,11 +2392,9 @@ void SMESH_MeshEditor::Smooth (map<int,const SMDS_MeshElement*> & theElems,
uvMap2[ nSeam ] = &listUV.back(); uvMap2[ nSeam ] = &listUV.back();
// collect movable nodes linked to ones on seam in nodesNearSeam // collect movable nodes linked to ones on seam in nodesNearSeam
SMDS_ElemIteratorPtr eIt = nSeam->GetInverseElementIterator(); SMDS_ElemIteratorPtr eIt = nSeam->GetInverseElementIterator(SMDSAbs_Face);
while ( eIt->more() ) { while ( eIt->more() ) {
const SMDS_MeshElement* e = eIt->next(); const SMDS_MeshElement* e = eIt->next();
if ( e->GetType() != SMDSAbs_Face )
continue;
int nbUseMap1 = 0, nbUseMap2 = 0; int nbUseMap1 = 0, nbUseMap2 = 0;
SMDS_ElemIteratorPtr nIt = e->nodesIterator(); SMDS_ElemIteratorPtr nIt = e->nodesIterator();
int nn = 0, nbn = e->NbNodes(); int nn = 0, nbn = e->NbNodes();
@ -2919,12 +2912,12 @@ static void sweepElement(SMESHDS_Mesh* aMesh,
//purpose : create 1D and 2D elements around swept elements //purpose : create 1D and 2D elements around swept elements
//======================================================================= //=======================================================================
static void makeWalls (SMESHDS_Mesh* aMesh, static void makeWalls (SMESHDS_Mesh* aMesh,
TNodeOfNodeListMap & mapNewNodes, TNodeOfNodeListMap & mapNewNodes,
TElemOfElemListMap & newElemsMap, TElemOfElemListMap & newElemsMap,
TElemOfVecOfNnlmiMap & elemNewNodesMap, TElemOfVecOfNnlmiMap & elemNewNodesMap,
map<int,const SMDS_MeshElement*>& elemSet, TIDSortedElemSet& elemSet,
const int nbSteps, const int nbSteps,
SMESH_SequenceOfElemPtr& myLastCreatedElems) SMESH_SequenceOfElemPtr& myLastCreatedElems)
{ {
ASSERT( newElemsMap.size() == elemNewNodesMap.size() ); ASSERT( newElemsMap.size() == elemNewNodesMap.size() );
@ -2947,7 +2940,7 @@ static void makeWalls (SMESHDS_Mesh* aMesh,
nbInitElems = 0; nbInitElems = 0;
highType = type; highType = type;
} }
if ( elemSet.find(el->GetID()) != elemSet.end() ) if ( elemSet.find(el) != elemSet.end() )
nbInitElems++; nbInitElems++;
} }
if ( nbInitElems < 2 ) { if ( nbInitElems < 2 ) {
@ -2993,8 +2986,8 @@ static void makeWalls (SMESHDS_Mesh* aMesh,
bool hasFreeLinks = false; bool hasFreeLinks = false;
map<int,const SMDS_MeshElement*> avoidSet; TIDSortedElemSet avoidSet;
avoidSet.insert( make_pair(elem->GetID(),elem) ); avoidSet.insert( elem );
set<const SMDS_MeshNode*> aFaceLastNodes; set<const SMDS_MeshNode*> aFaceLastNodes;
int iNode, nbNodes = vecNewNodes.size(); int iNode, nbNodes = vecNewNodes.size();
@ -3195,11 +3188,11 @@ static void makeWalls (SMESHDS_Mesh* aMesh,
//purpose : //purpose :
//======================================================================= //=======================================================================
void SMESH_MeshEditor::RotationSweep(map<int,const SMDS_MeshElement*> & theElems, void SMESH_MeshEditor::RotationSweep(TIDSortedElemSet & theElems,
const gp_Ax1& theAxis, const gp_Ax1& theAxis,
const double theAngle, const double theAngle,
const int theNbSteps, const int theNbSteps,
const double theTol) const double theTol)
{ {
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
myLastCreatedNodes.Clear(); myLastCreatedNodes.Clear();
@ -3220,9 +3213,9 @@ void SMESH_MeshEditor::RotationSweep(map<int,const SMDS_MeshElement*> & theElems
TElemOfElemListMap newElemsMap; TElemOfElemListMap newElemsMap;
// loop on theElems // loop on theElems
map<int, const SMDS_MeshElement* >::iterator itElem; TIDSortedElemSet::iterator itElem;
for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) { for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) {
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
if ( !elem ) if ( !elem )
continue; continue;
vector<TNodeOfNodeListMapItr> & newNodesItVec = mapElemNewNodes[ elem ]; vector<TNodeOfNodeListMapItr> & newNodesItVec = mapElemNewNodes[ elem ];
@ -3352,13 +3345,12 @@ const SMDS_MeshNode* SMESH_MeshEditor::CreateNode(const double x,
//purpose : //purpose :
//======================================================================= //=======================================================================
void SMESH_MeshEditor::ExtrusionSweep void SMESH_MeshEditor::ExtrusionSweep (TIDSortedElemSet & theElems,
(map<int,const SMDS_MeshElement*> & theElems, const gp_Vec& theStep,
const gp_Vec& theStep, const int theNbSteps,
const int theNbSteps, TElemOfElemListMap& newElemsMap,
TElemOfElemListMap& newElemsMap, const int theFlags,
const int theFlags, const double theTolerance)
const double theTolerance)
{ {
ExtrusParam aParams; ExtrusParam aParams;
aParams.myDir = gp_Dir(theStep); aParams.myDir = gp_Dir(theStep);
@ -3378,12 +3370,11 @@ void SMESH_MeshEditor::ExtrusionSweep
//purpose : //purpose :
//======================================================================= //=======================================================================
void SMESH_MeshEditor::ExtrusionSweep void SMESH_MeshEditor::ExtrusionSweep (TIDSortedElemSet & theElems,
(map<int,const SMDS_MeshElement*> & theElems, ExtrusParam& theParams,
ExtrusParam& theParams, TElemOfElemListMap& newElemsMap,
TElemOfElemListMap& newElemsMap, const int theFlags,
const int theFlags, const double theTolerance)
const double theTolerance)
{ {
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
myLastCreatedNodes.Clear(); myLastCreatedNodes.Clear();
@ -3398,10 +3389,10 @@ void SMESH_MeshEditor::ExtrusionSweep
//TElemOfVecOfMapNodesMap mapElemNewNodes; //TElemOfVecOfMapNodesMap mapElemNewNodes;
// loop on theElems // loop on theElems
map<int, const SMDS_MeshElement* >::iterator itElem; TIDSortedElemSet::iterator itElem;
for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) { for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) {
// check element type // check element type
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
if ( !elem ) if ( !elem )
continue; continue;
@ -3563,13 +3554,13 @@ protected:
//purpose : //purpose :
//======================================================================= //=======================================================================
SMESH_MeshEditor::Extrusion_Error SMESH_MeshEditor::Extrusion_Error
SMESH_MeshEditor::ExtrusionAlongTrack (std::map<int,const SMDS_MeshElement*> & theElements, SMESH_MeshEditor::ExtrusionAlongTrack (TIDSortedElemSet & theElements,
SMESH_subMesh* theTrack, SMESH_subMesh* theTrack,
const SMDS_MeshNode* theN1, const SMDS_MeshNode* theN1,
const bool theHasAngles, const bool theHasAngles,
std::list<double>& theAngles, list<double>& theAngles,
const bool theHasRefPoint, const bool theHasRefPoint,
const gp_Pnt& theRefPoint) const gp_Pnt& theRefPoint)
{ {
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
myLastCreatedNodes.Clear(); myLastCreatedNodes.Clear();
@ -3579,7 +3570,7 @@ SMESH_MeshEditor::Extrusion_Error
double aT1, aT2, aT, aAngle, aX, aY, aZ; double aT1, aT2, aT, aAngle, aX, aY, aZ;
std::list<double> aPrms; std::list<double> aPrms;
std::list<double>::iterator aItD; std::list<double>::iterator aItD;
std::map<int, const SMDS_MeshElement* >::iterator itElem; TIDSortedElemSet::iterator itElem;
Standard_Real aTx1, aTx2, aL2, aTolVec, aTolVec2; Standard_Real aTx1, aTx2, aL2, aTolVec, aTolVec2;
gp_Pnt aP3D, aV0; gp_Pnt aP3D, aV0;
@ -3719,7 +3710,7 @@ SMESH_MeshEditor::Extrusion_Error
itElem = theElements.begin(); itElem = theElements.begin();
for ( ; itElem != theElements.end(); itElem++ ) { for ( ; itElem != theElements.end(); itElem++ ) {
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
SMDS_ElemIteratorPtr itN = elem->nodesIterator(); SMDS_ElemIteratorPtr itN = elem->nodesIterator();
while ( itN->more() ) { while ( itN->more() ) {
@ -3748,7 +3739,7 @@ SMESH_MeshEditor::Extrusion_Error
for ( itElem = theElements.begin(); itElem != theElements.end(); itElem++ ) { for ( itElem = theElements.begin(); itElem != theElements.end(); itElem++ ) {
// check element type // check element type
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
aTypeE = elem->GetType(); aTypeE = elem->GetType();
if ( !elem || ( aTypeE != SMDSAbs_Face && aTypeE != SMDSAbs_Edge ) ) if ( !elem || ( aTypeE != SMDSAbs_Face && aTypeE != SMDSAbs_Edge ) )
continue; continue;
@ -3893,9 +3884,9 @@ SMESH_MeshEditor::Extrusion_Error
//purpose : //purpose :
//======================================================================= //=======================================================================
void SMESH_MeshEditor::Transform (map<int,const SMDS_MeshElement*> & theElems, void SMESH_MeshEditor::Transform (TIDSortedElemSet & theElems,
const gp_Trsf& theTrsf, const gp_Trsf& theTrsf,
const bool theCopy) const bool theCopy)
{ {
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
myLastCreatedNodes.Clear(); myLastCreatedNodes.Clear();
@ -3917,12 +3908,12 @@ void SMESH_MeshEditor::Transform (map<int,const SMDS_MeshElement*> & theElems,
// elements sharing moved nodes; those of them which have all // elements sharing moved nodes; those of them which have all
// nodes mirrored but are not in theElems are to be reversed // nodes mirrored but are not in theElems are to be reversed
map<int,const SMDS_MeshElement*> inverseElemSet; TIDSortedElemSet inverseElemSet;
// loop on theElems // loop on theElems
map<int, const SMDS_MeshElement* >::iterator itElem; TIDSortedElemSet::iterator itElem;
for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) { for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) {
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
if ( !elem ) if ( !elem )
continue; continue;
@ -3959,7 +3950,7 @@ void SMESH_MeshEditor::Transform (map<int,const SMDS_MeshElement*> & theElems,
SMDS_ElemIteratorPtr invElemIt = node->GetInverseElementIterator(); SMDS_ElemIteratorPtr invElemIt = node->GetInverseElementIterator();
while ( invElemIt->more() ) { while ( invElemIt->more() ) {
const SMDS_MeshElement* iel = invElemIt->next(); const SMDS_MeshElement* iel = invElemIt->next();
inverseElemSet.insert( make_pair(iel->GetID(),iel) ); inverseElemSet.insert( iel );
} }
} }
} }
@ -3971,7 +3962,7 @@ void SMESH_MeshEditor::Transform (map<int,const SMDS_MeshElement*> & theElems,
return; return;
if ( !inverseElemSet.empty()) { if ( !inverseElemSet.empty()) {
map<int,const SMDS_MeshElement*>::iterator invElemIt = inverseElemSet.begin(); TIDSortedElemSet::iterator invElemIt = inverseElemSet.begin();
for ( ; invElemIt != inverseElemSet.end(); invElemIt++ ) for ( ; invElemIt != inverseElemSet.end(); invElemIt++ )
theElems.insert( *invElemIt ); theElems.insert( *invElemIt );
} }
@ -3996,7 +3987,7 @@ void SMESH_MeshEditor::Transform (map<int,const SMDS_MeshElement*> & theElems,
}; };
for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) { for ( itElem = theElems.begin(); itElem != theElems.end(); itElem++ ) {
const SMDS_MeshElement* elem = (*itElem).second; const SMDS_MeshElement* elem = *itElem;
if ( !elem || elem->GetType() == SMDSAbs_Node ) if ( !elem || elem->GetType() == SMDSAbs_Node )
continue; continue;
@ -4972,19 +4963,18 @@ void SMESH_MeshEditor::MergeEqualElements()
//======================================================================= //=======================================================================
const SMDS_MeshElement* const SMDS_MeshElement*
SMESH_MeshEditor::FindFaceInSet(const SMDS_MeshNode* n1, SMESH_MeshEditor::FindFaceInSet(const SMDS_MeshNode* n1,
const SMDS_MeshNode* n2, const SMDS_MeshNode* n2,
const map<int,const SMDS_MeshElement*>& elemSet, const TIDSortedElemSet& elemSet,
const map<int,const SMDS_MeshElement*>& avoidSet) const TIDSortedElemSet& avoidSet)
{ {
SMDS_ElemIteratorPtr invElemIt = n1->GetInverseElementIterator(); SMDS_ElemIteratorPtr invElemIt = n1->GetInverseElementIterator(SMDSAbs_Face);
while ( invElemIt->more() ) { // loop on inverse elements of n1 while ( invElemIt->more() ) { // loop on inverse elements of n1
const SMDS_MeshElement* elem = invElemIt->next(); const SMDS_MeshElement* elem = invElemIt->next();
if (elem->GetType() != SMDSAbs_Face || if (avoidSet.find( elem ) != avoidSet.end() )
avoidSet.find( elem->GetID() ) != avoidSet.end() )
continue; continue;
if ( !elemSet.empty() && elemSet.find( elem->GetID() ) == elemSet.end()) if ( !elemSet.empty() && elemSet.find( elem ) == elemSet.end())
continue; continue;
// get face nodes and find index of n1 // get face nodes and find index of n1
int i1, nbN = elem->NbNodes(), iNode = 0; int i1, nbN = elem->NbNodes(), iNode = 0;
@ -5056,9 +5046,9 @@ static const SMDS_MeshElement* findAdjacentFace(const SMDS_MeshNode* n1,
const SMDS_MeshNode* n2, const SMDS_MeshNode* n2,
const SMDS_MeshElement* elem) const SMDS_MeshElement* elem)
{ {
map<int,const SMDS_MeshElement*> elemSet, avoidSet; TIDSortedElemSet elemSet, avoidSet;
if ( elem ) if ( elem )
avoidSet.insert ( make_pair(elem->GetID(),elem) ); avoidSet.insert ( elem );
return SMESH_MeshEditor::FindFaceInSet( n1, n2, elemSet, avoidSet ); return SMESH_MeshEditor::FindFaceInSet( n1, n2, elemSet, avoidSet );
} }
@ -5099,7 +5089,7 @@ bool SMESH_MeshEditor::FindFreeBorder (const SMDS_MeshNode* theFirst
list< const SMDS_MeshElement* > curElemList; list< const SMDS_MeshElement* > curElemList;
list< const SMDS_MeshNode* > nStartList; list< const SMDS_MeshNode* > nStartList;
SMDS_ElemIteratorPtr invElemIt = nStart->facesIterator(); SMDS_ElemIteratorPtr invElemIt = nStart->GetInverseElementIterator(SMDSAbs_Face);
while ( invElemIt->more() ) { while ( invElemIt->more() ) {
const SMDS_MeshElement* e = invElemIt->next(); const SMDS_MeshElement* e = invElemIt->next();
if ( e == curElem || foundElems.insert( e ).second ) { if ( e == curElem || foundElems.insert( e ).second ) {
@ -6017,11 +6007,9 @@ void SMESH_MeshEditor::UpdateVolumes (const SMDS_MeshNode* theBetweenNode
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
myLastCreatedNodes.Clear(); myLastCreatedNodes.Clear();
SMDS_ElemIteratorPtr invElemIt = theBetweenNode1->GetInverseElementIterator(); SMDS_ElemIteratorPtr invElemIt = theBetweenNode1->GetInverseElementIterator(SMDSAbs_Volume);
while (invElemIt->more()) { // loop on inverse elements of theBetweenNode1 while (invElemIt->more()) { // loop on inverse elements of theBetweenNode1
const SMDS_MeshElement* elem = invElemIt->next(); const SMDS_MeshElement* elem = invElemIt->next();
if (elem->GetType() != SMDSAbs_Volume)
continue;
// check, if current volume has link theBetweenNode1 - theBetweenNode2 // check, if current volume has link theBetweenNode1 - theBetweenNode2
SMDS_VolumeTool aVolume (elem); SMDS_VolumeTool aVolume (elem);
@ -6428,12 +6416,12 @@ bool SMESH_MeshEditor::ConvertFromQuadratic()
//======================================================================= //=======================================================================
SMESH_MeshEditor::Sew_Error SMESH_MeshEditor::Sew_Error
SMESH_MeshEditor::SewSideElements (map<int,const SMDS_MeshElement*>& theSide1, SMESH_MeshEditor::SewSideElements (TIDSortedElemSet& theSide1,
map<int,const SMDS_MeshElement*>& theSide2, TIDSortedElemSet& theSide2,
const SMDS_MeshNode* theFirstNode1, const SMDS_MeshNode* theFirstNode1,
const SMDS_MeshNode* theFirstNode2, const SMDS_MeshNode* theFirstNode2,
const SMDS_MeshNode* theSecondNode1, const SMDS_MeshNode* theSecondNode1,
const SMDS_MeshNode* theSecondNode2) const SMDS_MeshNode* theSecondNode2)
{ {
myLastCreatedElems.Clear(); myLastCreatedElems.Clear();
myLastCreatedNodes.Clear(); myLastCreatedNodes.Clear();
@ -6464,16 +6452,16 @@ SMESH_MeshEditor::Sew_Error
set<const SMDS_MeshElement*> * faceSetPtr[] = { &faceSet1, &faceSet2 }; set<const SMDS_MeshElement*> * faceSetPtr[] = { &faceSet1, &faceSet2 };
set<const SMDS_MeshElement*> * volSetPtr[] = { &volSet1, &volSet2 }; set<const SMDS_MeshElement*> * volSetPtr[] = { &volSet1, &volSet2 };
set<const SMDS_MeshNode*> * nodeSetPtr[] = { &nodeSet1, &nodeSet2 }; set<const SMDS_MeshNode*> * nodeSetPtr[] = { &nodeSet1, &nodeSet2 };
map<int,const SMDS_MeshElement*> * elemSetPtr[] = { &theSide1, &theSide2 }; TIDSortedElemSet * elemSetPtr[] = { &theSide1, &theSide2 };
int iSide, iFace, iNode; int iSide, iFace, iNode;
for ( iSide = 0; iSide < 2; iSide++ ) { for ( iSide = 0; iSide < 2; iSide++ ) {
set<const SMDS_MeshNode*> * nodeSet = nodeSetPtr[ iSide ]; set<const SMDS_MeshNode*> * nodeSet = nodeSetPtr[ iSide ];
map<int,const SMDS_MeshElement*> * elemSet = elemSetPtr[ iSide ]; TIDSortedElemSet * elemSet = elemSetPtr[ iSide ];
set<const SMDS_MeshElement*> * faceSet = faceSetPtr[ iSide ]; set<const SMDS_MeshElement*> * faceSet = faceSetPtr[ iSide ];
set<const SMDS_MeshElement*> * volSet = volSetPtr [ iSide ]; set<const SMDS_MeshElement*> * volSet = volSetPtr [ iSide ];
set<const SMDS_MeshElement*>::iterator vIt; set<const SMDS_MeshElement*>::iterator vIt;
map<int,const SMDS_MeshElement*>::iterator eIt; TIDSortedElemSet::iterator eIt;
set<const SMDS_MeshNode*>::iterator nIt; set<const SMDS_MeshNode*>::iterator nIt;
// check that given nodes belong to given elements // check that given nodes belong to given elements
@ -6481,7 +6469,7 @@ SMESH_MeshEditor::Sew_Error
const SMDS_MeshNode* n2 = ( iSide == 0 ) ? theSecondNode1 : theSecondNode2; const SMDS_MeshNode* n2 = ( iSide == 0 ) ? theSecondNode1 : theSecondNode2;
int firstIndex = -1, secondIndex = -1; int firstIndex = -1, secondIndex = -1;
for (eIt = elemSet->begin(); eIt != elemSet->end(); eIt++ ) { for (eIt = elemSet->begin(); eIt != elemSet->end(); eIt++ ) {
const SMDS_MeshElement* elem = (*eIt).second; const SMDS_MeshElement* elem = *eIt;
if ( firstIndex < 0 ) firstIndex = elem->GetNodeIndex( n1 ); if ( firstIndex < 0 ) firstIndex = elem->GetNodeIndex( n1 );
if ( secondIndex < 0 ) secondIndex = elem->GetNodeIndex( n2 ); if ( secondIndex < 0 ) secondIndex = elem->GetNodeIndex( n2 );
if ( firstIndex > -1 && secondIndex > -1 ) break; if ( firstIndex > -1 && secondIndex > -1 ) break;
@ -6502,7 +6490,7 @@ SMESH_MeshEditor::Sew_Error
// loop on the given element of a side // loop on the given element of a side
for (eIt = elemSet->begin(); eIt != elemSet->end(); eIt++ ) { for (eIt = elemSet->begin(); eIt != elemSet->end(); eIt++ ) {
//const SMDS_MeshElement* elem = *eIt; //const SMDS_MeshElement* elem = *eIt;
const SMDS_MeshElement* elem = (*eIt).second; const SMDS_MeshElement* elem = *eIt;
if ( elem->GetType() == SMDSAbs_Face ) { if ( elem->GetType() == SMDSAbs_Face ) {
faceSet->insert( elem ); faceSet->insert( elem );
set <const SMDS_MeshNode*> faceNodeSet; set <const SMDS_MeshNode*> faceNodeSet;
@ -6522,7 +6510,7 @@ SMESH_MeshEditor::Sew_Error
// ------------------------------------------------------------------------------ // ------------------------------------------------------------------------------
for ( nIt = nodeSet->begin(); nIt != nodeSet->end(); nIt++ ) { // loop on nodes of iSide for ( nIt = nodeSet->begin(); nIt != nodeSet->end(); nIt++ ) { // loop on nodes of iSide
SMDS_ElemIteratorPtr fIt = (*nIt)->facesIterator(); SMDS_ElemIteratorPtr fIt = (*nIt)->GetInverseElementIterator(SMDSAbs_Face);
while ( fIt->more() ) { // loop on faces sharing a node while ( fIt->more() ) { // loop on faces sharing a node
const SMDS_MeshElement* f = fIt->next(); const SMDS_MeshElement* f = fIt->next();
if ( faceSet->find( f ) == faceSet->end() ) { if ( faceSet->find( f ) == faceSet->end() ) {
@ -6618,7 +6606,7 @@ SMESH_MeshEditor::Sew_Error
const SMDS_MeshElement* e = invElemIt->next(); const SMDS_MeshElement* e = invElemIt->next();
if ( faceSet->find( e ) != faceSet->end() ) if ( faceSet->find( e ) != faceSet->end() )
nbSharedNodes++; nbSharedNodes++;
if ( elemSet->find( e->GetID() ) != elemSet->end() ) if ( elemSet->find( e ) != elemSet->end() )
nbSharedNodes++; nbSharedNodes++;
} }
} }
@ -6635,10 +6623,10 @@ SMESH_MeshEditor::Sew_Error
// choose a face most close to the bary center of the opposite side // choose a face most close to the bary center of the opposite side
gp_XYZ aBC( 0., 0., 0. ); gp_XYZ aBC( 0., 0., 0. );
set <const SMDS_MeshNode*> addedNodes; set <const SMDS_MeshNode*> addedNodes;
map<int,const SMDS_MeshElement*> * elemSet2 = elemSetPtr[ 1 - iSide ]; TIDSortedElemSet * elemSet2 = elemSetPtr[ 1 - iSide ];
eIt = elemSet2->begin(); eIt = elemSet2->begin();
for ( eIt = elemSet2->begin(); eIt != elemSet2->end(); eIt++ ) { for ( eIt = elemSet2->begin(); eIt != elemSet2->end(); eIt++ ) {
SMDS_ElemIteratorPtr nodeIt = (*eIt).second->nodesIterator(); SMDS_ElemIteratorPtr nodeIt = (*eIt)->nodesIterator();
while ( nodeIt->more() ) { // loop on free face nodes while ( nodeIt->more() ) { // loop on free face nodes
const SMDS_MeshNode* n = const SMDS_MeshNode* n =
static_cast<const SMDS_MeshNode*>( nodeIt->next() ); static_cast<const SMDS_MeshNode*>( nodeIt->next() );
@ -6682,7 +6670,7 @@ SMESH_MeshEditor::Sew_Error
// // ---------------------------------------------------------- // // ----------------------------------------------------------
// if ( nodeSetSize != nodeSet->size() ) { // if ( nodeSetSize != nodeSet->size() ) {
// for ( ; nIt != nodeSet->end(); nIt++ ) { // loop on nodes of iSide // for ( ; nIt != nodeSet->end(); nIt++ ) { // loop on nodes of iSide
// SMDS_ElemIteratorPtr fIt = (*nIt)->facesIterator(); // SMDS_ElemIteratorPtr fIt = (*nIt)->GetInverseElementIterator(SMDSAbs_Face);
// while ( fIt->more() ) { // loop on faces sharing a node // while ( fIt->more() ) { // loop on faces sharing a node
// const SMDS_MeshElement* f = fIt->next(); // const SMDS_MeshElement* f = fIt->next();
// if ( faceSet->find( f ) == faceSet->end() ) { // if ( faceSet->find( f ) == faceSet->end() ) {
@ -6766,7 +6754,7 @@ SMESH_MeshEditor::Sew_Error
set< const SMDS_MeshElement* > fMap; set< const SMDS_MeshElement* > fMap;
for ( int i = 0; i < 2; i++ ) { // loop on 2 nodes of a link for ( int i = 0; i < 2; i++ ) { // loop on 2 nodes of a link
const SMDS_MeshNode* n = i ? n1 : n2; // a node of a link const SMDS_MeshNode* n = i ? n1 : n2; // a node of a link
SMDS_ElemIteratorPtr fIt = n->facesIterator(); SMDS_ElemIteratorPtr fIt = n->GetInverseElementIterator(SMDSAbs_Face);
while ( fIt->more() ) { // loop on faces sharing a node while ( fIt->more() ) { // loop on faces sharing a node
const SMDS_MeshElement* f = fIt->next(); const SMDS_MeshElement* f = fIt->next();
if (faceSet->find( f ) != faceSet->end() && // f is in face set if (faceSet->find( f ) != faceSet->end() && // f is in face set
@ -7092,11 +7080,10 @@ SMESH_MeshEditor::FindMatchingNodes(set<const SMDS_MeshElement*>& theSide1,
// during a loop of the first node, we find all faces around n1, // during a loop of the first node, we find all faces around n1,
// during a loop of the second node, we find one face sharing both n1 and n2 // during a loop of the second node, we find one face sharing both n1 and n2
const SMDS_MeshNode* n = iNode ? n1 : n2; // a node of a link const SMDS_MeshNode* n = iNode ? n1 : n2; // a node of a link
SMDS_ElemIteratorPtr fIt = n->GetInverseElementIterator(); SMDS_ElemIteratorPtr fIt = n->GetInverseElementIterator(SMDSAbs_Face);
while ( fIt->more() ) { // loop on faces sharing a node while ( fIt->more() ) { // loop on faces sharing a node
const SMDS_MeshElement* f = fIt->next(); const SMDS_MeshElement* f = fIt->next();
if (f->GetType() == SMDSAbs_Face && if (faceSet->find( f ) != faceSet->end() && // f is in face set
faceSet->find( f ) != faceSet->end() && // f is in face set
! facesOfNode1.insert( f ).second ) // f encounters twice ! facesOfNode1.insert( f ).second ) // f encounters twice
{ {
if ( face[ iSide ] ) { if ( face[ iSide ] ) {

View File

@ -34,11 +34,12 @@
#include "SMESH_Controls.hxx" #include "SMESH_Controls.hxx"
#include "SMESH_SequenceOfNode.hxx" #include "SMESH_SequenceOfNode.hxx"
#include "SMESH_SequenceOfElemPtr.hxx" #include "SMESH_SequenceOfElemPtr.hxx"
#include "gp_Dir.hxx"
#include "TColStd_HSequenceOfReal.hxx" #include "TColStd_HSequenceOfReal.hxx"
#include "SMESH_MesherHelper.hxx" #include "SMESH_MesherHelper.hxx"
#include "SMDS_MeshElement.hxx" #include "SMDS_MeshElement.hxx"
#include <gp_Dir.hxx>
#include <list> #include <list>
#include <map> #include <map>
@ -55,26 +56,27 @@ class gp_Ax1;
class gp_Vec; class gp_Vec;
class gp_Pnt; class gp_Pnt;
// ============================================================
/*!
* \brief Set of elements sorted by ID, to be used to assure
* predictability of edition
*/
// ============================================================
template < class TMeshElem >
struct TIDCompare {
bool operator () (const TMeshElem* e1, const TMeshElem* e2) const
{ return e1->GetID() < e2->GetID(); }
};
typedef std::set< const SMDS_MeshElement*, TIDCompare< SMDS_MeshElement> > TIDSortedElemSet;
// ============================================================
/*!
* \brief Editor of a mesh
*/
// ============================================================
class SMESH_MeshEditor { class SMESH_MeshEditor {
public:
// define a set of elements sorted by ID, to be used to assure
// predictability of edition
struct TIDCompare {
bool operator () (const SMDS_MeshElement* e1, const SMDS_MeshElement* e2)
{ return e1->GetID() < e2->GetID(); }
};
typedef set< const SMDS_MeshElement*, TIDCompare > TIDSortedElemSet;
/*!
* \brief Insert element in a map of elements sorted by ID
* \param elem - element to insert
* \param elemMap - the map to fill in
*/
static void Insert(const SMDS_MeshElement* elem,
std::map<int,const SMDS_MeshElement*> & elemMap) {
elemMap.insert( make_pair( elem->GetID(), elem ));
}
public: public:
@ -114,7 +116,7 @@ public:
* is still performed; theMaxAngle is mesured in radians. * is still performed; theMaxAngle is mesured in radians.
* \retval bool - Success or not. * \retval bool - Success or not.
*/ */
bool TriToQuad (std::map<int,const SMDS_MeshElement*> & theElems, bool TriToQuad (TIDSortedElemSet & theElems,
SMESH::Controls::NumericalFunctorPtr theCriterion, SMESH::Controls::NumericalFunctorPtr theCriterion,
const double theMaxAngle); const double theMaxAngle);
@ -124,7 +126,7 @@ public:
* \param theCriterion - Is used to choose a diagonal for splitting. * \param theCriterion - Is used to choose a diagonal for splitting.
* \retval bool - Success or not. * \retval bool - Success or not.
*/ */
bool QuadToTri (std::map<int,const SMDS_MeshElement*> & theElems, bool QuadToTri (TIDSortedElemSet & theElems,
SMESH::Controls::NumericalFunctorPtr theCriterion); SMESH::Controls::NumericalFunctorPtr theCriterion);
/*! /*!
@ -133,8 +135,8 @@ public:
* \param the13Diag - Is used to choose a diagonal for splitting. * \param the13Diag - Is used to choose a diagonal for splitting.
* \retval bool - Success or not. * \retval bool - Success or not.
*/ */
bool QuadToTri (std::map<int,const SMDS_MeshElement*> & theElems, bool QuadToTri (TIDSortedElemSet & theElems,
const bool the13Diag); const bool the13Diag);
/*! /*!
* \brief Find better diagonal for splitting. * \brief Find better diagonal for splitting.
@ -148,12 +150,12 @@ public:
enum SmoothMethod { LAPLACIAN = 0, CENTROIDAL }; enum SmoothMethod { LAPLACIAN = 0, CENTROIDAL };
void Smooth (std::map<int,const SMDS_MeshElement*> & theElements, void Smooth (TIDSortedElemSet & theElements,
std::set<const SMDS_MeshNode*> & theFixedNodes, std::set<const SMDS_MeshNode*> & theFixedNodes,
const SmoothMethod theSmoothMethod, const SmoothMethod theSmoothMethod,
const int theNbIterations, const int theNbIterations,
double theTgtAspectRatio = 1.0, double theTgtAspectRatio = 1.0,
const bool the2D = true); const bool the2D = true);
// Smooth theElements using theSmoothMethod during theNbIterations // Smooth theElements using theSmoothMethod during theNbIterations
// or until a worst element has aspect ratio <= theTgtAspectRatio. // or until a worst element has aspect ratio <= theTgtAspectRatio.
// Aspect Ratio varies in range [1.0, inf]. // Aspect Ratio varies in range [1.0, inf].
@ -164,11 +166,11 @@ public:
// on geometrical faces // on geometrical faces
void RotationSweep (std::map<int,const SMDS_MeshElement*> & theElements, void RotationSweep (TIDSortedElemSet & theElements,
const gp_Ax1& theAxis, const gp_Ax1& theAxis,
const double theAngle, const double theAngle,
const int theNbSteps, const int theNbSteps,
const double theToler); const double theToler);
// Generate new elements by rotation of theElements around theAxis // Generate new elements by rotation of theElements around theAxis
// by theAngle by theNbSteps // by theAngle by theNbSteps
@ -214,12 +216,12 @@ public:
* EXTRUSION_FLAG_SEW is set * EXTRUSION_FLAG_SEW is set
*/ */
void ExtrusionSweep void ExtrusionSweep
(map<int,const SMDS_MeshElement*> & theElems, (TIDSortedElemSet & theElems,
const gp_Vec& theStep, const gp_Vec& theStep,
const int theNbSteps, const int theNbSteps,
TElemOfElemListMap& newElemsMap, TElemOfElemListMap& newElemsMap,
const int theFlags = EXTRUSION_FLAG_BOUNDARY, const int theFlags = EXTRUSION_FLAG_BOUNDARY,
const double theTolerance = 1.e-6); const double theTolerance = 1.e-6);
/*! /*!
* Generate new elements by extrusion of theElements * Generate new elements by extrusion of theElements
@ -231,11 +233,11 @@ public:
* EXTRUSION_FLAG_SEW is set * EXTRUSION_FLAG_SEW is set
* param theParams - special structure for manage of extrusion * param theParams - special structure for manage of extrusion
*/ */
void ExtrusionSweep (map<int,const SMDS_MeshElement*> & theElems, void ExtrusionSweep (TIDSortedElemSet & theElems,
ExtrusParam& theParams, ExtrusParam& theParams,
TElemOfElemListMap& newElemsMap, TElemOfElemListMap& newElemsMap,
const int theFlags, const int theFlags,
const double theTolerance); const double theTolerance);
// Generate new elements by extrusion of theElements // Generate new elements by extrusion of theElements
@ -251,19 +253,19 @@ public:
EXTR_CANT_GET_TANGENT EXTR_CANT_GET_TANGENT
}; };
Extrusion_Error ExtrusionAlongTrack (std::map<int,const SMDS_MeshElement*> & theElements, Extrusion_Error ExtrusionAlongTrack (TIDSortedElemSet & theElements,
SMESH_subMesh* theTrackPattern, SMESH_subMesh* theTrackPattern,
const SMDS_MeshNode* theNodeStart, const SMDS_MeshNode* theNodeStart,
const bool theHasAngles, const bool theHasAngles,
std::list<double>& theAngles, std::list<double>& theAngles,
const bool theHasRefPoint, const bool theHasRefPoint,
const gp_Pnt& theRefPoint); const gp_Pnt& theRefPoint);
// Generate new elements by extrusion of theElements along path given by theTrackPattern, // Generate new elements by extrusion of theElements along path given by theTrackPattern,
// theHasAngles are the rotation angles, base point can be given by theRefPoint // theHasAngles are the rotation angles, base point can be given by theRefPoint
void Transform (std::map<int,const SMDS_MeshElement*> & theElements, void Transform (TIDSortedElemSet & theElements,
const gp_Trsf& theTrsf, const gp_Trsf& theTrsf,
const bool theCopy); const bool theCopy);
// Move or copy theElements applying theTrsf to their nodes // Move or copy theElements applying theTrsf to their nodes
typedef std::list< std::list< const SMDS_MeshNode* > > TListOfListOfNodes; typedef std::list< std::list< const SMDS_MeshNode* > > TListOfListOfNodes;
@ -346,12 +348,12 @@ public:
// nodes are inserted. // nodes are inserted.
// Return false, if sewing failed. // Return false, if sewing failed.
Sew_Error SewSideElements (std::map<int,const SMDS_MeshElement*>& theSide1, Sew_Error SewSideElements (TIDSortedElemSet& theSide1,
std::map<int,const SMDS_MeshElement*>& theSide2, TIDSortedElemSet& theSide2,
const SMDS_MeshNode* theFirstNode1ToMerge, const SMDS_MeshNode* theFirstNode1ToMerge,
const SMDS_MeshNode* theFirstNode2ToMerge, const SMDS_MeshNode* theFirstNode2ToMerge,
const SMDS_MeshNode* theSecondNode1ToMerge, const SMDS_MeshNode* theSecondNode1ToMerge,
const SMDS_MeshNode* theSecondNode2ToMerge); const SMDS_MeshNode* theSecondNode2ToMerge);
// Sew two sides of a mesh. Nodes belonging to theSide1 are // Sew two sides of a mesh. Nodes belonging to theSide1 are
// merged with nodes of elements of theSide2. // merged with nodes of elements of theSide2.
// Number of elements in theSide1 and in theSide2 must be // Number of elements in theSide1 and in theSide2 must be
@ -403,10 +405,10 @@ public:
// remove elemToAdd from the groups // remove elemToAdd from the groups
static const SMDS_MeshElement* static const SMDS_MeshElement*
FindFaceInSet(const SMDS_MeshNode* n1, FindFaceInSet(const SMDS_MeshNode* n1,
const SMDS_MeshNode* n2, const SMDS_MeshNode* n2,
const std::map<int,const SMDS_MeshElement*>& elemSet, const TIDSortedElemSet& elemSet,
const std::map<int,const SMDS_MeshElement*>& avoidSet); const TIDSortedElemSet& avoidSet);
// Return a face having linked nodes n1 and n2 and which is // Return a face having linked nodes n1 and n2 and which is
// - not in avoidSet, // - not in avoidSet,
// - in elemSet provided that !elemSet.empty() // - in elemSet provided that !elemSet.empty()