22 const std::set<std::string> &
33 params.
addParam<
unsigned int>(
"nl_max_its", 50,
"Max Nonlinear Iterations");
34 params.
addParam<
unsigned int>(
"nl_forced_its", 0,
"The Number of Forced Nonlinear Iterations");
35 params.
addParam<
unsigned int>(
"nl_max_funcs", 10000,
"Max Nonlinear solver function evaluations");
36 params.
addParam<
Real>(
"nl_abs_tol", 1.0e-50,
"Nonlinear Absolute Tolerance");
37 params.
addParam<
Real>(
"nl_rel_tol", 1.0e-8,
"Nonlinear Relative Tolerance");
41 "Nonlinear Relative Divergence Tolerance. A negative value disables this check.");
45 "Nonlinear Absolute Divergence Tolerance. A negative value disables this check.");
46 params.
addParam<
Real>(
"nl_abs_step_tol", 0.,
"Nonlinear Absolute step Tolerance");
47 params.
addParam<
Real>(
"nl_rel_step_tol", 0.,
"Nonlinear Relative step Tolerance");
48 params.
addParam<
unsigned int>(
"n_max_nonlinear_pingpong",
50 "The maximum number of times the nonlinear residual can ping pong " 51 "before requesting halting the current evaluation and requesting " 52 "timestep cut for transient simulations");
55 "nl_max_its nl_forced_its nl_max_funcs nl_abs_tol nl_rel_tol " 56 "nl_rel_step_tol nl_abs_step_tol nl_div_tol nl_abs_div_tol n_max_nonlinear_pingpong",
70 std::set<std::string> alias_line_searches = {
"default",
"none",
"basic"};
71 line_searches.insert(alias_line_searches.begin(), alias_line_searches.end());
73 line_searches.insert(petsc_line_searches.begin(), petsc_line_searches.end());
75 MooseEnum line_search(line_search_string,
"default");
76 std::string addtl_doc_str(
" (Note: none = basic)");
78 "line_search", line_search,
"Specifies the line search type" + addtl_doc_str);
79 MooseEnum line_search_package(
"petsc moose",
"petsc");
82 "The solver package to use to conduct the line-search");
84 params.
addParam<
unsigned>(
"contact_line_search_allowed_lambda_cuts",
86 "The number of times lambda is allowed to be cut in half in the " 87 "contact line search. We recommend this number be roughly bounded by 0 " 88 "<= allowed_lambda_cuts <= 3");
90 "The linear relative tolerance to be used while the contact state is " 91 "changing between non-linear iterations. We recommend that this tolerance " 92 "be looser than the standard linear tolerance");
95 params.addParam<
Real>(
"l_tol", 1.0e-5,
"Linear Relative Tolerance");
96 params.addParam<
Real>(
"l_abs_tol", 1.0e-50,
"Linear Absolute Tolerance");
97 params.addParam<
unsigned int>(
"l_max_its", 10000,
"Max Linear Iterations");
98 params.addParam<std::vector<ConvergenceName>>(
99 "nonlinear_convergence",
100 "Name of the Convergence object(s) to use to assess convergence of the " 101 "nonlinear system(s) solve. If not provided, the default Convergence " 102 "associated with the Problem will be constructed internally.");
103 params.addParam<std::vector<ConvergenceName>>(
104 "linear_convergence",
105 "Name of the Convergence object(s) to use to assess convergence of the " 106 "linear system(s) solve. If not provided, the linear solver tolerance parameters are used");
107 params.addParam<
bool>(
110 "Specifies whether or not to reuse the base vector for matrix-free calculation");
111 params.addParam<
bool>(
112 "skip_exception_check",
false,
"Specifies whether or not to skip exception check");
113 params.addParam<
bool>(
114 "use_pre_SMO_residual",
116 "Compute the pre-SMO residual norm and use it in the relative convergence check. The " 117 "pre-SMO residual is computed at the begining of the time step before solution-modifying " 118 "objects are executed. Solution-modifying objects include preset BCs, constraints, " 120 params.addParam<
bool>(
"automatic_scaling",
"Whether to use automatic scaling for the variables.");
121 params.addParam<std::vector<bool>>(
122 "compute_scaling_once",
124 "Whether the scaling factors should only be computed once at the beginning of the simulation " 125 "through an extra Jacobian evaluation. If this is set to false, then the scaling factors " 126 "will be computed during an extra Jacobian evaluation at the beginning of every time step. " 127 "Vector entries correspond to each nonlinear system.");
128 params.addParam<std::vector<bool>>(
129 "off_diagonals_in_auto_scaling",
131 "Whether to consider off-diagonals when determining automatic scaling factors. Vector " 132 "entries correspond to each nonlinear system.");
133 params.addRangeCheckedParam<std::vector<Real>>(
134 "resid_vs_jac_scaling_param",
136 "0<=resid_vs_jac_scaling_param<=1",
137 "A parameter that indicates the weighting of the residual vs the Jacobian in determining " 138 "variable scaling parameters. A value of 1 indicates pure residual-based scaling. A value of " 139 "0 indicates pure Jacobian-based scaling. Vector entries correspond to each nonlinear " 141 params.addParam<std::vector<std::vector<std::vector<std::string>>>>(
142 "scaling_group_variables",
143 "Name of variables that are grouped together for determining scale factors. (Multiple " 144 "groups can be provided, separated by semicolon). Vector entries correspond to each " 145 "nonlinear system.");
146 params.addParam<std::vector<std::vector<std::string>>>(
147 "ignore_variables_for_autoscaling",
148 "List of variables that do not participate in autoscaling. Vector entries correspond to each " 149 "nonlinear system.");
150 params.addRangeCheckedParam<
unsigned int>(
154 "The number of grids to use for a grid sequencing algorithm. This includes the final grid, " 155 "so num_grids = 1 indicates just one solve in a time-step");
156 params.addParam<std::vector<bool>>(
"residual_and_jacobian_together",
158 "Whether to compute the residual and Jacobian together. " 159 "Vector entries correspond to each nonlinear system.");
161 params.addParam<
bool>(
"reuse_preconditioner",
163 "If true reuse the previously calculated " 164 "preconditioner for the linearized " 165 "system across multiple solves " 166 "spanning nonlinear iterations and time steps. " 167 "The preconditioner resets as controlled by " 168 "reuse_preconditioner_max_linear_its");
169 params.addParam<
unsigned int>(
"reuse_preconditioner_max_linear_its",
171 "Reuse the previously calculated " 172 "preconditioner for the linear system " 173 "until the number of linear iterations " 174 "exceeds this number");
179 params.addParam<
bool>(
180 "multi_system_fixed_point",
182 "Whether to perform fixed point (Picard) iterations between the nonlinear systems.");
183 params.addRangeCheckedParam<std::vector<Real>>(
184 "multi_system_fixed_point_relaxation_factor",
186 "multi_system_fixed_point_relaxation_factor>0 & multi_system_fixed_point_relaxation_factor<2",
187 "Relaxation factor(s) applied to system solution updates during multi-system fixed point " 188 "iterations; 1 disables relaxation. If one value is provided it is applied to every system; " 189 "otherwise the vector must match the number/order of systems being solved.");
190 params.addParam<ConvergenceName>(
191 "multi_system_fixed_point_convergence",
192 "Convergence object to determine the convergence of the multi-system fixed point iteration. " 193 "If unspecified, defaults to checking that every system is converged (based on their own " 194 "convergence criterion)");
196 params.addParamNamesToGroup(
"l_tol l_abs_tol l_max_its reuse_preconditioner " 197 "reuse_preconditioner_max_linear_its",
199 params.addParamNamesToGroup(
200 "solve_type snesmf_reuse_base use_pre_SMO_residual " 201 "num_grids residual_and_jacobian_together nonlinear_convergence linear_convergence",
203 params.addParamNamesToGroup(
204 "automatic_scaling compute_scaling_once off_diagonals_in_auto_scaling " 205 "scaling_group_variables resid_vs_jac_scaling_param ignore_variables_for_autoscaling",
206 "Solver variable scaling");
207 params.addParamNamesToGroup(
"line_search line_search_package contact_line_search_ltol " 208 "contact_line_search_allowed_lambda_cuts",
209 "Solver line search");
210 params.addParamNamesToGroup(
"multi_system_fixed_point multi_system_fixed_point_convergence " 211 "multi_system_fixed_point_relaxation_factor",
212 "Multiple solver system");
213 params.addParamNamesToGroup(
"skip_exception_check",
"Advanced");
220 _num_grid_steps(
cast_int<unsigned
int>(getParam<unsigned
int>(
"num_grids") - 1)),
221 _using_multi_sys_fp_iterations(getParam<bool>(
"multi_system_fixed_point")),
222 _multi_sys_fp_convergence(nullptr)
226 paramError(
"Can't use relaxation factors because multisystem fixed point iteration hasn't been " 235 auto set_solver_params = [
this, &ex](
const SolverSystem & sys)
237 const auto prefix = sys.prefix();
238 if (dynamic_cast<const LinearSystem *>(&sys))
245 solver_params.
_prefix = prefix;
246 solver_params._solver_sys_num = sys.number();
250 for (
const auto *
const sys :
_systems)
251 set_solver_params(*sys);
257 es.parameters.set<
Real>(
"linear solver absolute tolerance") = getParam<Real>(
"l_abs_tol");
258 es.parameters.set<
unsigned int>(
"linear solver maximum iterations") =
259 getParam<unsigned int>(
"l_max_its");
260 es.parameters.set<
bool>(
"reuse preconditioner") = getParam<bool>(
"reuse_preconditioner");
261 es.parameters.set<
unsigned int>(
"reuse preconditioner maximum linear iterations") =
262 getParam<unsigned int>(
"reuse_preconditioner_max_linear_its");
272 mooseError(
"The selected problem does not allow 'nonlinear_convergence' to be set.");
274 getParam<std::vector<ConvergenceName>>(
"nonlinear_convergence"));
282 "linear_convergence",
283 "Setting 'linear_convergence' is currently only possible for solving linear systems");
285 getParam<std::vector<ConvergenceName>>(
"linear_convergence"));
293 [
this](
const auto & solver_sys)
297 "Automatic scaling isn't implemented for the case where you do not have a " 298 "preconditioning matrix. No scaling will be applied");
306 ? getParam<bool>(
"automatic_scaling")
310 [
this](
const auto & solver_sys)
317 paramError(
"multi_system_fixed_point_convergence",
318 "Cannot set a convergence object for multi-system fixed point iterations if " 319 "'multi_system_fixed_point' is set to false");
321 paramError(
"multi_system_fixed_point_convergence",
322 "Must set a convergence object for multi-system fixed point iterations if using " 323 "multi-system fixed point iterations");
338 const auto res_and_jac =
339 getParamFromNonlinearSystemVectorParam<bool>(
"residual_and_jacobian_together", i_nl_sys);
341 nl.residualAndJacobianTogether();
344 nl.computeScalingOnce(
345 getParamFromNonlinearSystemVectorParam<bool>(
"compute_scaling_once", i_nl_sys));
347 getParamFromNonlinearSystemVectorParam<Real>(
"resid_vs_jac_scaling_param", i_nl_sys));
348 nl.offDiagonalsInAutoScaling(
349 getParamFromNonlinearSystemVectorParam<bool>(
"off_diagonals_in_auto_scaling", i_nl_sys));
351 nl.scalingGroupVariables(
353 "scaling_group_variables", i_nl_sys));
360 const auto & ignore_variables_for_autoscaling =
361 getParamFromNonlinearSystemVectorParam<std::vector<std::string>>(
362 "ignore_variables_for_autoscaling", i_nl_sys);
363 const auto & scaling_group_variables =
364 getParamFromNonlinearSystemVectorParam<std::vector<std::vector<std::string>>>(
365 "scaling_group_variables", i_nl_sys);
366 for (
const auto & group : scaling_group_variables)
367 for (
const auto & var_name : group)
368 if (
std::find(ignore_variables_for_autoscaling.begin(),
369 ignore_variables_for_autoscaling.end(),
370 var_name) != ignore_variables_for_autoscaling.end())
371 paramError(
"ignore_variables_for_autoscaling",
372 "Variables cannot be in a scaling grouping and also be ignored");
374 nl.ignoreVariablesForAutoscaling(
376 "ignore_variables_for_autoscaling", i_nl_sys));
384 template <
typename T>
387 unsigned int index)
const 389 const auto & param_vec = getParam<std::vector<T>>(param_name);
392 "Vector parameter is requested at index (" + std::to_string(index) +
393 ") which is larger than number of nonlinear systems (" +
395 if (param_vec.size() == 0)
398 "This parameter was passed to a routine which cannot handle empty vector parameters");
401 "Vector parameter size (" + std::to_string(param_vec.size()) +
402 ") is different than the number of nonlinear systems (" +
406 if (param_vec.size() == 1)
409 return param_vec[index];
432 for (
const auto & conv_name : conv_names)
441 const auto conv_names = getParam<std::vector<ConvergenceName>>(
"linear_convergence");
442 for (
const auto & conv_name : conv_names)
450 if (
isParamValid(
"multi_system_fixed_point_convergence"))
463 getParam<std::vector<Real>>(
"multi_system_fixed_point_relaxation_factor");
467 paramError(
"multi_system_fixed_point_relaxation_factor",
469 " values (one per system in the solve order).");
476 bool converged =
false;
477 unsigned int num_fp_multisys_iters = 0;
484 num_fp_multisys_iters = 0;
493 const Real fp_relax =
495 const bool apply_fp_relax =
499 sys->setFixedPointRelaxationFactor(fp_relax);
500 sys->saveOldSolutionForFixedPointRelaxation();
508 const auto linear_sys_number =
514 const auto solve_name =
515 _systems.size() == 1 ?
" Solve" :
"System " + sys->name() +
": Solve";
521 sys->applyFixedPointRelaxation();
522 _console << COLOR_GREEN << solve_name <<
" Converged!" << COLOR_DEFAULT << std::endl;
526 _console << COLOR_RED << solve_name <<
" Did NOT Converge!" << COLOR_DEFAULT
529 sys->clearFixedPointRelaxation();
534 _console << COLOR_GREEN << solve_name <<
" Skipped!" << COLOR_DEFAULT << std::endl;
538 const auto linear_sys_number =
549 sys->clearFixedPointRelaxation();
563 num_fp_multisys_iters++;
static InputParameters validParams()
const std::vector< ConvergenceName > & getNonlinearConvergenceNames() const
Gets the nonlinear system convergence object name(s).
FEProblemBase & _problem
Reference to FEProblem.
Moose::PetscSupport::PetscOptions & getPetscOptions()
Retrieve a writable reference the PETSc options (used by PetscSupport)
KOKKOS_INLINE_FUNCTION const T * find(const T &target, const T *const begin, const T *const end)
Find a value in an array.
void accumulateTimeStepIntoTotalOccurences(const unsigned int timestep_index)
Pass the number of solution invalid occurrences from current timestep to cumulative timestep counter ...
const InputParameters & _pars
The object's parameters.
void paramError(const std::string ¶m, Args... args) const
Emits an error prefixed with the file and line number of the given param (from the input file) along ...
const T & getParam(const std::string &name) const
Retrieve a parameter for the object.
virtual std::size_t numNonlinearSystems() const override
std::set< std::string > getPetscValidLineSearches()
Returns the valid petsc line search options as a set of strings.
void accumulateIterationIntoTimeStepOccurences()
Pass the number of solution invalid occurrences from current iteration to cumulative counters...
virtual MooseConvergenceStatus checkConvergence(unsigned int iter)=0
Returns convergence status.
static std::set< std::string > const _moose_line_searches
Moose provided line searches.
std::vector< Real > _multi_sys_fp_relax_factors
Per-system relaxation factors for multi-system fixed point iterations (expanded to match the number/o...
virtual bool onlyAllowDefaultNonlinearConvergence() const
Returns true if an error will result if the user supplies 'nonlinear_convergence'.
virtual bool solve() override
Picard solve the FEProblem.
const auto MULTISYSTEM_FIXED_POINT
FEProblemSolve(Executioner &ex)
virtual void initialSetup()
Method that should be executed once, before any solve calls.
const unsigned int _num_grid_steps
The number of steps to perform in a grid sequencing algorithm.
virtual void solve(const unsigned int nl_sys_num)
MooseApp & getMooseApp() const
Get the MooseApp this class is associated with.
void computeGradients()
Compute and store raw and requested limited Green-Gauss gradients for linear FV variables.
Nonlinear system to be solved.
void skipExceptionCheck(bool skip_exception_check)
Set a flag that indicates if we want to skip exception and stop solve.
virtual void addLineSearch(const InputParameters &)
add a MOOSE line search
void setConvergedReasonFlags(FEProblemBase &fe_problem, std::string prefix)
Set flags that will instruct the user on the reason their simulation diverged from PETSc's perspectiv...
void syncIteration()
Sync iteration counts to main processor Sum across all processors.
void uniformRefine()
uniformly refine the problem mesh(es).
void numGridSteps(unsigned int num_grid_steps)
Set the number of steps in a grid sequences.
Convergence * _multi_sys_fp_convergence
Convergence object to assess the convergence of the multi-system fixed point iteration.
virtual Convergence & getConvergence(const std::string &name, const THREAD_ID tid=0) const
Gets a Convergence object.
SolutionInvalidity & solutionInvalidity()
Get the SolutionInvalidity for this app.
Jacobian-Free Newton Krylov.
virtual libMesh::EquationSystems & es() override
virtual bool converged(const unsigned int sys_num)
Eventually we want to convert this virtual over to taking a solver system number argument.
static InputParameters feProblemDefaultConvergenceParams()
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type It sho...
void setLinearConvergenceNames(const std::vector< ConvergenceName > &convergence_names)
Sets the linear convergence object name(s) if there is one.
Executioners are objects that do the actual work of solving your problem.
virtual void checkIterationType(IterationType) const
Perform checks related to the iteration type.
MooseApp & _app
The MOOSE application this is associated with.
void setNonlinearConvergenceNames(const std::vector< ConvergenceName > &convergence_names)
Sets the nonlinear convergence object name(s) if there is one.
static InputParameters validParams()
std::string stringify(const T &t)
conversion to string
void setNeedToAddDefaultNonlinearConvergence()
Sets _need_to_add_default_nonlinear_convergence to true.
LinearSystem & getLinearSystem(unsigned int sys_num)
Get non-constant reference to a linear system.
void dontAddCommonSNESOptions(FEProblemBase &fe_problem)
Function to ensure that common SNES options are not added to the PetscOptions storage object to be la...
void setupMultiSystemFixedPointRelaxationFactors()
Initializes/expands the multi-system fixed point relaxation factors.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
InputParameters getPetscValidParams()
Returns the PETSc options that are common between Executioners and Preconditioners.
T getParamFromNonlinearSystemVectorParam(const std::string ¶m_name, unsigned int index) const
Helper routine to get the nonlinear system parameter at the right index.
T & set(const std::string &)
unsigned int _num_nl_systems
Number of nonlinear systems.
void mooseError(Args &&... args) const
Emits an error prefixed with object name and type and optionally a file path to the top-level block p...
SolverParams & solverParams(unsigned int solver_sys_num=0)
Get the solver parameters.
const bool _using_multi_sys_fp_iterations
Whether we are using fixed point iterations for multi-system.
void convergenceSetup()
Performs setup related to Convergence objects.
virtual std::size_t numLinearSystems() const override
bool isParamValid(const std::string &name) const
Test if the supplied parameter is valid.
const ConsoleStream _console
An instance of helper class to write streams to the Console objects.
void automaticScaling(bool automatic_scaling) override
Automatic scaling setter.
void paramWarning(const std::string ¶m, Args... args) const
void storePetscOptions(FEProblemBase &fe_problem, const std::string &prefix, const ParallelParamObject ¶m_object)
Stores the PETSc options supplied from the parameter object on the problem.
void setSNESMFReuseBase(bool reuse, bool set_by_user)
If or not to reuse the base vector for matrix-free calculation.
virtual void solveLinearSystem(const unsigned int linear_sys_num, const Moose::PetscSupport::PetscOptions *po=nullptr)
Build and solve a linear system.
bool isRecovering() const
Whether or not this is a "recover" calculation.
void ErrorVector unsigned int
auto index_range(const T &sizable)
const std::string & _type
The type of this class.
std::vector< SolverSystem * > _systems
Vector of pointers to the systems.
virtual void initialSetup() override
Method that should be executed once, before any solve calls.
void setPreSMOResidual(bool use)
Set whether to evaluate the pre-SMO residual and use it in the subsequent relative convergence checks...
Tnew cast_int(Told oldvar)
static const std::set< std::string > & mooseLineSearches()
A solve object for use when wanting to solve multiple systems.