52475: CGNS file is incorrectly read

Fix a problem that nodes merged according incorrect description of zone-to-zone interface
This commit is contained in:
eap 2014-08-07 14:51:11 +04:00
parent d8557600d9
commit aff2cee17c

View File

@ -29,6 +29,7 @@
#include "SMESHDS_Group.hxx"
#include "SMESHDS_Mesh.hxx"
#include "SMESH_Comment.hxx"
#include "SMESH_TypeDefs.hxx"
#include <gp_XYZ.hxx>
@ -76,7 +77,9 @@ namespace
}
bool IsStructured() const { return ( _type == CGNS_ENUMV( Structured )); }
int IndexSize() const { return IsStructured() ? _meshDim : 1; }
string ReadZonesConnection(int file, int base, const map< string, TZoneData >& zonesByName);
string ReadZonesConnection(int file, int base,
const map< string, TZoneData >& zonesByName,
SMESHDS_Mesh* mesh);
void ReplaceNodes( cgsize_t* ids, int nbIds, int idShift = 0 ) const;
// Methods for a structured zone
@ -205,6 +208,37 @@ namespace
//gp_XYZ End() const { return gp_XYZ( _end[0]-1, _end[1]-1, _end[2]-1 ); }
};
//================================================================================
/*!
* \brief Checks if the two arrays of node IDs describe nodes with equal coordinates
*/
//================================================================================
bool isEqualNodes( const int* nIds1, const int* nIds2, int nbNodes, SMESHDS_Mesh* mesh )
{
if ( nbNodes > 0 )
{
SMESH_TNodeXYZ nn1[2], nn2[2];
nn1[0] = mesh->FindNode( nIds1[0] );
nn2[0] = mesh->FindNode( nIds2[0] );
if ( !nn1[0]._node || !nn2[0]._node )
return false;
double dist1 = ( nn1[0] - nn2[0] ).Modulus();
double dist2 = 0, tol = 1e-7;
if ( nbNodes > 1 )
{
nn1[1] = mesh->FindNode( nIds1[1] );
nn2[1] = mesh->FindNode( nIds2[1] );
if ( !nn1[1]._node || !nn2[1]._node )
return false;
dist2 = ( nn1[1] - nn2[1] ).Modulus();
tol = 1e-5 * ( nn1[0] - nn1[1] ).Modulus();
}
return ( dist1 < tol & dist2 < tol );
}
return false;
}
//================================================================================
/*!
* \brief Reads zone interface connectivity
@ -220,7 +254,8 @@ namespace
string TZoneData::ReadZonesConnection( int file,
int base,
const map< string, TZoneData >& zonesByName)
const map< string, TZoneData >& zonesByName,
SMESHDS_Mesh* mesh)
{
string error;
@ -277,6 +312,26 @@ namespace
continue; // this interface already read
}
}
// check if range and donorRange describe the same nodes
{
int ids1[2], ids2[2], nbN = 0;
TPointRangeIterator rangeIt1bis( range, _meshDim );
index1 = rangeIt1bis.Next();
index2 = T * ( index1 - begin1 ) + begin2;
ids1[0] = NodeID( index1 );
ids2[0] = zone2.NodeID( index2 );
++nbN;
if ( rangeIt1bis.More() )
{
index1 = rangeIt1bis.Next();
index2 = T * ( index1 - begin1 ) + begin2;
ids1[1] = NodeID( index1 );
ids2[1] = zone2.NodeID( index2 );
++nbN;
}
if ( !isEqualNodes( &ids1[0], &ids2[0], nbN, mesh ))
continue;
}
while ( rangeIt1.More() )
{
index1 = rangeIt1.Next();
@ -361,7 +416,9 @@ namespace
points[i] += zone._nodeIdShift;
}
}
for ( size_t i = 0; i < ids.size() && i < donorIds.size(); ++i )
size_t nbN = std::min( ids.size(), donorIds.size());
if ( isEqualNodes( &ids[0], &donorIds[0], nbN, mesh ))
for ( size_t i = 0; i < nbN; ++i )
_nodeReplacementMap.insert( make_pair( ids[i], donorIds[i] ));
}
else
@ -710,7 +767,7 @@ Driver_Mesh::Status DriverCGNS_Read::Perform()
// Read connectivity between zones. Nodes of the zone interface will be
// replaced withing the zones read later
string err = zone.ReadZonesConnection( _fn, cgnsBase, zonesByName );
string err = zone.ReadZonesConnection( _fn, cgnsBase, zonesByName, myMesh );
if ( !err.empty() )
addMessage( err );