ASPECT
stokes_matrix_free.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2011 - 2025 by the authors of the ASPECT code.
3 
4  This file is part of ASPECT.
5 
6  ASPECT is free software; you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation; either version 2, or (at your option)
9  any later version.
10 
11  ASPECT is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with ASPECT; see the file LICENSE. If not see
18  <http://www.gnu.org/licenses/>.
19 */
20 
21 #ifndef _aspect_simulator_solver_stokes_matrix_free_h
22 #define _aspect_simulator_solver_stokes_matrix_free_h
23 
25 #include <aspect/global.h>
26 #include <aspect/parameters.h>
28 #include <aspect/utilities.h>
29 
30 #include <deal.II/multigrid/mg_transfer_matrix_free.h>
31 #include <deal.II/multigrid/mg_transfer_global_coarsening.templates.h>
32 
33 #include <deal.II/lac/solver_bicgstab.h>
34 
35 namespace aspect
36 {
40  using GMGNumberType = double;
41 
46  template <int dim>
48  {
49  public:
54  virtual void setup_dofs()=0;
55 
63  virtual void assemble()=0;
64 
70  virtual void build_preconditioner()=0;
71 
75  static
76  void declare_parameters (ParameterHandler &prm);
77 
81  virtual std::size_t get_dof_handler_memory_consumption() const = 0;
82 
86  virtual std::size_t get_mg_transfer_memory_consumption() const = 0;
87 
91  virtual std::size_t get_constraint_memory_consumption() const = 0;
92 
97  virtual std::size_t get_cell_data_memory_consumption() const = 0;
98  };
99 
103  template <int dim>
104  std::unique_ptr<StokesMatrixFreeHandler<dim>> create_matrix_free_solver(Simulator<dim> &simulator, const Parameters<dim> &parameters);
105 
106 
107 
108 }
109 
110 #endif
virtual std::size_t get_dof_handler_memory_consumption() const =0
const Simulator< dim > * simulator
virtual std::size_t get_mg_transfer_memory_consumption() const =0
virtual std::size_t get_cell_data_memory_consumption() const =0
std::unique_ptr< StokesMatrixFreeHandler< dim > > create_matrix_free_solver(Simulator< dim > &simulator, const Parameters< dim > &parameters)
double GMGNumberType
virtual void build_preconditioner()=0
static void declare_parameters(ParameterHandler &prm)
virtual std::size_t get_constraint_memory_consumption() const =0