suanPan
Loading...
Searching...
No Matches
Element.h
Go to the documentation of this file.
1/*******************************************************************************
2 * Copyright (C) 2017-2023 Theodore Chang
3 *
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
16 ******************************************************************************/
28#ifndef ELEMENT_H
29#define ELEMENT_H
30
31#include <Element/ElementBase.h>
32
33enum class MaterialType : unsigned;
34enum class SectionType : unsigned;
35
37 const uvec node_encoding; // node encoding
38 const uvec material_tag; // material tags
39 const uvec section_tag; // section tags
40
41 const bool nlgeom = false; // nonlinear geometry switch
42
43 bool update_mass = true; // flag to indicate if update matrix
44 bool update_damping = true; // flag to indicate if update matrix
45 bool update_stiffness = true; // flag to indicate if update matrix
46 bool update_geometry = true; // flag to indicate if update matrix
47
48 uvec dof_encoding; // DoF encoding vector
49
50 mat initial_mass{}; // mass matrix
51 mat initial_damping{}; // damping matrix
52 mat initial_stiffness{}; // stiffness matrix
53 mat initial_geometry{}; // geometry matrix
54
55 mat trial_mass{}; // mass matrix
56 mat trial_damping{}; // damping matrix
57 mat trial_stiffness{}; // stiffness matrix
58 mat trial_geometry{}; // geometry matrix
59
60 mat current_mass{}; // mass matrix
61 mat current_damping{}; // damping matrix
62 mat current_stiffness{}; // stiffness matrix
63 mat current_geometry{}; // geometry matrix
64
65 vec trial_resistance{}; // resistance vector
66 vec current_resistance{}; // resistance vector
67 vec trial_damping_force{}; // damping force
68 vec current_damping_force{}; // damping force
69 vec trial_inertial_force{}; // inertial force
70 vec current_inertial_force{}; // inertial force
71
76
78 mat traction{};
79
80 mat stiffness_container{}; // universal container to accommodate matrix based on modified stiffness matrix
81 mat mass_container{}; // universal container to accommodate matrix based on modified mass matrix
82
83 double strain_energy = 0.;
84 double kinetic_energy = 0.;
85 double viscous_energy = 0.;
87 vec momentum{};
88
89 const double characteristic_length = 1.;
90};
91
92class Element : protected DataElement, public ElementBase {
93 const unsigned num_node; // number of nodes
94 const unsigned num_dof; // number of DoFs
95 const unsigned num_size = num_dof * num_node; // number of size
96
97 const bool initialized = false;
98 const bool symmetric = false;
99 const bool use_group = false;
100 const unsigned use_other = 0;
101
102 const MaterialType mat_type;
103 const SectionType sec_type;
104
105 const std::vector<DOF> dof_identifier;
106
107 std::vector<MappingDOF> dof_mapping;
108
109 friend void ConstantMass(DataElement*);
110 friend void ConstantDamping(DataElement*);
111 friend void ConstantStiffness(DataElement*);
112 friend void ConstantGeometry(DataElement*);
113
114 void update_strain_energy() override;
115 void update_kinetic_energy() override;
116 void update_viscous_energy() override;
117 void update_complementary_energy() override;
118 void update_momentum() override;
119
120protected:
121 std::vector<weak_ptr<Node>> node_ptr; // node pointers
122
123 [[nodiscard]] mat get_coordinate(unsigned) const override;
124
125 [[nodiscard]] vec get_incre_displacement() const override;
126 [[nodiscard]] vec get_incre_velocity() const override;
127 [[nodiscard]] vec get_incre_acceleration() const override;
128 [[nodiscard]] vec get_trial_displacement() const override;
129 [[nodiscard]] vec get_trial_velocity() const override;
130 [[nodiscard]] vec get_trial_acceleration() const override;
131 [[nodiscard]] vec get_current_displacement() const override;
132 [[nodiscard]] vec get_current_velocity() const override;
133 [[nodiscard]] vec get_current_acceleration() const override;
134
135 [[nodiscard]] vec get_node_incre_resistance() const override;
136 [[nodiscard]] vec get_node_trial_resistance() const override;
137 [[nodiscard]] vec get_node_current_resistance() const override;
138
139 [[nodiscard]] std::vector<shared_ptr<Material>> get_material(const shared_ptr<DomainBase>&) const override;
140 [[nodiscard]] std::vector<shared_ptr<Section>> get_section(const shared_ptr<DomainBase>&) const override;
141
142public:
143 Element(unsigned, // tag
144 unsigned, // number of nodes
145 unsigned, // number of dofs
146 uvec&&, // node encoding
147 std::vector<DOF>&& // dof identifier
148 );
149 Element(unsigned, // tag
150 unsigned, // number of nodes
151 unsigned, // number of dofs
152 uvec&&, // node encoding
153 uvec&&, // material tags
154 bool, // nonlinear geometry switch
155 MaterialType, // material type for internal check
156 std::vector<DOF>&& // dof identifier
157 );
158 Element(unsigned, // tag
159 unsigned, // number of nodes
160 unsigned, // number of dofs
161 uvec&&, // node encoding
162 uvec&&, // section tags
163 bool, // nonlinear geometry switch
164 SectionType, // section type for internal check
165 std::vector<DOF>&& // dof identifier
166 );
167 Element(unsigned, // tag
168 unsigned, // number of dofs
169 uvec&& // group encoding
170 );
171 Element(unsigned, // tag
172 unsigned, // number of dofs
173 unsigned, // other element tag
174 unsigned // node tag
175 );
176 Element(const Element&) = delete; // copy forbidden
177 Element(Element&&) = delete; // move forbidden
178 Element& operator=(const Element&) = delete; // assign forbidden
179 Element& operator=(Element&&) = delete; // assign forbidden
180
181 ~Element() override = default;
182
183 int initialize_base(const shared_ptr<DomainBase>&) final;
184
185 void set_initialized(bool) const override;
186 void set_symmetric(bool) const override;
187 [[nodiscard]] bool is_initialized() const override;
188 [[nodiscard]] bool is_symmetric() const override;
189 [[nodiscard]] bool is_nlgeom() const override;
190
191 void update_dof_encoding() override;
192
193 [[nodiscard]] bool if_update_mass() const override;
194 [[nodiscard]] bool if_update_damping() const override;
195 [[nodiscard]] bool if_update_stiffness() const override;
196 [[nodiscard]] bool if_update_geometry() const override;
197
198 [[nodiscard]] const uvec& get_dof_encoding() const override;
199 [[nodiscard]] const uvec& get_node_encoding() const override;
200
201 [[nodiscard]] const std::vector<MappingDOF>& get_dof_mapping() const override;
202
203 [[nodiscard]] const uvec& get_material_tag() const override;
204 [[nodiscard]] const uvec& get_section_tag() const override;
205
206 [[nodiscard]] unsigned get_dof_number() const override;
207 [[nodiscard]] unsigned get_node_number() const override;
208 [[nodiscard]] unsigned get_total_number() const override;
209
210 void clear_node_ptr() override;
211 [[nodiscard]] const std::vector<weak_ptr<Node>>& get_node_ptr() const override;
212
213 [[nodiscard]] const vec& get_trial_resistance() const override;
214 [[nodiscard]] const vec& get_current_resistance() const override;
215 [[nodiscard]] const vec& get_trial_damping_force() const override;
216 [[nodiscard]] const vec& get_current_damping_force() const override;
217 [[nodiscard]] const vec& get_trial_inertial_force() override;
218 [[nodiscard]] const vec& get_current_inertial_force() override;
219
220 [[nodiscard]] const vec& get_trial_body_force() const override;
221 [[nodiscard]] const vec& get_current_body_force() const override;
222 [[nodiscard]] const vec& get_trial_traction() const override;
223 [[nodiscard]] const vec& get_current_traction() const override;
224
225 [[nodiscard]] const mat& get_trial_mass() const override;
226 [[nodiscard]] const mat& get_trial_damping() const override;
227 [[nodiscard]] const mat& get_trial_stiffness() const override;
228 [[nodiscard]] const mat& get_trial_geometry() const override;
229 [[nodiscard]] const mat& get_trial_secant() const override;
230
231 [[nodiscard]] const mat& get_current_mass() const override;
232 [[nodiscard]] const mat& get_current_damping() const override;
233 [[nodiscard]] const mat& get_current_stiffness() const override;
234 [[nodiscard]] const mat& get_current_geometry() const override;
235 [[nodiscard]] const mat& get_current_secant() const override;
236
237 [[nodiscard]] const mat& get_initial_mass() const override;
238 [[nodiscard]] const mat& get_initial_damping() const override;
239 [[nodiscard]] const mat& get_initial_stiffness() const override;
240 [[nodiscard]] const mat& get_initial_geometry() const override;
241 [[nodiscard]] const mat& get_initial_secant() const override;
242
243 [[nodiscard]] const mat& get_mass_container() const override;
244 [[nodiscard]] const mat& get_stiffness_container() const override;
245
246 int clear_status() override = 0;
247 int commit_status() override = 0;
248 int reset_status() override = 0;
249
250 const vec& update_body_force(const vec&) override;
251 const vec& update_traction(const vec&) override;
252
253 std::vector<vec> record(OutputType) override;
254
255 [[nodiscard]] double get_strain_energy() const override;
256 [[nodiscard]] double get_complementary_energy() const override;
257 [[nodiscard]] double get_kinetic_energy() const override;
258 [[nodiscard]] double get_viscous_energy() const override;
259 [[nodiscard]] const vec& get_momentum() const override;
260 [[nodiscard]] double get_momentum_component(DOF) const override;
261
262 [[nodiscard]] double get_characteristic_length() const override;
263
264 [[nodiscard]] mat compute_shape_function(const mat&, unsigned) const override;
265};
266
267#endif
268
OutputType
Definition: OutputType.h:21
A ElementBase class.
Definition: ElementBase.h:42
friend mat get_coordinate(const ElementBase *, unsigned)
Definition: Element.cpp:606
A Element class.
Definition: Element.h:92
const mat & get_initial_damping() const override
Definition: Element.cpp:482
friend void ConstantGeometry(DataElement *)
Definition: Element.cpp:600
std::vector< shared_ptr< Section > > get_section(const shared_ptr< DomainBase > &) const override
Definition: Element.cpp:244
const vec & get_current_resistance() const override
Definition: Element.cpp:436
Element(const Element &)=delete
void update_dof_encoding() override
Definition: Element.cpp:390
std::vector< shared_ptr< Material > > get_material(const shared_ptr< DomainBase > &) const override
Definition: Element.cpp:238
unsigned get_dof_number() const override
Definition: Element.cpp:424
const mat & get_initial_mass() const override
Definition: Element.cpp:480
unsigned get_node_number() const override
Definition: Element.cpp:426
const uvec & get_node_encoding() const override
Definition: Element.cpp:416
const vec & get_current_traction() const override
Definition: Element.cpp:458
const std::vector< weak_ptr< Node > > & get_node_ptr() const override
Definition: Element.cpp:432
const uvec & get_dof_encoding() const override
Definition: Element.cpp:414
const vec & get_current_inertial_force() override
Definition: Element.cpp:447
void clear_node_ptr() override
Definition: Element.cpp:430
~Element() override=default
const vec & get_trial_body_force() const override
Definition: Element.cpp:452
vec get_node_current_resistance() const override
Definition: Element.cpp:225
const mat & get_trial_stiffness() const override
Definition: Element.cpp:464
const vec & get_current_damping_force() const override
Definition: Element.cpp:440
friend void ConstantDamping(DataElement *)
Definition: Element.cpp:588
vec get_current_velocity() const override
Definition: Element.cpp:173
vec get_trial_velocity() const override
Definition: Element.cpp:134
bool if_update_damping() const override
Definition: Element.cpp:408
const mat & get_stiffness_container() const override
Definition: Element.cpp:492
vec get_current_acceleration() const override
Definition: Element.cpp:186
const mat & get_initial_stiffness() const override
Definition: Element.cpp:484
const vec & get_current_body_force() const override
Definition: Element.cpp:454
double get_characteristic_length() const override
Definition: Element.cpp:578
const vec & get_trial_inertial_force() override
Definition: Element.cpp:442
double get_momentum_component(DOF) const override
Definition: Element.cpp:567
const mat & get_current_damping() const override
Definition: Element.cpp:472
vec get_incre_acceleration() const override
Definition: Element.cpp:108
bool is_symmetric() const override
Definition: Element.cpp:386
bool if_update_stiffness() const override
Definition: Element.cpp:410
int initialize_base(const shared_ptr< DomainBase > &) final
Definition: Element.cpp:291
const std::vector< MappingDOF > & get_dof_mapping() const override
Definition: Element.cpp:418
const vec & get_momentum() const override
Definition: Element.cpp:565
const vec & get_trial_damping_force() const override
Definition: Element.cpp:438
vec get_current_displacement() const override
Definition: Element.cpp:160
friend void ConstantMass(DataElement *)
Definition: Element.cpp:582
std::vector< weak_ptr< Node > > node_ptr
Definition: Element.h:121
const mat & get_initial_secant() const override
Definition: Element.cpp:488
const mat & get_current_geometry() const override
Definition: Element.cpp:476
bool is_nlgeom() const override
Definition: Element.cpp:388
const mat & get_current_mass() const override
Definition: Element.cpp:470
vec get_trial_acceleration() const override
Definition: Element.cpp:147
unsigned get_total_number() const override
Definition: Element.cpp:428
const mat & get_trial_geometry() const override
Definition: Element.cpp:466
int reset_status() override=0
Definition: Element.cpp:539
Element & operator=(Element &&)=delete
Element(Element &&)=delete
vec get_trial_displacement() const override
Definition: Element.cpp:121
double get_viscous_energy() const override
Definition: Element.cpp:563
friend void ConstantStiffness(DataElement *)
Definition: Element.cpp:594
Element & operator=(const Element &)=delete
const mat & get_trial_secant() const override
Definition: Element.cpp:468
vec get_incre_velocity() const override
Definition: Element.cpp:95
const vec & update_body_force(const vec &) override
Definition: Element.cpp:551
int clear_status() override=0
Definition: Element.cpp:494
double get_strain_energy() const override
Definition: Element.cpp:557
bool if_update_mass() const override
Definition: Element.cpp:406
void set_initialized(bool) const override
Definition: Element.cpp:380
const vec & get_trial_resistance() const override
Definition: Element.cpp:434
vec get_node_trial_resistance() const override
Definition: Element.cpp:212
bool is_initialized() const override
Definition: Element.cpp:384
const mat & get_trial_mass() const override
Definition: Element.cpp:460
const uvec & get_material_tag() const override
Definition: Element.cpp:420
vec get_incre_displacement() const override
Definition: Element.cpp:82
const mat & get_trial_damping() const override
Definition: Element.cpp:462
double get_complementary_energy() const override
Definition: Element.cpp:559
vec get_node_incre_resistance() const override
Definition: Element.cpp:199
const vec & get_trial_traction() const override
Definition: Element.cpp:456
const mat & get_initial_geometry() const override
Definition: Element.cpp:486
const mat & get_current_stiffness() const override
Definition: Element.cpp:474
int commit_status() override=0
Definition: Element.cpp:521
const mat & get_current_secant() const override
Definition: Element.cpp:478
mat compute_shape_function(const mat &, unsigned) const override
Definition: Element.cpp:580
std::vector< vec > record(OutputType) override
Definition: Element.cpp:555
double get_kinetic_energy() const override
Definition: Element.cpp:561
bool if_update_geometry() const override
Definition: Element.cpp:412
const mat & get_mass_container() const override
Definition: Element.cpp:490
const uvec & get_section_tag() const override
Definition: Element.cpp:422
void set_symmetric(bool) const override
Definition: Element.cpp:382
const vec & update_traction(const vec &) override
Definition: Element.cpp:553
MaterialType
Definition: Material.h:34
DOF
Definition: DOF.h:29
SectionType
Definition: Section.h:34
Definition: Element.h:36
vec trial_traction
Definition: Element.h:74
vec current_damping_force
Definition: Element.h:68
uvec dof_encoding
Definition: Element.h:48
bool update_stiffness
Definition: Element.h:45
mat traction
Definition: Element.h:78
mat trial_stiffness
Definition: Element.h:57
bool update_geometry
Definition: Element.h:46
vec trial_damping_force
Definition: Element.h:67
vec current_body_force
Definition: Element.h:73
mat trial_damping
Definition: Element.h:56
const uvec section_tag
Definition: Element.h:39
mat trial_mass
Definition: Element.h:55
mat initial_damping
Definition: Element.h:51
bool update_mass
Definition: Element.h:43
double complementary_energy
Definition: Element.h:86
double viscous_energy
Definition: Element.h:85
vec current_resistance
Definition: Element.h:66
bool update_damping
Definition: Element.h:44
mat stiffness_container
Definition: Element.h:80
vec momentum
Definition: Element.h:87
vec trial_body_force
Definition: Element.h:72
mat initial_stiffness
Definition: Element.h:52
const double characteristic_length
Definition: Element.h:89
const bool nlgeom
Definition: Element.h:41
vec current_inertial_force
Definition: Element.h:70
mat mass_container
Definition: Element.h:81
mat current_damping
Definition: Element.h:61
const uvec node_encoding
Definition: Element.h:37
double strain_energy
Definition: Element.h:83
mat body_force
Definition: Element.h:77
const uvec material_tag
Definition: Element.h:38
mat initial_geometry
Definition: Element.h:53
vec trial_inertial_force
Definition: Element.h:69
mat trial_geometry
Definition: Element.h:58
mat current_mass
Definition: Element.h:60
mat current_geometry
Definition: Element.h:63
mat current_stiffness
Definition: Element.h:62
vec trial_resistance
Definition: Element.h:65
vec current_traction
Definition: Element.h:75
mat initial_mass
Definition: Element.h:50
double kinetic_energy
Definition: Element.h:84