6#include <deal.II/lac/diagonal_matrix.h>
7#include <deal.II/lac/precondition.h>
8#include <deal.II/lac/solver_control.h>
9#include <deal.II/lac/solver_selector.h>
23#include <prismspf/config.h>
27template <
unsigned int dim,
unsigned int degree,
typename number>
34template <
unsigned int dim,
unsigned int degree,
typename number>
42 dealii::PreconditionChebyshev<MFOperator<dim, degree, number>,
44 dealii::DiagonalMatrix<BlockVector<number>>>;
53 :
SolverBase<dim, degree, number>(_solve_block, _solve_context)
74 init(
const std::list<DependencyMap> &all_dependeny_sets)
override
176 dealii::PreconditionIdentity());
186 catch (dealii::SolverControl::NoConvergence &exc)
189 <<
"[Increment " <<
solve_context->get_simulation_timer().get_increment()
191 <<
"Warning: linear solver did not converge as per set tolerances before "
194 if (
solve_context->get_user_inputs().output_parameters.should_output(
198 <<
" Linear solve final residual : "
222 value *= std::sqrt(
solve_context->get_triangulation_manager().get_volume());
226 value *= std::sqrt(
double(
solve_block.field_indices.size()));
249 precond_data.smoothing_range = chebyshev_params.smoothing_range;
250 precond_data.eig_cg_n_iterations = chebyshev_params.eig_cg_n_iterations;
264 const typename dealii::SolverRichardson<BlockVector<number>>::AdditionalData
265 local_richardson_parameters(richardson_parameters.omega,
266 richardson_parameters.use_preconditioned_residual);
267 const typename dealii::SolverBicgstab<BlockVector<number>>::AdditionalData
268 local_bicgstab_parameters(bicgstab_parameters.exact_residual,
269 bicgstab_parameters.breakdown);
270 const typename dealii::SolverGMRES<BlockVector<number>>::AdditionalData
271 local_gmres_parameters(gmres_parameters.max_basis_size,
272 gmres_parameters.right_preconditioning,
273 gmres_parameters.use_default_residual,
274 gmres_parameters.force_re_orthogonalization,
275 gmres_parameters.batched_mode,
276 gmres_parameters.orthogonalization_strategy);
277 const typename dealii::SolverFGMRES<BlockVector<number>>::AdditionalData
278 local_fgmres_parameters(gmres_parameters.max_basis_size,
279 gmres_parameters.orthogonalization_strategy);
281 lin_solver.set_data(local_richardson_parameters);
282 lin_solver.set_data(local_bicgstab_parameters);
325PRISMS_PF_END_NAMESPACE
static dealii::ConditionalOStream & pout_summary()
Log output stream for writing a summary.log file.
Definition conditional_ostreams.cc:35
static dealii::ConditionalOStream & pout_base()
Generic parallel output stream. Used for essential information in release and debug mode.
Definition conditional_ostreams.cc:44
BlockVector< number > inhomogeneous_values
Vector containing only the inhomogeneous constraints (namely, non-zero Dirichlet values)
Definition linear_solver.h:314
void initialize_preconditioner()
Definition linear_solver.h:232
MFOperator< dim, degree, number > rhs_operator
Matrix free operators.
Definition linear_solver.h:210
void initialize_solver()
Definition linear_solver.h:259
BlockVector< number > rhs_vector
Definition linear_solver.h:213
const LinearSolverParameters & lin_params() const
Linear solver parameters.
Definition linear_solver.h:295
double normalization_value()
Definition linear_solver.h:216
PreconditionChebyshev precond_chebyshev
Definition linear_solver.h:321
int do_linear_solve(BlockVector< number > &b_vector, MFOperator< dim, degree, number > &lhs_matrix, BlockVector< number > &x_vector)
Definition linear_solver.h:164
PreconditionChebyshev::AdditionalData precond_data
Definition linear_solver.h:322
MFOperator< dim, degree, number > lhs_operator
Definition linear_solver.h:212
void init(const std::list< DependencyMap > &all_dependeny_sets) override
Initialize the solver.
Definition linear_solver.h:74
BlockVector< number > inhomogeneous_rhs
Result of the linear operator applied to the inhomogeneous values.
Definition linear_solver.h:319
dealii::SolverSelector< BlockVector< number > > lin_solver
Solver. Can switch between different linear solvers.
Definition linear_solver.h:308
dealii::PreconditionChebyshev< MFOperator< dim, degree, number >, BlockVector< number >, dealii::DiagonalMatrix< BlockVector< number > > > PreconditionChebyshev
Definition linear_solver.h:41
void initialize_chebyshev()
Definition linear_solver.h:245
dealii::SolverControl linear_solver_control
Solver control. Contains max iterations and tolerance.
Definition linear_solver.h:303
void solve_impl() override
Solve for a single update step.
Definition linear_solver.h:122
LinearSolver(SolveBlock _solve_block, const SolveContext< dim, degree, number > &_solve_context)
Constructor.
Definition linear_solver.h:51
void reinit() override
Reinitialize the solver.
Definition linear_solver.h:107
This class exists to evaluate a single user-defined operator for the matrix-free implementation of so...
Definition mf_operator.h:55
void eval_matrix_diagonal()
Evaluate matrix diagonal (and inverse).
Definition mf_operator.cc:221
void reinit_matrix_diagonal(const BlockVector< number > &shape)
Reinit diagonal matrix to have the correct shape.
Definition mf_operator.cc:213
This class contains the user implementation of each PDE operator.
Definition pde_operator_base.h:27
Structure to hold the attributes of a solve-block.
Definition solve_block.h:59
This class provides context for a solver with ptrs to all the relevant dependencies.
Definition solve_context.h:34
virtual void reinit()
Reinitialize the solution vectors & apply constraints.
Definition solver_base.h:97
SolverBase(SolveBlock _solve_block, const SolveContext< dim, degree, number > &_solve_context)
Constructor.
Definition solver_base.h:36
virtual void init(const std::list< DependencyMap > &all_dependeny_sets)
Initialize the solver.
Definition solver_base.h:84
GroupSolutionHandler< dim, number > solutions
Solution vectors for fields handled by this solver.
Definition solver_base.h:271
const SolveContext< dim, degree, number > * solve_context
Solver context provides access to external information.
Definition solver_base.h:266
SolveBlock solve_block
Information about the solve block this handler is responsible for.
Definition solver_base.h:261
static void start_section(const char *name)
Start a new timer section.
Definition timer.cc:116
static void end_section(const char *name)
End the timer section.
Definition timer.cc:127
dealii::LinearAlgebra::distributed::BlockVector< number > BlockVector
Typedef for solution block vector.
Definition group_solution_handler.h:29
Definition conditional_ostreams.cc:20
Struct that stores relevant linear solve information of a certain solve block.
Definition linear_solve_parameters.h:25
unsigned int max_iterations
Definition linear_solve_parameters.h:36
dealii::SolverGMRES ::AdditionalData gmres_parameters
Definition linear_solve_parameters.h:45
SolverToleranceType tolerance_type
Definition linear_solve_parameters.h:33
dealii::PreconditionChebyshev ::AdditionalData chebyshev_parameters
Definition linear_solve_parameters.h:41
dealii::SolverBicgstab ::AdditionalData bicgstab_parameters
Definition linear_solve_parameters.h:44
dealii::SolverRichardson ::AdditionalData richardson_parameters
Definition linear_solve_parameters.h:43
SolverToleranceType
Solver tolerance type.
Definition type_enums.h:112
@ RMSEPerField
The mean local error averaged over each field is lower than the tolerance.
Definition type_enums.h:124
@ AbsoluteResidual
Legacy.
Definition type_enums.h:116
@ RMSETotal
The sum of the average local errors of each field is lower than the tolerance.
Definition type_enums.h:132
@ IntegratedPerField
The integrated error averaged over each field is lower than the tolerance.
Definition type_enums.h:128
@ Chebyshev
Definition type_enums.h:145
@ None
Definition type_enums.h:144