IPAL54633: Bad viscous layers

This commit is contained in:
eap 2020-03-20 18:57:40 +03:00
parent 1f0895c06c
commit d487f882d9

View File

@ -3304,12 +3304,22 @@ bool _ViscousBuilder::findShapesToSmooth( _SolidData& data )
if ( isC1 ) if ( isC1 )
{ {
double maxEdgeLen = 3 * Min( eov._edges[0]->_maxLen, eov._hyp.GetTotalThickness() ); double maxEdgeLen = 3 * Min( eov._edges[0]->_maxLen, eov._hyp.GetTotalThickness() );
double eLen1 = SMESH_Algo::EdgeLength( TopoDS::Edge( dirOfEdges[i].first->_shape )); for ( int isJ = 0; isJ < 2; ++isJ ) // loop on [i,j]
double eLen2 = SMESH_Algo::EdgeLength( TopoDS::Edge( dirOfEdges[j].first->_shape )); {
if ( eLen1 < maxEdgeLen ) eov._eosC1.push_back( dirOfEdges[i].first ); size_t k = isJ ? j : i;
if ( eLen2 < maxEdgeLen ) eov._eosC1.push_back( dirOfEdges[j].first ); const TopoDS_Edge& e = TopoDS::Edge( dirOfEdges[k].first->_shape );
dirOfEdges[i].first = 0; double eLen = SMESH_Algo::EdgeLength( e );
dirOfEdges[j].first = 0; if ( eLen < maxEdgeLen )
{
TopoDS_Shape oppV = SMESH_MesherHelper::IthVertex( 0, e );
if ( oppV.IsSame( V ))
oppV = SMESH_MesherHelper::IthVertex( 1, e );
_EdgesOnShape* eovOpp = data.GetShapeEdges( oppV );
if ( dirOfEdges[k].second * eovOpp->_edges[0]->_normal < 0 )
eov._eosC1.push_back( dirOfEdges[k].first );
}
dirOfEdges[k].first = 0;
}
} }
} }
} // fill _eosC1 of VERTEXes } // fill _eosC1 of VERTEXes