ryujin 2.1.1 revision 7ab52d499a3934b3ba6afcabe5103994024860b0
parabolic_solver.h
Go to the documentation of this file.
1//
2// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
3// Copyright (C) 2023 - 2024 by the ryujin authors
4//
5
6#pragma once
7
8#include "hyperbolic_module.h"
9
10#include <compile_time_options.h>
11
12#include <convenience_macros.h>
13#include <initial_values.h>
14#include <offline_data.h>
15#include <simd.h>
16#include <sparse_matrix_simd.h>
17
19
20#include <deal.II/base/mg_level_object.h>
21#include <deal.II/base/parameter_acceptor.h>
22#include <deal.II/base/timer.h>
23#include <deal.II/lac/la_parallel_block_vector.h>
24#include <deal.II/lac/precondition.h>
25#include <deal.II/lac/sparse_matrix.templates.h>
26#include <deal.II/lac/vector.h>
27#include <deal.II/matrix_free/matrix_free.h>
28#include <deal.II/multigrid/mg_base.h>
29#include <deal.II/multigrid/mg_smoother.h>
30#include <deal.II/multigrid/mg_transfer_matrix_free.h>
31
32namespace ryujin
33{
34 namespace NavierStokes
35 {
36 template <int, typename>
37 class DiagonalMatrix;
38
111 template <typename Description, int dim, typename Number = double>
112 class ParabolicSolver final : public dealii::ParameterAcceptor
113 {
114 public:
119
121
122 using View =
123 typename Description::template HyperbolicSystemView<dim, Number>;
124
126
127 using ScalarNumber = typename View::ScalarNumber;
128
129 static constexpr auto problem_dimension = View::problem_dimension;
130
131 using state_type = typename View::state_type;
132
134
136
138
140
144
149 const MPI_Comm &mpi_communicator,
150 std::map<std::string, dealii::Timer> &computing_timer,
151 const HyperbolicSystem &hyperbolic_system,
152 const ParabolicSystem &parabolic_system,
153 const OfflineData<dim, Number> &offline_data,
154 const InitialValues<Description, dim, Number> &initial_values,
155 const std::string &subsection = "ParabolicSolver");
156
162 void prepare();
163
165
169
175 void backward_euler_step(const StateVector &old_state_vector,
176 const Number old_t,
177 StateVector &new_state_vector,
178 Number tau,
179 const IDViolationStrategy id_violation_strategy,
180 const bool reinitialize_gmg) const;
181
187 void print_solver_statistics(std::ostream &output) const;
188
190
194
195 ACCESSOR_READ_ONLY(n_restarts)
196 ACCESSOR_READ_ONLY(n_warnings)
197
198 //@}
199
200 private:
205
206 bool use_gmg_velocity_;
207 ACCESSOR_READ_ONLY(use_gmg_velocity)
208
209 bool use_gmg_internal_energy_;
210 ACCESSOR_READ_ONLY(use_gmg_internal_energy)
211
212 Number tolerance_;
213 bool tolerance_linfty_norm_;
214
215 unsigned int gmg_max_iter_vel_;
216 unsigned int gmg_max_iter_en_;
217 double gmg_smoother_range_vel_;
218 double gmg_smoother_range_en_;
219 double gmg_smoother_max_eig_vel_;
220 double gmg_smoother_max_eig_en_;
221 unsigned int gmg_smoother_degree_;
222 unsigned int gmg_smoother_n_cg_iter_;
223 unsigned int gmg_min_level_;
224
226
230
231 // FIXME: refactor
232 static constexpr unsigned int order_fe = 1;
233 static constexpr unsigned int order_quad = 2;
234
235 const MPI_Comm &mpi_communicator_;
236 std::map<std::string, dealii::Timer> &computing_timer_;
237
238 dealii::SmartPointer<const HyperbolicSystem> hyperbolic_system_;
239 dealii::SmartPointer<const ParabolicSystem> parabolic_system_;
240 dealii::SmartPointer<const ryujin::OfflineData<dim, Number>>
241 offline_data_;
242 dealii::SmartPointer<
244 initial_values_;
245
246 mutable unsigned int n_restarts_;
247 mutable unsigned int n_warnings_;
248 mutable double n_iterations_velocity_;
249 mutable double n_iterations_internal_energy_;
250
251 mutable dealii::MatrixFree<dim, Number> matrix_free_;
252
253 mutable BlockVector velocity_;
254 mutable BlockVector velocity_rhs_;
255 mutable ScalarVector internal_energy_;
256 mutable ScalarVector internal_energy_rhs_;
257 mutable ScalarVector density_;
258
259 mutable dealii::MGLevelObject<dealii::MatrixFree<dim, float>>
260 level_matrix_free_;
261 mutable dealii::MGConstrainedDoFs mg_constrained_dofs_;
262 mutable dealii::MGLevelObject<
263 dealii::LinearAlgebra::distributed::Vector<float>>
264 level_density_;
265 mutable MGTransferVelocity<dim, float> mg_transfer_velocity_;
266 mutable dealii::MGLevelObject<VelocityMatrix<dim, float, Number>>
267 level_velocity_matrices_;
268 mutable MGTransferEnergy<dim, float> mg_transfer_energy_;
269 mutable dealii::MGLevelObject<EnergyMatrix<dim, float, Number>>
270 level_energy_matrices_;
271
272 mutable dealii::mg::SmootherRelaxation<
273 dealii::PreconditionChebyshev<
275 dealii::LinearAlgebra::distributed::BlockVector<float>,
277 dealii::LinearAlgebra::distributed::BlockVector<float>>
278 mg_smoother_velocity_;
279
280 mutable dealii::mg::SmootherRelaxation<
281 dealii::PreconditionChebyshev<
283 dealii::LinearAlgebra::distributed::Vector<float>>,
284 dealii::LinearAlgebra::distributed::Vector<float>>
285 mg_smoother_energy_;
286
288 };
289
290 } // namespace NavierStokes
291} /* namespace ryujin */
void backward_euler_step(const StateVector &old_state_vector, const Number old_t, StateVector &new_state_vector, Number tau, const IDViolationStrategy id_violation_strategy, const bool reinitialize_gmg) const
typename Description::ParabolicSystem ParabolicSystem
typename View::ScalarNumber ScalarNumber
typename View::StateVector StateVector
typename Description::template HyperbolicSystemView< dim, Number > View
void print_solver_statistics(std::ostream &output) const
typename Description::HyperbolicSystem HyperbolicSystem
Vectors::ScalarVector< Number > ScalarVector
ParabolicSolver(const MPI_Comm &mpi_communicator, std::map< std::string, dealii::Timer > &computing_timer, const HyperbolicSystem &hyperbolic_system, const ParabolicSystem &parabolic_system, const OfflineData< dim, Number > &offline_data, const InitialValues< Description, dim, Number > &initial_values, const std::string &subsection="ParabolicSolver")
Vectors::BlockVector< Number > BlockVector
typename View::state_type state_type
#define ACCESSOR_READ_ONLY(member)
dealii::LinearAlgebra::distributed::Vector< Number > ScalarVector
Definition: state_vector.h:25
dealii::LinearAlgebra::distributed::BlockVector< Number > BlockVector
Definition: state_vector.h:31
std::tuple< MultiComponentVector< Number, problem_dim >, MultiComponentVector< Number, prec_dim >, BlockVector< Number > > StateVector
Definition: state_vector.h:45
Euler::HyperbolicSystem HyperbolicSystem
Definition: description.h:31
NavierStokes::ParabolicSystem ParabolicSystem
Definition: description.h:36