ASPECT
simulator.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2011 - 2024 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 
22 #ifndef _aspect_simulator_h
23 #define _aspect_simulator_h
24 
25 #include <deal.II/base/timer.h>
26 #include <deal.II/base/parameter_handler.h>
27 #include <deal.II/base/conditional_ostream.h>
28 #include <deal.II/base/symmetric_tensor.h>
29 
30 DEAL_II_DISABLE_EXTRA_DIAGNOSTICS
31 
32 #include <deal.II/lac/affine_constraints.h>
33 
34 #include <deal.II/distributed/tria.h>
35 
36 #include <deal.II/dofs/dof_handler.h>
37 #include <deal.II/dofs/dof_tools.h>
38 
39 #include <deal.II/fe/fe_system.h>
40 #include <deal.II/fe/mapping.h>
41 #include <deal.II/base/tensor_function.h>
42 
43 DEAL_II_ENABLE_EXTRA_DIAGNOSTICS
44 
45 #include <aspect/global.h>
71 #include <aspect/advection_field.h>
72 
73 #include <boost/iostreams/tee.hpp>
74 #include <boost/iostreams/stream.hpp>
75 
76 #include <memory>
77 #include <thread>
78 
79 namespace WorldBuilder
80 {
81  class World;
82 }
83 
84 
85 namespace aspect
86 {
87  template <int dim>
88  class MeltHandler;
89 
90  template <int dim>
91  class NewtonHandler;
92 
93  template <int dim>
95 
96  namespace StokesSolver
97  {
98  template <int dim>
99  class Direct;
100  }
101 
102  template <int dim, int velocity_degree>
104 
105  namespace MeshDeformation
106  {
107  template <int dim>
109  }
110 
111  template <int dim>
113 
114  namespace internal
115  {
116  namespace Assembly
117  {
118  namespace Scratch
119  {
120  template <int dim> struct StokesPreconditioner;
121  template <int dim> struct StokesSystem;
122  template <int dim> struct AdvectionSystem;
123  }
124 
125  namespace CopyData
126  {
127  template <int dim> struct StokesPreconditioner;
128  template <int dim> struct StokesSystem;
129  template <int dim> struct AdvectionSystem;
130  }
131  }
132  }
133 
134  namespace Assemblers
135  {
136  template <int dim> class Interface;
137  template <int dim> class Manager;
138  }
139 
141  {
145  double residual;
146  double residual_old;
149  std::pair<double,double> stokes_residuals;
150  };
151 
155  template <int dim>
157  {
159  :
160  scalar_moment_of_inertia(numbers::signaling_nan<double>()),
161  scalar_angular_momentum(numbers::signaling_nan<double>()),
162  scalar_rotation(numbers::signaling_nan<double>()),
163  tensor_moment_of_inertia(numbers::signaling_nan<SymmetricTensor<2,dim>>()),
164  tensor_angular_momentum(numbers::signaling_nan<Tensor<1,dim>>()),
165  tensor_rotation(numbers::signaling_nan<Tensor<1,dim>>())
166  {};
167 
175 
179  SymmetricTensor<2,dim> tensor_moment_of_inertia;
180  Tensor<1,dim> tensor_angular_momentum;
181  Tensor<1,dim> tensor_rotation;
182  };
183 
187  DeclExceptionMsg(ExcNonlinearSolverNoConvergence,
188  "Nonlinear solver failed to converge in the prescribed number of steps. "
189  "Consider changing `Max nonlinear iterations` or `Nonlinear solver failure "
190  "strategy`.");
191 
199  template <int dim>
201  {
202  public:
216  Simulator (const MPI_Comm mpi_communicator,
217  ParameterHandler &prm);
218 
223  ~Simulator ();
224 
239  static
240  void declare_parameters (ParameterHandler &prm, const unsigned int mpi_rank);
241 
250  void run ();
251 
263  void
264  write_plugin_graph (std::ostream &output_stream) const;
265 
270 
275 
277 
278  private:
279 
299 
317  {
318  IntermediaryConstructorAction (const std::function<void ()> &action);
319  };
320 
335  void setup_dofs ();
336 
345  void setup_introspection ();
346 
358  void set_initial_temperature_and_compositional_fields ();
359 
375  void compute_initial_pressure_field ();
376 
382  void compute_initial_velocity_boundary_constraints (AffineConstraints<double> &constraints);
383 
389  void compute_current_velocity_boundary_constraints (AffineConstraints<double> &constraints);
390 
403  void compute_current_constraints ();
404 
418  double compute_pressure_scaling_factor () const;
419 
431  void start_timestep ();
432 
440  void solve_timestep ();
441 
453  void solve_no_advection_no_stokes ();
454 
465  void solve_no_advection_single_stokes ();
466 
478  void solve_no_advection_single_stokes_first_timestep_only ();
479 
492  void solve_no_advection_iterated_stokes ();
493 
506  void solve_no_advection_iterated_defect_correction_stokes ();
507 
519  void solve_single_advection_no_stokes ();
520 
532  void solve_single_advection_single_stokes ();
533 
546  void solve_single_advection_iterated_stokes ();
547 
560  void solve_single_advection_iterated_defect_correction_stokes ();
561 
581  void solve_single_advection_iterated_newton_stokes (bool use_newton_iterations);
582 
594  void solve_iterated_advection_no_stokes ();
595 
608  void solve_iterated_advection_and_stokes ();
609 
623  void solve_iterated_advection_and_defect_correction_stokes ();
624 
643  void solve_iterated_advection_and_newton_stokes (bool use_newton_iterations);
644 
653  void build_stokes_preconditioner ();
654 
662  void build_advection_preconditioner (const AdvectionField &advection_field,
664  const double diagonal_strengthening);
665 
672  void assemble_stokes_system ();
673 
688  double assemble_and_solve_temperature (const double &initial_residual = 0,
689  double *residual = nullptr);
690 
706  std::vector<double> assemble_and_solve_composition (const std::vector<double> &initial_residual = {},
707  const unsigned int nonlinear_iteration = 0,
708  std::vector<double> *residual = nullptr);
709 
724  double assemble_and_solve_stokes (const double &initial_nonlinear_residual = 0,
725  double *nonlinear_residual = nullptr);
726 
739  void do_one_defect_correction_Stokes_step(DefectCorrectionResiduals &dcr,
740  const bool use_picard);
741 
749  void assemble_advection_system (const AdvectionField &advection_field);
750 
761  double solve_advection (const AdvectionField &advection_field);
762 
767  void interpolate_particle_properties (const std::vector<AdvectionField> &advection_fields);
768 
845  std::pair<double,double>
846  solve_stokes (LinearAlgebra::BlockVector &solution_vector);
847 
860  void postprocess ();
861 
877  void refine_mesh (const unsigned int max_grid_level);
878 
894  unsigned int determine_last_good_snapshot() const;
895 
903  unsigned int determine_resume_snapshot() const;
904 
916  void create_snapshot();
917 
931  void resume_from_snapshot();
932 
939  template <class Archive>
940  void serialize (Archive &ar, const unsigned int version);
957  Table<2,DoFTools::Coupling>
958  setup_system_matrix_coupling () const;
959 
967  void setup_system_matrix (const std::vector<IndexSet> &system_partitioning);
968 
980  void setup_system_preconditioner (const std::vector<IndexSet> &system_partitioning);
981 
1003  std::unique_ptr<Assemblers::Manager<dim>> assemblers;
1004 
1013  void set_assemblers ();
1014 
1025  void set_advection_assemblers ();
1026 
1036  void set_stokes_assemblers ();
1037 
1044  void assemble_stokes_preconditioner ();
1045 
1053  void
1054  local_assemble_stokes_preconditioner (const typename DoFHandler<dim>::active_cell_iterator &cell,
1057 
1065  void
1066  copy_local_to_global_stokes_preconditioner (const internal::Assembly::CopyData::StokesPreconditioner<dim> &data);
1067 
1075  void
1076  local_assemble_stokes_system (const typename DoFHandler<dim>::active_cell_iterator &cell,
1079 
1087  void
1088  copy_local_to_global_stokes_system (const internal::Assembly::CopyData::StokesSystem<dim> &data);
1089 
1097  void
1098  local_assemble_advection_face_terms(const AdvectionField &advection_field,
1099  const typename DoFHandler<dim>::active_cell_iterator &cell,
1109  void
1110  local_assemble_advection_system (const AdvectionField &advection_field,
1111  const Vector<double> &viscosity_per_cell,
1112  const typename DoFHandler<dim>::active_cell_iterator &cell,
1115 
1123  void
1124  copy_local_to_global_advection_system (const AdvectionField &advection_field,
1126 
1151  void make_pressure_rhs_compatible(LinearAlgebra::BlockVector &vector);
1152 
1162  template <typename T>
1163  void get_artificial_viscosity (Vector<T> &viscosity_per_cell,
1164  const AdvectionField &advection_field,
1165  const bool skip_interior_cells = false) const;
1166 
1199  double normalize_pressure(LinearAlgebra::BlockVector &vector) const;
1200 
1240  void denormalize_pressure(const double pressure_adjustment,
1241  LinearAlgebra::BlockVector &vector) const;
1242 
1251  void apply_limiter_to_dg_solutions (const AdvectionField &advection_field);
1252 
1269  void compute_unique_advection_support_points (const std::vector<AdvectionField> &advection_fields,
1270  std::vector<Point<dim>> &unique_support_points,
1271  std::vector<std::vector<unsigned int>> &support_point_index_by_field) const;
1272 
1295  void compute_reactions ();
1296 
1306  void update_solution_vectors_with_reaction_results (const unsigned int block_index,
1307  const LinearAlgebra::BlockVector &distributed_vector,
1308  const LinearAlgebra::BlockVector &distributed_reaction_vector);
1309 
1320  void initialize_current_linearization_point ();
1321 
1341  void interpolate_material_output_into_advection_field (const std::vector<AdvectionField> &adv_field);
1342 
1343 
1351  void interpolate_onto_velocity_system(const TensorFunction<1,dim> &func,
1352  LinearAlgebra::Vector &vec) const;
1353 
1371  double perform_line_search(const DefectCorrectionResiduals &dcr,
1372  const bool use_picard,
1373  const LinearAlgebra::BlockVector &search_direction);
1374 
1389  void setup_nullspace_constraints(AffineConstraints<double> &constraints);
1390 
1391 
1404  void remove_nullspace(LinearAlgebra::BlockVector &solution,
1405  LinearAlgebra::BlockVector &distributed_stokes_solution) const;
1406 
1422  compute_net_angular_momentum(const bool use_constant_density,
1423  const LinearAlgebra::BlockVector &solution,
1424  const bool limit_to_top_faces = false) const;
1425 
1442  void remove_net_angular_momentum(const bool use_constant_density,
1443  LinearAlgebra::BlockVector &relevant_dst,
1444  LinearAlgebra::BlockVector &tmp_distributed_stokes,
1445  const bool limit_to_top_faces = false) const;
1446 
1454  void replace_outflow_boundary_ids(const unsigned int boundary_id_offset,
1455  const bool is_composition,
1456  const unsigned int composition_index);
1457 
1465  void restore_outflow_boundary_ids(const unsigned int boundary_id_offset);
1466 
1480  void remove_net_linear_momentum(const bool use_constant_density,
1481  LinearAlgebra::BlockVector &relevant_dst,
1482  LinearAlgebra::BlockVector &tmp_distributed_stokes) const;
1483 
1491  double get_maximal_velocity (const LinearAlgebra::BlockVector &solution) const;
1492 
1505  double get_entropy_variation (const double average_field,
1506  const AdvectionField &advection_field) const;
1507 
1516  std::pair<double,double>
1517  get_extrapolated_advection_field_range (const AdvectionField &advection_field) const;
1518 
1527  void exchange_refinement_flags();
1528 
1529 
1538  void maybe_write_timing_output () const;
1539 
1547  bool maybe_write_checkpoint (const std::time_t last_checkpoint_time,
1548  const bool force_writing_checkpoint);
1549 
1566  bool maybe_do_initial_refinement (const unsigned int max_refinement_level);
1567 
1576  void maybe_refine_mesh (const double new_time_step,
1577  unsigned int &max_refinement_level);
1578 
1586  void advance_time (const double step_size);
1587 
1595  double
1596  compute_viscosity(internal::Assembly::Scratch::AdvectionSystem<dim> &scratch,
1597  const double global_u_infty,
1598  const double global_field_variation,
1599  const double average_field,
1600  const double global_entropy_variation,
1601  const double cell_diameter,
1602  const AdvectionField &advection_field) const;
1603 
1612  void
1613  compute_advection_system_residual(internal::Assembly::Scratch::AdvectionSystem<dim> &scratch,
1614  const double average_field,
1615  const AdvectionField &advection_field,
1616  double &max_residual,
1617  double &max_velocity,
1618  double &max_density,
1619  double &max_specific_heat,
1620  double &conductivity) const;
1621 
1636  bool
1637  stokes_matrix_depends_on_solution () const;
1638 
1648  bool
1649  stokes_A_block_is_symmetric () const;
1650 
1663  void
1664  check_consistency_of_formulation ();
1665 
1671  void
1672  select_default_solver_and_averaging ();
1673 
1684  void
1685  check_consistency_of_boundary_conditions () const;
1686 
1690  double
1691  compute_initial_newton_residual ();
1692 
1701  double
1702  compute_Eisenstat_Walker_linear_tolerance(const bool EisenstatWalkerChoiceOne,
1703  const double maximum_linear_stokes_solver_tolerance,
1704  const double linear_stokes_solver_tolerance,
1705  const double stokes_residual,
1706  const double newton_residual,
1707  const double newton_residual_old);
1708 
1718  void output_statistics();
1719 
1731  double
1732  compute_initial_stokes_residual();
1733 
1744 
1750  std::unique_ptr<MeltHandler<dim>> melt_handler;
1751 
1757  std::unique_ptr<NewtonHandler<dim>> newton_handler;
1758 
1760 
1762 
1770  std::unique_ptr<VolumeOfFluidHandler<dim>> volume_of_fluid_handler;
1771 
1773 
1774 
1776 
1781  std::ofstream log_file_stream;
1782 
1783  using TeeDevice = boost::iostreams::tee_device<std::ostream, std::ofstream>;
1784  using TeeStream = boost::iostreams::stream<TeeDevice>;
1785 
1788 
1793  ConditionalOStream pcout;
1794 
1804  TableHandler statistics;
1805 
1822 
1823  mutable TimerOutput computing_timer;
1824 
1829  Timer wall_timer;
1830 
1836 
1842  unsigned int last_checkpoint_id;
1843 
1852 
1861  const std::shared_ptr<InitialTopographyModel::Interface<dim>> initial_topography_model;
1862  const std::unique_ptr<GeometryModel::Interface<dim>> geometry_model;
1864  const std::unique_ptr<MaterialModel::Interface<dim>> material_model;
1865  const std::unique_ptr<GravityModel::Interface<dim>> gravity_model;
1866 
1871  const std::unique_ptr<PrescribedStokesSolution::Interface<dim>> prescribed_stokes_solution;
1872 
1883  std::shared_ptr<InitialTemperature::Manager<dim>> initial_temperature_manager;
1884  std::shared_ptr<InitialComposition::Manager<dim>> initial_composition_manager;
1885 
1886  const std::unique_ptr<AdiabaticConditions::Interface<dim>> adiabatic_conditions;
1887 #ifdef ASPECT_WITH_WORLD_BUILDER
1888 
1899  std::shared_ptr<WorldBuilder::World> world_builder;
1900 #endif
1903  const std::unique_ptr<BoundaryHeatFlux::Interface<dim>> boundary_heat_flux;
1904 
1912  double time;
1913  double time_step;
1915  unsigned int timestep_number;
1916  unsigned int pre_refinement_step;
1917  unsigned int nonlinear_iteration;
1945  parallel::distributed::Triangulation<dim> triangulation;
1948 
1951 
1960  std::unique_ptr<Mapping<dim>> mapping;
1961 
1962  const FESystem<dim> finite_element;
1963 
1964  DoFHandler<dim> dof_handler;
1965 
1967 
1971  std::vector<Particle::Manager<dim>> particle_managers;
1972 
1984  AffineConstraints<double> constraints;
1985  AffineConstraints<double> current_constraints;
1986 
1992 
1999 
2007 
2027 
2033 
2047 
2052 
2054 
2055  // only used if is_compressible()
2057 
2058  // only used if operator split is enabled
2060 
2061 
2062 
2063  std::unique_ptr<LinearAlgebra::PreconditionAMG> Amg_preconditioner;
2064  std::unique_ptr<LinearAlgebra::PreconditionBase> Mp_preconditioner;
2065 
2071 
2087 
2093 
2099 
2104 
2114  std::unique_ptr<MeshDeformation::MeshDeformationHandler<dim>> mesh_deformation;
2115 
2119  std::unique_ptr<StokesMatrixFreeHandler<dim>> stokes_matrix_free;
2120 
2124  std::unique_ptr<StokesSolver::Direct<dim>> stokes_direct;
2125 
2126 
2127  friend class boost::serialization::access;
2128  friend class SimulatorAccess<dim>;
2130  friend class VolumeOfFluidHandler<dim>;
2131  friend class StokesMatrixFreeHandler<dim>;
2132  template <int dimension, int velocity_degree> friend class StokesMatrixFreeHandlerLocalSmoothingImplementation;
2133  template <int dimension, int velocity_degree> friend class StokesMatrixFreeHandlerGlobalCoarseningImplementation;
2134  friend struct Parameters<dim>;
2135  };
2136 }
2137 
2138 
2139 #endif
The NullspaceRemoval struct.
Definition: parameters.h:134
unsigned int nonlinear_iteration
Definition: simulator.h:1917
BoundaryVelocity::Manager< dim > boundary_velocity_manager
Definition: simulator.h:1901
const std::unique_ptr< AdiabaticConditions::Interface< dim > > adiabatic_conditions
Definition: simulator.h:1886
std::shared_ptr< InitialComposition::Manager< dim > > initial_composition_manager
Definition: simulator.h:1884
void write_plugin_graph(std::ostream &output_stream)
parallel::distributed::Triangulation< dim > triangulation
Definition: simulator.h:1945
TimerOutput computing_timer
Definition: simulator.h:1823
BoundaryTemperature::Manager< dim > boundary_temperature_manager
Definition: simulator.h:1867
boost::iostreams::tee_device< std::ostream, std::ofstream > TeeDevice
Definition: simulator.h:1783
std::unique_ptr< StokesSolver::Direct< dim > > stokes_direct
Definition: simulator.h:2124
::TrilinosWrappers::MPI::BlockVector BlockVector
Definition: global.h:270
double pressure_scaling
Definition: simulator.h:1998
Tensor< 1, dim > tensor_rotation
Definition: simulator.h:181
double old_time_step
Definition: simulator.h:1914
Tensor< 1, dim > tensor_angular_momentum
Definition: simulator.h:180
AffineConstraints< double > constraints
Definition: simulator.h:1984
bool assemble_newton_stokes_system
Definition: simulator.h:2098
LinearAlgebra::BlockVector old_solution
Definition: simulator.h:2049
const IntermediaryConstructorAction post_geometry_model_creation_action
Definition: simulator.h:1863
std::unique_ptr< VolumeOfFluidHandler< dim > > volume_of_fluid_handler
Definition: simulator.h:1770
bool rebuild_stokes_matrix
Definition: simulator.h:2086
Parameters< dim > parameters
Definition: simulator.h:1743
SymmetricTensor< 2, dim > tensor_moment_of_inertia
Definition: simulator.h:179
AffineConstraints< double > current_constraints
Definition: simulator.h:1985
std::unique_ptr< MeshDeformation::MeshDeformationHandler< dim > > mesh_deformation
Definition: simulator.h:2114
LinearAlgebra::BlockVector system_rhs
Definition: simulator.h:2051
std::pair< double, double > stokes_residuals
Definition: simulator.h:149
std::vector< Particle::Manager< dim > > particle_managers
Definition: simulator.h:1971
std::thread output_statistics_thread
Definition: simulator.h:1851
LateralAveraging< dim > lateral_averaging
Definition: simulator.h:1936
DeclExceptionMsg(ExcNonlinearSolverNoConvergence, "Nonlinear solver failed to converge in the prescribed number of steps. " "Consider changing `Max nonlinear iterations` or `Nonlinear solver failure " "strategy`.")
TeeStream iostream_tee_stream
Definition: simulator.h:1787
::TrilinosWrappers::MPI::Vector Vector
Definition: global.h:264
MeshRefinement::Manager< dim > mesh_refinement_manager
Definition: simulator.h:1949
std::size_t statistics_last_write_size
Definition: simulator.h:1820
const std::unique_ptr< MaterialModel::Interface< dim > > material_model
Definition: simulator.h:1864
unsigned int nonlinear_solver_failures
Definition: simulator.h:1918
double last_pressure_normalization_adjustment
Definition: simulator.h:1991
::TrilinosWrappers::BlockSparseMatrix BlockSparseMatrix
Definition: global.h:281
double total_walltime_until_last_snapshot
Definition: simulator.h:1835
void declare_parameters(ParameterHandler &prm)
const std::unique_ptr< GeometryModel::Interface< dim > > geometry_model
Definition: simulator.h:1862
LinearAlgebra::BlockVector operator_split_reaction_vector
Definition: simulator.h:2059
DoFHandler< dim > dof_handler
Definition: simulator.h:1964
std::unique_ptr< StokesMatrixFreeHandler< dim > > stokes_matrix_free
Definition: simulator.h:2119
unsigned int last_checkpoint_id
Definition: simulator.h:1842
std::unique_ptr< Assemblers::Manager< dim > > assemblers
Definition: simulator.h:1003
bool rebuild_sparsity_and_matrices
Definition: simulator.h:2070
const IntermediaryConstructorAction post_signal_creation
Definition: simulator.h:1761
double global_Omega_diameter
Definition: simulator.h:1946
unsigned int timestep_number
Definition: simulator.h:1915
bool assemble_newton_stokes_matrix
Definition: simulator.h:2092
Manager< dim > World
Definition: world.h:39
ConditionalOStream pcout
Definition: simulator.h:1793
unsigned int pre_refinement_step
Definition: simulator.h:1916
TimeStepping::Manager< dim > time_stepping_manager
Definition: simulator.h:1927
std::size_t statistics_last_hash
Definition: simulator.h:1821
TableHandler statistics
Definition: simulator.h:1804
Introspection< dim > introspection
Definition: simulator.h:1772
MPI_Comm mpi_communicator
Definition: simulator.h:1775
typename Parameters< dim >::NullspaceRemoval NullspaceRemoval
Definition: simulator.h:274
LinearAlgebra::BlockSparseMatrix system_preconditioner_matrix
Definition: simulator.h:2046
bool do_pressure_rhs_compatibility_modification
Definition: simulator.h:2006
LinearAlgebra::BlockVector current_linearization_point
Definition: simulator.h:2053
BoundaryConvectiveHeating::Manager< dim > boundary_convective_heating_manager
Definition: simulator.h:1868
LinearAlgebra::BlockVector old_old_solution
Definition: simulator.h:2050
BoundaryTraction::Manager< dim > boundary_traction_manager
Definition: simulator.h:1902
LinearAlgebra::BlockVector pressure_shape_function_integrals
Definition: simulator.h:2056
std::ofstream log_file_stream
Definition: simulator.h:1781
std::unique_ptr< LinearAlgebra::PreconditionAMG > Amg_preconditioner
Definition: simulator.h:2063
std::shared_ptr< InitialTemperature::Manager< dim > > initial_temperature_manager
Definition: simulator.h:1883
TeeDevice iostream_tee_device
Definition: simulator.h:1786
boost::iostreams::stream< TeeDevice > TeeStream
Definition: simulator.h:1784
LinearAlgebra::BlockSparseMatrix system_matrix
Definition: simulator.h:2026
std::unique_ptr< MeltHandler< dim > > melt_handler
Definition: simulator.h:1750
LinearAlgebra::BlockVector inverse_lumped_mass_matrix
Definition: simulator.h:2032
bool rebuild_stokes_preconditioner
Definition: simulator.h:2103
PrescribedSolution::Manager< dim > prescribed_solution_manager
Definition: simulator.h:1870
const std::shared_ptr< InitialTopographyModel::Interface< dim > > initial_topography_model
Definition: simulator.h:1861
std::unique_ptr< Mapping< dim > > mapping
Definition: simulator.h:1960
const std::unique_ptr< PrescribedStokesSolution::Interface< dim > > prescribed_stokes_solution
Definition: simulator.h:1871
HeatingModel::Manager< dim > heating_model_manager
Definition: simulator.h:1950
SimulatorSignals< dim > signals
Definition: simulator.h:1759
const std::unique_ptr< BoundaryHeatFlux::Interface< dim > > boundary_heat_flux
Definition: simulator.h:1903
const FESystem< dim > finite_element
Definition: simulator.h:1962
bool simulator_is_past_initialization
Definition: simulator.h:298
LinearAlgebra::BlockVector solution
Definition: simulator.h:2048
std::unique_ptr< NewtonHandler< dim > > newton_handler
Definition: simulator.h:1757
typename Parameters< dim >::NonlinearSolver NonlinearSolver
Definition: simulator.h:269
Postprocess::Manager< dim > postprocess_manager
Definition: simulator.h:1966
const std::unique_ptr< GravityModel::Interface< dim > > gravity_model
Definition: simulator.h:1865
double newton_residual_for_derivative_scaling_factor
Definition: simulator.h:148
double global_volume
Definition: simulator.h:1947
BoundaryComposition::Manager< dim > boundary_composition_manager
Definition: simulator.h:1869
std::unique_ptr< LinearAlgebra::PreconditionBase > Mp_preconditioner
Definition: simulator.h:2064
::TrilinosWrappers::PreconditionILU PreconditionILU