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