IOSS  2.0
Ioss_SideSet.h
Go to the documentation of this file.
1 // Copyright(C) 1999-2017 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 // Redistribution and use in source and binary forms, with or without
6 // modification, are permitted provided that the following conditions are
7 // met:
8 //
9 // * Redistributions of source code must retain the above copyright
10 // notice, this list of conditions and the following disclaimer.
11 //
12 // * Redistributions in binary form must reproduce the above
13 // copyright notice, this list of conditions and the following
14 // disclaimer in the documentation and/or other materials provided
15 // with the distribution.
16 //
17 // * Neither the name of NTESS nor the names of its
18 // contributors may be used to endorse or promote products derived
19 // from this software without specific prior written permission.
20 //
21 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 
33 #ifndef IOSS_Ioss_SideSet_h
34 #define IOSS_Ioss_SideSet_h
35 
36 #include "Ioss_EntityType.h" // for EntityType, etc
37 #include <Ioss_GroupingEntity.h> // for GroupingEntity
38 #include <Ioss_Property.h> // for Property
39 #include <cstddef> // for size_t
40 #include <cstdint> // for int64_t
41 #include <string> // for string
42 #include <vector> // for vector
43 namespace Ioss {
44  class DatabaseIO;
45 } // namespace Ioss
46 namespace Ioss {
47  class Field;
48 } // namespace Ioss
49 namespace Ioss {
50  class SideBlock;
51 } // namespace Ioss
52 
53 namespace Ioss {
54 
55  using SideBlockContainer = std::vector<SideBlock *>;
56 
57  /** \brief A collection of element sides.
58  */
59  class SideSet : public GroupingEntity
60  {
61  public:
62  SideSet(DatabaseIO *io_database, const std::string &my_name);
63  ~SideSet() override;
64 
65  std::string type_string() const override { return "SideSet"; }
66  std::string short_type_string() const override { return "surface"; }
67  EntityType type() const override { return SIDESET; }
68 
69  bool add(SideBlock *side_block);
70  const SideBlockContainer &get_side_blocks() const;
71  SideBlock * get_side_block(const std::string &my_name) const;
72  size_t side_block_count() const { return sideBlocks.size(); }
73 
74  size_t block_count() const { return sideBlocks.size(); }
75  SideBlock *get_block(size_t which) const;
76 
77  void block_membership(std::vector<std::string> &block_members) override;
78 
79  // Handle implicit properties -- These are calcuated from data stored
80  // in the grouping entity instead of having an explicit value assigned.
81  // An example would be 'element_block_count' for a region.
82  Property get_implicit_property(const std::string &my_name) const override;
83 
84  int max_parametric_dimension() const;
85 
86  protected:
87  int64_t internal_get_field_data(const Field &field, void *data,
88  size_t data_size) const override;
89 
90  int64_t internal_put_field_data(const Field &field, void *data,
91  size_t data_size) const override;
92 
93  private:
95  std::vector<std::string> blockMembership; // What element blocks do the
96  // elements in this sideset belong to.
97  };
98 } // namespace Ioss
99 #endif
A named value that has a known type.
Definition: Ioss_Property.h:47
~SideSet() override
Definition: Ioss_SideSet.C:63
Definition: Ioss_EntityType.h:48
size_t side_block_count() const
Definition: Ioss_SideSet.h:72
The main namespace for the Ioss library.
Definition: Iocgns_DatabaseIO.h:50
An input or output Database.
Definition: Ioss_DatabaseIO.h:80
std::string short_type_string() const override
Get a short name of the particular type of entity.
Definition: Ioss_SideSet.h:66
EntityType type() const override
Get the EntityType, which indicates the particular type of GroupingEntity this is.
Definition: Ioss_SideSet.h:67
int64_t internal_put_field_data(const Field &field, void *data, size_t data_size) const override
Definition: Ioss_SideSet.C:113
Base class for all &#39;grouping&#39; entities. The following derived classes are typical: ...
Definition: Ioss_GroupingEntity.h:93
int64_t internal_get_field_data(const Field &field, void *data, size_t data_size) const override
Definition: Ioss_SideSet.C:107
A collection of element sides having the same topology.
Definition: Ioss_SideBlock.h:61
std::vector< SideBlock * > SideBlockContainer
Definition: Ioss_SideSet.h:55
void block_membership(std::vector< std::string > &block_members) override
Get list of blocks that the entities in this GroupingEntity "touch".
Definition: Ioss_SideSet.C:151
int max_parametric_dimension() const
Definition: Ioss_SideSet.C:131
SideBlockContainer sideBlocks
Definition: Ioss_SideSet.h:94
bool add(SideBlock *side_block)
Definition: Ioss_SideSet.C:99
SideBlock * get_block(size_t which) const
Definition: Ioss_SideSet.C:76
SideBlock * get_side_block(const std::string &my_name) const
Definition: Ioss_SideSet.C:86
size_t block_count() const
Definition: Ioss_SideSet.h:74
std::vector< std::string > blockMembership
Definition: Ioss_SideSet.h:95
SideSet(DatabaseIO *io_database, const std::string &my_name)
Create a side set with no members initially.
Definition: Ioss_SideSet.C:56
const SideBlockContainer & get_side_blocks() const
Definition: Ioss_SideSet.C:74
Property get_implicit_property(const std::string &my_name) const override
Calculate and get an implicit property.
Definition: Ioss_SideSet.C:119
A collection of element sides.
Definition: Ioss_SideSet.h:59
Holds metadata for bulk data associated with a GroupingEntity.
Definition: Ioss_Field.h:47
EntityType
The particular type of GroupingEntity.
Definition: Ioss_EntityType.h:39
std::string type_string() const override
Get the name of the particular type of entity.
Definition: Ioss_SideSet.h:65
std::vector< char > data
Definition: Ioss_Utils.C:78