Newer
Older
Norihiro Watanabe
committed
/**
* \copyright
* Copyright (c) 2012-2016, OpenGeoSys Community (http://www.opengeosys.org)
Norihiro Watanabe
committed
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*
*/
#ifndef PYRAMIDRULE5_H_
#define PYRAMIDRULE5_H_
#include "MeshLib/MeshEnums.h"
#include "Element.h"
#include "EdgeReturn.h"
#include "CellRule.h"
Norihiro Watanabe
committed
namespace MeshLib
{
/**
* This class represents a 3d pyramid element. The following sketch shows the node and edge numbering.
* @anchor Pyramid5NodeAndEdgeNumbering
Norihiro Watanabe
committed
* @code
*
* 4
* //|\
* // | \
* 7// | \6
* // |5 \
* // | \
* 3/.... |.....2
* ./ | 2 /
* ./4 | /
* 3./ | /1
* ./ | /
* ./ |/
* 0------------1
* 0
* @endcode
*/
class PyramidRule5 : public CellRule
Norihiro Watanabe
committed
{
public:
/// Constant: The number of base nodes for this element
static const unsigned n_base_nodes = 5u;
Norihiro Watanabe
committed
/// Constant: The number of all nodes for this element
static const unsigned n_all_nodes = 5u;
Norihiro Watanabe
committed
/// Constant: The geometric type of the element
static const MeshElemType mesh_elem_type = MeshElemType::PYRAMID;
Norihiro Watanabe
committed
/// Constant: The FEM type of the element
static const CellType cell_type = CellType::PYRAMID5;
Norihiro Watanabe
committed
/// Constant: The number of faces
static const unsigned n_faces = 5;
Norihiro Watanabe
committed
/// Constant: The number of edges
static const unsigned n_edges = 8;
Norihiro Watanabe
committed
/// Constant: The number of neighbors
static const unsigned n_neighbors = 5;
Norihiro Watanabe
committed
/// Constant: Local node index table for faces
static const unsigned face_nodes[5][4];
Norihiro Watanabe
committed
/// Constant: Local node index table for edge
static const unsigned edge_nodes[8][2];
Norihiro Watanabe
committed
/// Constant: Table for the number of nodes for each face
static const unsigned n_face_nodes[5];
Norihiro Watanabe
committed
/// Returns the i-th edge of the element.
typedef LinearEdgeReturn EdgeReturn;
Norihiro Watanabe
committed
/// Returns the i-th face of the element.
static const Element* getFace(const Element* e, unsigned i);
Norihiro Watanabe
committed
* \copydoc MeshLib::Element::isPntInElement()
* @param nodes the nodes of the element.
static bool isPntInElement(Node const* const* nodes,
MathLib::Point3d const& pnt, double eps);
Norihiro Watanabe
committed
/**
* Tests if the element is geometrically valid.
*/
static ElementErrorCode validate(const Element* e);
Norihiro Watanabe
committed
/// Returns the ID of a face given an array of nodes.
static unsigned identifyFace(Node const* const*, Node* nodes[3]);
Norihiro Watanabe
committed
/// Calculates the volume of a convex hexahedron by partitioning it into six tetrahedra.
static double computeVolume(Node const* const* _nodes);
Norihiro Watanabe
committed
}; /* class */
} /* namespace */
#endif /* PYRAMIDRULE5_H_ */