2019-02-14 16:55:47 +05:00
|
|
|
// Copyright (C) 2007-2019 CEA/DEN, EDF R&D, OPEN CASCADE
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// This library is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
|
|
// License as published by the Free Software Foundation; either
|
2014-02-20 18:25:37 +06:00
|
|
|
// version 2.1 of the License, or (at your option) any later version.
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// This library is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
// Lesser General Public License for more details.
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
|
|
// License along with this library; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
2009-02-17 10:27:49 +05:00
|
|
|
//
|
2012-08-09 16:03:55 +06:00
|
|
|
|
2017-12-28 16:28:17 +05:00
|
|
|
// SMESH SMDS : implementation of Salome mesh data structure
|
2003-07-10 15:49:12 +06:00
|
|
|
//
|
2005-01-20 11:25:54 +05:00
|
|
|
#ifdef _MSC_VER
|
|
|
|
#pragma warning(disable:4786)
|
|
|
|
#endif
|
|
|
|
|
2003-09-03 23:30:36 +06:00
|
|
|
#include "SMDS_MeshElement.hxx"
|
2017-12-22 16:14:24 +05:00
|
|
|
|
|
|
|
#include "SMDS_Mesh.hxx"
|
|
|
|
#include "SMDS_ElementFactory.hxx"
|
|
|
|
|
2003-09-03 23:30:36 +06:00
|
|
|
#include "utilities.h"
|
2003-05-19 19:49:00 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Constructor of a non-used element
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2004-12-01 15:48:31 +05:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
SMDS_MeshElement::SMDS_MeshElement(): myHolder(0)
|
2012-08-09 16:03:55 +06:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Check if a node is a medium node of a quadratic cell
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2012-08-09 16:03:55 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
bool SMDS_MeshElement::IsMediumNode(const SMDS_MeshNode* node) const
|
2003-05-19 19:49:00 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
return !( GetNodeIndex( node ) < NbCornerNodes() );
|
2003-05-19 19:49:00 +06:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Return true if index of node is valid (0 <= ind < NbNodes())
|
|
|
|
* \param ind - node index
|
|
|
|
* \retval bool - index check result
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2003-05-19 19:49:00 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
bool SMDS_MeshElement::IsValidIndex(const int ind) const
|
2003-05-19 19:49:00 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
return ( ind>-1 && ind<NbNodes() );
|
2003-05-19 19:49:00 +06:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Return a valid corner node index, fixing the given one if necessary
|
|
|
|
* \param ind - node index
|
|
|
|
* \retval int - valid node index
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2003-05-19 19:49:00 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
int SMDS_MeshElement::WrappedIndex(const int ind) const
|
2003-05-19 19:49:00 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
if ( ind < 0 ) return NbCornerNodes() + ind % NbCornerNodes();
|
|
|
|
if ( ind >= NbCornerNodes() ) return ind % NbCornerNodes();
|
|
|
|
return ind;
|
2003-05-19 19:49:00 +06:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Check if a node belongs to the element
|
|
|
|
* \param node - the node to check
|
|
|
|
* \retval int - node index within the element, -1 if not found
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2003-05-19 19:49:00 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
int SMDS_MeshElement::GetNodeIndex( const SMDS_MeshNode* node ) const
|
2003-05-19 19:49:00 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
SMDS_ElemIteratorPtr nIt = nodesIterator();
|
|
|
|
for ( int i = 0; nIt->more(); ++i )
|
|
|
|
if ( nIt->next() == node )
|
|
|
|
return i;
|
|
|
|
return -1;
|
2003-05-19 19:49:00 +06:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Return ID of an element
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2003-05-19 19:49:00 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
int SMDS_MeshElement::GetID() const
|
2003-05-19 19:49:00 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
return myHolder ? myHolder->GetID( this ) : -1;
|
2003-05-19 19:49:00 +06:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Set ID of a shape this element was generated on
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2003-05-19 19:49:00 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
void SMDS_MeshElement::setShapeID( const int shapeID ) const
|
2003-05-19 19:49:00 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
const_cast<SMDS_ElementChunk*>( myHolder )->SetShapeID( this, shapeID );
|
2012-08-09 16:03:55 +06:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Return ID of a shape this element was generated on
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2013-05-16 22:08:00 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
int SMDS_MeshElement::GetShapeID() const
|
2013-05-16 22:08:00 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
return myHolder->GetShapeID( this );
|
2013-05-16 22:08:00 +06:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Return VTK ID of this element
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2013-05-16 22:08:00 +06:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
int SMDS_MeshElement::GetVtkID() const
|
2013-05-16 22:08:00 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
return myHolder->GetVtkID( this );
|
2003-05-19 19:49:00 +06:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Mark this element
|
|
|
|
*/
|
|
|
|
//================================================================================
|
2006-03-13 20:29:49 +05:00
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
void SMDS_MeshElement::setIsMarked( bool is ) const
|
2006-03-13 20:29:49 +05:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
const_cast<SMDS_ElementChunk*>( myHolder )->SetIsMarked( this, is );
|
2006-03-13 20:29:49 +05:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Check if this element is marked
|
|
|
|
*/
|
|
|
|
//================================================================================
|
|
|
|
|
|
|
|
bool SMDS_MeshElement::isMarked() const
|
2006-03-13 20:29:49 +05:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
return myHolder->IsMarked( this );
|
2006-03-13 20:29:49 +05:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Store VTK ID
|
|
|
|
*/
|
|
|
|
//================================================================================
|
|
|
|
|
|
|
|
void SMDS_MeshElement::setVtkID( const int vtkID )
|
2006-03-13 20:29:49 +05:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
myHolder->SetVTKID( this, vtkID );
|
2006-03-13 20:29:49 +05:00
|
|
|
}
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
|
|
|
* \brief Return the mesh this element belongs to
|
|
|
|
*/
|
|
|
|
//================================================================================
|
|
|
|
|
|
|
|
SMDS_Mesh* SMDS_MeshElement::GetMesh() const
|
2006-03-13 20:29:49 +05:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
return const_cast<SMDS_ElementChunk*>( myHolder )->GetMesh();
|
2006-03-13 20:29:49 +05:00
|
|
|
}
|
2006-05-06 14:51:48 +06:00
|
|
|
|
2012-08-09 16:03:55 +06:00
|
|
|
//================================================================================
|
|
|
|
/*!
|
2017-12-22 16:14:24 +05:00
|
|
|
* \brief Return a SMDS_UnstructuredGrid
|
2012-08-09 16:03:55 +06:00
|
|
|
*/
|
|
|
|
//================================================================================
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
SMDS_UnstructuredGrid* SMDS_MeshElement::getGrid() const
|
2012-08-09 16:03:55 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
return const_cast<SMDS_ElementChunk*>( myHolder )->GetMesh()->GetGrid();
|
2012-08-09 16:03:55 +06:00
|
|
|
}
|
|
|
|
|
2006-05-06 14:51:48 +06:00
|
|
|
//================================================================================
|
2016-11-09 20:59:43 +05:00
|
|
|
/*!
|
2017-12-22 16:14:24 +05:00
|
|
|
* \brief Print self
|
2016-11-09 20:59:43 +05:00
|
|
|
*/
|
2006-05-06 14:51:48 +06:00
|
|
|
//================================================================================
|
|
|
|
|
2017-12-22 16:14:24 +05:00
|
|
|
void SMDS_MeshElement::Print(ostream & OS) const
|
2006-05-06 14:51:48 +06:00
|
|
|
{
|
2017-12-22 16:14:24 +05:00
|
|
|
OS << "dump of mesh element" << endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
ostream & operator <<(ostream & OS, const SMDS_MeshElement * e)
|
|
|
|
{
|
|
|
|
e->Print(OS);
|
|
|
|
return OS;
|
2006-05-06 14:51:48 +06:00
|
|
|
}
|