suanPan
🧮 An Open Source, Parallel and Heterogeneous Finite Element Analysis Framework
Loading...
Searching...
No Matches
Material.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 MATERIAL_H
29#define MATERIAL_H
30
31#include <Domain/Tag.h>
32#include <array>
33
34using pod2 = std::array<double, 2>;
35using pod6 = std::array<double, 6>;
36
37enum class MaterialType : unsigned {
38 D0 = 0,
39 D1 = 1,
40 D2 = 3,
41 D3 = 6,
42 DS = 10,
43 OS = 3
44};
45
46enum class PlaneType : unsigned {
47 S = 1,
48 E = 2,
49 A = 3,
50 N = 0
51};
52
53class DomainBase;
54enum class OutputType;
55
59
62
65
66 mat initial_couple_stiffness{}; // stiffness matrix
67 mat current_couple_stiffness{}; // stiffness matrix
68 mat trial_couple_stiffness{}; // stiffness matrix
69};
70
72 const double density = 0.;
75
76 const double tolerance = 1E-14;
77 const double characteristic_length = -1.;
78
79 vec current_strain{}; // current status
80 vec current_strain_rate{}; // current status
81 vec current_strain_acc{}; // current status
82 vec current_stress{}; // current status
83 // vec current_stress_rate{}; // current status
84
85 vec trial_strain{}; // trial status
86 vec trial_strain_rate{}; // trial status
87 vec trial_strain_acc{}; // trial status
88 vec trial_stress{}; // trial status
89 // vec trial_stress_rate{}; // trial status
90
91 vec incre_strain{}; // incremental status
92 vec incre_strain_rate{}; // incremental status
93 vec incre_strain_acc{}; // incremental status
94 vec incre_stress{}; // incremental status
95 // vec incre_stress_rate{}; // incremental status
96
97 vec initial_history{}; // initial status
98 vec current_history{}; // current status
99 vec trial_history{}; // trial status
100
101 mat initial_stiffness{}; // stiffness matrix
102 mat current_stiffness{}; // stiffness matrix
103 mat trial_stiffness{}; // stiffness matrix
104
105 mat initial_damping{}; // damping matrix
106 mat current_damping{}; // damping matrix
107 mat trial_damping{}; // damping matrix
108
109 mat initial_inertial{}; // inertial matrix
110 mat current_inertial{}; // inertial matrix
111 mat trial_inertial{}; // inertial matrix
112};
113
114class Material : protected DataMaterial, protected DataCoupleMaterial, public CopyableTag {
115 const bool initialized = false;
116 const bool symmetric = false;
117 const bool support_couple = false; // indicate if the material supports couple stress theory
118
119 friend void ConstantStiffness(DataMaterial*);
120 friend void ConstantDamping(DataMaterial*);
121 friend void ConstantInertial(DataMaterial*);
123 friend void PureWrapper(Material*);
124
125public:
126 enum class Parameter {
127 ELASTIC,
128 POISSON,
129 SHEAR,
130 BULK,
133 };
134
135 explicit Material(
136 unsigned = 0, // tag
137 MaterialType = MaterialType::D0, // material type
138 double = 0. // density
139 );
140
141 [[nodiscard]] double get_density() const;
142 [[nodiscard]] MaterialType get_material_type() const;
143 [[nodiscard]] PlaneType get_plane_type() const;
144
145 int initialize_base(const shared_ptr<DomainBase>&);
146
147 virtual int initialize(const shared_ptr<DomainBase>&) = 0;
148 virtual void initialize_couple(const shared_ptr<DomainBase>&);
149
150 virtual void initialize_history(unsigned);
151 virtual void set_initial_history(const vec&);
152
153 void set_initialized(bool) const;
154 void set_symmetric(bool) const;
155 void set_support_couple(bool) const;
156 [[nodiscard]] bool is_initialized() const;
157 [[nodiscard]] bool is_symmetric() const;
158 [[nodiscard]] bool is_support_couple() const;
159
160 void set_characteristic_length(double) const;
161 [[nodiscard]] double get_characteristic_length() const;
162
163 [[nodiscard]] virtual double get(Parameter) const;
164
165 virtual const vec& get_trial_strain();
166 virtual const vec& get_trial_strain_rate();
167 virtual const vec& get_trial_strain_acc();
168 virtual const vec& get_trial_stress();
169 virtual const mat& get_trial_stiffness();
170 virtual const mat& get_trial_secant();
171 virtual const mat& get_trial_damping();
172 virtual const mat& get_trial_inertial();
173
174 virtual const vec& get_current_strain();
175 virtual const vec& get_current_strain_rate();
176 virtual const vec& get_current_strain_acc();
177 virtual const vec& get_current_stress();
178 virtual const mat& get_current_stiffness();
179 virtual const mat& get_current_secant();
180 virtual const mat& get_current_damping();
181 virtual const mat& get_current_inertial();
182
183 [[nodiscard]] virtual const vec& get_initial_history() const;
184 [[nodiscard]] virtual const mat& get_initial_stiffness() const;
185 [[nodiscard]] virtual const mat& get_initial_damping() const;
186 [[nodiscard]] virtual const mat& get_initial_inertial() const;
187
188 virtual const vec& get_trial_curvature();
189 virtual const vec& get_trial_couple_stress();
190 virtual const mat& get_trial_couple_stiffness();
191
192 virtual const vec& get_current_curvature();
193 virtual const vec& get_current_couple_stress();
194 virtual const mat& get_current_couple_stiffness();
195
196 [[nodiscard]] virtual const mat& get_initial_couple_stiffness() const;
197
198 virtual unique_ptr<Material> unique_copy() = 0;
199
200 int update_incre_status(double);
201 int update_incre_status(double, double);
202 int update_incre_status(double, double, double);
203 int update_trial_status(double);
204 int update_trial_status(double, double);
205 int update_trial_status(double, double, double);
206
207 virtual int update_incre_status(const vec&);
208 virtual int update_incre_status(const vec&, const vec&);
209 virtual int update_incre_status(const vec&, const vec&, const vec&);
210 virtual int update_trial_status(const vec&);
211 virtual int update_trial_status(const vec&, const vec&);
212 virtual int update_trial_status(const vec&, const vec&, const vec&);
213
214 int update_couple_incre_status(double);
215 int update_couple_incre_status(double, double);
216 int update_couple_incre_status(double, double, double);
217 int update_couple_trial_status(double);
218 int update_couple_trial_status(double, double);
219 int update_couple_trial_status(double, double, double);
220
221 virtual int update_couple_incre_status(const vec&);
222 virtual int update_couple_incre_status(const vec&, const vec&);
223 virtual int update_couple_incre_status(const vec&, const vec&, const vec&);
224 virtual int update_couple_trial_status(const vec&);
225 virtual int update_couple_trial_status(const vec&, const vec&);
226 virtual int update_couple_trial_status(const vec&, const vec&, const vec&);
227
228 virtual int clear_status() = 0;
229 virtual int commit_status() = 0;
230 virtual int reset_status() = 0;
231
232 virtual int clear_couple_status();
233 virtual int commit_couple_status();
234 virtual int reset_couple_status();
235
236 [[nodiscard]] virtual std::vector<vec> record(OutputType) const;
237
238protected:
239 class prop {
240 const double e, v;
241
242 public:
243 prop(const double E, const double P)
244 : e(E)
245 , v(P) {}
246
247 double operator()(const Parameter P) const {
248 switch(P) {
250 return e;
252 return v;
253 case Parameter::SHEAR:
254 return e / (2. + 2. * v);
255 case Parameter::BULK:
256 return e / (3. - 6. * v);
259 default:
260 return 0.;
261 }
262 }
263 };
264};
265
266namespace suanpan {
267 unique_ptr<Material> unique_copy(const shared_ptr<Material>&);
268} // namespace suanpan
269
270#endif
271
OutputType
Definition OutputType.h:23
Label objects that can be copied.
Definition Tag.h:73
The DomainBase class is a template.
Definition DomainBase.h:94
Definition Material.h:239
prop(const double E, const double P)
Definition Material.h:243
double operator()(const Parameter P) const
Definition Material.h:247
A Material abstract base class.
Definition Material.h:114
virtual const vec & get_trial_couple_stress()
Definition Material.cpp:128
virtual const vec & get_current_strain_acc()
Definition Material.cpp:106
friend void ConstantCoupleStiffness(DataCoupleMaterial *)
Definition Material.cpp:320
friend void ConstantInertial(DataMaterial *)
Definition Material.cpp:315
int update_couple_incre_status(double)
Definition Material.cpp:173
virtual int reset_couple_status()
Definition Material.cpp:286
virtual const mat & get_current_couple_stiffness()
Definition Material.cpp:136
virtual int commit_status()=0
Definition Material.cpp:232
virtual void initialize_couple(const shared_ptr< DomainBase > &)
Definition Material.cpp:52
virtual int commit_couple_status()
Definition Material.cpp:278
double get_characteristic_length() const
Definition Material.cpp:76
PlaneType get_plane_type() const
Definition Material.cpp:32
virtual int clear_couple_status()
Definition Material.cpp:266
virtual int initialize(const shared_ptr< DomainBase > &)=0
virtual const mat & get_current_stiffness()
Definition Material.cpp:110
virtual int clear_status()=0
Definition Material.cpp:200
virtual const vec & get_trial_strain()
Definition Material.cpp:80
virtual const mat & get_initial_couple_stiffness() const
Definition Material.cpp:138
friend void ConstantDamping(DataMaterial *)
Definition Material.cpp:310
virtual std::vector< vec > record(OutputType) const
Definition Material.cpp:294
virtual const vec & get_trial_stress()
Definition Material.cpp:86
virtual int reset_status()=0
Definition Material.cpp:249
virtual const vec & get_current_strain()
Definition Material.cpp:102
virtual const mat & get_initial_stiffness() const
Definition Material.cpp:120
void set_support_couple(bool) const
Definition Material.cpp:66
virtual const mat & get_trial_couple_stiffness()
Definition Material.cpp:130
bool is_support_couple() const
Definition Material.cpp:72
friend void PureWrapper(Material *)
Definition Material.cpp:325
virtual unique_ptr< Material > unique_copy()=0
Definition Material.cpp:140
virtual const mat & get_current_damping()
Definition Material.cpp:114
virtual const mat & get_current_inertial()
Definition Material.cpp:116
virtual const mat & get_trial_inertial()
Definition Material.cpp:100
virtual const mat & get_initial_damping() const
Definition Material.cpp:122
virtual const vec & get_initial_history() const
Definition Material.cpp:118
virtual double get(Parameter) const
Definition Material.cpp:78
virtual const vec & get_current_couple_stress()
Definition Material.cpp:134
MaterialType get_material_type() const
Definition Material.cpp:30
virtual const vec & get_trial_curvature()
Definition Material.cpp:126
bool is_symmetric() const
Definition Material.cpp:70
bool is_initialized() const
Definition Material.cpp:68
void set_symmetric(bool) const
Definition Material.cpp:64
friend void ConstantStiffness(DataMaterial *)
Definition Material.cpp:305
virtual const mat & get_trial_damping()
Definition Material.cpp:98
int update_trial_status(double)
Definition Material.cpp:148
virtual void initialize_history(unsigned)
Definition Material.cpp:54
int update_couple_trial_status(double)
Definition Material.cpp:179
virtual const mat & get_trial_stiffness()
Definition Material.cpp:88
int update_incre_status(double)
Definition Material.cpp:142
virtual const mat & get_trial_secant()
Definition Material.cpp:90
virtual const vec & get_current_stress()
Definition Material.cpp:108
void set_characteristic_length(double) const
Definition Material.cpp:74
virtual void set_initial_history(const vec &)
Definition Material.cpp:60
virtual const vec & get_current_strain_rate()
Definition Material.cpp:104
void set_initialized(bool) const
Definition Material.cpp:62
int initialize_base(const shared_ptr< DomainBase > &)
Definition Material.cpp:34
virtual const vec & get_current_curvature()
Definition Material.cpp:132
double get_density() const
Definition Material.cpp:28
Parameter
Definition Material.h:126
virtual const vec & get_trial_strain_rate()
Definition Material.cpp:82
virtual const mat & get_initial_inertial() const
Definition Material.cpp:124
virtual const vec & get_trial_strain_acc()
Definition Material.cpp:84
virtual const mat & get_current_secant()
Definition Material.cpp:112
std::array< double, 2 > pod2
Definition Material.h:34
std::array< double, 6 > pod6
Definition Material.h:35
MaterialType
Definition Material.h:37
PlaneType
Definition Material.h:46
Definition SparseMatMAGMA.hpp:43
unique_ptr< Material > unique_copy(const shared_ptr< Material > &)
Definition Material.cpp:371
Definition Material.h:56
mat current_couple_stiffness
Definition Material.h:67
vec trial_curvature
Definition Material.h:60
vec incre_couple_stress
Definition Material.h:64
mat trial_couple_stiffness
Definition Material.h:68
vec incre_curvature
Definition Material.h:63
vec current_couple_stress
Definition Material.h:58
mat initial_couple_stiffness
Definition Material.h:66
vec current_curvature
Definition Material.h:57
vec trial_couple_stress
Definition Material.h:61
Definition Material.h:71
mat current_inertial
Definition Material.h:110
vec trial_strain_acc
Definition Material.h:87
vec current_strain
Definition Material.h:79
vec incre_stress
Definition Material.h:94
mat initial_stiffness
Definition Material.h:101
const double density
Definition Material.h:72
mat initial_inertial
Definition Material.h:109
const double characteristic_length
Definition Material.h:77
const MaterialType material_type
Definition Material.h:73
vec current_history
Definition Material.h:98
mat current_damping
Definition Material.h:106
mat trial_damping
Definition Material.h:107
mat trial_inertial
Definition Material.h:111
vec incre_strain_rate
Definition Material.h:92
vec incre_strain_acc
Definition Material.h:93
vec current_stress
Definition Material.h:82
const PlaneType plane_type
Definition Material.h:74
vec trial_strain
Definition Material.h:85
vec trial_stress
Definition Material.h:88
mat trial_stiffness
Definition Material.h:103
mat current_stiffness
Definition Material.h:102
vec current_strain_rate
Definition Material.h:80
vec current_strain_acc
Definition Material.h:81
vec incre_strain
Definition Material.h:91
vec trial_history
Definition Material.h:99
mat initial_damping
Definition Material.h:105
vec initial_history
Definition Material.h:97
vec trial_strain_rate
Definition Material.h:86
const double tolerance
Definition Material.h:76