#19913 [CEA] Crash when compute mesh with body fitting and shared faces

1) fix the crash
  2) fix missing volumes when taking shared faces into account

  overlapping volumes remain to fix
This commit is contained in:
eap 2020-08-19 11:56:22 +03:00
parent 951dd4234e
commit 66de7ed40f

View File

@ -2388,6 +2388,7 @@ namespace
{ {
_i = i; _j = j; _k = k; _i = i; _j = j; _k = k;
bool isCompute = solid;
if ( !solid ) if ( !solid )
solid = _grid->GetSolid(); solid = _grid->GetSolid();
@ -2417,6 +2418,9 @@ namespace
_intNodes.clear(); _intNodes.clear();
_vIntNodes.clear(); _vIntNodes.clear();
if ( !isCompute )
return;
if ( _nbFaceIntNodes + _eIntPoints.size() > 0 && if ( _nbFaceIntNodes + _eIntPoints.size() > 0 &&
_nbFaceIntNodes + _eIntPoints.size() + _nbCornerNodes > 3) _nbFaceIntNodes + _eIntPoints.size() + _nbCornerNodes > 3)
{ {
@ -2596,7 +2600,8 @@ namespace
} // loop on _eIntPoints } // loop on _eIntPoints
} }
else if ( 3 < _nbCornerNodes && _nbCornerNodes < 8 ) // _nbFaceIntNodes == 0 else if (( 3 < _nbCornerNodes && _nbCornerNodes < 8 ) || // _nbFaceIntNodes == 0
( !_grid->_geometry.IsOneSolid() ))
{ {
_Link split; _Link split;
// create sub-links (_splits) of whole links // create sub-links (_splits) of whole links
@ -3331,7 +3336,9 @@ namespace
if ( hex ) // split hexahedron if ( hex ) // split hexahedron
{ {
intHexa.push_back( hex ); intHexa.push_back( hex );
if ( hex->_nbFaceIntNodes > 0 || hex->_eIntPoints.size() > 0 ) if ( hex->_nbFaceIntNodes > 0 ||
hex->_eIntPoints.size() > 0 ||
hex->getSolids( solidIDs ) > 1 )
continue; // treat intersected hex later in parallel continue; // treat intersected hex later in parallel
this->init( hex->_i, hex->_j, hex->_k ); this->init( hex->_i, hex->_j, hex->_k );
} }
@ -4464,11 +4471,14 @@ namespace
{ {
curIntPnt._paramOnLine = coords[ ijk[ iDir ]] - coords[0] + _grid->_tol; curIntPnt._paramOnLine = coords[ ijk[ iDir ]] - coords[0] + _grid->_tol;
const GridLine& line = _grid->_lines[ iDir ][ lineIndex[ iL ]]; const GridLine& line = _grid->_lines[ iDir ][ lineIndex[ iL ]];
if ( !line._intPoints.empty() )
{
multiset< F_IntersectPoint >::const_iterator ip = multiset< F_IntersectPoint >::const_iterator ip =
line._intPoints.upper_bound( curIntPnt ); line._intPoints.upper_bound( curIntPnt );
--ip; --ip;
firstIntPnt = &(*ip); firstIntPnt = &(*ip);
} }
}
else if ( !link._fIntPoints.empty() ) else if ( !link._fIntPoints.empty() )
{ {
firstIntPnt = link._fIntPoints[0]; firstIntPnt = link._fIntPoints[0];