suanPan
🧮 An Open Source, Parallel and Heterogeneous Finite Element Analysis Framework
Loading...
Searching...
No Matches
Element.h
Go to the documentation of this file.
1/*******************************************************************************
2 * Copyright (C) 2017-2026 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/Distributed.h>
32#include <Element/ElementBase.h>
33
34enum class MaterialType : unsigned;
35enum class SectionType : unsigned;
36
37// struct StateElement {
38// mat mass{};
39// mat damping{};
40// mat stiffness{};
41// mat geometry{};
42//
43// vec resistance{};
44// vec damping_force{};
45// vec inertial_force{};
46//
47// vec body_force{};
48// vec traction{};
49// };
50
52 const uvec node_encoding; // node encoding
53 const uvec material_tag; // material tags
54 const uvec section_tag; // section tags
55
56 const bool nlgeom = false; // nonlinear geometry switch
57
58 bool update_mass = true; // flag to indicate if update matrix
59 bool update_viscous = true; // flag to indicate if update matrix
60 bool update_nonviscous = true; // flag to indicate if update matrix
61 bool update_stiffness = true; // flag to indicate if update matrix
62 bool update_geometry = true; // flag to indicate if update matrix
63
64 bool modify_mass = true; // flag to indicate if modify matrix
65 bool modify_viscous = true; // flag to indicate if modify matrix
66 bool modify_nonviscous = true; // flag to indicate if modify matrix
67
68 uvec dof_encoding{}; // DoF encoding vector
69
70 mat initial_mass{}; // mass matrix
71 mat initial_viscous{}; // viscous damping matrix
72 mat initial_nonviscous{}; // nonviscous damping matrix
73 mat initial_stiffness{}; // stiffness matrix
74 mat initial_geometry{}; // geometry matrix
75
76 mat trial_mass{}; // mass matrix
77 mat trial_viscous{}; // viscous damping matrix
78 mat trial_nonviscous{}; // nonviscous damping matrix
79 mat trial_stiffness{}; // stiffness matrix
80 mat trial_geometry{}; // geometry matrix
81
82 mat current_mass{}; // mass matrix
83 mat current_viscous{}; // viscous damping matrix
84 mat current_nonviscous{}; // nonviscous damping matrix
85 mat current_stiffness{}; // stiffness matrix
86 mat current_geometry{}; // geometry matrix
87
88 vec trial_resistance{}; // resistance vector
89 vec current_resistance{}; // resistance vector
90 vec trial_viscous_force{}; // viscous damping force
91 vec current_viscous_force{}; // viscous damping force
92 cx_mat trial_nonviscous_force{}; // nonviscous damping force
93 cx_mat current_nonviscous_force{}; // nonviscous damping force
94 vec trial_inertial_force{}; // inertial force
95 vec current_inertial_force{}; // inertial force
96
101
103 mat traction{};
104
105 mat stiffness_container{}; // universal container to accommodate matrix based on modified stiffness matrix
106 mat mass_container{}; // universal container to accommodate matrix based on modified mass matrix
107
108 double strain_energy = 0.;
109 double kinetic_energy = 0.;
110 double viscous_energy = 0.;
111 double nonviscous_energy = 0.;
113 vec momentum{};
114
115 const double characteristic_length = 1.;
116};
117
118class Element : protected DataElement, public ElementBase, public Distributed {
119 const unsigned num_node; // number of nodes
120 const unsigned num_dof; // number of DoFs
121 const unsigned num_size = num_dof * num_node; // number of size
122
123 const bool initialized = false;
124 const bool symmetric = false;
125 const bool use_group = false;
126 const unsigned use_other = 0;
127
128 const MaterialType material_type;
129 const SectionType section_type;
130
131 const std::vector<Node::DOF> dof_identifier;
132
133 std::vector<MappingDOF> dof_mapping;
134
135 friend void ConstantMass(DataElement*);
136 friend void ConstantDamping(DataElement*);
137 friend void ConstantStiffness(DataElement*);
138 friend void ConstantGeometry(DataElement*);
139
140 void update_strain_energy() override;
141 void update_kinetic_energy() override;
142 void update_viscous_energy() override;
143 void update_nonviscous_energy() override;
144 void update_complementary_energy() override;
145 void update_momentum() override;
146
147 void validate() const;
148
149protected:
150 std::vector<std::weak_ptr<Node>> node_ptr; // node pointers
151
152 [[nodiscard]] vec get_node_incre_resistance() const override;
153 [[nodiscard]] vec get_node_trial_resistance() const override;
154 [[nodiscard]] vec get_node_current_resistance() const override;
155
156 [[nodiscard]] std::vector<shared_ptr<Material>> get_material(const shared_ptr<DomainBase>&) const override;
157 [[nodiscard]] std::vector<shared_ptr<Section>> get_section(const shared_ptr<DomainBase>&) const override;
158
159public:
160 Element(
161 unsigned, // tag
162 unsigned, // number of nodes
163 unsigned, // number of dofs
164 uvec&&, // node encoding
165 std::vector<Node::DOF>&& // dof identifier
166 );
167 Element(
168 unsigned, // tag
169 unsigned, // number of nodes
170 unsigned, // number of dofs
171 uvec&&, // node encoding
172 uvec&&, // material tags
173 bool, // nonlinear geometry switch
174 MaterialType, // material type for internal check
175 std::vector<Node::DOF>&& // dof identifier
176 );
177 Element(
178 unsigned, // tag
179 unsigned, // number of nodes
180 unsigned, // number of dofs
181 uvec&&, // node encoding
182 uvec&&, // section tags
183 bool, // nonlinear geometry switch
184 SectionType, // section type for internal check
185 std::vector<Node::DOF>&& // dof identifier
186 );
187 Element(
188 unsigned, // tag
189 unsigned, // number of dofs
190 uvec&&, // group encoding
191 std::vector<Node::DOF>&& // dof identifier
192 );
193 Element(
194 unsigned, // tag
195 unsigned, // number of dofs
196 unsigned, // other element tag
197 unsigned, // node tag
198 std::vector<Node::DOF>&& // dof identifier
199 );
200
201 int initialize_base(const shared_ptr<DomainBase>&) final;
202
203 void set_initialized(bool) const override;
204 void set_symmetric(bool) const override;
205 [[nodiscard]] bool is_initialized() const override;
206 [[nodiscard]] bool is_symmetric() const override;
207 [[nodiscard]] bool is_nlgeom() const override;
208
209 [[nodiscard]] Type type() const override;
210
211 void update_dof_encoding() override;
212
213 [[nodiscard]] bool if_update_mass() const override;
214 [[nodiscard]] bool if_update_viscous() const override;
215 [[nodiscard]] bool if_update_nonviscous() const override;
216 [[nodiscard]] bool if_update_stiffness() const override;
217 [[nodiscard]] bool if_update_geometry() const override;
218
219 [[nodiscard]] bool allow_modify_mass() const override;
220 [[nodiscard]] bool allow_modify_viscous() const override;
221 [[nodiscard]] bool allow_modify_nonviscous() const override;
222
223 [[nodiscard]] const uvec& get_dof_encoding() const override;
224 [[nodiscard]] const uvec& get_node_encoding() const override;
225
226 [[nodiscard]] const std::vector<Node::DOF>& get_dof_identifier() const override;
227 [[nodiscard]] const std::vector<MappingDOF>& get_dof_mapping() const override;
228
229 [[nodiscard]] bool validate_dof(const std::vector<Node::DOF>&) const override;
230 [[nodiscard]] uvec index_of(const std::vector<Node::DOF>&) const override;
231
232 [[nodiscard]] const uvec& get_material_tag() const override;
233 [[nodiscard]] const uvec& get_section_tag() const override;
234
235 [[nodiscard]] unsigned get_dof_number() const override;
236 [[nodiscard]] unsigned get_node_number() const override;
237 [[nodiscard]] unsigned get_total_number() const override;
238
239 void clear_node_ptr() override;
240 [[nodiscard]] const std::vector<std::weak_ptr<Node>>& get_node_ptr() const override;
241
242 [[nodiscard]] mat get_coordinate() const override;
243 [[nodiscard]] mat get_coordinate(unsigned) const override;
244
245 [[nodiscard]] vec get_incre_displacement() const override;
246 [[nodiscard]] vec get_incre_velocity() const override;
247 [[nodiscard]] vec get_incre_acceleration() const override;
248 [[nodiscard]] vec get_trial_displacement() const override;
249 [[nodiscard]] vec get_trial_velocity() const override;
250 [[nodiscard]] vec get_trial_acceleration() const override;
251 [[nodiscard]] vec get_current_displacement() const override;
252 [[nodiscard]] vec get_current_velocity() const override;
253 [[nodiscard]] vec get_current_acceleration() const override;
254
255 [[nodiscard]] const vec& get_trial_resistance() const override;
256 [[nodiscard]] const vec& get_current_resistance() const override;
257 [[nodiscard]] const vec& get_trial_damping_force() const override;
258 [[nodiscard]] const vec& get_current_damping_force() const override;
259 [[nodiscard]] const cx_mat& get_trial_nonviscous_force() const override;
260 [[nodiscard]] const cx_mat& get_current_nonviscous_force() const override;
261 [[nodiscard]] const vec& get_trial_inertial_force() override;
262 [[nodiscard]] const vec& get_current_inertial_force() override;
263
264 [[nodiscard]] const vec& get_trial_body_force() const override;
265 [[nodiscard]] const vec& get_current_body_force() const override;
266 [[nodiscard]] const vec& get_trial_traction() const override;
267 [[nodiscard]] const vec& get_current_traction() const override;
268
269 [[nodiscard]] const mat& get_trial_mass() const override;
270 [[nodiscard]] const mat& get_trial_viscous() const override;
271 [[nodiscard]] const mat& get_trial_nonviscous() const override;
272 [[nodiscard]] const mat& get_trial_stiffness() const override;
273 [[nodiscard]] const mat& get_trial_geometry() const override;
274 [[nodiscard]] const mat& get_trial_secant() const override;
275
276 [[nodiscard]] const mat& get_current_mass() const override;
277 [[nodiscard]] const mat& get_current_viscous() const override;
278 [[nodiscard]] const mat& get_current_nonviscous() const override;
279 [[nodiscard]] const mat& get_current_stiffness() const override;
280 [[nodiscard]] const mat& get_current_geometry() const override;
281 [[nodiscard]] const mat& get_current_secant() const override;
282
283 [[nodiscard]] const mat& get_initial_mass() const override;
284 [[nodiscard]] const mat& get_initial_viscous() const override;
285 [[nodiscard]] const mat& get_initial_nonviscous() const override;
286 [[nodiscard]] const mat& get_initial_stiffness() const override;
287 [[nodiscard]] const mat& get_initial_geometry() const override;
288 [[nodiscard]] const mat& get_initial_secant() const override;
289
290 [[nodiscard]] const mat& get_mass_container() const override;
291 [[nodiscard]] const mat& get_stiffness_container() const override;
292
293 int clear_status() override = 0;
294 int commit_status() override = 0;
295 int reset_status() override = 0;
296
297 const vec& update_body_force(const vec&) override;
298 const vec& update_traction(const vec&) override;
299
300 [[nodiscard]] std::vector<vec> record(OutputType) const override;
301
302 [[nodiscard]] double get_strain_energy() const override;
303 [[nodiscard]] double get_complementary_energy() const override;
304 [[nodiscard]] double get_kinetic_energy() const override;
305 [[nodiscard]] double get_viscous_energy() const override;
306 [[nodiscard]] double get_nonviscous_energy() const override;
307 [[nodiscard]] const vec& get_momentum() const override;
308
309 [[nodiscard]] double get_characteristic_length() const override;
310 [[nodiscard]] double get(Parameter) const override;
311
312 [[nodiscard]] mat compute_shape_function(const mat&, unsigned) const override;
313};
314
315#endif
316
OutputType
Definition OutputType.h:23
Definition Distributed.h:23
A ElementBase class.
Definition ElementBase.h:42
Parameter
Definition ElementBase.h:64
Type
Definition ElementBase.h:59
A Element class.
Definition Element.h:118
friend void ConstantGeometry(DataElement *)
Definition Element.cpp:44
std::vector< shared_ptr< Section > > get_section(const shared_ptr< DomainBase > &) const override
Definition Element.cpp:139
uvec index_of(const std::vector< Node::DOF > &) const override
Definition Element.cpp:337
const vec & get_current_resistance() const override
Definition Element.cpp:496
std::vector< vec > record(OutputType) const override
Definition Element.cpp:633
const std::vector< Node::DOF > & get_dof_identifier() const override
Definition Element.cpp:326
void update_dof_encoding() override
Definition Element.cpp:290
std::vector< shared_ptr< Material > > get_material(const shared_ptr< DomainBase > &) const override
Definition Element.cpp:133
unsigned get_dof_number() const override
Definition Element.cpp:349
const mat & get_initial_mass() const override
Definition Element.cpp:548
unsigned get_node_number() const override
Definition Element.cpp:351
const std::vector< std::weak_ptr< Node > > & get_node_ptr() const override
Definition Element.cpp:357
const mat & get_current_viscous() const override
Definition Element.cpp:538
bool allow_modify_nonviscous() const override
Definition Element.cpp:320
const uvec & get_node_encoding() const override
Definition Element.cpp:324
const vec & get_current_traction() const override
Definition Element.cpp:522
bool validate_dof(const std::vector< Node::DOF > &) const override
Definition Element.cpp:330
const uvec & get_dof_encoding() const override
Definition Element.cpp:322
const vec & get_current_inertial_force() override
Definition Element.cpp:511
void clear_node_ptr() override
Definition Element.cpp:355
const vec & get_trial_body_force() const override
Definition Element.cpp:516
vec get_node_current_resistance() const override
Definition Element.cpp:120
const mat & get_trial_stiffness() const override
Definition Element.cpp:530
const vec & get_current_damping_force() const override
Definition Element.cpp:500
friend void ConstantDamping(DataElement *)
Definition Element.cpp:32
double get(Parameter) const override
Definition Element.cpp:649
vec get_current_velocity() const override
Definition Element.cpp:468
vec get_trial_velocity() const override
Definition Element.cpp:429
const mat & get_stiffness_container() const override
Definition Element.cpp:562
vec get_current_acceleration() const override
Definition Element.cpp:481
const mat & get_initial_stiffness() const override
Definition Element.cpp:554
const vec & get_current_body_force() const override
Definition Element.cpp:518
double get_characteristic_length() const override
Definition Element.cpp:647
const vec & get_trial_inertial_force() override
Definition Element.cpp:506
bool if_update_viscous() const override
Definition Element.cpp:308
const cx_mat & get_trial_nonviscous_force() const override
Definition Element.cpp:502
vec get_incre_acceleration() const override
Definition Element.cpp:403
bool is_symmetric() const override
Definition Element.cpp:284
bool if_update_stiffness() const override
Definition Element.cpp:312
int initialize_base(const shared_ptr< DomainBase > &) final
Definition Element.cpp:192
const std::vector< MappingDOF > & get_dof_mapping() const override
Definition Element.cpp:328
const vec & get_momentum() const override
Definition Element.cpp:645
const vec & get_trial_damping_force() const override
Definition Element.cpp:498
vec get_current_displacement() const override
Definition Element.cpp:455
friend void ConstantMass(DataElement *)
Definition Element.cpp:26
Type type() const override
Definition Element.cpp:288
const mat & get_initial_secant() const override
Definition Element.cpp:558
double get_nonviscous_energy() const override
Definition Element.cpp:643
const mat & get_current_geometry() const override
Definition Element.cpp:544
const mat & get_initial_viscous() const override
Definition Element.cpp:550
bool is_nlgeom() const override
Definition Element.cpp:286
const mat & get_current_mass() const override
Definition Element.cpp:536
vec get_trial_acceleration() const override
Definition Element.cpp:442
unsigned get_total_number() const override
Definition Element.cpp:353
const mat & get_trial_geometry() const override
Definition Element.cpp:532
int reset_status() override=0
Definition Element.cpp:615
bool allow_modify_viscous() const override
Definition Element.cpp:318
const mat & get_trial_nonviscous() const override
Definition Element.cpp:528
vec get_trial_displacement() const override
Definition Element.cpp:416
double get_viscous_energy() const override
Definition Element.cpp:641
friend void ConstantStiffness(DataElement *)
Definition Element.cpp:38
const mat & get_trial_secant() const override
Definition Element.cpp:534
vec get_incre_velocity() const override
Definition Element.cpp:390
const vec & update_body_force(const vec &) override
Definition Element.cpp:629
int clear_status() override=0
Definition Element.cpp:564
double get_strain_energy() const override
Definition Element.cpp:635
const mat & get_initial_nonviscous() const override
Definition Element.cpp:552
bool if_update_mass() const override
Definition Element.cpp:306
void set_initialized(bool) const override
Definition Element.cpp:278
const vec & get_trial_resistance() const override
Definition Element.cpp:494
vec get_node_trial_resistance() const override
Definition Element.cpp:107
bool allow_modify_mass() const override
Definition Element.cpp:316
bool is_initialized() const override
Definition Element.cpp:282
const mat & get_trial_mass() const override
Definition Element.cpp:524
const cx_mat & get_current_nonviscous_force() const override
Definition Element.cpp:504
mat get_coordinate() const override
Definition Element.cpp:359
const uvec & get_material_tag() const override
Definition Element.cpp:345
vec get_incre_displacement() const override
Definition Element.cpp:377
double get_complementary_energy() const override
Definition Element.cpp:637
vec get_node_incre_resistance() const override
Definition Element.cpp:94
const mat & get_current_nonviscous() const override
Definition Element.cpp:540
const mat & get_trial_viscous() const override
Definition Element.cpp:526
const vec & get_trial_traction() const override
Definition Element.cpp:520
const mat & get_initial_geometry() const override
Definition Element.cpp:556
const mat & get_current_stiffness() const override
Definition Element.cpp:542
int commit_status() override=0
Definition Element.cpp:595
const mat & get_current_secant() const override
Definition Element.cpp:546
mat compute_shape_function(const mat &, unsigned) const override
Definition Element.cpp:651
double get_kinetic_energy() const override
Definition Element.cpp:639
bool if_update_nonviscous() const override
Definition Element.cpp:310
bool if_update_geometry() const override
Definition Element.cpp:314
std::vector< std::weak_ptr< Node > > node_ptr
Definition Element.h:150
const mat & get_mass_container() const override
Definition Element.cpp:560
const uvec & get_section_tag() const override
Definition Element.cpp:347
void set_symmetric(bool) const override
Definition Element.cpp:280
const vec & update_traction(const vec &) override
Definition Element.cpp:631
MaterialType
Definition Material.h:37
SectionType
Definition Section.h:33
Definition Element.h:51
bool modify_nonviscous
Definition Element.h:66
cx_mat trial_nonviscous_force
Definition Element.h:92
vec trial_traction
Definition Element.h:99
uvec dof_encoding
Definition Element.h:68
bool update_stiffness
Definition Element.h:61
mat traction
Definition Element.h:103
mat trial_stiffness
Definition Element.h:79
bool update_geometry
Definition Element.h:62
bool modify_viscous
Definition Element.h:65
double nonviscous_energy
Definition Element.h:111
vec current_body_force
Definition Element.h:98
const uvec section_tag
Definition Element.h:54
mat trial_mass
Definition Element.h:76
bool update_mass
Definition Element.h:58
double complementary_energy
Definition Element.h:112
mat initial_viscous
Definition Element.h:71
cx_mat current_nonviscous_force
Definition Element.h:93
mat current_viscous
Definition Element.h:83
double viscous_energy
Definition Element.h:110
vec current_resistance
Definition Element.h:89
mat initial_nonviscous
Definition Element.h:72
mat stiffness_container
Definition Element.h:105
vec momentum
Definition Element.h:113
vec trial_body_force
Definition Element.h:97
bool update_viscous
Definition Element.h:59
vec current_viscous_force
Definition Element.h:91
mat initial_stiffness
Definition Element.h:73
const double characteristic_length
Definition Element.h:115
const bool nlgeom
Definition Element.h:56
vec current_inertial_force
Definition Element.h:95
mat mass_container
Definition Element.h:106
vec trial_viscous_force
Definition Element.h:90
const uvec node_encoding
Definition Element.h:52
double strain_energy
Definition Element.h:108
bool update_nonviscous
Definition Element.h:60
mat trial_viscous
Definition Element.h:77
mat body_force
Definition Element.h:102
const uvec material_tag
Definition Element.h:53
mat current_nonviscous
Definition Element.h:84
mat initial_geometry
Definition Element.h:74
vec trial_inertial_force
Definition Element.h:94
mat trial_geometry
Definition Element.h:80
mat current_mass
Definition Element.h:82
mat current_geometry
Definition Element.h:86
mat current_stiffness
Definition Element.h:85
vec trial_resistance
Definition Element.h:88
mat trial_nonviscous
Definition Element.h:78
bool modify_mass
Definition Element.h:64
vec current_traction
Definition Element.h:100
mat initial_mass
Definition Element.h:70
double kinetic_energy
Definition Element.h:109