[SALOME platform 0013410]: SubMesh not taken into account with Netgen 1D-2D et 1D-2D-3D

1)        algo->Compute() depending on algo->SupportSubmeshes()
2)
+  /*!
+   * \brief Return true if no mesh entities is bound to the submesh
+   */
+  bool IsEmpty() const;
This commit is contained in:
eap 2008-09-16 14:38:55 +00:00
parent 794f960633
commit dacb38a9d9
2 changed files with 35 additions and 9 deletions

View File

@ -186,6 +186,19 @@ void SMESH_subMesh::SetIsAlwaysComputed(bool isAlCo)
ComputeStateEngine( CHECK_COMPUTE_STATE ); ComputeStateEngine( CHECK_COMPUTE_STATE );
} }
//=======================================================================
/*!
* \brief Return true if no mesh entities is bound to the submesh
*/
//=======================================================================
bool SMESH_subMesh::IsEmpty() const
{
if (SMESHDS_SubMesh * subMeshDS = ((SMESH_subMesh*)this)->GetSubMeshDS())
return (!subMeshDS->GetNodes()->more() && !subMeshDS->GetElements()->more());
return true;
}
//======================================================================= //=======================================================================
//function : IsMeshComputed //function : IsMeshComputed
//purpose : check if _subMeshDS contains mesh elements //purpose : check if _subMeshDS contains mesh elements
@ -498,6 +511,11 @@ bool SMESH_subMesh::CanAddHypothesis(const SMESH_Hypothesis* theHypothesis) cons
{ {
int aHypDim = theHypothesis->GetDim(); int aHypDim = theHypothesis->GetDim();
int aShapeDim = SMESH_Gen::GetShapeDim(_subShape); int aShapeDim = SMESH_Gen::GetShapeDim(_subShape);
if (aHypDim == 3 && aShapeDim == 3) {
// check case of open shell
if (_subShape.ShapeType() == TopAbs_SHELL && !_subShape.Closed())
return false;
}
if ( aHypDim <= aShapeDim ) if ( aHypDim <= aShapeDim )
return true; return true;
@ -963,11 +981,13 @@ SMESH_Hypothesis::Hypothesis_Status
TopTools_ListIteratorOfListOfShape it( _father->GetAncestors( _subShape )); TopTools_ListIteratorOfListOfShape it( _father->GetAncestors( _subShape ));
for ( ; ( ret == SMESH_Hypothesis::HYP_OK && it.More()); it.Next() ) { for ( ; ( ret == SMESH_Hypothesis::HYP_OK && it.More()); it.Next() ) {
if ( SMESH_Algo* upperAlgo = gen->GetAlgo( *_father, it.Value() )) if ( SMESH_Algo* upperAlgo = gen->GetAlgo( *_father, it.Value() ))
if ( !upperAlgo->NeedDescretBoundary() ) if ( !upperAlgo->NeedDescretBoundary() && !upperAlgo->SupportSubmeshes())
ret = SMESH_Hypothesis::HYP_HIDDEN_ALGO; ret = SMESH_Hypothesis::HYP_HIDDEN_ALGO;
} }
// is algo hiding? // is algo hiding?
if ( ret == SMESH_Hypothesis::HYP_OK && !algo->NeedDescretBoundary() ) { if ( ret == SMESH_Hypothesis::HYP_OK &&
!algo->NeedDescretBoundary() &&
!algo->SupportSubmeshes()) {
map<int, SMESH_subMesh*>::reverse_iterator i_sm = _mapDepend.rbegin(); map<int, SMESH_subMesh*>::reverse_iterator i_sm = _mapDepend.rbegin();
for ( ; ( ret == SMESH_Hypothesis::HYP_OK && i_sm != _mapDepend.rend()) ; ++i_sm ) for ( ; ( ret == SMESH_Hypothesis::HYP_OK && i_sm != _mapDepend.rend()) ; ++i_sm )
if ( gen->GetAlgo( *_father, i_sm->second->_subShape )) if ( gen->GetAlgo( *_father, i_sm->second->_subShape ))
@ -1304,6 +1324,7 @@ bool SMESH_subMesh::ComputeStateEngine(int event)
else else
subComputed = SubMeshesComputed(); subComputed = SubMeshesComputed();
ret = ( algo->NeedDescretBoundary() ? subComputed : ret = ( algo->NeedDescretBoundary() ? subComputed :
algo->SupportSubmeshes() ? true :
( !subComputed || _father->IsNotConformAllowed() )); ( !subComputed || _father->IsNotConformAllowed() ));
if (!ret) { if (!ret) {
_computeState = FAILED_TO_COMPUTE; _computeState = FAILED_TO_COMPUTE;
@ -1338,7 +1359,7 @@ bool SMESH_subMesh::ComputeStateEngine(int event)
{ {
ret = algo->Compute((*_father), shape); ret = algo->Compute((*_father), shape);
} }
if ( !ret ) if ( !ret && _computeError->IsOK() ) // algo can set _computeError of submesh
_computeError = algo->GetComputeError(); _computeError = algo->GetComputeError();
} }
catch ( std::bad_alloc& exc ) { catch ( std::bad_alloc& exc ) {
@ -1384,7 +1405,7 @@ bool SMESH_subMesh::ComputeStateEngine(int event)
else else
ret = false; ret = false;
} }
if (ret && !_alwaysComputed) { // check if anything was built if (ret && !_alwaysComputed && shape == _subShape) { // check if anything was built
ret = ( GetSubMeshDS() && ( GetSubMeshDS()->NbElements() || GetSubMeshDS()->NbNodes() )); ret = ( GetSubMeshDS() && ( GetSubMeshDS()->NbElements() || GetSubMeshDS()->NbNodes() ));
} }
bool isComputeErrorSet = !CheckComputeError( algo, shape ); bool isComputeErrorSet = !CheckComputeError( algo, shape );
@ -1574,7 +1595,7 @@ bool SMESH_subMesh::CheckComputeError(SMESH_Algo* theAlgo, const TopoDS_Shape& t
for (TopoDS_Iterator subIt( theShape ); subIt.More(); subIt.Next()) { for (TopoDS_Iterator subIt( theShape ); subIt.More(); subIt.Next()) {
SMESH_subMesh* sm = _father->GetSubMesh( subIt.Value() ); SMESH_subMesh* sm = _father->GetSubMesh( subIt.Value() );
if ( sm != this ) { if ( sm != this ) {
if ( !sm->CheckComputeError( theAlgo )) if ( !sm->CheckComputeError( theAlgo, sm->GetSubShape() ))
noErrors = false; noErrors = false;
UpdateDependantsState( SUBMESH_COMPUTED ); // send event SUBMESH_COMPUTED UpdateDependantsState( SUBMESH_COMPUTED ); // send event SUBMESH_COMPUTED
} }
@ -1803,8 +1824,8 @@ TopoDS_Shape SMESH_subMesh::GetCollection(SMESH_Gen * theGen,
else if ( subMesh->GetComputeState() == READY_TO_COMPUTE ) else if ( subMesh->GetComputeState() == READY_TO_COMPUTE )
{ {
SMESH_Algo* anAlgo = theGen->GetAlgo( *_father, S ); SMESH_Algo* anAlgo = theGen->GetAlgo( *_father, S );
if (anAlgo == theAlgo && if (strcmp( anAlgo->GetName(), theAlgo->GetName()) == 0 && // same algo
anAlgo->GetUsedHypothesis( *_father, S, ignoreAuxiliaryHyps ) == aUsedHyp) anAlgo->GetUsedHypothesis( *_father, S, ignoreAuxiliaryHyps ) == aUsedHyp) // same hyps
aBuilder.Add( aCompound, S ); aBuilder.Add( aCompound, S );
if ( !subMesh->SubMeshesComputed() ) if ( !subMesh->SubMeshesComputed() )
theSubComputed = false; theSubComputed = false;

View File

@ -75,7 +75,7 @@ class SMESH_EXPORT SMESH_subMesh
SMESH_subMesh *GetFirstToCompute(); SMESH_subMesh *GetFirstToCompute();
const map < int, SMESH_subMesh * >& DependsOn(); const std::map < int, SMESH_subMesh * >& DependsOn();
//const map < int, SMESH_subMesh * >&Dependants(); //const map < int, SMESH_subMesh * >&Dependants();
/*! /*!
* \brief Return iterator on the submeshes this one depends on * \brief Return iterator on the submeshes this one depends on
@ -211,6 +211,11 @@ public:
SMESH_Hypothesis::Hypothesis_Status CheckConcurentHypothesis (const int theHypType); SMESH_Hypothesis::Hypothesis_Status CheckConcurentHypothesis (const int theHypType);
// check if there are several applicable hypothesis on fathers // check if there are several applicable hypothesis on fathers
/*!
* \brief Return true if no mesh entities is bound to the submesh
*/
bool IsEmpty() const;
bool IsMeshComputed() const; bool IsMeshComputed() const;
// check if _subMeshDS contains mesh elements // check if _subMeshDS contains mesh elements
@ -276,7 +281,7 @@ protected:
SMESH_Mesh * _father; SMESH_Mesh * _father;
int _Id; int _Id;
map < int, SMESH_subMesh * >_mapDepend; std::map < int, SMESH_subMesh * >_mapDepend;
bool _dependenceAnalysed; bool _dependenceAnalysed;
int _algoState; int _algoState;