suanPan
Loading...
Searching...
No Matches
Integrator.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 ******************************************************************************/
39#ifndef INTEGRATOR_H
40#define INTEGRATOR_H
41
42#include <Domain/Tag.h>
43
44class DomainBase;
45
46enum class IntegratorType {
49};
50
51class Integrator : public UniqueTag {
52 bool time_step_switch = true;
53 bool matrix_assembled_switch = false;
54
55 std::weak_ptr<DomainBase> database;
56
57protected:
58 virtual void update_parameter(double);
59
60 [[nodiscard]] virtual int process_load_impl(bool);
61 [[nodiscard]] virtual int process_constraint_impl(bool);
62
63 [[nodiscard]] virtual bool has_corrector() const;
64
65 virtual int correct_trial_status();
66
67public:
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 constexpr IntegratorType type() const { return IntegratorType::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
99 virtual vec get_force_residual();
100 virtual vec get_displacement_residual();
101 [[nodiscard]] vec get_auxiliary_residual() const;
102 virtual sp_mat get_reference_load();
103
104 [[nodiscard]] virtual const vec& get_trial_displacement() const;
105
106 void update_load() const;
107 void update_constraint() const;
108
109 void update_trial_load_factor(double) const;
110 void update_trial_load_factor(const vec&) const;
111 virtual void update_from_ninja();
112
113 void update_trial_time(double);
114 virtual void update_incre_time(double);
115
116 virtual int update_trial_status(bool);
117
118 int sync_status(bool);
119
120 virtual int update_internal(const mat&);
121
122 mat solve(const mat&);
123 mat solve(const sp_mat&);
124 mat solve(mat&&);
125 mat solve(sp_mat&&);
126 virtual int solve(mat&, const mat&);
127 virtual int solve(mat&, const sp_mat&);
128 virtual int solve(mat&, mat&&);
129 virtual int solve(mat&, sp_mat&&);
130
131 void erase_machine_error(vec&) const;
132
134
135 void stage_status() const;
136 virtual void commit_status();
137 virtual void clear_status();
138 virtual void reset_status();
139
140 virtual vec from_incre_velocity(const vec&, const uvec&); // obtain target displacement from increment of velocity
141 virtual vec from_incre_acceleration(const vec&, const uvec&); // obtain target displacement from increment of acceleration
142 virtual vec from_total_velocity(const vec&, const uvec&);
143 virtual vec from_total_acceleration(const vec&, const uvec&);
144 vec from_incre_velocity(double, const uvec&);
145 vec from_incre_acceleration(double, const uvec&);
146 vec from_total_velocity(double, const uvec&);
147 vec from_total_acceleration(double, const uvec&);
148};
149
151public:
153
154 [[nodiscard]] constexpr IntegratorType type() const override { return IntegratorType::Implicit; }
155};
156
158public:
160
161 [[nodiscard]] constexpr IntegratorType type() const override { return IntegratorType::Explicit; }
162
163 void assemble_resistance() override;
164 void assemble_matrix() override;
165
166 [[nodiscard]] const vec& get_trial_displacement() const override;
167
168 void update_from_ninja() override;
169
170 int solve(mat&, const mat&) override;
171 int solve(mat&, const sp_mat&) override;
172 int solve(mat&, mat&&) override;
173 int solve(mat&, sp_mat&&) override;
174
175 vec from_incre_velocity(const vec&, const uvec&) override;
176
177 vec from_incre_acceleration(const vec&, const uvec&) override; // obtain target acceleration from increment of acceleration
178 vec from_total_acceleration(const vec&, const uvec&) override;
179};
180
181#endif
182
The DomainBase class is a template.
Definition DomainBase.h:102
Definition Integrator.h:157
const vec & get_trial_displacement() const override
Definition Integrator.cpp:391
void update_from_ninja() override
Definition Integrator.cpp:393
vec from_total_acceleration(const vec &, const uvec &) override
Definition Integrator.cpp:410
vec from_incre_acceleration(const vec &, const uvec &) override
Definition Integrator.cpp:408
vec from_incre_velocity(const vec &, const uvec &) override
Definition Integrator.cpp:406
void assemble_resistance() override
Definition Integrator.cpp:372
void assemble_matrix() override
Definition Integrator.cpp:389
constexpr IntegratorType type() const override
Definition Integrator.h:161
int solve(mat &, const mat &) override
Definition Integrator.cpp:398
Definition Integrator.h:150
constexpr IntegratorType type() const override
Definition Integrator.h:154
The Integrator class is basically a wrapper of the DomainBase class with regard to some status changi...
Definition Integrator.h:51
virtual void update_incre_time(double)
Definition Integrator.cpp:201
virtual constexpr IntegratorType type() const
Definition Integrator.h:75
virtual int process_constraint_impl(bool)
Definition Integrator.cpp:25
int process_load_resistance()
Definition Integrator.cpp:109
void set_matrix_assembled_switch(bool)
Definition Integrator.cpp:83
virtual vec get_displacement_residual()
Definition Integrator.cpp:157
void update_constraint() const
Definition Integrator.cpp:181
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:175
int process_modifier() const
Definition Integrator.cpp:107
void update_trial_load_factor(double) const
Definition Integrator.cpp:183
void update_load() const
Definition Integrator.cpp:179
virtual vec from_incre_acceleration(const vec &, const uvec &)
Definition Integrator.cpp:338
int process_load()
Definition Integrator.cpp:95
Integrator(unsigned=0)
Definition Integrator.cpp:58
int sync_status(bool)
Definition Integrator.cpp:223
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:190
virtual void update_parameter(double)
Definition Integrator.cpp:318
void stage_status() const
Definition Integrator.cpp:304
virtual bool time_independent_matrix() const
Definition Integrator.cpp:93
vec get_auxiliary_residual() const
Definition Integrator.cpp:169
virtual void commit_status()
Definition Integrator.cpp:306
virtual const vec & get_trial_displacement() const
Definition Integrator.cpp:177
virtual vec from_incre_velocity(const vec &, const uvec &)
Definition Integrator.cpp:328
mat solve(const mat &)
Definition Integrator.cpp:254
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:348
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:308
virtual void assemble_matrix()
Definition Integrator.cpp:133
virtual int update_internal(const mat &)
Definition Integrator.cpp:252
void erase_machine_error(vec &) const
Definition Integrator.cpp:291
virtual int update_trial_status(bool)
Definition Integrator.cpp:207
bool allow_to_change_time_step() const
Definition Integrator.cpp:81
virtual void reset_status()
Definition Integrator.cpp:313
void update_trial_time(double)
Definition Integrator.cpp:195
bool matrix_is_assembled() const
Definition Integrator.cpp:85
virtual vec from_total_velocity(const vec &, const uvec &)
Definition Integrator.cpp:340
virtual int process_load_impl(bool)
Definition Integrator.cpp:23
virtual vec get_force_residual()
Definition Integrator.cpp:144
virtual int correct_trial_status()
Definition Integrator.cpp:56
void stage_and_commit_status()
Definition Integrator.cpp:299
Definition Tag.h:77
IntegratorType
Definition Integrator.h:46