IOSS 2.0
Loading...
Searching...
No Matches
Ioss_Shell9.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_export.h"
10
11#include "Ioss_CodeTypes.h" // for IntVector
12#include "Ioss_ElementTopology.h" // for ElementTopology
13
14namespace Ioss {
15 class IOSS_EXPORT Shell9 final : public Ioss::ElementTopology
16 {
17
18 public:
19 static const char *name;
20
21 static void factory();
22
24 IOSS_NODISCARD int spatial_dimension() const override;
25 IOSS_NODISCARD int parametric_dimension() const override;
26 IOSS_NODISCARD bool is_element() const override { return true; }
27 IOSS_NODISCARD bool is_shell() const override { return true; }
28 IOSS_NODISCARD int order() const override;
29
30 IOSS_NODISCARD int number_corner_nodes() const override;
31 IOSS_NODISCARD int number_nodes() const override;
32 IOSS_NODISCARD int number_edges() const override;
33 IOSS_NODISCARD int number_faces() const override;
34
35 IOSS_NODISCARD int number_nodes_edge(int edge = 0) const override;
36 IOSS_NODISCARD int number_nodes_face(int face = 0) const override;
37 IOSS_NODISCARD int number_edges_face(int face = 0) const override;
38
39 IOSS_NODISCARD Ioss::IntVector edge_connectivity(int edge_number) const override;
40 IOSS_NODISCARD Ioss::IntVector face_connectivity(int face_number) const override;
41 IOSS_NODISCARD Ioss::IntVector element_connectivity() const override;
42
43 IOSS_NODISCARD Ioss::IntVector face_edge_connectivity(int face_number) const override;
44
45 IOSS_NODISCARD Ioss::ElementTopology *face_type(int face_number = 0) const override;
46 IOSS_NODISCARD Ioss::ElementTopology *edge_type(int edge_number = 0) const override;
47
48 protected:
49 Shell9();
50 };
51} // namespace Ioss
#define IOSS_NODISCARD
Definition Ioss_CodeTypes.h:57
Represents an element topology.
Definition Ioss_ElementTopology.h:73
Definition Ioss_Shell9.h:16
static void factory()
Definition Ioss_Shell9.C:65
static const char * name
Definition Ioss_Shell9.h:19
IOSS_NODISCARD ElementShape shape() const override
Definition Ioss_Shell9.h:23
IOSS_NODISCARD bool is_shell() const override
Definition Ioss_Shell9.h:27
Shell9()
Definition Ioss_Shell9.C:71
IOSS_NODISCARD bool is_element() const override
Definition Ioss_Shell9.h:26
The main namespace for the Ioss library.
Definition Ioad_DatabaseIO.C:40
ElementShape
Definition Ioss_ElementTopology.h:24
@ QUAD
Definition Ioss_ElementTopology.h:31
std::vector< int > IntVector
Definition Ioss_CodeTypes.h:21