22316: EDF 2719 SMESH: Split hexas into prisms

+  static int GetOppFaceIndexOfHex( int faceIndex );
This commit is contained in:
eap 2014-01-20 10:32:49 +00:00
parent 80d5c05fce
commit b9b3af112d
2 changed files with 44 additions and 14 deletions

View File

@ -132,8 +132,6 @@ static int Penta_nbN [] = { 3, 3, 4, 4, 4 };
// / | / | // / | / |
// N4+----------+N7 | // N4+----------+N7 |
// | | | | HEXAHEDRON // | | | | HEXAHEDRON
// | | | |
// | | | |
// | N1+------|---+N2 // | N1+------|---+N2
// | / | / // | / | /
// | / | / // | / | /
@ -155,6 +153,7 @@ static int Hexa_RE [6][5] = { // REVERSED -> EXTERNAL
{ 3, 7, 6, 2, 3 }, { 3, 7, 6, 2, 3 },
{ 0, 4, 7, 3, 0 }}; { 0, 4, 7, 3, 0 }};
static int Hexa_nbN [] = { 4, 4, 4, 4, 4, 4 }; static int Hexa_nbN [] = { 4, 4, 4, 4, 4, 4 };
static int Hexa_oppF[] = { 1, 0, 4, 5, 2, 3 }; // oppopsite facet indices
/* /*
// N8 +------+ N9 // N8 +------+ N9
@ -279,7 +278,7 @@ static int QuadPyram_nbN [] = { 8, 6, 6, 6, 6 };
*/ */
static int QuadPenta_F [5][9] = { // FORWARD static int QuadPenta_F [5][9] = { // FORWARD
{ 0, 6, 1, 7, 2, 8, 0, 0, 0 }, { 0, 6, 1, 7, 2, 8, 0, 0, 0 },
{ 3,11, 5, 10,4, 9, 3, 3, 3 }, { 3, 11,5, 10,4, 9, 3, 3, 3 },
{ 0, 12,3, 9, 4, 13,1, 6, 0 }, { 0, 12,3, 9, 4, 13,1, 6, 0 },
{ 1, 13,4, 10,5, 14,2, 7, 1 }, { 1, 13,4, 10,5, 14,2, 7, 1 },
{ 0, 8, 2, 14,5, 11,3, 12,0 }}; { 0, 8, 2, 14,5, 11,3, 12,0 }};
@ -1147,12 +1146,7 @@ int SMDS_VolumeTool::GetOppFaceIndex( int faceIndex ) const
break; break;
case 20: case 20:
case 27: case 27:
if ( faceIndex <= 1 ) // top or bottom ind = GetOppFaceIndexOfHex( faceIndex );
ind = 1 - faceIndex;
else {
const int nbSideFaces = myAllFacesNbNodes[0] / 2;
ind = ( faceIndex - nbHoriFaces + nbSideFaces/2 ) % nbSideFaces + nbHoriFaces;
}
break; break;
default:; default:;
} }
@ -1160,6 +1154,16 @@ int SMDS_VolumeTool::GetOppFaceIndex( int faceIndex ) const
return ind; return ind;
} }
//=======================================================================
//function : GetOppFaceIndexOfHex
//purpose : Return index of the opposite face of the hexahedron
//=======================================================================
int SMDS_VolumeTool::GetOppFaceIndexOfHex( int faceIndex )
{
return Hexa_oppF[ faceIndex ];
}
//======================================================================= //=======================================================================
//function : IsLinked //function : IsLinked
//purpose : return true if theNode1 is linked with theNode2 //purpose : return true if theNode1 is linked with theNode2
@ -1660,16 +1664,38 @@ bool SMDS_VolumeTool::IsFreeFaceAdv( int faceIndex, const SMDS_MeshElement** oth
//purpose : Return index of a face formed by theFaceNodes //purpose : Return index of a face formed by theFaceNodes
//======================================================================= //=======================================================================
int SMDS_VolumeTool::GetFaceIndex( const set<const SMDS_MeshNode*>& theFaceNodes ) const int SMDS_VolumeTool::GetFaceIndex( const set<const SMDS_MeshNode*>& theFaceNodes,
const int theFaceIndexHint ) const
{ {
if ( theFaceIndexHint >= 0 )
{
int nbNodes = NbFaceNodes( theFaceIndexHint );
if ( nbNodes == (int) theFaceNodes.size() )
{
const SMDS_MeshNode** nodes = GetFaceNodes( theFaceIndexHint );
while ( nbNodes )
if ( theFaceNodes.count( nodes[ nbNodes-1 ]))
--nbNodes;
else
break;
if ( nbNodes == 0 )
return theFaceIndexHint;
}
}
for ( int iFace = 0; iFace < myNbFaces; iFace++ ) for ( int iFace = 0; iFace < myNbFaces; iFace++ )
{ {
const int nbNodes = NbFaceNodes( iFace ); if ( iFace == theFaceIndexHint )
continue;
int nbNodes = NbFaceNodes( iFace );
if ( nbNodes == (int) theFaceNodes.size() ) if ( nbNodes == (int) theFaceNodes.size() )
{ {
const SMDS_MeshNode** nodes = GetFaceNodes( iFace ); const SMDS_MeshNode** nodes = GetFaceNodes( iFace );
set<const SMDS_MeshNode*> nodeSet( nodes, nodes + nbNodes); while ( nbNodes )
if ( theFaceNodes == nodeSet ) if ( theFaceNodes.count( nodes[ nbNodes-1 ]))
--nbNodes;
else
break;
if ( nbNodes == 0 )
return iFace; return iFace;
} }
} }

View File

@ -201,7 +201,8 @@ class SMDS_EXPORT SMDS_VolumeTool
int GetCenterNodeIndex( int faceIndex ) const; int GetCenterNodeIndex( int faceIndex ) const;
// Return index of the node located at face center of a quadratic element like HEX27 // Return index of the node located at face center of a quadratic element like HEX27
int GetFaceIndex( const std::set<const SMDS_MeshNode*>& theFaceNodes ) const; int GetFaceIndex( const std::set<const SMDS_MeshNode*>& theFaceNodes,
const int theFaceIndexHint=-1) const;
// Return index of a face formed by theFaceNodes. // Return index of a face formed by theFaceNodes.
// Return -1 if a face not found // Return -1 if a face not found
@ -238,6 +239,9 @@ class SMDS_EXPORT SMDS_VolumeTool
static int NbCornerNodes(VolumeType type); static int NbCornerNodes(VolumeType type);
// Useful to know nb of corner nodes of a quadratic volume // Useful to know nb of corner nodes of a quadratic volume
static int GetOppFaceIndexOfHex( int faceIndex );
// Return index of the opposite face of the hexahedron
private: private:
bool setFace( int faceIndex ) const; bool setFace( int faceIndex ) const;