SheafSystem  0.0.0.0
quad_connectivity.h
1 
2 //
3 // Copyright (c) 2014 Limit Point Systems, Inc.
4 //
5 // Licensed under the Apache License, Version 2.0 (the "License");
6 // you may not use this file except in compliance with the License.
7 // You may obtain a copy of the License at
8 //
9 // http://www.apache.org/licenses/LICENSE-2.0
10 //
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
16 //
17 
18 // Interface for class quad_connectivity
19 
20 #ifndef QUAD_CONNECTIVITY_H
21 #define QUAD_CONNECTIVITY_H
22 
23 #ifndef SHEAF_DLL_SPEC_H
24 #include "SheafSystem/sheaf_dll_spec.h"
25 #endif
26 
27 #ifndef BASE_CONNECTIVITY_H
28 #include "SheafSystem/block_connectivity.h"
29 #endif
30 
31 namespace fiber_bundle
32 {
33 
34  using namespace sheaf;
35 
36 
40 class SHEAF_DLL_SPEC quad_connectivity : public block_connectivity
41 {
42 
43 public:
44  // ===========================================================
45  // @name QUAD_CONNECTIVITY FACET
46  // ===========================================================
48 
54 
58  quad_connectivity(const quad_connectivity& xother);
59 
67  quad_connectivity(const pod_index_type* xnode_ids,
68  size_type xnode_id_ct,
69  size_type xnode_ct);
70 
77  quad_connectivity(size_type xi_size, size_type xj_size, pod_index_type xstart_id = 0);
78 
82  virtual ~quad_connectivity();
83 
84 
90  enum static_const_int {NODES_PER_ELEMENT = 4};
91 
92 protected:
93 
97  void create_connectivity(size_type xi_size,
98  size_type xj_size,
99  pod_index_type xstart_id);
100 
101 
102 private:
103 
105 
106  // ===========================================================
108  // ===========================================================
110 
111 public:
112 
116  virtual cell_type element_type() const;
117 
118 protected:
119 
120 private:
121 
123 
124  // ===========================================================
125  // ANY FACET
126  // ===========================================================
127 
132  virtual quad_connectivity* clone() const;
133 
134 // ///
135 // /// Class invariant.
136 // ///
137  virtual bool invariant() const;
138 
139 // ///
140 // /// Conformance test; true if other conforms to this
141 // ///
142  virtual bool is_ancestor_of(const any* other) const;
143 
144 };
145 
146 } // namespace fiber_bundle
147 
148 #endif // ifndef QUAD_CONNECTIVITY_H
Zone to node connectivity relation for a block of zones of a given type.
Abstract base class with useful features for all objects.
Definition: any.h:39
unsigned long size_type
An unsigned integral type used to represent sizes and capacities.
Definition: sheaf.h:52
static_const_int
Static const integral data members.
Nodal connectivity for a block containing zones of type quad.
int_type pod_index_type
The plain old data index type.
Definition: pod_types.h:49
Namespace for the sheaves component of the sheaf system.
Namespace for the fiber_bundles component of the sheaf system.