Fix export structured CGNS when there is a group on several volumes that leads to duplicate name in 1to1 connectivity

TODO: do not put _1 if there is only one group with this name
This commit is contained in:
Christophe Bourcier 2024-12-13 18:33:46 +01:00
parent 8db3567826
commit 1841c623c3
2 changed files with 69 additions and 22 deletions

View File

@ -81,7 +81,48 @@ std::string DriverStructuredCGNS_Write::GetGroupName( const int shapeToIndex, in
}
}
}
return std::string("");
// else by convention, create a group called ZONESOLID or ZONEFACE
std::string emptyZoneName("ZONE");
if (dim == 3)
emptyZoneName += "SOLID";
else
emptyZoneName += "FACE";
return emptyZoneName;
}
void DriverStructuredCGNS_Write::GetGroupNamesMap( const TopoDS_Shape& shape, int dim, std::map<unsigned int, std::string>& groupNameMapById )
{
// get all zone names
// get a unique name for each zone name
// std::map<unsigned int, std::string> groupNameMapById;
std::map<std::string, int> countGroupName;
TopAbs_ShapeEnum exploreType;
if (dim == 3)
exploreType = TopAbs_SOLID;
else
exploreType = TopAbs_FACE;
for ( TopExp_Explorer fEx( shape, exploreType ); fEx.More(); fEx.Next() )
{
unsigned int solidId;
if (dim == 3)
{
auto currentSolid = TopoDS::Solid(fEx.Current());
solidId = myMesh->ShapeToIndex(currentSolid);
}
else
{
auto currentSolid = TopoDS::Face(fEx.Current());
solidId = myMesh->ShapeToIndex(currentSolid);
}
std::string zoneName = GetGroupName(solidId, dim);
// update the frequency count
countGroupName[zoneName]++;
int count = countGroupName[zoneName];
// Append frequency count to end of the string
zoneName += "_"+std::to_string(count);
// store the name
groupNameMapById[solidId] = zoneName;
}
}
void DriverStructuredCGNS_Write::CheckForGroupNameOnFaceInterfaces( const SMESHUtils::SMESH_RegularGrid* grid, std::vector<std::string>& boundaryNames )
@ -196,7 +237,10 @@ Driver_Mesh::Status DriverStructuredCGNS_Write::Perform()
if ( meshDim == 3 )
{
std::set<std::string> zNames;
// get a map of unique names for each solid
std::map<unsigned int, std::string> groupNameMapById;
GetGroupNamesMap(shape, meshDim, groupNameMapById);
// Fill the cgns info for each solid
for ( TopExp_Explorer fEx( shape, TopAbs_SOLID ); fEx.More(); fEx.Next() )
{
TopoDS_Solid currentSolid = TopoDS::Solid(fEx.Current());
@ -210,11 +254,8 @@ Driver_Mesh::Status DriverStructuredCGNS_Write::Perform()
cgsize_t size[9] = {imax, jmax, kmax, imax - 1, jmax - 1, kmax - 1, 0, 0, 0};
std::string zoneName = GetGroupName(myMesh->ShapeToIndex(currentSolid),meshDim);
zoneName = zoneName.empty() ? "ZONESOLID" + std::to_string(myMesh->ShapeToIndex(currentSolid)) : zoneName;
if ( zNames.count(zoneName) != 0 )
zoneName = zoneName + "_" + std::to_string(myMesh->ShapeToIndex(currentSolid));
zNames.insert( zoneName );
unsigned int currentSolidId = myMesh->ShapeToIndex(currentSolid);
std::string zoneName = groupNameMapById[currentSolidId];
// write Zone
int iZone;
if(cg_zone_write(_fn, iBase, zoneName.c_str(), size,
@ -312,9 +353,10 @@ Driver_Mesh::Status DriverStructuredCGNS_Write::Perform()
interfacecgns[i] = cgsize_t(interface[i+1]);
int iConn;
std::string neigbourZoneName = GetGroupName(myMesh->ShapeToIndex(neighbourSolid),meshDim);
neigbourZoneName = neigbourZoneName.empty() ? "ZONESOLID" + std::to_string(myMesh->ShapeToIndex(neighbourSolid)) : neigbourZoneName;
std::string interfaceName = zoneName + "_" + neigbourZoneName + "_" + std::to_string(interface[0]);
unsigned int neighbourSolidId = myMesh->ShapeToIndex(neighbourSolid);
std::string neigbourZoneName = groupNameMapById[neighbourSolidId];
// interfaceName must be unique (it should be by construction)
std::string interfaceName = zoneName + "_" + neigbourZoneName;
if(cg_1to1_write(_fn, iBase, iZone, interfaceName.c_str(), neigbourZoneName.c_str(),
&interfacecgns[0], &interfacecgns[6], &interface[13], &iConn) != CG_OK) return addMessage(cg_get_error(), /*fatal = */true);
}
@ -326,7 +368,9 @@ Driver_Mesh::Status DriverStructuredCGNS_Write::Perform()
}
else if ( meshDim == 2 )
{
std::set<std::string> zNames;
// get a map of unique names for each face
std::map<unsigned int, std::string> groupNameMapById;
GetGroupNamesMap(shape, meshDim, groupNameMapById);
for ( TopExp_Explorer fEx( shape, TopAbs_FACE ); fEx.More(); fEx.Next() )
{
TopoDS_Face currentFace = TopoDS::Face(fEx.Current());
@ -339,12 +383,9 @@ Driver_Mesh::Status DriverStructuredCGNS_Write::Perform()
int iZone;
cgsize_t size[6] = {imax, jmax, imax - 1, jmax - 1, 0, 0};
std::string zoneName = GetGroupName(myMesh->ShapeToIndex(currentFace),meshDim);
zoneName = zoneName.empty() ? "ZONEFACE" + std::to_string(myMesh->ShapeToIndex(currentFace)) : zoneName;
unsigned int currentFaceId = myMesh->ShapeToIndex(currentFace);
std::string zoneName = groupNameMapById[currentFaceId];
if ( zNames.count(zoneName) != 0 )
zoneName = zoneName + "_" + std::to_string(myMesh->ShapeToIndex(currentFace));
zNames.insert( zoneName );
// write Zone
if(cg_zone_write(_fn, iBase, zoneName.c_str(), size,
CGNS_ENUMV(Structured), &iZone) != CG_OK)
@ -442,9 +483,9 @@ Driver_Mesh::Status DriverStructuredCGNS_Write::Perform()
interfacecgns[i] = cgsize_t(interface[i+1]);
int iConn;
std::string neigbourZoneName = GetGroupName(myMesh->ShapeToIndex(neighbourFace),meshDim);
neigbourZoneName = neigbourZoneName.empty() ? "ZONEFACE" + std::to_string(myMesh->ShapeToIndex(neighbourFace)) : neigbourZoneName;
std::string interfaceName = zoneName + "_" + neigbourZoneName + "_" + std::to_string(interface[0]);
unsigned int neighbourFaceId = myMesh->ShapeToIndex(neighbourFace);
std::string neigbourZoneName = groupNameMapById[neighbourFaceId];
std::string interfaceName = zoneName + "_" + neigbourZoneName;
if(cg_1to1_write(_fn, iBase, iZone, interfaceName.c_str(), neigbourZoneName.c_str(),
&interfacecgns[0], &interfacecgns[4], &interface[9], &iConn) != CG_OK) return addMessage(cg_get_error(), /*fatal = */true);

View File

@ -25,6 +25,7 @@
// occt
#include <TopoDS.hxx>
#include <TopoDS_Shape.hxx>
// smesh
#include "SMESH_DriverCGNS.hxx"
@ -65,6 +66,11 @@ public:
private:
int _fn; //!< file index
/*!
* \brief Get the map between a solid (or face) id and its unique name.
* Add a suffix if needed to avoid duplicate group name.
*/
void GetGroupNamesMap( const TopoDS_Shape& shape, int dim, std::map<unsigned int, std::string>& groupNameMapById );
};
#endif