suanPan
ElementBase.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 ELEMENTBASE_H
29 #define ELEMENTBASE_H
30 
31 #include <Domain/Tag.h>
33 
34 class Node;
35 class DomainBase;
36 class Material;
37 class Section;
38 enum class OutputType;
39 enum class DOF : unsigned short;
40 
41 class ElementBase : public Tag, public vtkBase {
42  virtual void update_strain_energy() = 0;
43  virtual void update_kinetic_energy() = 0;
44  virtual void update_viscous_energy() = 0;
45  virtual void update_complementary_energy() = 0;
46  virtual void update_momentum() = 0;
47 
48 protected:
49  friend mat get_coordinate(const ElementBase*, unsigned);
50 
51  friend vec get_incre_displacement(const ElementBase*);
52  friend vec get_incre_velocity(const ElementBase*);
53  friend vec get_incre_acceleration(const ElementBase*);
54  friend vec get_trial_displacement(const ElementBase*);
55  friend vec get_trial_velocity(const ElementBase*);
56  friend vec get_trial_acceleration(const ElementBase*);
57  friend vec get_current_displacement(const ElementBase*);
58  friend vec get_current_velocity(const ElementBase*);
59  friend vec get_current_acceleration(const ElementBase*);
60 
61  [[nodiscard]] virtual mat get_coordinate(unsigned) const = 0;
62 
63  [[nodiscard]] virtual vec get_incre_displacement() const = 0;
64  [[nodiscard]] virtual vec get_incre_velocity() const = 0;
65  [[nodiscard]] virtual vec get_incre_acceleration() const = 0;
66  [[nodiscard]] virtual vec get_trial_displacement() const = 0;
67  [[nodiscard]] virtual vec get_trial_velocity() const = 0;
68  [[nodiscard]] virtual vec get_trial_acceleration() const = 0;
69  [[nodiscard]] virtual vec get_current_displacement() const = 0;
70  [[nodiscard]] virtual vec get_current_velocity() const = 0;
71  [[nodiscard]] virtual vec get_current_acceleration() const = 0;
72 
73  [[nodiscard]] virtual vec get_node_incre_resistance() const = 0;
74  [[nodiscard]] virtual vec get_node_trial_resistance() const = 0;
75  [[nodiscard]] virtual vec get_node_current_resistance() const = 0;
76 
77  [[nodiscard]] virtual std::vector<shared_ptr<Material>> get_material(const shared_ptr<DomainBase>&) const = 0;
78  [[nodiscard]] virtual std::vector<shared_ptr<Section>> get_section(const shared_ptr<DomainBase>&) const = 0;
79 
80 public:
81  explicit ElementBase(const unsigned T)
82  : Tag(T) {}
83 
84  ElementBase(const ElementBase&) = delete; // copy forbidden
85  ElementBase(ElementBase&&) = delete; // move forbidden
86  ElementBase& operator=(const ElementBase&) = delete; // assign forbidden
87  ElementBase& operator=(ElementBase&&) = delete; // assign forbidden
88 
89  ~ElementBase() override = default;
90 
91  virtual int initialize_base(const shared_ptr<DomainBase>&) = 0;
92  virtual int initialize(const shared_ptr<DomainBase>&) = 0;
93 
94  virtual void set_initialized(bool) const = 0;
95  virtual void set_symmetric(bool) const = 0;
96  [[nodiscard]] virtual bool is_initialized() const = 0;
97  [[nodiscard]] virtual bool is_symmetric() const = 0;
98  [[nodiscard]] virtual bool is_nlgeom() const = 0;
99 
100  virtual void update_dof_encoding() = 0;
101 
102  [[nodiscard]] virtual bool if_update_mass() const = 0;
103  [[nodiscard]] virtual bool if_update_damping() const = 0;
104  [[nodiscard]] virtual bool if_update_stiffness() const = 0;
105  [[nodiscard]] virtual bool if_update_geometry() const = 0;
106 
107  [[nodiscard]] virtual const uvec& get_dof_encoding() const = 0;
108  [[nodiscard]] virtual const uvec& get_node_encoding() const = 0;
109 
110  [[nodiscard]] virtual const uvec& get_material_tag() const = 0;
111  [[nodiscard]] virtual const uvec& get_section_tag() const = 0;
112 
113  [[nodiscard]] virtual unsigned get_dof_number() const = 0;
114  [[nodiscard]] virtual unsigned get_node_number() const = 0;
115  [[nodiscard]] virtual unsigned get_total_number() const = 0;
116 
117  virtual void clear_node_ptr() = 0;
118  [[nodiscard]] virtual const std::vector<weak_ptr<Node>>& get_node_ptr() const = 0;
119 
120  [[nodiscard]] virtual const vec& get_trial_resistance() const = 0;
121  [[nodiscard]] virtual const vec& get_current_resistance() const = 0;
122  [[nodiscard]] virtual const vec& get_trial_damping_force() const = 0;
123  [[nodiscard]] virtual const vec& get_current_damping_force() const = 0;
124  [[nodiscard]] virtual const vec& get_trial_inertial_force() = 0;
125  [[nodiscard]] virtual const vec& get_current_inertial_force() = 0;
126 
127  [[nodiscard]] virtual const vec& get_trial_body_force() const = 0;
128  [[nodiscard]] virtual const vec& get_current_body_force() const = 0;
129  [[nodiscard]] virtual const vec& get_trial_traction() const = 0;
130  [[nodiscard]] virtual const vec& get_current_traction() const = 0;
131 
132  [[nodiscard]] virtual const mat& get_trial_mass() const = 0;
133  [[nodiscard]] virtual const mat& get_trial_damping() const = 0;
134  [[nodiscard]] virtual const mat& get_trial_stiffness() const = 0;
135  [[nodiscard]] virtual const mat& get_trial_geometry() const = 0;
136  [[nodiscard]] virtual const mat& get_trial_secant() const = 0;
137 
138  [[nodiscard]] virtual const mat& get_current_mass() const = 0;
139  [[nodiscard]] virtual const mat& get_current_damping() const = 0;
140  [[nodiscard]] virtual const mat& get_current_stiffness() const = 0;
141  [[nodiscard]] virtual const mat& get_current_geometry() const = 0;
142  [[nodiscard]] virtual const mat& get_current_secant() const = 0;
143 
144  [[nodiscard]] virtual const mat& get_initial_mass() const = 0;
145  [[nodiscard]] virtual const mat& get_initial_damping() const = 0;
146  [[nodiscard]] virtual const mat& get_initial_stiffness() const = 0;
147  [[nodiscard]] virtual const mat& get_initial_geometry() const = 0;
148  [[nodiscard]] virtual const mat& get_initial_secant() const = 0;
149 
150  [[nodiscard]] virtual const mat& get_mass_container() const = 0;
151  [[nodiscard]] virtual const mat& get_stiffness_container() const = 0;
152 
153  virtual int update_status() = 0;
154  virtual int clear_status() = 0;
155  virtual int commit_status() = 0;
156  virtual int reset_status() = 0;
157 
158  virtual const vec& update_body_force(const vec&) = 0;
159  virtual const vec& update_traction(const vec&) = 0;
160 
161  virtual std::vector<vec> record(OutputType) = 0;
162 
163  [[nodiscard]] virtual double get_strain_energy() const = 0;
164  [[nodiscard]] virtual double get_complementary_energy() const = 0;
165  [[nodiscard]] virtual double get_kinetic_energy() const = 0;
166  [[nodiscard]] virtual double get_viscous_energy() const = 0;
167  [[nodiscard]] virtual const vec& get_momentum() const = 0;
168  [[nodiscard]] virtual double get_momentum_component(DOF) const = 0;
169 
170  [[nodiscard]] virtual double get_characteristic_length() const = 0;
171 
172  [[nodiscard]] virtual mat compute_shape_function(const mat&, unsigned) const = 0;
173 };
174 
175 #endif
176 
OutputType
Definition: OutputType.h:21
The DomainBase class is a template.
Definition: DomainBase.h:96
A ElementBase class.
Definition: ElementBase.h:41
virtual void update_dof_encoding()=0
virtual std::vector< vec > record(OutputType)=0
virtual vec get_current_velocity() const =0
virtual const vec & get_current_body_force() const =0
virtual const mat & get_trial_geometry() const =0
virtual bool is_initialized() const =0
virtual const vec & get_current_resistance() const =0
virtual const vec & get_trial_traction() const =0
virtual const uvec & get_node_encoding() const =0
virtual const vec & get_current_traction() const =0
virtual const vec & get_trial_resistance() const =0
virtual const vec & update_body_force(const vec &)=0
virtual double get_characteristic_length() const =0
virtual bool if_update_geometry() const =0
virtual vec get_node_trial_resistance() const =0
virtual unsigned get_total_number() const =0
virtual int initialize(const shared_ptr< DomainBase > &)=0
virtual mat compute_shape_function(const mat &, unsigned) const =0
virtual const mat & get_initial_damping() const =0
virtual const mat & get_trial_mass() const =0
virtual std::vector< shared_ptr< Material > > get_material(const shared_ptr< DomainBase > &) const =0
ElementBase & operator=(ElementBase &&)=delete
virtual vec get_incre_displacement() const =0
virtual int reset_status()=0
virtual const mat & get_initial_stiffness() const =0
virtual double get_viscous_energy() const =0
virtual double get_kinetic_energy() const =0
virtual std::vector< shared_ptr< Section > > get_section(const shared_ptr< DomainBase > &) const =0
virtual const mat & get_current_damping() const =0
virtual const vec & get_momentum() const =0
virtual const std::vector< weak_ptr< Node > > & get_node_ptr() const =0
virtual void clear_node_ptr()=0
virtual const mat & get_current_secant() const =0
virtual const uvec & get_material_tag() const =0
ElementBase(const ElementBase &)=delete
virtual double get_momentum_component(DOF) const =0
virtual vec get_trial_acceleration() const =0
virtual vec get_trial_displacement() const =0
virtual bool if_update_mass() const =0
virtual const vec & get_trial_damping_force() const =0
virtual vec get_incre_velocity() const =0
virtual void set_initialized(bool) const =0
virtual double get_complementary_energy() const =0
virtual const vec & get_trial_body_force() const =0
~ElementBase() override=default
virtual bool if_update_stiffness() const =0
virtual const mat & get_current_stiffness() const =0
virtual int update_status()=0
ElementBase & operator=(const ElementBase &)=delete
virtual const vec & get_trial_inertial_force()=0
virtual const mat & get_stiffness_container() const =0
virtual const mat & get_trial_damping() const =0
virtual vec get_current_displacement() const =0
ElementBase(const unsigned T)
Definition: ElementBase.h:81
virtual int initialize_base(const shared_ptr< DomainBase > &)=0
virtual void set_symmetric(bool) const =0
virtual const vec & get_current_inertial_force()=0
virtual bool is_nlgeom() const =0
virtual unsigned get_node_number() const =0
virtual const mat & get_trial_secant() const =0
virtual bool if_update_damping() const =0
virtual const uvec & get_section_tag() const =0
virtual unsigned get_dof_number() const =0
ElementBase(ElementBase &&)=delete
friend mat get_coordinate(const ElementBase *, unsigned)
Definition: Element.cpp:598
virtual int commit_status()=0
virtual const uvec & get_dof_encoding() const =0
virtual vec get_node_current_resistance() const =0
virtual const mat & get_initial_secant() const =0
virtual int clear_status()=0
virtual const mat & get_initial_mass() const =0
virtual vec get_node_incre_resistance() const =0
virtual const vec & update_traction(const vec &)=0
virtual vec get_trial_velocity() const =0
virtual vec get_current_acceleration() const =0
virtual const mat & get_current_geometry() const =0
virtual const mat & get_trial_stiffness() const =0
virtual vec get_incre_acceleration() const =0
virtual double get_strain_energy() const =0
virtual const vec & get_current_damping_force() const =0
virtual const mat & get_current_mass() const =0
virtual const mat & get_mass_container() const =0
virtual bool is_symmetric() const =0
virtual const mat & get_initial_geometry() const =0
virtual mat get_coordinate(unsigned) const =0
A Material abstract base class.
Definition: Material.h:102
The Node class holds the number of DoFs, coordinate, displacement, velocity and acceleration.
Definition: Node.h:77
A Section class.
Definition: Section.h:73
A base Tag class.
Definition: Tag.h:38
The vtkBase class.
Definition: vtkBase.h:44
DOF
Definition: DOF.h:29