6#include <deal.II/lac/affine_constraints.h>
7#include <deal.II/lac/solver_cg.h>
16#include <prismspf/config.h>
20template <
unsigned int dim,
unsigned int degree,
typename number>
26template <
unsigned int dim,
unsigned int degree,
typename number>
47 solve_context->get_user_inputs().nonlinear_solve_parameters.newton_solvers.
at(
58 unsigned int num_levels =
solve_context->get_dof_manager().get_dof_handlers().size();
60 for (
unsigned int relative_level = 0; relative_level < num_levels; ++relative_level)
63 solutions.get_solution_full_vector(relative_level));
75 for (
unsigned int relative_level = 0; relative_level < num_levels; ++relative_level)
78 solutions.get_solution_full_vector(relative_level));
98 if (!
solutions.get_solution_level(relative_level).old_solutions.empty())
100 solutions.get_solution_full_vector(relative_level) =
101 solutions.get_old_solution_full_vector(0, relative_level);
106 unsigned int iter = 0;
125 solutions.get_solution_full_vector(relative_level)
129 solutions.apply_constraints(relative_level);
143 if (
solve_context->get_user_inputs().output_parameters.should_output(
155 <<
"[Increment " <<
solve_context->get_simulation_timer().get_increment()
158 <<
" iterations.\n\n";
static dealii::ConditionalOStream & pout_summary()
Log output stream for writing a summary.log file.
Definition conditional_ostreams.cc:34
static dealii::ConditionalOStream & pout_base()
Generic parallel output stream. Used for essential information in release and debug mode.
Definition conditional_ostreams.cc:43
This class handles the explicit solves of all explicit fields.
Definition linear_solver.h:34
std::vector< MFOperator< dim, degree, number > > rhs_operators
Matrix free operators for each level.
Definition linear_solver.h:184
int do_linear_solve(BlockVector< number > &b_vector, MFOperator< dim, degree, number > &lhs_operator, BlockVector< number > &x_vector)
Definition linear_solver.h:150
double normalization_value()
Definition linear_solver.h:190
void init(const std::list< DependencyMap > &all_dependeny_sets) override
Initialize the solver.
Definition linear_solver.h:56
std::vector< BlockVector< number > > rhs_vector
Definition linear_solver.h:187
std::vector< MFOperator< dim, degree, number > > lhs_operators
Definition linear_solver.h:186
void reinit() override
Reinitialize the solver.
Definition linear_solver.h:112
This class exists to evaluate a single user-defined operator for the matrix-free implementation of so...
Definition mf_operator.h:50
This class handles the explicit solves of all explicit fields.
Definition newton_solver.h:28
void reinit() override
Reinitialize the solver.
Definition newton_solver.h:71
NonlinearSolverParameters newton_params
Definition newton_solver.h:164
void init(const std::list< DependencyMap > &all_dependeny_sets) override
Initialize the solver.
Definition newton_solver.h:55
void solve_level(unsigned int relative_level) override
Solve for a single update step.
Definition newton_solver.h:86
std::vector< BlockVector< number > > newton_updates
Definition newton_solver.h:163
NewtonSolver(SolveGroup _solve_group, const SolveContext< dim, degree, number > &_solve_context)
Constructor.
Definition newton_solver.h:43
This class provides context for a solver with ptrs to all the relevant dependencies.
Definition solve_context.h:36
Structure to hold the attributes of a solve-group.
Definition solve_group.h:59
Definition solver_base.h:32
SolveGroup solve_group
Information about the solve group this handler is responsible for.
Definition solver_base.h:259
GroupSolutionHandler< dim, number > solutions
Solution vectors for fields handled by this solver.
Definition solver_base.h:269
const SolveContext< dim, degree, number > * solve_context
Solver context provides access to external information.
Definition solver_base.h:264
static void start_section(const char *name)
Start a new timer section.
Definition timer.cc:116
static void end_section(const char *name)
End the timer section.
Definition timer.cc:127
@ Value
Use value of the variable as a criterion for refinement.
Definition grid_refiner_criterion.h:31
dealii::LinearAlgebra::distributed::BlockVector< number > BlockVector
Typedef for solution block vector.
Definition group_solution_handler.h:29
Definition conditional_ostreams.cc:20
Struct that stores relevant nonlinear solve information of a certain field.
Definition nonlinear_solve_parameters.h:18
double step_length
Definition nonlinear_solve_parameters.h:20
double tolerance_value
Definition nonlinear_solve_parameters.h:26
unsigned int max_iterations
Definition nonlinear_solve_parameters.h:23