suanPan
🧮 An Open Source, Parallel and Heterogeneous Finite Element Analysis Framework
Loading...
Searching...
No Matches
Integrator.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 ******************************************************************************/
39#ifndef INTEGRATOR_H
40#define INTEGRATOR_H
41
42#include <Domain/Tag.h>
43
44class DomainBase;
45
46class Integrator : public UniqueTag {
47 bool time_step_switch = true;
48 bool matrix_assembled_switch = false;
49
50 std::weak_ptr<DomainBase> database;
51
52protected:
53 virtual void update_parameter(double);
54
55 [[nodiscard]] virtual int process_load_impl(bool);
56 [[nodiscard]] virtual int process_constraint_impl(bool);
57
58 [[nodiscard]] virtual bool has_corrector() const;
59
60 virtual int correct_trial_status();
61
62public:
63 enum class Type {
66 };
67
68 explicit Integrator(unsigned = 0);
69
70 void set_domain(const std::weak_ptr<DomainBase>&);
71 [[nodiscard]] shared_ptr<DomainBase> get_domain() const;
72
73 virtual int initialize();
74
75 [[nodiscard]] virtual Type type() const { return Type::Implicit; }
76
77 // ! some multistep integrators may require fixed time step for some consecutive sub-steps
78 void set_time_step_switch(bool);
79 [[nodiscard]] bool allow_to_change_time_step() const;
80
81 // ! manually set switch after assembling global matrix
83 [[nodiscard]] bool matrix_is_assembled() const;
84
85 [[nodiscard]] virtual bool time_independent_matrix() const;
86
87 [[nodiscard]] int process_load();
88 [[nodiscard]] virtual int process_constraint();
89 [[nodiscard]] int process_criterion() const;
90 [[nodiscard]] int process_modifier() const;
91 [[nodiscard]] int process_load_resistance();
92 [[nodiscard]] virtual int process_constraint_resistance();
93
94 void record() const;
95
96 virtual void assemble_resistance();
97 virtual void assemble_matrix();
98 virtual void assemble_effective_matrix();
99
100 virtual vec get_force_residual();
101 virtual vec get_displacement_residual();
102 [[nodiscard]] vec get_auxiliary_residual() const;
103 virtual sp_mat get_reference_load();
104
105 [[nodiscard]] virtual const vec& get_trial_displacement() const;
106
107 void update_load() const;
108 void update_constraint() const;
109
110 void update_trial_load_factor(double) const;
111 void update_trial_load_factor(const vec&) const;
112 virtual void update_from_ninja();
113
114 void update_trial_time(double);
115 virtual void update_incre_time(double);
116
117 virtual int update_trial_status(bool);
118
119 int sync_status(bool);
120
121 virtual int update_internal(const mat&);
122
123 mat solve(const mat&);
124 mat solve(const sp_mat&);
125 mat solve(mat&&);
126 mat solve(sp_mat&&);
127 virtual int solve(mat&, const mat&);
128 virtual int solve(mat&, const sp_mat&);
129 virtual int solve(mat&, mat&&);
130 virtual int solve(mat&, sp_mat&&);
131
132 void erase_machine_error(vec&) const;
133
135
136 void stage_status() const;
137 virtual void commit_status();
138 virtual void clear_status();
139 virtual void reset_status();
140
141 virtual vec from_incre_velocity(const vec&, const uvec&); // obtain target displacement from increment of velocity
142 virtual vec from_incre_acceleration(const vec&, const uvec&); // obtain target displacement from increment of acceleration
143 virtual vec from_total_velocity(const vec&, const uvec&);
144 virtual vec from_total_acceleration(const vec&, const uvec&);
145 vec from_incre_velocity(double, const uvec&);
146 vec from_incre_acceleration(double, const uvec&);
147 vec from_total_velocity(double, const uvec&);
148 vec from_total_acceleration(double, const uvec&);
149};
150
152public:
154
155 [[nodiscard]] Type type() const final { return Type::Implicit; }
156
157 void assemble_matrix() override;
158};
159
161public:
163
164 [[nodiscard]] Type type() const final { return Type::Explicit; }
165
166 void assemble_resistance() override;
167 void assemble_matrix() override;
168 void assemble_effective_matrix() override;
169
170 [[nodiscard]] const vec& get_trial_displacement() const override;
171
172 void update_from_ninja() override;
173
174 int solve(mat&, const mat&) override;
175 int solve(mat&, const sp_mat&) override;
176 int solve(mat&, mat&&) override;
177 int solve(mat&, sp_mat&&) override;
178
179 vec from_incre_velocity(const vec&, const uvec&) override;
180
181 vec from_incre_acceleration(const vec&, const uvec&) override; // obtain target acceleration from increment of acceleration
182 vec from_total_acceleration(const vec&, const uvec&) override;
183};
184
185#endif
186
The DomainBase class is a template.
Definition DomainBase.h:94
Definition Integrator.h:160
const vec & get_trial_displacement() const override
Definition Integrator.cpp:415
void update_from_ninja() override
Definition Integrator.cpp:417
Type type() const final
Definition Integrator.h:164
void assemble_effective_matrix() override
Definition Integrator.cpp:413
vec from_total_acceleration(const vec &, const uvec &) override
Definition Integrator.cpp:434
vec from_incre_acceleration(const vec &, const uvec &) override
Definition Integrator.cpp:432
vec from_incre_velocity(const vec &, const uvec &) override
Definition Integrator.cpp:430
void assemble_resistance() override
Definition Integrator.cpp:394
void assemble_matrix() override
Definition Integrator.cpp:411
int solve(mat &, const mat &) override
Definition Integrator.cpp:422
Definition Integrator.h:151
void assemble_matrix() override
Definition Integrator.cpp:378
Type type() const final
Definition Integrator.h:155
The Integrator class is basically a wrapper of the DomainBase class with regard to some status changi...
Definition Integrator.h:46
virtual void update_incre_time(double)
Definition Integrator.cpp:207
virtual int process_constraint_impl(bool)
Definition Integrator.cpp:25
int process_load_resistance()
Definition Integrator.cpp:109
virtual void assemble_effective_matrix()
Definition Integrator.cpp:143
virtual vec get_displacement_residual()
Definition Integrator.cpp:163
void update_constraint() const
Definition Integrator.cpp:187
virtual bool has_corrector() const
Definition Integrator.cpp:47
virtual int process_constraint()
Definition Integrator.cpp:103
virtual sp_mat get_reference_load()
Definition Integrator.cpp:181
int process_modifier() const
Definition Integrator.cpp:107
void update_trial_load_factor(double) const
Definition Integrator.cpp:189
Type
Definition Integrator.h:63
void update_load() const
Definition Integrator.cpp:185
virtual vec from_incre_acceleration(const vec &, const uvec &)
Definition Integrator.cpp:344
int process_load()
Definition Integrator.cpp:95
Integrator(unsigned=0)
Definition Integrator.cpp:58
int sync_status(bool)
Definition Integrator.cpp:229
void set_time_step_switch(bool)
Definition Integrator.cpp:74
void record() const
Definition Integrator.cpp:120
virtual void update_from_ninja()
Definition Integrator.cpp:196
virtual void update_parameter(double)
Definition Integrator.cpp:324
void stage_status() const
Definition Integrator.cpp:310
virtual bool time_independent_matrix() const
Definition Integrator.cpp:93
vec get_auxiliary_residual() const
Definition Integrator.cpp:175
virtual void commit_status()
Definition Integrator.cpp:312
virtual const vec & get_trial_displacement() const
Definition Integrator.cpp:183
virtual vec from_incre_velocity(const vec &, const uvec &)
Definition Integrator.cpp:334
mat solve(const mat &)
Definition Integrator.cpp:260
void set_domain(const std::weak_ptr< DomainBase > &)
Definition Integrator.cpp:61
virtual int initialize()
Definition Integrator.cpp:67
virtual int process_constraint_resistance()
Definition Integrator.cpp:118
virtual vec from_total_acceleration(const vec &, const uvec &)
Definition Integrator.cpp:354
virtual void assemble_resistance()
Definition Integrator.cpp:122
int process_criterion() const
Definition Integrator.cpp:105
shared_ptr< DomainBase > get_domain() const
Definition Integrator.cpp:65
virtual void clear_status()
Definition Integrator.cpp:314
virtual void assemble_matrix()
Definition Integrator.cpp:133
virtual Type type() const
Definition Integrator.h:75
virtual int update_internal(const mat &)
Definition Integrator.cpp:258
void erase_machine_error(vec &) const
Definition Integrator.cpp:297
virtual int update_trial_status(bool)
Definition Integrator.cpp:213
bool allow_to_change_time_step() const
Definition Integrator.cpp:81
virtual void reset_status()
Definition Integrator.cpp:319
void update_trial_time(double)
Definition Integrator.cpp:201
bool matrix_is_assembled() const
Definition Integrator.cpp:85
virtual vec from_total_velocity(const vec &, const uvec &)
Definition Integrator.cpp:346
virtual int process_load_impl(bool)
Definition Integrator.cpp:23
virtual vec get_force_residual()
Definition Integrator.cpp:150
virtual int correct_trial_status()
Definition Integrator.cpp:56
void stage_and_commit_status()
Definition Integrator.cpp:305
void set_matrix_assembled_switch()
Definition Integrator.cpp:83
Label objects that cannot be copied.
Definition Tag.h:88