mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-14 02:30:33 +05:00
Fix SALOME_TESTS/Grids/smesh/bugs_07/H5 as the geometry changed
This commit is contained in:
parent
845b5221ba
commit
9b504e4867
@ -440,13 +440,15 @@ bool SMESH_Algo::GetSortedNodesOnEdge(const SMESHDS_Mesh* theM
|
|||||||
TopExp::Vertices(theEdge, v1, v2);
|
TopExp::Vertices(theEdge, v1, v2);
|
||||||
const SMDS_MeshNode* n1 = VertexNode( v1, eSubMesh, 0 );
|
const SMDS_MeshNode* n1 = VertexNode( v1, eSubMesh, 0 );
|
||||||
const SMDS_MeshNode* n2 = VertexNode( v2, eSubMesh, 0 );
|
const SMDS_MeshNode* n2 = VertexNode( v2, eSubMesh, 0 );
|
||||||
|
const SMDS_MeshNode* nEnd[2] = { nbNodes ? theNodes.begin()->second : 0,
|
||||||
|
nbNodes ? theNodes.rbegin()->second : 0 };
|
||||||
Standard_Real f, l;
|
Standard_Real f, l;
|
||||||
BRep_Tool::Range(theEdge, f, l);
|
BRep_Tool::Range(theEdge, f, l);
|
||||||
if ( v1.Orientation() != TopAbs_FORWARD )
|
if ( v1.Orientation() != TopAbs_FORWARD )
|
||||||
std::swap( f, l );
|
std::swap( f, l );
|
||||||
if ( n1 && ++nbNodes )
|
if ( n1 && n1 != nEnd[0] && n1 != nEnd[1] && ++nbNodes )
|
||||||
theNodes.insert( make_pair( f, n1 ));
|
theNodes.insert( make_pair( f, n1 ));
|
||||||
if ( n2 && ++nbNodes )
|
if ( n2 && n2 != nEnd[0] && n2 != nEnd[1] && ++nbNodes )
|
||||||
theNodes.insert( make_pair( l, n2 ));
|
theNodes.insert( make_pair( l, n2 ));
|
||||||
|
|
||||||
return (int)theNodes.size() == nbNodes;
|
return (int)theNodes.size() == nbNodes;
|
||||||
|
@ -2568,6 +2568,7 @@ bool SMESH_MesherHelper::LoadNodeColumns(TParam2ColumnMap & theParam2
|
|||||||
}
|
}
|
||||||
|
|
||||||
// get nodes on theBaseEdge sorted by param on edge and initialize theParam2ColumnMap with them
|
// get nodes on theBaseEdge sorted by param on edge and initialize theParam2ColumnMap with them
|
||||||
|
const SMDS_MeshNode* prevEndNodes[2] = { 0, 0 };
|
||||||
edge = theBaseSide.begin();
|
edge = theBaseSide.begin();
|
||||||
for ( int iE = 0; edge != theBaseSide.end(); ++edge, ++iE )
|
for ( int iE = 0; edge != theBaseSide.end(); ++edge, ++iE )
|
||||||
{
|
{
|
||||||
@ -2635,11 +2636,16 @@ bool SMESH_MesherHelper::LoadNodeColumns(TParam2ColumnMap & theParam2
|
|||||||
const double prevPar = theParam2ColumnMap.empty() ? 0 : theParam2ColumnMap.rbegin()->first;
|
const double prevPar = theParam2ColumnMap.empty() ? 0 : theParam2ColumnMap.rbegin()->first;
|
||||||
for ( u_n = sortedBaseNN.begin(); u_n != sortedBaseNN.end(); u_n++ )
|
for ( u_n = sortedBaseNN.begin(); u_n != sortedBaseNN.end(); u_n++ )
|
||||||
{
|
{
|
||||||
|
if ( u_n->second == prevEndNodes[0] ||
|
||||||
|
u_n->second == prevEndNodes[1] )
|
||||||
|
continue;
|
||||||
double par = prevPar + coeff * ( u_n->first - f );
|
double par = prevPar + coeff * ( u_n->first - f );
|
||||||
TParam2ColumnMap::iterator u2nn =
|
TParam2ColumnMap::iterator u2nn =
|
||||||
theParam2ColumnMap.insert( theParam2ColumnMap.end(), make_pair( par, TNodeColumn()));
|
theParam2ColumnMap.insert( theParam2ColumnMap.end(), make_pair( par, TNodeColumn()));
|
||||||
u2nn->second.push_back( u_n->second );
|
u2nn->second.push_back( u_n->second );
|
||||||
}
|
}
|
||||||
|
prevEndNodes[0] = sortedBaseNN.begin()->second;
|
||||||
|
prevEndNodes[1] = sortedBaseNN.rbegin()->second;
|
||||||
}
|
}
|
||||||
if ( theParam2ColumnMap.size() < 2 )
|
if ( theParam2ColumnMap.size() < 2 )
|
||||||
return false;
|
return false;
|
||||||
|
@ -380,7 +380,8 @@ bool StdMeshers_Hexa_3D::Compute(SMESH_Mesh & aMesh,
|
|||||||
StdMeshers_Quadrangle_2D quadAlgo( _gen->GetANewId(), GetStudyId(), _gen);
|
StdMeshers_Quadrangle_2D quadAlgo( _gen->GetANewId(), GetStudyId(), _gen);
|
||||||
for ( int i = 0; i < 6; ++i )
|
for ( int i = 0; i < 6; ++i )
|
||||||
{
|
{
|
||||||
if ( !( quad[i] = FaceQuadStructPtr( quadAlgo.CheckNbEdges( aMesh, FF( i+1 )))))
|
if ( !( quad[i] = FaceQuadStructPtr( quadAlgo.CheckNbEdges( aMesh, FF( i+1 ),
|
||||||
|
/*considerMesh=*/true))))
|
||||||
return error( quadAlgo.GetComputeError() );
|
return error( quadAlgo.GetComputeError() );
|
||||||
if ( quad[i]->side.size() != 4 )
|
if ( quad[i]->side.size() != 4 )
|
||||||
return error( COMPERR_BAD_SHAPE, "Not a quadrangular box side" );
|
return error( COMPERR_BAD_SHAPE, "Not a quadrangular box side" );
|
||||||
|
Loading…
Reference in New Issue
Block a user