![]() |
Reference documentation for deal.II version 8.1.0
|
#include <solver_minres.h>
Classes | |
struct | AdditionalData |
Public Member Functions | |
SolverMinRes (SolverControl &cn, VectorMemory< VECTOR > &mem, const AdditionalData &data=AdditionalData()) | |
SolverMinRes (SolverControl &cn, const AdditionalData &data=AdditionalData()) | |
virtual | ~SolverMinRes () |
template<class MATRIX , class PRECONDITIONER > | |
void | solve (const MATRIX &A, VECTOR &x, const VECTOR &b, const PRECONDITIONER &precondition) |
DeclException0 (ExcPreconditionerNotDefinite) | |
![]() | |
Solver (SolverControl &solver_control, VectorMemory< VECTOR > &vector_memory) | |
Solver (SolverControl &solver_control) | |
SolverControl & | control () const |
![]() | |
Subscriptor () | |
Subscriptor (const Subscriptor &) | |
virtual | ~Subscriptor () |
Subscriptor & | operator= (const Subscriptor &) |
void | subscribe (const char *identifier=0) const |
void | unsubscribe (const char *identifier=0) const |
unsigned int | n_subscriptions () const |
void | list_subscribers () const |
DeclException3 (ExcInUse, int, char *, std::string &,<< "Object of class "<< arg2<< " is still used by "<< arg1<< " other objects.\n"<< "(Additional information: "<< arg3<< ")\n"<< "Note the entry in the Frequently Asked Questions of "<< "deal.II (linked to from http://www.dealii.org/) for "<< "more information on what this error means.") | |
DeclException2 (ExcNoSubscriber, char *, char *,<< "No subscriber with identifier \""<< arg2<< "\" did subscribe to this object of class "<< arg1) | |
template<class Archive > | |
void | serialize (Archive &ar, const unsigned int version) |
Protected Member Functions | |
virtual double | criterion () |
virtual void | print_vectors (const unsigned int step, const VECTOR &x, const VECTOR &r, const VECTOR &d) const |
Protected Attributes | |
VECTOR * | Vu0 |
VECTOR * | Vu1 |
VECTOR * | Vu2 |
VECTOR * | Vm0 |
VECTOR * | Vm1 |
VECTOR * | Vm2 |
VECTOR * | Vv |
double | res2 |
![]() | |
GrowingVectorMemory< VECTOR > | static_vector_memory |
SolverControl & | cntrl |
VectorMemory< VECTOR > & | memory |
Minimal residual method for symmetric matrices.
For the requirements on matrices and vectors in order to work with this class, see the documentation of the Solver base class.
Like all other solver classes, this class has a local structure called AdditionalData
which is used to pass additional parameters to the solver, like damping parameters or the number of temporary vectors. We use this additional structure instead of passing these values directly to the constructor because this makes the use of the SolverSelector
and other classes much easier and guarantees that these will continue to work even if number or type of the additional parameters for a certain solver changes.
However, since the MinRes method does not need additional data, the respective structure is empty and does not offer any functionality. The constructor has a default argument, so you may call it without the additional parameter.
The preconditioner has to be positive definite and symmetric
The algorithm is taken from the Master thesis of Astrid Batterman with some changes. The full text can be found at http://scholar.lib.vt.edu/theses/public/etd-12164379662151/etd-title.html
Definition at line 63 of file solver_minres.h.
SolverMinRes< VECTOR >::SolverMinRes | ( | SolverControl & | cn, |
VectorMemory< VECTOR > & | mem, | ||
const AdditionalData & | data = AdditionalData() |
||
) |
Constructor.
SolverMinRes< VECTOR >::SolverMinRes | ( | SolverControl & | cn, |
const AdditionalData & | data = AdditionalData() |
||
) |
Constructor. Use an object of type GrowingVectorMemory as a default to allocate memory.
|
virtual |
Virtual destructor.
void SolverMinRes< VECTOR >::solve | ( | const MATRIX & | A, |
VECTOR & | x, | ||
const VECTOR & | b, | ||
const PRECONDITIONER & | precondition | ||
) |
Solve the linear system for x.
|
protectedvirtual |
Implementation of the computation of the norm of the residual.
|
protectedvirtual |
Interface for derived class. This function gets the current iteration vector, the residual and the update vector in each step. It can be used for a graphical output of the convergence history.
|
protected |
Temporary vectors, allocated through the VectorMemory
object at the start of the actual solution process and deallocated at the end.
Definition at line 142 of file solver_minres.h.
|
protected |
Within the iteration loop, the square of the residual vector is stored in this variable. The function criterion
uses this variable to compute the convergence value, which in this class is the norm of the residual vector and thus the square root of the res2
value.
Definition at line 156 of file solver_minres.h.