119 const unsigned num_node;
120 const unsigned num_dof;
121 const unsigned num_size = num_dof * num_node;
123 const bool initialized =
false;
124 const bool symmetric =
false;
125 const bool use_group =
false;
126 const unsigned use_other = 0;
131 const std::vector<DOF> dof_identifier;
133 std::vector<MappingDOF> dof_mapping;
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;
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;
205 [[nodiscard]]
bool is_nlgeom()
const override;
222 [[nodiscard]]
const std::vector<MappingDOF>&
get_dof_mapping()
const override;
232 [[nodiscard]]
const std::vector<std::weak_ptr<Node>>&
get_node_ptr()
const override;
304std::vector<vec>&
append_to(std::vector<vec>&, std::vector<vec>&&);
OutputType
Definition OutputType.h:23
Definition Distributed.h:23
A ElementBase class.
Definition ElementBase.h:42
friend mat get_coordinate(const ElementBase *, unsigned)
Definition Element.cpp:657
A Element class.
Definition Element.h:118
friend void ConstantGeometry(DataElement *)
Definition Element.cpp:651
std::vector< shared_ptr< Section > > get_section(const shared_ptr< DomainBase > &) const override
Definition Element.cpp:249
const vec & get_current_resistance() const override
Definition Element.cpp:462
void update_dof_encoding() override
Definition Element.cpp:406
std::vector< shared_ptr< Material > > get_material(const shared_ptr< DomainBase > &) const override
Definition Element.cpp:243
unsigned get_dof_number() const override
Definition Element.cpp:450
const mat & get_initial_mass() const override
Definition Element.cpp:514
unsigned get_node_number() const override
Definition Element.cpp:452
const std::vector< std::weak_ptr< Node > > & get_node_ptr() const override
Definition Element.cpp:458
const mat & get_current_viscous() const override
Definition Element.cpp:504
bool allow_modify_nonviscous() const override
Definition Element.cpp:438
const uvec & get_node_encoding() const override
Definition Element.cpp:442
const vec & get_current_traction() const override
Definition Element.cpp:488
const uvec & get_dof_encoding() const override
Definition Element.cpp:440
const vec & get_current_inertial_force() override
Definition Element.cpp:477
void clear_node_ptr() override
Definition Element.cpp:456
const vec & get_trial_body_force() const override
Definition Element.cpp:482
vec get_node_current_resistance() const override
Definition Element.cpp:230
const mat & get_trial_stiffness() const override
Definition Element.cpp:496
const vec & get_current_damping_force() const override
Definition Element.cpp:466
friend void ConstantDamping(DataElement *)
Definition Element.cpp:639
vec get_current_velocity() const override
Definition Element.cpp:178
vec get_trial_velocity() const override
Definition Element.cpp:139
const mat & get_stiffness_container() const override
Definition Element.cpp:528
vec get_current_acceleration() const override
Definition Element.cpp:191
const mat & get_initial_stiffness() const override
Definition Element.cpp:520
const vec & get_current_body_force() const override
Definition Element.cpp:484
double get_characteristic_length() const override
Definition Element.cpp:624
const vec & get_trial_inertial_force() override
Definition Element.cpp:472
bool if_update_viscous() const override
Definition Element.cpp:426
double get_momentum_component(DOF) const override
Definition Element.cpp:613
const cx_mat & get_trial_nonviscous_force() const override
Definition Element.cpp:468
vec get_incre_acceleration() const override
Definition Element.cpp:113
bool is_symmetric() const override
Definition Element.cpp:402
bool if_update_stiffness() const override
Definition Element.cpp:430
int initialize_base(const shared_ptr< DomainBase > &) final
Definition Element.cpp:304
const std::vector< MappingDOF > & get_dof_mapping() const override
Definition Element.cpp:444
const vec & get_momentum() const override
Definition Element.cpp:611
const vec & get_trial_damping_force() const override
Definition Element.cpp:464
vec get_current_displacement() const override
Definition Element.cpp:165
friend void ConstantMass(DataElement *)
Definition Element.cpp:633
const mat & get_initial_secant() const override
Definition Element.cpp:524
double get_nonviscous_energy() const override
Definition Element.cpp:609
const mat & get_current_geometry() const override
Definition Element.cpp:510
const mat & get_initial_viscous() const override
Definition Element.cpp:516
bool is_nlgeom() const override
Definition Element.cpp:404
const mat & get_current_mass() const override
Definition Element.cpp:502
vec get_trial_acceleration() const override
Definition Element.cpp:152
unsigned get_total_number() const override
Definition Element.cpp:454
const mat & get_trial_geometry() const override
Definition Element.cpp:498
int reset_status() override=0
Definition Element.cpp:581
bool allow_modify_viscous() const override
Definition Element.cpp:436
const mat & get_trial_nonviscous() const override
Definition Element.cpp:494
vec get_trial_displacement() const override
Definition Element.cpp:126
double get_viscous_energy() const override
Definition Element.cpp:607
friend void ConstantStiffness(DataElement *)
Definition Element.cpp:645
const mat & get_trial_secant() const override
Definition Element.cpp:500
vec get_incre_velocity() const override
Definition Element.cpp:100
const vec & update_body_force(const vec &) override
Definition Element.cpp:595
int clear_status() override=0
Definition Element.cpp:530
double get_strain_energy() const override
Definition Element.cpp:601
const mat & get_initial_nonviscous() const override
Definition Element.cpp:518
bool if_update_mass() const override
Definition Element.cpp:424
void set_initialized(bool) const override
Definition Element.cpp:396
const vec & get_trial_resistance() const override
Definition Element.cpp:460
vec get_node_trial_resistance() const override
Definition Element.cpp:217
bool allow_modify_mass() const override
Definition Element.cpp:434
bool is_initialized() const override
Definition Element.cpp:400
const mat & get_trial_mass() const override
Definition Element.cpp:490
const cx_mat & get_current_nonviscous_force() const override
Definition Element.cpp:470
const uvec & get_material_tag() const override
Definition Element.cpp:446
vec get_incre_displacement() const override
Definition Element.cpp:87
double get_complementary_energy() const override
Definition Element.cpp:603
vec get_node_incre_resistance() const override
Definition Element.cpp:204
const mat & get_current_nonviscous() const override
Definition Element.cpp:506
const mat & get_trial_viscous() const override
Definition Element.cpp:492
const vec & get_trial_traction() const override
Definition Element.cpp:486
const mat & get_initial_geometry() const override
Definition Element.cpp:522
const mat & get_current_stiffness() const override
Definition Element.cpp:508
int commit_status() override=0
Definition Element.cpp:561
const mat & get_current_secant() const override
Definition Element.cpp:512
mat compute_shape_function(const mat &, unsigned) const override
Definition Element.cpp:626
std::vector< vec > record(OutputType) override
Definition Element.cpp:599
double get_kinetic_energy() const override
Definition Element.cpp:605
bool if_update_nonviscous() const override
Definition Element.cpp:428
bool if_update_geometry() const override
Definition Element.cpp:432
std::vector< std::weak_ptr< Node > > node_ptr
Definition Element.h:148
const mat & get_mass_container() const override
Definition Element.cpp:526
const uvec & get_section_tag() const override
Definition Element.cpp:448
void set_symmetric(bool) const override
Definition Element.cpp:398
const vec & update_traction(const vec &) override
Definition Element.cpp:597
std::vector< vec > & append_to(std::vector< vec > &, std::vector< vec > &&)
Definition Element.cpp:628
MaterialType
Definition Material.h:39
SectionType
Definition Section.h:33
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