OpenFCST: The open-source Fuel Cell Simulation Toolbox
|
Base class for all classes performing Newton's iteration. More...
#include <newton_base.h>
Public Member Functions | |
newtonBase (ApplicationBase &app) | |
Constructor, receiving the application computing the residual and solving the linear problem. More... | |
virtual void | declare_parameters (ParameterHandler ¶m) |
Declare the input parameters. More... | |
virtual void | initialize (ParameterHandler ¶m) |
Read the parameters. More... | |
void | _initialize (ParameterHandler ¶m) |
Read the parameters local to newtonBase. More... | |
double | threshold (double new_value) |
Set the maximal residual reduction allowed without triggering assembling in the next step. More... | |
void | initialize_initial_guess (BlockVector< double > &dst) |
Control object for the Newton iteration. More... | |
virtual void | assemble () |
Instead of assembling, this function only sets a flag, such that the inner application will be required to assemble a new derivative matrix next time solve() is called. More... | |
virtual double | residual (FuelCell::ApplicationCore::FEVector &dst, const FuelCell::ApplicationCore::FEVectors &rhs) |
Returns the L2-norm of the residual and the residual vector in "dst" using the residual function in the ApplicationBase used to initialize the application. More... | |
virtual void | solve (FuelCell::ApplicationCore::FEVector &u, const FuelCell::ApplicationCore::FEVectors &in_vectors)=0 |
The actual Newton solver. More... | |
Public Member Functions inherited from FuelCell::ApplicationCore::ApplicationWrapper | |
ApplicationWrapper (ApplicationBase &app) | |
Constructor for a derived application. More... | |
~ApplicationWrapper () | |
Destructor. More... | |
virtual void | remesh () |
Generate the next mesh depending on the mesh generation parameters. More... | |
virtual void | init_vector (FEVector &dst) const |
Initialize vector to problem size. More... | |
virtual double | residual (FEVector &dst, const FEVectors &src, bool apply_boundaries=true) |
Compute residual of src and store it into dst . More... | |
virtual void | Tsolve (FEVector &dst, const FEVectors &src) |
Solve the dual system assembled with right hand side rhs and return the result in start . More... | |
virtual double | estimate (const FEVectors &src) |
Estimate cell-wise errors. More... | |
virtual double | evaluate (const FEVectors &src) |
Evaluate a functional. More... | |
virtual void | grid_out (const std::string &filename) const |
virtual void | data_out (const std::string &filename, const FEVectors &src) |
Write data in the format specified by the ParameterHandler. More... | |
virtual std::string | id () const |
Return a unique identification string for this application. More... | |
virtual void | notify (const Event &reason) |
Add a reason for assembling. More... | |
Public Member Functions inherited from FuelCell::ApplicationCore::ApplicationBase | |
ApplicationBase (boost::shared_ptr< ApplicationData > data=boost::shared_ptr< ApplicationData >()) | |
Constructor for an application. More... | |
ApplicationBase (const ApplicationBase &other) | |
Copy constructor. More... | |
virtual | ~ApplicationBase () |
Virtual destructor. More... | |
void | print_parameters_to_file (ParameterHandler ¶m, const std::string &file_name, const ParameterHandler::OutputStyle &style) |
Print default parameters for the application to a file. More... | |
virtual void | start_vector (FEVector &dst, std::string caller) const |
Initialize vector to problem size. More... | |
virtual void | grid_out (const std::string &filename) |
Write the mesh in the format specified by the ParameterHandler. More... | |
boost::shared_ptr < ApplicationData > | get_data () |
Get access to the protected variable data. More... | |
const boost::shared_ptr < ApplicationData > | get_data () const |
Get read-only access to the protected variable data. More... | |
virtual void | clear () |
All true in notifications . More... | |
virtual void | clear_events () |
All false in notifications . More... | |
Public Attributes | |
ReductionControl | control |
Control object for the Newton iteration. More... | |
double | numIter |
Number of Iterations;. More... | |
Static Public Attributes | |
static const FuelCell::ApplicationCore::Event | bad_derivative |
The Event set by Jason if convergence is becoming bad and a new matrix should be assembled. More... | |
Protected Member Functions | |
void | debug_output (const FEVector &sol, const FEVector &update, const FEVector &residual) const |
Function used to output any necessary information at each Newton iteration for debugging purposes. More... | |
Protected Member Functions inherited from FuelCell::ApplicationCore::ApplicationWrapper | |
SmartPointer< ApplicationBase > | get_wrapped_application () |
Gain access to the inner application. More... | |
Protected Member Functions inherited from FuelCell::ApplicationCore::ApplicationBase | |
void | print_caller_name (const std::string &caller_name) const |
Print caller name. More... | |
Protected Attributes | |
bool | assemble_now |
This flag is set by the function assemble(), indicating that the matrix must be assembled anew upon start. More... | |
double | assemble_threshold |
Threshold for re-assembling matrix. More... | |
bool | debug_solution |
Print updated solution after each step into file Newton_uNNN ? More... | |
bool | debug_update |
Print Newton update after each step into file Newton_dNNN ? More... | |
bool | debug_residual |
Print Newton residual after each step into file Newton_rNNN ? More... | |
unsigned int | debug |
Write debug output to FcstUtilities::log; the higher the number, the more output. More... | |
unsigned int | step |
The number of a basic Newton iteration. More... | |
std::vector< unsigned int > | blocks |
This vector specifies the blocks of the global solution which are supposed to be treated specially. More... | |
unsigned int | n_blocks |
The total number of blocks . More... | |
Protected Attributes inherited from FuelCell::ApplicationCore::ApplicationWrapper | |
SmartPointer< ApplicationBase > | app |
Pointer to the application this one depends upon. More... | |
Protected Attributes inherited from FuelCell::ApplicationCore::ApplicationBase | |
boost::shared_ptr < ApplicationData > | data |
Object for auxiliary data. More... | |
Event | notifications |
Accumulate reasons for assembling here. More... | |
Base class for all classes performing Newton's iteration.
Children of this class mainly differ due to the global search method implemented as discussed below.
Theory
Newton's method approximates a value for such that
where is a system of non-linear equations.
The solution is iteratively determined by evaluating
where is the ith Newton iterate starting from an initial guess and
The matrix
is the Jacobian matrix evaluated at . Most steady-steady openFCST linear applications compute the Jacobian and solve the linear system above in order to provide the Newton solver with the iteration update, , based on the system of PDEs that the user wants to solve.
Newton iterations are performed until the error between the iterate and the final solution is sufficiently small:
The error is not known in practice. However, the norm of the residual proves to be an effective indicator of the rate of decay of the error. In the case of openFCST, the L2 norm of the residual is used as a termination criteria.
openFCST checks if
where is the user-supplied absolute tolerance. If the absolute tolerance is satisfied, the Newton iterations are terminated. This user-supplied parameter is an input parameter specified in "set Tolerance = 1e-5" as discussed below.
Further, the user can specify a maximum number of iteration in the Newton subsection of the input file using "set Max steps = 10". In this case, the solver would terminate when the max. number of iterations is reached regardless of the value of the residual, i.e. the nonlinear problem is not solved.
A third option for stopping convergence, not used in openFCST, is to terminate when
where is the user-supplied relative tolerance.
Newton’s method should converge to the solution as the number of Newton iterations becomes large. If the initial guess is poor, however, convergence may fail to occur. Often the failure of convergence is a consequence of the Newton step, , overshooting the correct value of .
The problem of overshooting can usually be solved by using only a fraction of the Newton direction for each Newton iteration; see section 1.6 of [2] for additional details. In other words, a Newton step , , is applied to each Newton iteration such that
where is known as the step size.
The method used to determine is referred to as the global-convergence strategy. The strategy can greatly affect both the efficiency and versatility of Newton’s method.
Several Newton solvers have been implemented that implement a different global-convergence strategy. In particular the user has three options:
For a more detailed example, please see AdaptiveRefinement.
The parameters that control all Newton solvers are defined in the subsection Newton in the data input file. The parameters are the following:
[1] C. T. Kelley. Iterative methods for linear and nonlinear equations, volume 16 of Frontiers in Applied Mathematics. Society for Industrial and Applied Mathematics (SIAM), Philadelphia, PA, 1995. With separately available software.
[2] C. T. Kelley. Solving nonlinear equations with Newton’s method. Fundamentals of Algorithms. Society for Industrial and Applied Mathematics (SIAM), Philadelphia, PA, 2003.
FuelCell::ApplicationCore::newtonBase::newtonBase | ( | ApplicationBase & | app | ) |
Constructor, receiving the application computing the residual and solving the linear problem.
void FuelCell::ApplicationCore::newtonBase::_initialize | ( | ParameterHandler & | param | ) |
Read the parameters local to newtonBase.
|
virtual |
Instead of assembling, this function only sets a flag, such that the inner application will be required to assemble a new derivative matrix next time solve() is called.
|
protected |
Function used to output any necessary information at each Newton iteration for debugging purposes.
|
virtual |
Declare the input parameters.
The following are the parameters used and their default values: In section: "Newton"
Reimplemented from FuelCell::ApplicationCore::ApplicationWrapper.
Reimplemented in FuelCell::ApplicationCore::Newton3pp, FuelCell::ApplicationCore::NewtonLineSearch, and FuelCell::ApplicationCore::NewtonBasic.
|
virtual |
Read the parameters.
Reimplemented from FuelCell::ApplicationCore::ApplicationWrapper.
Reimplemented in FuelCell::ApplicationCore::Newton3pp, FuelCell::ApplicationCore::NewtonLineSearch, and FuelCell::ApplicationCore::NewtonBasic.
|
inline |
Control object for the Newton iteration.
|
virtual |
Returns the L2-norm of the residual and the residual vector in "dst" using the residual function in the ApplicationBase used to initialize the application.
The FEVectors rhs should contain at least the following vectors:
|
pure virtual |
The actual Newton solver.
In this section, the Newton solver performs the iterations necessary to solve the nonlinear system. During the process it will call assemble() and residual() as needed. Once it is done, it will return the solution as parameter {u}.
Reimplemented from FuelCell::ApplicationCore::ApplicationWrapper.
Implemented in FuelCell::ApplicationCore::Newton3pp, FuelCell::ApplicationCore::NewtonLineSearch, and FuelCell::ApplicationCore::NewtonBasic.
double FuelCell::ApplicationCore::newtonBase::threshold | ( | double | new_value | ) |
Set the maximal residual reduction allowed without triggering assembling in the next step.
Return the previous value.
|
protected |
This flag is set by the function assemble(), indicating that the matrix must be assembled anew upon start.
|
protected |
Threshold for re-assembling matrix.
If the quotient of two consecutive residuals is smaller than this threshold, the system matrix is not assembled in this step.
|
static |
The Event set by Jason if convergence is becoming bad and a new matrix should be assembled.
|
protected |
This vector specifies the blocks of the global solution which are supposed to be treated specially.
Such blocks usually include the density or molar fraction of oxygen (burns as a result of chemical reactions) and the density or molar fraction of hydrogen (burns as well as a result of chemical reactions).
These blocks are defined in the parameter files manually. Therefore, you need to know them beforehand.
Knowing these blocks, the non-linear solver checks against the negative values in those blocks and reduces the solution update if needed to keep the values positive.
ReductionControl FuelCell::ApplicationCore::newtonBase::control |
Control object for the Newton iteration.
|
protected |
Write debug output to FcstUtilities::log; the higher the number, the more output.
|
protected |
Print Newton residual after each step into file Newton_rNNN
?
|
protected |
Print updated solution after each step into file Newton_uNNN
?
|
protected |
Print Newton update after each step into file Newton_dNNN
?
|
protected |
The total number of blocks
.
double FuelCell::ApplicationCore::newtonBase::numIter |
Number of Iterations;.
|
protected |
The number of a basic Newton iteration.