libMesh
linear_solver.h
Go to the documentation of this file.
1 // The libMesh Finite Element Library.
2 // Copyright (C) 2002-2025 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner
3 
4 // This library is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU Lesser General Public
6 // License as published by the Free Software Foundation; either
7 // version 2.1 of the License, or (at your option) any later version.
8 
9 // This library 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 GNU
12 // Lesser General Public License for more details.
13 
14 // You should have received a copy of the GNU Lesser General Public
15 // License along with this library; if not, write to the Free Software
16 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 
18 
19 
20 #ifndef LIBMESH_LINEAR_SOLVER_H
21 #define LIBMESH_LINEAR_SOLVER_H
22 
23 // Local includes
24 #include "libmesh/libmesh_common.h"
25 #include "libmesh/enum_subset_solve_mode.h" // SUBSET_ZERO
26 #include "libmesh/reference_counted_object.h"
27 #include "libmesh/libmesh.h"
28 #include "libmesh/parallel_object.h"
29 
30 // C++ includes
31 #include <cstddef>
32 #include <vector>
33 #include <memory>
34 #include <optional>
35 
36 namespace libMesh
37 {
38 
39 // forward declarations
40 template <typename T> class SparseMatrix;
41 template <typename T> class NumericVector;
42 template <typename T> class ShellMatrix;
43 template <typename T> class Preconditioner;
44 class System;
45 class SolverConfiguration;
46 enum SolverPackage : int;
47 enum PreconditionerType : int;
48 enum SolverType : int;
50 
58 template <typename T>
59 class LinearSolver : public ReferenceCountedObject<LinearSolver<T>>,
60  public ParallelObject
61 {
62 public:
63 
68 
72  virtual ~LinearSolver ();
73 
78  static std::unique_ptr<LinearSolver<T>> build(const libMesh::Parallel::Communicator & comm_in,
79  const SolverPackage solver_package = libMesh::default_solver_package());
80 
85  bool initialized () const { return _is_initialized; }
86 
90  virtual void clear () {}
91 
96  virtual void init (const char * name = nullptr) = 0;
97 
106  virtual void init_names (const System &) {}
107 
111  SolverType solver_type () const { return _solver_type; }
112 
116  void set_solver_type (const SolverType st)
117  { _solver_type = st; }
118 
123 
128 
132  void attach_preconditioner(Preconditioner<T> * preconditioner);
133 
138  virtual void reuse_preconditioner(bool );
139 
145 
153  virtual void restrict_solve_to (const std::vector<unsigned int> * const dofs,
154  const SubsetSolveMode subset_solve_mode=SUBSET_ZERO);
155 
163  virtual std::pair<unsigned int, Real> solve (SparseMatrix<T> &, // System Matrix
164  NumericVector<T> &, // Solution vector
165  NumericVector<T> &, // RHS vector
166  const std::optional<double> tol = std::nullopt,
167  const std::optional<unsigned int> m_its = std::nullopt) = 0; // N. Iterations
168 
176  virtual std::pair<unsigned int, Real> adjoint_solve (SparseMatrix<T> &, // System Matrix
177  NumericVector<T> &, // Solution vector
178  NumericVector<T> &, // RHS vector
179  const std::optional<double> tol = std::nullopt,
180  const std::optional<unsigned int> m_its = std::nullopt); // N. Iterations
181 
187  virtual std::pair<unsigned int, Real> solve (SparseMatrix<T> &, // System Matrix
188  SparseMatrix<T> &, // Preconditioning Matrix
189  NumericVector<T> &, // Solution vector
190  NumericVector<T> &, // RHS vector
191  const std::optional<double> tol = std::nullopt,
192  const std::optional<unsigned int> m_its = std::nullopt) = 0; // N. Iterations
193 
200  std::pair<unsigned int, Real> solve (SparseMatrix<T> & matrix,
201  SparseMatrix<T> * precond_matrix,
202  NumericVector<T> &, // Solution vector
203  NumericVector<T> &, // RHS vector
204  const std::optional<double> tol = std::nullopt,
205  const std::optional<unsigned int> m_its = std::nullopt); // N. Iterations
206 
207 
208 
212  virtual std::pair<unsigned int, Real> solve (const ShellMatrix<T> & shell_matrix,
213  NumericVector<T> &, // Solution vector
214  NumericVector<T> &, // RHS vector
215  const std::optional<double> tol = std::nullopt,
216  const std::optional<unsigned int> m_its = std::nullopt) = 0; // N. Iterations
217 
218 
224  virtual std::pair<unsigned int, Real> solve (const ShellMatrix<T> & shell_matrix,
225  const SparseMatrix<T> & precond_matrix,
226  NumericVector<T> &, // Solution vector
227  NumericVector<T> &, // RHS vector
228  const std::optional<double> tol = std::nullopt,
229  const std::optional<unsigned int> m_its = std::nullopt) = 0; // N. Iterations
230 
231 
236  std::pair<unsigned int, Real> solve (const ShellMatrix<T> & matrix,
237  const SparseMatrix<T> * precond_matrix,
238  NumericVector<T> &, // Solution vector
239  NumericVector<T> &, // RHS vector
240  const std::optional<double> tol = std::nullopt,
241  const std::optional<unsigned int> m_its = std::nullopt); // N. Iterations
242 
243 
248  virtual void print_converged_reason() const;
249 
253  virtual LinearConvergenceReason get_converged_reason() const = 0;
254 
258  void set_solver_configuration(SolverConfiguration & solver_configuration);
259 
260 protected:
265 
270 
275 
280 
288 
294 
299  double get_real_solver_setting(const std::string & setting_name,
300  const std::optional<double> & setting,
301  const std::optional<double> default_value = std::nullopt);
302 
307  int get_int_solver_setting(const std::string & setting_name,
308  const std::optional<int> & setting,
309  const std::optional<int> default_value = std::nullopt);
310 };
311 
312 
313 
314 
315 /*----------------------- inline functions ----------------------------------*/
316 template <typename T>
317 inline
319 {
320  this->LinearSolver::clear ();
321 }
322 
323 template <typename T>
324 inline
326 {
327  return same_preconditioner;
328 }
329 
330 template <typename T>
331 inline
332 std::pair<unsigned int, Real>
334  SparseMatrix<T> * pc_mat,
335  NumericVector<T> & sol,
336  NumericVector<T> & rhs,
337  const std::optional<double> tol,
338  const std::optional<unsigned int> n_iter)
339 {
340  if (pc_mat)
341  return this->solve(mat, *pc_mat, sol, rhs, tol, n_iter);
342  else
343  return this->solve(mat, sol, rhs, tol, n_iter);
344 }
345 
346 
347 template <typename T>
348 inline
349 std::pair<unsigned int, Real>
351  const SparseMatrix<T> * pc_mat,
352  NumericVector<T> & sol,
353  NumericVector<T> & rhs,
354  const std::optional<double> tol,
355  const std::optional<unsigned int> n_iter)
356 {
357  if (pc_mat)
358  return this->solve(mat, *pc_mat, sol, rhs, tol, n_iter);
359  else
360  return this->solve(mat, sol, rhs, tol, n_iter);
361 }
362 
363 
364 } // namespace libMesh
365 
366 
367 #endif // LIBMESH_LINEAR_SOLVER_H
std::string name(const ElemQuality q)
This function returns a string containing some name for q.
Definition: elem_quality.C:42
virtual void clear()
Release all memory and clear data structures.
Definition: linear_solver.h:90
SolverType _solver_type
Enum stating which type of iterative solver to use.
virtual ~LinearSolver()
Destructor.
static std::unique_ptr< LinearSolver< T > > build(const libMesh::Parallel::Communicator &comm_in, const SolverPackage solver_package=libMesh::default_solver_package())
Builds a LinearSolver using the linear solver package specified by solver_package.
Definition: linear_solver.C:59
Preconditioner< T > * _preconditioner
Holds the Preconditioner object to be used for the linear solves.
virtual void print_converged_reason() const
Prints a useful message about why the latest linear solve con(di)verged.
LinearConvergenceReason
Linear solver convergence flags (taken from the PETSc flags).
Provides a uniform interface to vector storage schemes for different linear algebra libraries...
Definition: vector_fe_ex5.C:44
The libMesh namespace provides an interface to certain functionality in the library.
Generic sparse matrix.
Definition: vector_fe_ex5.C:46
SolverPackage default_solver_package()
Definition: libmesh.C:1117
double get_real_solver_setting(const std::string &setting_name, const std::optional< double > &setting, const std::optional< double > default_value=std::nullopt)
Get solver settings based on optional parameters and the solver configuration object.
This class provides a uniform interface for preconditioners.
LinearSolver(const libMesh::Parallel::Communicator &comm_in)
Constructor.
Definition: linear_solver.C:44
virtual void init(const char *name=nullptr)=0
Initialize data structures if not done so already.
bool initialized() const
Definition: linear_solver.h:85
Manages consistently variables, degrees of freedom, and coefficient vectors.
Definition: system.h:96
SolverConfiguration * _solver_configuration
Optionally store a SolverOptions object that can be used to set parameters like solver type...
void set_preconditioner_type(const PreconditionerType pct)
Sets the type of preconditioner to use.
This class stores solver configuration data, e.g.
void set_solver_type(const SolverType st)
Sets the type of solver to use.
virtual std::pair< unsigned int, Real > solve(SparseMatrix< T > &, NumericVector< T > &, NumericVector< T > &, const std::optional< double > tol=std::nullopt, const std::optional< unsigned int > m_its=std::nullopt)=0
This function calls the solver _solver_type preconditioned with the _preconditioner_type precondition...
void attach_preconditioner(Preconditioner< T > *preconditioner)
Attaches a Preconditioner object to be used.
void set_solver_configuration(SolverConfiguration &solver_configuration)
Set the solver configuration object.
PreconditionerType
Defines an enum for preconditioner types.
PreconditionerType preconditioner_type() const
SolverType
Defines an enum for iterative solver types.
virtual LinearConvergenceReason get_converged_reason() const =0
int get_int_solver_setting(const std::string &setting_name, const std::optional< int > &setting, const std::optional< int > default_value=std::nullopt)
Get solver settings based on optional parameters and the solver configuration object.
virtual void reuse_preconditioner(bool)
Set the same_preconditioner flag, which indicates if we reuse the same preconditioner for subsequent ...
PreconditionerType _preconditioner_type
Enum stating with type of preconditioner to use.
bool same_preconditioner
Boolean flag to indicate whether we want to use an identical preconditioner to the previous solve...
virtual void restrict_solve_to(const std::vector< unsigned int > *const dofs, const SubsetSolveMode subset_solve_mode=SUBSET_ZERO)
After calling this method, all successive solves will be restricted to the given set of dofs...
SolverPackage
Defines an enum for various linear solver packages.
Generic shell matrix, i.e.
virtual std::pair< unsigned int, Real > adjoint_solve(SparseMatrix< T > &, NumericVector< T > &, NumericVector< T > &, const std::optional< double > tol=std::nullopt, const std::optional< unsigned int > m_its=std::nullopt)
Function to solve the adjoint system.
SubsetSolveMode
defines an enum for the question what happens to the dofs outside the given subset when a system is s...
void ErrorVector unsigned int
Definition: adjoints_ex3.C:360
SolverType solver_type() const
virtual void init_names(const System &)
Apply names to the system to be solved.
bool _is_initialized
Flag indicating if the data structures have been initialized.