22 #ifndef _aspect_parameters_h 23 #define _aspect_parameters_h 25 #include <deal.II/base/parameter_handler.h> 33 struct CompositionalFieldDescription;
36 namespace GeometryModel
80 iterated_Advection_and_Newton_Stokes
88 return input == NonlinearSolver::iterated_Advection_and_Newton_Stokes ||
89 input == NonlinearSolver::single_Advection_iterated_Newton_Stokes ||
90 input == NonlinearSolver::no_Advection_iterated_defect_correction_Stokes ||
91 input == NonlinearSolver::single_Advection_iterated_defect_correction_Stokes ||
92 input == NonlinearSolver::iterated_Advection_and_defect_correction_Stokes
103 return input == NonlinearSolver::no_Advection_iterated_Stokes ||
104 input == NonlinearSolver::no_Advection_iterated_defect_correction_Stokes ||
105 input == NonlinearSolver::single_Advection_iterated_Stokes ||
106 input == NonlinearSolver::single_Advection_iterated_defect_correction_Stokes ||
107 input == NonlinearSolver::single_Advection_iterated_Newton_Stokes ||
108 input == NonlinearSolver::iterated_Advection_and_Stokes ||
109 input == NonlinearSolver::iterated_Advection_and_defect_correction_Stokes ||
110 input == NonlinearSolver::iterated_Advection_and_Newton_Stokes
136 if (input ==
"continue with next timestep")
137 return continue_with_next_timestep;
138 else if (input ==
"cut timestep size")
139 return cut_timestep_size;
140 else if (input ==
"abort program")
141 return abort_program;
143 AssertThrow(
false, ExcNotImplemented());
167 if (input ==
"continue with nonlinear solver")
168 return continue_with_nonlinear_solver;
169 else if (input ==
"abort")
172 AssertThrow(
false, ExcNotImplemented());
184 net_translation_x = 0x1,
185 net_translation_y = 0x2,
186 net_translation_z = 0x4,
187 net_translation = 0x1+0x2+0x4,
188 linear_momentum_x = 0x8,
189 linear_momentum_y = 0x10,
190 linear_momentum_z = 0x20,
191 linear_momentum = linear_momentum_x+linear_momentum_y+linear_momentum_z,
193 angular_momentum = 0x80,
194 net_surface_rotation = 0x100,
195 any_translation = net_translation+linear_momentum,
196 any_rotation = net_rotation+angular_momentum+net_surface_rotation,
221 prescribed_field_with_diffusion
255 if (input ==
"isentropic compression")
256 return Formulation::isentropic_compression;
257 else if (input ==
"anelastic liquid approximation")
258 return Formulation::anelastic_liquid_approximation;
259 else if (input ==
"Boussinesq approximation")
260 return Formulation::boussinesq_approximation;
261 else if (input ==
"custom")
262 return Formulation::custom;
264 AssertThrow(
false, ExcNotImplemented());
299 if (input ==
"isentropic compression")
300 return Formulation::MassConservation::isentropic_compression;
301 else if (input ==
"hydrostatic compression")
302 return Formulation::MassConservation::hydrostatic_compression;
303 else if (input ==
"reference density profile")
304 return Formulation::MassConservation::reference_density_profile;
305 else if (input ==
"implicit reference density profile")
306 return Formulation::MassConservation::implicit_reference_density_profile;
307 else if (input ==
"incompressible")
308 return Formulation::MassConservation::incompressible;
309 else if (input ==
"projected density field")
310 return Formulation::MassConservation::projected_density_field;
311 else if (input ==
"ask material model")
312 return Formulation::MassConservation::ask_material_model;
314 AssertThrow(
false, ExcNotImplemented());
334 reference_density_profile
345 if (input ==
"real density")
346 return Formulation::TemperatureEquation::real_density;
347 else if (input ==
"reference density profile")
348 return Formulation::TemperatureEquation::reference_density_profile;
350 AssertThrow(
false, ExcNotImplemented());
376 if (input ==
"entropy viscosity")
377 return entropy_viscosity;
378 else if (input ==
"SUPG")
381 AssertThrow(
false, ExcNotImplemented());
388 return "entropy viscosity|SUPG";
408 return "default solver|block AMG|direct solver|block GMG";
414 if (input ==
"block AMG")
416 else if (input ==
"direct solver")
417 return direct_solver;
418 else if (input ==
"block GMG")
420 else if (input ==
"default solver")
421 return default_solver;
423 AssertThrow(
false, ExcNotImplemented());
443 return "local smoothing|global coarsening";
449 if (input ==
"local smoothing")
450 return local_smoothing;
451 else if (input ==
"global coarsening")
452 return global_coarsening;
454 AssertThrow(
false, ExcNotImplemented());
474 return "GMRES|IDR(s)";
480 if (input ==
"GMRES")
482 else if (input ==
"IDR(s)")
485 AssertThrow(
false, ExcNotImplemented());
505 return "ARKode|fixed step";
511 if (input ==
"ARKode")
513 else if (input ==
"fixed step")
516 AssertThrow(
false, ExcNotImplemented());
539 const MPI_Comm mpi_communicator);
569 void parse_parameters (ParameterHandler &prm,
570 const MPI_Comm mpi_communicator);
588 void parse_geometry_dependent_parameters (ParameterHandler &prm,
The NullspaceRemoval struct.
bool use_full_A_block_preconditioner
unsigned int min_grid_level
unsigned int n_expensive_stokes_solver_steps
std::vector< double > global_composition_min_preset
static Kind parse(const std::string &input)
double linear_stokes_solver_tolerance
unsigned int n_cheap_stokes_solver_steps
static Kind parse(const std::string &input)
unsigned int initial_adaptive_refinement
double coarsening_fraction
std::vector< unsigned int > normalized_fields
double maximum_first_time_step
double global_temperature_max_preset
unsigned int initial_global_refinement
static const std::string pattern()
double AMG_aggregation_threshold
std::vector< bool > use_discontinuous_composition_discretization
unsigned int stabilization_alpha
double linear_solver_A_block_tolerance
std::vector< double > additional_refinement_times
std::map< unsigned int, std::pair< std::string, unsigned int > > mapped_particle_properties
bool use_limiter_for_discontinuous_temperature_solution
bool use_locally_conservative_discretization
double nonlinear_tolerance
unsigned int stokes_gmres_restart_length
static Kind parse(const std::string &input)
static Kind parse(const std::string &input)
unsigned int temperature_degree
unsigned int idr_s_parameter
bool force_nonsymmetric_A_block_solver
bool mesh_deformation_enabled
Formulation::MassConservation::Kind formulation_mass_conservation
bool skip_solvers_on_initial_refinement
bool run_postprocessors_on_initial_refinement
bool adapt_by_fraction_of_cells
AdvectionFieldMethod::Kind temperature_method
bool have_discontinuous_composition_discretization
unsigned int AMG_smoother_sweeps
void declare_parameters(ParameterHandler &prm)
unsigned int resume_checkpoint_id
double temperature_solver_tolerance
NonlinearSolver::Kind nonlinear_solver
std::string world_builder_file
std::vector< bool > use_limiter_for_discontinuous_composition_solution
AdvectionStabilizationMethod::Kind advection_stabilization_method
unsigned int stokes_velocity_degree
bool enable_additional_stokes_rhs
NullspaceRemoval::Kind nullspace_removal
static Kind parse(const std::string &input)
static const std::string pattern()
static const std::string pattern()
bool use_artificial_viscosity_smoothing
double discontinuous_penalty
bool volume_of_fluid_tracking_enabled
static bool solve_Stokes_iteratively(const typename NonlinearSolver::Kind &input)
double reaction_time_step
double stabilization_gamma
double linear_solver_S_block_tolerance
bool use_direct_stokes_solver
bool use_operator_splitting
double refinement_fraction
unsigned int n_compositional_fields
unsigned int max_composition_degree
std::vector< unsigned int > composition_degrees
MaterialModel::MaterialAveraging::AveragingOperation material_averaging
unsigned int reaction_steps_per_advection_step
unsigned int n_particle_managers
bool use_conduction_timestep
double maximum_relative_increase_time_step
double composition_solver_tolerance
std::vector< std::string > names_of_compositional_fields
unsigned int max_nonlinear_iterations
NonlinearSolverFailureStrategy::Kind nonlinear_solver_failure_strategy
bool run_postprocessors_on_nonlinear_iterations
bool use_discontinuous_temperature_discretization
static Kind parse(const std::string &input)
static bool is_defect_correction(const typename NonlinearSolver::Kind &input)
StokesGMGType::Kind stokes_gmg_type
static std::string get_options_string()
std::set< types::boundary_id > fixed_heat_flux_boundary_indicators
std::string output_directory
std::vector< double > stabilization_beta
std::vector< aspect::CompositionalFieldDescription > composition_descriptions
std::vector< double > stabilization_c_R
LinearSolverFailureStrategy::Kind linear_solver_failure_strategy
std::vector< std::string > compositional_fields_with_disabled_boundary_entropy_viscosity
std::string pressure_normalization
bool use_equal_order_interpolation_for_stokes
double ARKode_relative_tolerance
StokesSolverType::Kind stokes_solver_type
unsigned int advection_gmres_restart_length
bool enable_prescribed_dilation
static const std::string pattern()
std::string AMG_smoother_type
StokesKrylovType::Kind stokes_krylov_type
double global_temperature_min_preset
Formulation::TemperatureEquation::Kind formulation_temperature_equation
static Kind parse(const std::string &input)
unsigned int n_checkpoints_to_keep
bool include_melt_transport
double adiabatic_surface_temperature
std::vector< unsigned int > chemical_composition_indices
unsigned int max_nonlinear_iterations_in_prerefinement
std::vector< double > global_composition_max_preset
unsigned int timing_output_frequency
std::vector< typename AdvectionFieldMethod::Kind > compositional_field_methods
Formulation::Kind formulation
unsigned int n_chemical_compositions
bool skip_setup_initial_conditions_on_initial_refinement
unsigned int adaptive_refinement_interval
ReactionSolverType::Kind reaction_solver_type
double diffusion_length_scale