mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-14 02:30:33 +05:00
22360: EDF SMESH: Body Fitting algorithm: incorporate edges
take transition into account when creating splits of links
This commit is contained in:
parent
e89c030400
commit
2f84a8c897
@ -696,7 +696,7 @@ namespace
|
|||||||
{
|
{
|
||||||
tranSet.clear();
|
tranSet.clear();
|
||||||
ip1 = ip2++;
|
ip1 = ip2++;
|
||||||
while ( ip2->_paramOnLine - ip1->_paramOnLine <= tol && ip2 != _intPoints.end())
|
while ( ip2 != _intPoints.end() && ip2->_paramOnLine - ip1->_paramOnLine <= tol )
|
||||||
{
|
{
|
||||||
tranSet.insert( ip1->_transition );
|
tranSet.insert( ip1->_transition );
|
||||||
tranSet.insert( ip2->_transition );
|
tranSet.insert( ip2->_transition );
|
||||||
@ -1552,23 +1552,33 @@ namespace
|
|||||||
_Link& link = _hexLinks[ iLink ];
|
_Link& link = _hexLinks[ iLink ];
|
||||||
link._splits.clear();
|
link._splits.clear();
|
||||||
split._nodes[ 0 ] = link._nodes[0];
|
split._nodes[ 0 ] = link._nodes[0];
|
||||||
|
bool isOut = ( ! link._nodes[0]->Node() );
|
||||||
|
//int iEnd = link._intNodes.size() - bool( link._nodes[1]->_intPoint );
|
||||||
for ( size_t i = 0; i < link._intNodes.size(); ++i )
|
for ( size_t i = 0; i < link._intNodes.size(); ++i )
|
||||||
{
|
{
|
||||||
if ( split._nodes[ 0 ]->Node() )
|
if ( link._intNodes[i].Node() )
|
||||||
{
|
{
|
||||||
split._nodes[ 1 ] = &link._intNodes[i];
|
if ( split._nodes[ 0 ]->Node() && !isOut )
|
||||||
link._splits.push_back( split );
|
{
|
||||||
|
split._nodes[ 1 ] = &link._intNodes[i];
|
||||||
|
link._splits.push_back( split );
|
||||||
|
}
|
||||||
|
split._nodes[ 0 ] = &link._intNodes[i];
|
||||||
|
}
|
||||||
|
switch ( link._intNodes[i].FaceIntPnt()->_transition ) {
|
||||||
|
case Trans_OUT: isOut = true; break;
|
||||||
|
case Trans_IN : isOut = false; break;
|
||||||
|
default:; // isOut remains the same
|
||||||
}
|
}
|
||||||
split._nodes[ 0 ] = &link._intNodes[i];
|
|
||||||
}
|
}
|
||||||
if ( link._nodes[ 1 ]->Node() && split._nodes[ 0 ]->Node() )
|
if ( link._nodes[ 1 ]->Node() && split._nodes[ 0 ]->Node() && !isOut )
|
||||||
{
|
{
|
||||||
split._nodes[ 1 ] = link._nodes[1];
|
split._nodes[ 1 ] = link._nodes[1];
|
||||||
link._splits.push_back( split );
|
link._splits.push_back( split );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// create _Node's at intersections with EDGEs
|
// Create _Node's at intersections with EDGEs.
|
||||||
|
|
||||||
const double tol2 = _grid->_tol * _grid->_tol;
|
const double tol2 = _grid->_tol * _grid->_tol;
|
||||||
int facets[3], nbFacets, subEntity;
|
int facets[3], nbFacets, subEntity;
|
||||||
@ -1683,7 +1693,7 @@ namespace
|
|||||||
if ( _nbCornerNodes + _nbIntNodes < 4 )
|
if ( _nbCornerNodes + _nbIntNodes < 4 )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ( _nbBndNodes == _nbCornerNodes && isInHole() )
|
if ( _nbBndNodes == _nbCornerNodes && _nbIntNodes == 0 && isInHole() )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
_polygons.clear();
|
_polygons.clear();
|
||||||
@ -1719,21 +1729,6 @@ namespace
|
|||||||
{
|
{
|
||||||
_OrientedLink split = quad._links[ iE ].ResultLink( iS );
|
_OrientedLink split = quad._links[ iE ].ResultLink( iS );
|
||||||
_Node* n1 = split.FirstNode();
|
_Node* n1 = split.FirstNode();
|
||||||
_Node* n2 = split.LastNode();
|
|
||||||
if ( !n1->IsLinked( n2->_intPoint ))
|
|
||||||
{
|
|
||||||
if ( findChain( n1, n2, quad, chainNodes ))
|
|
||||||
{
|
|
||||||
for ( size_t i = 1; i < chainNodes.size(); ++i )
|
|
||||||
{
|
|
||||||
polyLink._nodes[0] = chainNodes[i-1];
|
|
||||||
polyLink._nodes[1] = chainNodes[i];
|
|
||||||
polygon._polyLinks.push_back( polyLink );
|
|
||||||
polygon._links.push_back( _OrientedLink( &polygon._polyLinks.back() ));
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ( !polygon._links.empty() )
|
if ( !polygon._links.empty() )
|
||||||
{
|
{
|
||||||
_Node* nPrev = polygon._links.back().LastNode();
|
_Node* nPrev = polygon._links.back().LastNode();
|
||||||
@ -1821,6 +1816,7 @@ namespace
|
|||||||
_polygons.resize( _polygons.size() + 1 );
|
_polygons.resize( _polygons.size() + 1 );
|
||||||
_Face& polygon = _polygons.back();
|
_Face& polygon = _polygons.back();
|
||||||
polygon._polyLinks.reserve( 20 );
|
polygon._polyLinks.reserve( 20 );
|
||||||
|
polygon._links.reserve( 20 );
|
||||||
|
|
||||||
_OrientedLink* curLink = 0;
|
_OrientedLink* curLink = 0;
|
||||||
_Node* curNode;
|
_Node* curNode;
|
||||||
@ -2019,7 +2015,7 @@ namespace
|
|||||||
multiset< F_IntersectPoint >::const_iterator ip = line._intPoints.begin();
|
multiset< F_IntersectPoint >::const_iterator ip = line._intPoints.begin();
|
||||||
for ( ; ip != line._intPoints.end(); ++ip )
|
for ( ; ip != line._intPoints.end(); ++ip )
|
||||||
{
|
{
|
||||||
if ( !ip->_node ) continue;
|
//if ( !ip->_node ) continue;
|
||||||
lineInd.SetIndexOnLine( ip->_indexOnLine );
|
lineInd.SetIndexOnLine( ip->_indexOnLine );
|
||||||
for ( int iL = 0; iL < 4; ++iL ) // loop on 4 cells sharing a link
|
for ( int iL = 0; iL < 4; ++iL ) // loop on 4 cells sharing a link
|
||||||
{
|
{
|
||||||
@ -2042,7 +2038,7 @@ namespace
|
|||||||
}
|
}
|
||||||
const int iLink = iL + iDir * 4;
|
const int iLink = iL + iDir * 4;
|
||||||
hex->_hexLinks[iLink]._intNodes.push_back( _Node( 0, &(*ip) ));
|
hex->_hexLinks[iLink]._intNodes.push_back( _Node( 0, &(*ip) ));
|
||||||
hex->_nbIntNodes++;
|
hex->_nbIntNodes += bool( ip->_node );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2534,6 +2530,9 @@ namespace
|
|||||||
*/
|
*/
|
||||||
bool Hexahedron::isInHole() const
|
bool Hexahedron::isInHole() const
|
||||||
{
|
{
|
||||||
|
if ( !_vertexNodes.empty() )
|
||||||
|
return false;
|
||||||
|
|
||||||
const int ijk[3] = { _i, _j, _k };
|
const int ijk[3] = { _i, _j, _k };
|
||||||
F_IntersectPoint curIntPnt;
|
F_IntersectPoint curIntPnt;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user