Version: 6.3.1
Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes | Static Protected Attributes | Friends

SMDS_Downward Class Reference

#include <SMDS_Downward.hxx>

Inheritance diagram for SMDS_Downward:
Inheritance graph
[legend]

Public Member Functions

virtual int getNumberOfDownCells (int cellId)
 Get the number of downward entities associated to a cell (always the same for a given vtk type of cell)
virtual const intgetDownCells (int cellId)
 get a pointer on the downward entities id's associated to a cell.
virtual const unsigned char * getDownTypes (int cellId)
 get a list of vtk cell types associated to downward entities of a given cell, in the same order than the downward entities id's list (
virtual int getNumberOfUpCells (int cellId)=0
virtual const intgetUpCells (int cellId)=0
virtual const unsigned char * getUpTypes (int cellId)=0
virtual void getNodeIds (int cellId, std::set< int > &nodeSet)=0
virtual int getNodes (int cellId, int *nodevec)
int getVtkCellId (int cellId)
int getMaxId ()

Static Public Member Functions

static int getCellDimension (unsigned char cellType)
 get the dimension of a cell (1,2,3 for 1D, 2D 3D) given the vtk cell type

Protected Member Functions

 SMDS_Downward (SMDS_UnstructuredGrid *grid, int nbDownCells)
 Generic constructor for all the downward connectivity structures (one per vtk cell type).
 ~SMDS_Downward ()
int addCell (int vtkId=-1)
 Give or create an entry for downward connectivity structure relative to a cell.
virtual void initCell (int cellId)
 generic method do nothing.
virtual void allocate (int nbElems)=0
virtual void compactStorage ()=0
virtual void addDownCell (int cellId, int lowCellId, unsigned char aType)
 Id's are downward connectivity id's.
virtual void addUpCell (int cellId, int upCellId, unsigned char aType)
 Id's are downward connectivity id's.
virtual int getNodeSet (int cellId, int *nodeSet)

Protected Attributes

SMDS_UnstructuredGrid_grid
int _maxId
int _nbDownCells
 the same number for all cells of a derived class
std::vector< int_cellIds
 growing size: all the down cell id's, size = _maxId * _nbDownCells
std::vector< int_vtkCellIds
 growing size: size = _maxId, either vtkId or -1
std::vector< unsigned char > _cellTypes
 fixed size: the same vector for all cells of a derived class

Static Protected Attributes

static std::vector< int_cellDimension
 conversion table: type --> dimension

Friends

class SMDS_UnstructuredGrid
class SMDS_Down2D
class SMDS_Down3D

Detailed Description

Definition at line 67 of file SMDS_Downward.hxx.


Constructor & Destructor Documentation

SMDS_Downward::SMDS_Downward ( SMDS_UnstructuredGrid grid,
int  nbDownCells 
) [protected]

Generic constructor for all the downward connectivity structures (one per vtk cell type).

The static structure for cell dimension is set only once.

Parameters:
gridunstructured grid associated to the mesh.
nbDownCellsnumber of downward entities associated to this vtk type of cell.
Returns:

Definition at line 75 of file SMDS_Downward.cxx.

References _cellDimension, _cellIds, _cellTypes, _maxId, and VTK_MAXTYPE.

                                                                         :
  _grid(grid), _nbDownCells(nbDownCells)
{
  this->_maxId = 0;
  this->_cellIds.clear();
  this->_cellTypes.clear();
  if (_cellDimension.empty())
    {
      _cellDimension.resize(VTK_MAXTYPE + 1, 0);
      _cellDimension[VTK_LINE] = 1;
      _cellDimension[VTK_QUADRATIC_EDGE] = 1;
      _cellDimension[VTK_TRIANGLE] = 2;
      _cellDimension[VTK_QUADRATIC_TRIANGLE] = 2;
      _cellDimension[VTK_QUAD] = 2;
      _cellDimension[VTK_QUADRATIC_QUAD] = 2;
      _cellDimension[VTK_TETRA] = 3;
      _cellDimension[VTK_QUADRATIC_TETRA] = 3;
      _cellDimension[VTK_HEXAHEDRON] = 3;
      _cellDimension[VTK_QUADRATIC_HEXAHEDRON] = 3;
      _cellDimension[VTK_WEDGE] = 3;
      _cellDimension[VTK_QUADRATIC_WEDGE] = 3;
      _cellDimension[VTK_PYRAMID] = 3;
      _cellDimension[VTK_QUADRATIC_PYRAMID] = 3;
    }
}
SMDS_Downward::~SMDS_Downward ( ) [protected]

Definition at line 101 of file SMDS_Downward.cxx.

{
}

Member Function Documentation

int SMDS_Downward::addCell ( int  vtkId = -1) [protected]

Give or create an entry for downward connectivity structure relative to a cell.

If the entry already exists, just return its id, otherwise, create it. The internal storage memory is allocated if needed. The SMDS_UnstructuredGrid._cellIdToDownId vector is completed for vtkUnstructuredGrid cells.

Parameters:
vtkIdfor a vtkUnstructuredGrid cell or -1 (default) for a created downward cell.
Returns:
the rank in downward[vtkType] structure.

Definition at line 112 of file SMDS_Downward.cxx.

References _grid, _maxId, _vtkCellIds, allocate(), SMDS_UnstructuredGrid.CellIdToDownId(), initCell(), and SMDS_UnstructuredGrid.setCellIdToDownId().

{
  int localId = -1;
  if (vtkId >= 0)
    localId = _grid->CellIdToDownId(vtkId);
  if (localId >= 0)
    return localId;

  localId = this->_maxId;
  this->_maxId++;
  this->allocate(_maxId);
  if (vtkId >= 0)
    {
      this->_vtkCellIds[localId] = vtkId;
      _grid->setCellIdToDownId(vtkId, localId);
    }
  this->initCell(localId);
  return localId;
}
void SMDS_Downward::addDownCell ( int  cellId,
int  lowCellId,
unsigned char  aType 
) [protected, virtual]

Id's are downward connectivity id's.

add a downward entity of dimension n-1 (cell or node) to a given cell.

Actual implementation is done in derived methods.

Parameters:
cellIdindex of the parent cell (dimension n) in the downward structure relative to a vtk cell type.
lowCellIdindex of the children cell to add (dimension n-1)
aTypevtk cell type of the cell to add (needed to find the SMDS_Downward structure containing the cell to add).

Reimplemented in SMDS_DownTriangle, SMDS_DownQuadTriangle, SMDS_DownQuadrangle, SMDS_DownQuadQuadrangle, SMDS_DownTetra, SMDS_DownQuadTetra, SMDS_DownPyramid, SMDS_DownQuadPyramid, SMDS_DownPenta, SMDS_DownQuadPenta, SMDS_DownHexa, and SMDS_DownQuadHexa.

Definition at line 179 of file SMDS_Downward.cxx.

{
  ASSERT(0); // must be re-implemented in derived class
}
void SMDS_Downward::addUpCell ( int  cellId,
int  upCellId,
unsigned char  aType 
) [protected, virtual]

Id's are downward connectivity id's.

add a downward entity of dimension n+1 to a given cell.

Actual implementation is done in derived methods.

Parameters:
cellIdindex of the children cell (dimension n) in the downward structure relative to a vtk cell type.
upCellIdindex of the parent cell to add (dimension n+1)
aTypevtk cell type of the cell to add (needed to find the SMDS_Downward structure containing the cell to add).

Reimplemented in SMDS_Down1D, and SMDS_Down2D.

Definition at line 190 of file SMDS_Downward.cxx.

{
  ASSERT(0); // must be re-implemented in derived class
}
virtual void SMDS_Downward.allocate ( int  nbElems) [protected, pure virtual]

Implemented in SMDS_Down1D, SMDS_Down2D, and SMDS_Down3D.

Referenced by addCell().

virtual void SMDS_Downward.compactStorage ( ) [protected, pure virtual]

Implemented in SMDS_Down1D, SMDS_Down2D, and SMDS_Down3D.

int SMDS_Downward::getCellDimension ( unsigned char  cellType) [static]

get the dimension of a cell (1,2,3 for 1D, 2D 3D) given the vtk cell type

Parameters:
cellTypevtk cell type
See also:
vtkCellType.h
Returns:
1,2 or 3

Definition at line 44 of file SMDS_Downward.cxx.

References VTK_MAXTYPE.

Referenced by SMDS_UnstructuredGrid.BuildDownwardConnectivity(), SMDS_Down1D.computeFaces(), SMDS_Down2D.computeVolumeIdsFromNodesFace(), SMDS_Down1D.computeVtkCells(), SMDS_UnstructuredGrid.GetNeighbors(), SMDS_UnstructuredGrid.getOrderedNodesOfFace(), and SMDS_UnstructuredGrid.GetParentVolumes().

{
  if (_cellDimension.empty())
    {
      _cellDimension.resize(VTK_MAXTYPE + 1, 0);
      _cellDimension[VTK_LINE] = 1;
      _cellDimension[VTK_QUADRATIC_EDGE] = 1;
      _cellDimension[VTK_TRIANGLE] = 2;
      _cellDimension[VTK_QUADRATIC_TRIANGLE] = 2;
      _cellDimension[VTK_QUAD] = 2;
      _cellDimension[VTK_QUADRATIC_QUAD] = 2;
      _cellDimension[VTK_TETRA] = 3;
      _cellDimension[VTK_QUADRATIC_TETRA] = 3;
      _cellDimension[VTK_HEXAHEDRON] = 3;
      _cellDimension[VTK_QUADRATIC_HEXAHEDRON] = 3;
      _cellDimension[VTK_WEDGE] = 3;
      _cellDimension[VTK_QUADRATIC_WEDGE] = 3;
      _cellDimension[VTK_PYRAMID] = 3;
      _cellDimension[VTK_QUADRATIC_PYRAMID] = 3;
    }
  return _cellDimension[cellType];
}
const int * SMDS_Downward::getDownCells ( int  cellId) [virtual]

get a pointer on the downward entities id's associated to a cell.

See also:
SMDS_Downward.getNumberOfDownCells for the number of downward entities.
SMDS_Downward.getDownTypes for the vtk cell types associated to the downward entities.
Parameters:
cellIdindex of the cell in the downward structure relative to a given vtk cell type.
Returns:
table of downward entities id's.

Definition at line 156 of file SMDS_Downward.cxx.

References _cellIds, and _nbDownCells.

Referenced by SMDS_Down1D.computeFaces(), and SMESH_MeshEditor.DoubleNodesOnGroupBoundaries().

{
  //ASSERT((cellId >=0) && (cellId < _maxId));
  return &_cellIds[_nbDownCells * cellId];
}
const unsigned char * SMDS_Downward::getDownTypes ( int  cellId) [virtual]

get a list of vtk cell types associated to downward entities of a given cell, in the same order than the downward entities id's list (

See also:
SMDS_Downward.getDownCells).
Parameters:
cellIdindex of the cell in the downward structure relative to a vtk cell type.
Returns:
table of downward entities types.

Definition at line 168 of file SMDS_Downward.cxx.

References _cellTypes.

Referenced by SMDS_Down1D.computeFaces(), and SMESH_MeshEditor.DoubleNodesOnGroupBoundaries().

{
  return &_cellTypes[0];
}
int SMDS_Downward.getMaxId ( )

Definition at line 85 of file SMDS_Downward.hxx.

References _maxId.

Referenced by SMDS_UnstructuredGrid.BuildDownwardConnectivity().

  {
    return _maxId;
  }
virtual void SMDS_Downward.getNodeIds ( int  cellId,
std::set< int > &  nodeSet 
) [pure virtual]

Implemented in SMDS_Down1D, SMDS_Down2D, and SMDS_Down3D.

Referenced by SMDS_Down2D.getNodeIds().

virtual int SMDS_Downward.getNodes ( int  cellId,
int nodevec 
) [virtual]

Reimplemented in SMDS_Down1D.

Definition at line 80 of file SMDS_Downward.hxx.

Referenced by SMESH_MeshEditor.DoubleNodesOnGroupBoundaries().

{return 0; }
int SMDS_Downward::getNodeSet ( int  cellId,
int nodeSet 
) [protected, virtual]

Reimplemented in SMDS_Down1D, and SMDS_Down2D.

Definition at line 195 of file SMDS_Downward.cxx.

Referenced by SMDS_Down2D.FindEdgeByNodes(), and SMDS_Down3D.FindFaceByNodes().

{
  return 0;
}
int SMDS_Downward::getNumberOfDownCells ( int  cellId) [virtual]

Get the number of downward entities associated to a cell (always the same for a given vtk type of cell)

Parameters:
cellIdnot used here.
Returns:

Definition at line 145 of file SMDS_Downward.cxx.

References _nbDownCells.

Referenced by SMDS_Down1D.computeFaces(), and SMESH_MeshEditor.DoubleNodesOnGroupBoundaries().

{
  return _nbDownCells;
}
virtual int SMDS_Downward.getNumberOfUpCells ( int  cellId) [pure virtual]

Implemented in SMDS_Down1D, SMDS_Down2D, and SMDS_Down3D.

virtual const int* SMDS_Downward.getUpCells ( int  cellId) [pure virtual]

Implemented in SMDS_Down1D, SMDS_Down2D, and SMDS_Down3D.

virtual const unsigned char* SMDS_Downward.getUpTypes ( int  cellId) [pure virtual]

Implemented in SMDS_Down1D, SMDS_Down2D, and SMDS_Down3D.

int SMDS_Downward.getVtkCellId ( int  cellId)

Definition at line 81 of file SMDS_Downward.hxx.

References _vtkCellIds.

  {
    return _vtkCellIds[cellId];
  }
void SMDS_Downward::initCell ( int  cellId) [protected, virtual]

generic method do nothing.

see derived methods

Parameters:
cellId

Reimplemented in SMDS_Down1D.

Definition at line 136 of file SMDS_Downward.cxx.

Referenced by addCell().

{
}

Friends And Related Function Documentation

friend class SMDS_Down2D [friend]

Definition at line 70 of file SMDS_Downward.hxx.

friend class SMDS_Down3D [friend]

Definition at line 71 of file SMDS_Downward.hxx.

friend class SMDS_UnstructuredGrid [friend]

Field Documentation

vector< int > SMDS_Downward::_cellDimension [static, protected]

conversion table: type --> dimension

Definition at line 108 of file SMDS_Downward.hxx.

Referenced by SMDS_Downward().

std::vector<int> SMDS_Downward._cellIds [protected]
std::vector<unsigned char> SMDS_Downward._cellTypes [protected]
std::vector<int> SMDS_Downward._vtkCellIds [protected]
Copyright © 2007-2011 CEA/DEN, EDF R&D, OPEN CASCADE
Copyright © 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS