IOSS 2.0
Loading...
Searching...
No Matches
Ioss_Pyramid5.h
Go to the documentation of this file.
1// Copyright(C) 1999-2024 National Technology & Engineering Solutions
2// of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
3// NTESS, the U.S. Government retains certain rights in this software.
4//
5// See packages/seacas/LICENSE for details
6
7#pragma once
8
9#include "Ioss_CodeTypes.h" // for IntVector
10#include "Ioss_ElementPermutation.h" // for ElementPermutation
11#include "Ioss_ElementTopology.h" // for ElementTopology
12
13#include "ioss_export.h"
14
15namespace Ioss {
16 class IOSS_EXPORT Pyramid5 : public Ioss::ElementTopology
17 {
18
19 public:
20 static const char *name;
21
22 static void factory();
23
24 IOSS_NODISCARD ElementShape shape() const override { return ElementShape::PYRAMID; }
25 IOSS_NODISCARD int spatial_dimension() const override;
26 IOSS_NODISCARD int parametric_dimension() const override;
27 IOSS_NODISCARD bool is_element() const override { return true; }
28 IOSS_NODISCARD bool is_shell() const override { return false; }
29 IOSS_NODISCARD int order() const override;
30
31 IOSS_NODISCARD int number_corner_nodes() const override;
32 IOSS_NODISCARD int number_nodes() const override;
33 IOSS_NODISCARD int number_edges() const override;
34 IOSS_NODISCARD int number_faces() const override;
35
36 IOSS_NODISCARD int number_nodes_edge(int edge = 0) const override;
37 IOSS_NODISCARD int number_nodes_face(int face = 0) const override;
38 IOSS_NODISCARD int number_edges_face(int face = 0) const override;
39
40 IOSS_NODISCARD bool faces_similar() const override;
41
42 IOSS_NODISCARD Ioss::IntVector edge_connectivity(int edge_number) const override;
43 IOSS_NODISCARD Ioss::IntVector face_connectivity(int face_number) const override;
44 IOSS_NODISCARD Ioss::IntVector element_connectivity() const override;
45
46 IOSS_NODISCARD Ioss::IntVector face_edge_connectivity(int face_number) const override;
47
48 IOSS_NODISCARD Ioss::ElementTopology *face_type(int face_number = 0) const override;
49 IOSS_NODISCARD Ioss::ElementTopology *edge_type(int edge_number = 0) const override;
50
51 protected:
52 Pyramid5();
53 };
54} // namespace Ioss
#define IOSS_NODISCARD
Definition Ioss_CodeTypes.h:55
Represents an element topology.
Definition Ioss_ElementTopology.h:68
Definition Ioss_Pyramid5.h:17
IOSS_NODISCARD bool is_element() const override
Definition Ioss_Pyramid5.h:27
IOSS_NODISCARD ElementShape shape() const override
Definition Ioss_Pyramid5.h:24
IOSS_NODISCARD bool is_shell() const override
Definition Ioss_Pyramid5.h:28
static const char * name
Definition Ioss_Pyramid5.h:20
The main namespace for the Ioss library.
Definition Ioad_DatabaseIO.C:40
ElementShape
Definition Ioss_ElementTopology.h:24
std::vector< int > IntVector
Definition Ioss_CodeTypes.h:21