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>
46 :
LinearSolver<dim, degree, number>(_solve_block, _solve_context)
53 init(
const std::list<DependencyMap> &all_dependeny_sets)
override
76 const number newton_tolerance =
85 if (!
solutions.get_solution_level(0).old_solutions.empty())
88 solutions.get_old_solution_full_vector(0, 0);
92 bool newton_unconverged =
true;
93 unsigned int iter = 0;
94 number l2_norm = -1.0;
95 int total_lin_iters = 0;
96 while (newton_unconverged && iter < newton_max_iterations)
104 newton_residual.zero_out_ghost_values();
107 newton_residual.update_ghost_values();
110 l2_norm = newton_residual.l2_norm();
111 newton_unconverged = l2_norm > newton_tolerance;
112 if (!newton_unconverged || iter == newton_max_iterations)
122 solutions.get_solution_full_vector(0).zero_out_ghost_values();
136 if (
solve_context->get_user_inputs().output_parameters.should_output(
141 <<
" Newton steps: " << iter <<
" Total linear steps: " << total_lin_iters
145 if (iter >= newton_max_iterations)
148 <<
"[Increment " <<
solve_context->get_simulation_timer().get_increment()
150 <<
"Warning: Newton solver did not converge before " << newton_max_iterations
151 <<
" iterations.\n\n";
165PRISMS_PF_END_NAMESPACE
static dealii::ConditionalOStream & pout_summary()
Log output stream for writing a summary.log file.
Definition conditional_ostreams.cc:35
static dealii::ConditionalOStream & pout_base()
Generic parallel output stream. Used for essential information in release and debug mode.
Definition conditional_ostreams.cc:44
MFOperator< dim, degree, number > rhs_operator
Matrix free operators.
Definition linear_solver.h:210
BlockVector< number > rhs_vector
Definition linear_solver.h:213
double normalization_value()
Definition linear_solver.h:216
int do_linear_solve(BlockVector< number > &b_vector, MFOperator< dim, degree, number > &lhs_matrix, BlockVector< number > &x_vector)
Definition linear_solver.h:164
MFOperator< dim, degree, number > lhs_operator
Definition linear_solver.h:212
void init(const std::list< DependencyMap > &all_dependeny_sets) override
Initialize the solver.
Definition linear_solver.h:74
LinearSolver(SolveBlock _solve_block, const SolveContext< dim, degree, number > &_solve_context)
Constructor.
Definition linear_solver.h:51
void reinit() override
Reinitialize the solver.
Definition linear_solver.h:107
This class exists to evaluate a single user-defined operator for the matrix-free implementation of so...
Definition mf_operator.h:55
void compute_operator(BlockVector< number > &dst, const BlockVector< number > &src=BlockVector< number >()) const
Calls cell_loop on function that calls user-defined operator.
Definition mf_operator.cc:18
void reinit() override
Reinitialize the solver.
Definition newton_solver.h:63
BlockVector< number > newton_update
Definition newton_solver.h:156
void solve_impl() override
Solve for a single update step.
Definition newton_solver.h:73
void init(const std::list< DependencyMap > &all_dependeny_sets) override
Initialize the solver.
Definition newton_solver.h:53
const NonlinearSolverParameters & newton_params() const
Definition newton_solver.h:159
NewtonSolver(SolveBlock _solve_block, const SolveContext< dim, degree, number > &_solve_context)
Constructor.
Definition newton_solver.h:44
Structure to hold the attributes of a solve-block.
Definition solve_block.h:59
This class provides context for a solver with ptrs to all the relevant dependencies.
Definition solve_context.h:34
SolverBase(SolveBlock _solve_block, const SolveContext< dim, degree, number > &_solve_context)
Constructor.
Definition solver_base.h:36
GroupSolutionHandler< dim, number > solutions
Solution vectors for fields handled by this solver.
Definition solver_base.h:271
const SolveContext< dim, degree, number > * solve_context
Solver context provides access to external information.
Definition solver_base.h:266
SolveBlock solve_block
Information about the solve block this handler is responsible for.
Definition solver_base.h:261
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
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:20
double step_length
Definition nonlinear_solve_parameters.h:22
double tolerance_value
Definition nonlinear_solve_parameters.h:28
unsigned int max_iterations
Definition nonlinear_solve_parameters.h:25