mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-27 12:40:32 +05:00
Fix regressions
viscous_layers_00/A4 viscous_layers_00/B2
This commit is contained in:
parent
59912620be
commit
a74e2f9cac
@ -2371,14 +2371,14 @@ void _ViscousBuilder::limitStepSizeByCurvature( _SolidData& data )
|
|||||||
|
|
||||||
for ( size_t iS = 0; iS < data._edgesOnShape.size(); ++iS )
|
for ( size_t iS = 0; iS < data._edgesOnShape.size(); ++iS )
|
||||||
{
|
{
|
||||||
_EdgesOnShape& eos = data._edgesOnShape[iS];
|
_EdgesOnShape& eof = data._edgesOnShape[iS];
|
||||||
if ( eos.ShapeType() != TopAbs_FACE ||
|
if ( eof.ShapeType() != TopAbs_FACE ||
|
||||||
data._ignoreFaceIds.count( eos._shapeID ))
|
data._ignoreFaceIds.count( eof._shapeID ))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
TopoDS_Face F = TopoDS::Face( eos._shape );
|
TopoDS_Face F = TopoDS::Face( eof._shape );
|
||||||
SMESH_subMesh * sm = eos._subMesh;
|
SMESH_subMesh * sm = eof._subMesh;
|
||||||
const TGeomID faceID = eos._shapeID;
|
const TGeomID faceID = eof._shapeID;
|
||||||
|
|
||||||
BRepAdaptor_Surface surface( F, false );
|
BRepAdaptor_Surface surface( F, false );
|
||||||
surfProp.SetSurface( surface );
|
surfProp.SetSurface( surface );
|
||||||
@ -2393,18 +2393,18 @@ void _ViscousBuilder::limitStepSizeByCurvature( _SolidData& data )
|
|||||||
sm = smIt->next();
|
sm = smIt->next();
|
||||||
const TGeomID subID = sm->GetId();
|
const TGeomID subID = sm->GetId();
|
||||||
// find _LayerEdge's of a sub-shape
|
// find _LayerEdge's of a sub-shape
|
||||||
size_t edgesEnd;
|
_EdgesOnShape* eos;
|
||||||
if ( _EdgesOnShape* eos = data.GetShapeEdges( subID ))
|
if (( eos = data.GetShapeEdges( subID )))
|
||||||
cnvFace._subIdToEOS.insert( make_pair( subID, eos ));
|
cnvFace._subIdToEOS.insert( make_pair( subID, eos ));
|
||||||
else
|
else
|
||||||
continue;
|
continue;
|
||||||
// check concavity and curvature and limit data._stepSize
|
// check concavity and curvature and limit data._stepSize
|
||||||
const double minCurvature =
|
const double minCurvature =
|
||||||
1. / ( eos._hyp.GetTotalThickness() * ( 1+theThickToIntersection ));
|
1. / ( eos->_hyp.GetTotalThickness() * ( 1+theThickToIntersection ));
|
||||||
size_t iStep = Max( 1, eos._edges.size() / nbTestPnt );
|
size_t iStep = Max( 1, eos->_edges.size() / nbTestPnt );
|
||||||
for ( size_t i = 0; i < eos._edges.size(); i += iStep )
|
for ( size_t i = 0; i < eos->_edges.size(); i += iStep )
|
||||||
{
|
{
|
||||||
gp_XY uv = helper.GetNodeUV( F, eos._edges[ i ]->_nodes[0] );
|
gp_XY uv = helper.GetNodeUV( F, eos->_edges[ i ]->_nodes[0] );
|
||||||
surfProp.SetParameters( uv.X(), uv.Y() );
|
surfProp.SetParameters( uv.X(), uv.Y() );
|
||||||
if ( !surfProp.IsCurvatureDefined() )
|
if ( !surfProp.IsCurvatureDefined() )
|
||||||
continue;
|
continue;
|
||||||
@ -2458,8 +2458,8 @@ void _ViscousBuilder::limitStepSizeByCurvature( _SolidData& data )
|
|||||||
set< const SMDS_MeshNode* > usedNodes;
|
set< const SMDS_MeshNode* > usedNodes;
|
||||||
|
|
||||||
// look for _LayerEdge's with null _sWOL
|
// look for _LayerEdge's with null _sWOL
|
||||||
map< TGeomID, _EdgesOnShape* >::iterator id2oes = convFace._subIdToEOS.begin();
|
id2eos = convFace._subIdToEOS.begin();
|
||||||
for ( ; id2oes != convFace._subIdToEOS.end(); ++id2oes )
|
for ( ; id2eos != convFace._subIdToEOS.end(); ++id2eos )
|
||||||
{
|
{
|
||||||
_EdgesOnShape& eos = * id2eos->second;
|
_EdgesOnShape& eos = * id2eos->second;
|
||||||
if ( !eos._sWOL.IsNull() )
|
if ( !eos._sWOL.IsNull() )
|
||||||
@ -4734,10 +4734,10 @@ bool _ViscousBuilder::updateNormalsOfConvexFaces( _SolidData& data,
|
|||||||
Bnd_B3d nodesBox;
|
Bnd_B3d nodesBox;
|
||||||
gp_Pnt center;
|
gp_Pnt center;
|
||||||
|
|
||||||
map< TGeomID, _EdgesOnShape* >::iterator id2oes = convFace._subIdToEOS.begin();
|
map< TGeomID, _EdgesOnShape* >::iterator id2eos = convFace._subIdToEOS.begin();
|
||||||
for ( ; id2oes != convFace._subIdToEOS.end(); ++id2oes )
|
for ( ; id2eos != convFace._subIdToEOS.end(); ++id2eos )
|
||||||
{
|
{
|
||||||
_EdgesOnShape& eos = *(id2oes->second);
|
_EdgesOnShape& eos = *(id2eos->second);
|
||||||
if ( eos.ShapeType() == TopAbs_VERTEX )
|
if ( eos.ShapeType() == TopAbs_VERTEX )
|
||||||
{
|
{
|
||||||
_LayerEdge* ledge = eos._edges[ 0 ];
|
_LayerEdge* ledge = eos._edges[ 0 ];
|
||||||
@ -4767,10 +4767,10 @@ bool _ViscousBuilder::updateNormalsOfConvexFaces( _SolidData& data,
|
|||||||
|
|
||||||
gp_XYZ avgNormal( 0,0,0 );
|
gp_XYZ avgNormal( 0,0,0 );
|
||||||
nbEdges = 0;
|
nbEdges = 0;
|
||||||
id2oes = convFace._subIdToEOS.begin();
|
id2eos = convFace._subIdToEOS.begin();
|
||||||
for ( ; id2oes != convFace._subIdToEOS.end(); ++id2oes )
|
for ( ; id2eos != convFace._subIdToEOS.end(); ++id2eos )
|
||||||
{
|
{
|
||||||
_EdgesOnShape& eos = *(id2oes->second);
|
_EdgesOnShape& eos = *(id2eos->second);
|
||||||
// set data of _CentralCurveOnEdge
|
// set data of _CentralCurveOnEdge
|
||||||
if ( eos.ShapeType() == TopAbs_EDGE )
|
if ( eos.ShapeType() == TopAbs_EDGE )
|
||||||
{
|
{
|
||||||
@ -4820,10 +4820,10 @@ bool _ViscousBuilder::updateNormalsOfConvexFaces( _SolidData& data,
|
|||||||
avgCosin /= nbCosin;
|
avgCosin /= nbCosin;
|
||||||
|
|
||||||
// set _LayerEdge::_normal = avgNormal
|
// set _LayerEdge::_normal = avgNormal
|
||||||
id2oes = convFace._subIdToEOS.begin();
|
id2eos = convFace._subIdToEOS.begin();
|
||||||
for ( ; id2oes != convFace._subIdToEOS.end(); ++id2oes )
|
for ( ; id2eos != convFace._subIdToEOS.end(); ++id2eos )
|
||||||
{
|
{
|
||||||
_EdgesOnShape& eos = *(id2oes->second);
|
_EdgesOnShape& eos = *(id2eos->second);
|
||||||
if ( eos.ShapeType() != TopAbs_EDGE )
|
if ( eos.ShapeType() != TopAbs_EDGE )
|
||||||
for ( size_t i = 0; i < eos._edges.size(); ++i )
|
for ( size_t i = 0; i < eos._edges.size(); ++i )
|
||||||
eos._edges[ i ]->_cosin = avgCosin;
|
eos._edges[ i ]->_cosin = avgCosin;
|
||||||
@ -4981,12 +4981,12 @@ bool _ViscousBuilder::updateNormalsOfConvexFaces( _SolidData& data,
|
|||||||
if ( nbCosin > 0 )
|
if ( nbCosin > 0 )
|
||||||
avgCosin /= nbCosin;
|
avgCosin /= nbCosin;
|
||||||
const TGeomID faceID = meshDS->ShapeToIndex( convFace._face );
|
const TGeomID faceID = meshDS->ShapeToIndex( convFace._face );
|
||||||
map< TGeomID, _EdgesOnShape* >::iterator id2oes = convFace._subIdToEOS.find( faceID );
|
map< TGeomID, _EdgesOnShape* >::iterator id2eos = convFace._subIdToEOS.find( faceID );
|
||||||
if ( id2oes != convFace._subIdToEOS.end() )
|
if ( id2eos != convFace._subIdToEOS.end() )
|
||||||
{
|
{
|
||||||
int iE = 0;
|
int iE = 0;
|
||||||
gp_XYZ newNorm;
|
gp_XYZ newNorm;
|
||||||
_EdgesOnShape& eos = * ( id2oes->second );
|
_EdgesOnShape& eos = * ( id2eos->second );
|
||||||
for ( size_t i = 0; i < eos._edges.size(); ++i )
|
for ( size_t i = 0; i < eos._edges.size(); ++i )
|
||||||
{
|
{
|
||||||
_LayerEdge* ledge = eos._edges[ i ];
|
_LayerEdge* ledge = eos._edges[ i ];
|
||||||
@ -5015,10 +5015,10 @@ bool _ViscousBuilder::updateNormalsOfConvexFaces( _SolidData& data,
|
|||||||
dumpFunction(SMESH_Comment("updateNormalsOfConvexFaces")<<data._index
|
dumpFunction(SMESH_Comment("updateNormalsOfConvexFaces")<<data._index
|
||||||
<<"_F"<<meshDS->ShapeToIndex( convFace._face ));
|
<<"_F"<<meshDS->ShapeToIndex( convFace._face ));
|
||||||
|
|
||||||
id2oes = convFace._subIdToEOS.begin();
|
id2eos = convFace._subIdToEOS.begin();
|
||||||
for ( ; id2oes != convFace._subIdToEOS.end(); ++id2oes )
|
for ( ; id2eos != convFace._subIdToEOS.end(); ++id2eos )
|
||||||
{
|
{
|
||||||
_EdgesOnShape& eos = * ( id2oes->second );
|
_EdgesOnShape& eos = * ( id2eos->second );
|
||||||
for ( size_t i = 0; i < eos._edges.size(); ++i )
|
for ( size_t i = 0; i < eos._edges.size(); ++i )
|
||||||
{
|
{
|
||||||
_LayerEdge* & ledge = eos._edges[ i ];
|
_LayerEdge* & ledge = eos._edges[ i ];
|
||||||
@ -6603,7 +6603,8 @@ bool _ViscousBuilder::shrink()
|
|||||||
subEOS.clear();
|
subEOS.clear();
|
||||||
lEdges.clear();
|
lEdges.clear();
|
||||||
{
|
{
|
||||||
SMESH_subMeshIteratorPtr subIt = sm->getDependsOnIterator(/*includeSelf=*/false);
|
SMESH_subMeshIteratorPtr subIt = sm->getDependsOnIterator(/*includeSelf=*/false,
|
||||||
|
/*complexFirst=*/true); //!!!
|
||||||
while ( subIt->more() )
|
while ( subIt->more() )
|
||||||
{
|
{
|
||||||
const TGeomID subID = subIt->next()->GetId();
|
const TGeomID subID = subIt->next()->GetId();
|
||||||
@ -6765,10 +6766,12 @@ bool _ViscousBuilder::shrink()
|
|||||||
int oldBadNb = badNb;
|
int oldBadNb = badNb;
|
||||||
badNb = 0;
|
badNb = 0;
|
||||||
moved = false;
|
moved = false;
|
||||||
|
// '% 5' minimizes NB FUNCTIONS on viscous_layers_00/B2 case
|
||||||
|
_SmoothNode::SmoothType smooTy = ( smooStep % 5 ) ? smoothType : _SmoothNode::LAPLACIAN;
|
||||||
for ( size_t i = 0; i < nodesToSmooth.size(); ++i )
|
for ( size_t i = 0; i < nodesToSmooth.size(); ++i )
|
||||||
{
|
{
|
||||||
moved |= nodesToSmooth[i].Smooth( badNb, surface, helper, refSign,
|
moved |= nodesToSmooth[i].Smooth( badNb, surface, helper, refSign,
|
||||||
smoothType, /*set3D=*/isConcaveFace);
|
smooTy, /*set3D=*/isConcaveFace);
|
||||||
}
|
}
|
||||||
if ( badNb < oldBadNb )
|
if ( badNb < oldBadNb )
|
||||||
nbNoImpSteps = 0;
|
nbNoImpSteps = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user