![]() |
Reference documentation for deal.II version 8.4.2
|
#include <deal.II/lac/solver_bicgstab.h>
Classes | |
| struct | AdditionalData |
| struct | IterationResult |
Public Member Functions | |
| SolverBicgstab (SolverControl &cn, VectorMemory< VectorType > &mem, const AdditionalData &data=AdditionalData()) | |
| SolverBicgstab (SolverControl &cn, const AdditionalData &data=AdditionalData()) | |
| virtual | ~SolverBicgstab () |
| template<typename MatrixType , typename PreconditionerType > | |
| void | solve (const MatrixType &A, VectorType &x, const VectorType &b, const PreconditionerType &precondition) |
Public Member Functions inherited from Solver< VectorType > | |
| Solver (SolverControl &solver_control, VectorMemory< VectorType > &vector_memory) | |
| Solver (SolverControl &solver_control) | |
| boost::signals2::connection | connect (const std_cxx11::function< SolverControl::State(const unsigned int iteration, const double check_value, const VectorType ¤t_iterate)> &slot) |
Public Member Functions inherited from Subscriptor | |
| 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."<< "\"<< "(Additional information: "<< arg3<< ")\"<< "See the entry in the Frequently Asked Questions of "<< "deal.II (linked to from http://www.dealii.org/) for "<< "a lot more information on what this error means and "<< "how to fix programs in which it happens.") | |
| DeclException2 (ExcNoSubscriber, char *, char *,<< "No subscriber with identifier <"<< arg2<< "> subscribes to this object of class "<< arg1<< ". Consequently, it cannot be unsubscribed.") | |
| template<class Archive > | |
| void | serialize (Archive &ar, const unsigned int version) |
Protected Member Functions | |
| template<typename MatrixType > | |
| double | criterion (const MatrixType &A, const VectorType &x, const VectorType &b) |
| virtual void | print_vectors (const unsigned int step, const VectorType &x, const VectorType &r, const VectorType &d) const |
Protected Attributes | |
| VectorType * | Vx |
| VectorType * | Vr |
| VectorType * | Vrbar |
| VectorType * | Vp |
| VectorType * | Vy |
| VectorType * | Vz |
| VectorType * | Vt |
| VectorType * | Vv |
| const VectorType * | Vb |
| double | alpha |
| double | beta |
| double | omega |
| double | rho |
| double | rhobar |
| unsigned int | step |
| double | res |
| AdditionalData | additional_data |
Protected Attributes inherited from Solver< VectorType > | |
| GrowingVectorMemory< VectorType > | static_vector_memory |
| VectorMemory< VectorType > & | memory |
| boost::signals2::signal< SolverControl::State(const unsigned int iteration, const double check_value, const VectorType ¤t_iterate), StateCombiner > | iteration_status |
Private Member Functions | |
| template<typename MatrixType > | |
| SolverControl::State | start (const MatrixType &A) |
| template<typename MatrixType , typename PreconditionerType > | |
| IterationResult | iterate (const MatrixType &A, const PreconditionerType &precondition) |
Additional Inherited Members | |
Public Types inherited from Solver< VectorType > | |
| typedef VectorType | vector_type |
Bicgstab algorithm by van der Vorst.
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.
The Bicgstab-method has two additional parameters: the first is a boolean, deciding whether to compute the actual residual in each step (true) or to use the length of the computed orthogonal residual (false). Note that computing the residual causes a third matrix-vector-multiplication, though no additional preconditioning, in each step. The reason for doing this is, that the size of the orthogonalized residual computed during the iteration may be larger by orders of magnitude than the true residual. This is due to numerical instabilities related to badly conditioned matrices. Since this instability results in a bad stopping criterion, the default for this parameter is true. Whenever the user knows that the estimated residual works reasonably as well, the flag should be set to false in order to increase the performance of the solver.
The second parameter is the size of a breakdown criterion. It is difficult to find a general good criterion, so if things do not work for you, try to change this value.
The solve() function of this class uses the mechanism described in the Solver base class to determine convergence. This mechanism can also be used to observe the progress of the iteration.
Definition at line 72 of file solver_bicgstab.h.
| SolverBicgstab< VectorType >::SolverBicgstab | ( | SolverControl & | cn, |
| VectorMemory< VectorType > & | mem, | ||
| const AdditionalData & | data = AdditionalData() |
||
| ) |
Constructor.
| SolverBicgstab< VectorType >::SolverBicgstab | ( | SolverControl & | cn, |
| const AdditionalData & | data = AdditionalData() |
||
| ) |
Constructor. Use an object of type GrowingVectorMemory as a default to allocate memory.
|
virtual |
Virtual destructor.
| void SolverBicgstab< VectorType >::solve | ( | const MatrixType & | A, |
| VectorType & | x, | ||
| const VectorType & | b, | ||
| const PreconditionerType & | precondition | ||
| ) |
Solve primal problem only.
|
protected |
Computation of the stopping criterion.
|
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.
|
private |
Everything before the iteration loop.
|
private |
The iteration loop itself. The function returns a structure indicating what happened in this function.
|
protected |
Auxiliary vector.
Definition at line 158 of file solver_bicgstab.h.
|
protected |
Auxiliary vector.
Definition at line 162 of file solver_bicgstab.h.
|
protected |
Auxiliary vector.
Definition at line 166 of file solver_bicgstab.h.
|
protected |
Auxiliary vector.
Definition at line 170 of file solver_bicgstab.h.
|
protected |
Auxiliary vector.
Definition at line 174 of file solver_bicgstab.h.
|
protected |
Auxiliary vector.
Definition at line 178 of file solver_bicgstab.h.
|
protected |
Auxiliary vector.
Definition at line 182 of file solver_bicgstab.h.
|
protected |
Auxiliary vector.
Definition at line 186 of file solver_bicgstab.h.
|
protected |
Right hand side vector.
Definition at line 190 of file solver_bicgstab.h.
|
protected |
Auxiliary value.
Definition at line 195 of file solver_bicgstab.h.
|
protected |
Auxiliary value.
Definition at line 199 of file solver_bicgstab.h.
|
protected |
Auxiliary value.
Definition at line 203 of file solver_bicgstab.h.
|
protected |
Auxiliary value.
Definition at line 207 of file solver_bicgstab.h.
|
protected |
Auxiliary value.
Definition at line 211 of file solver_bicgstab.h.
|
protected |
Current iteration step.
Definition at line 216 of file solver_bicgstab.h.
|
protected |
Residual.
Definition at line 221 of file solver_bicgstab.h.
|
protected |
Additional parameters.
Definition at line 226 of file solver_bicgstab.h.
1.8.12