![]() |
deal.II version 9.7.0
|
#include <deal.II/lac/trilinos_tpetra_precondition.h>
The class for the Chebyshev preconditioner within Ifpack2.
Definition at line 806 of file trilinos_tpetra_precondition.h.

Classes | |
| struct | AdditionalData |
| The set of additional parameters to tune the preconditioner. More... | |
Public Member Functions | |
| PreconditionChebyshev () | |
| Constructor. | |
| void | initialize (const SparseMatrix< Number, MemorySpace > &A, const AdditionalData &additional_data=AdditionalData()) |
| Compute the preconditioner based on the given matrix and parameters. | |
| void | initialize (const SparseMatrix< Number, MemorySpace > &A) |
| void | clear () |
| Destructor. Destroys the preconditioner, leaving an object like just after having called the constructor. | |
| virtual void | vmult (Vector< Number, MemorySpace > &dst, const Vector< Number, MemorySpace > &src) const |
| Apply the preconditioner. | |
| virtual void | Tvmult (Vector< Number, MemorySpace > &dst, const Vector< Number, MemorySpace > &src) const |
| Apply the transpose preconditioner. | |
| const TpetraTypes::LinearOperator< Number, MemorySpace > & | trilinos_operator () const |
| Access to underlying Trilinos data. | |
| Teuchos::RCP< TpetraTypes::LinearOperator< Number, MemorySpace > > | trilinos_rcp () const |
| Access to underlying Trilinos data. | |
| void | serialize (Archive &ar, const unsigned int version) |
Partitioners | |
| IndexSet | locally_owned_domain_indices () const |
| IndexSet | locally_owned_range_indices () const |
Querying the observer pointers an object has. | |
| unsigned int | n_subscriptions () const |
| void | list_subscribers (StreamType &stream) const |
| void | list_subscribers () const |
Static Public Member Functions | |
| static ::ExceptionBase & | ExcTrilinosIpack2PreconditionerUnsupported (std::string arg1) |
| static ::ExceptionBase & | ExcNonMatchingMaps (std::string arg1) |
| static ::ExceptionBase & | ExcTransposeNotSupported () |
| static ::ExceptionBase & | ExcInUse (int arg1, std::string arg2, std::string arg3) |
| static ::ExceptionBase & | ExcNoSubscriber (std::string arg1, std::string arg2) |
Protected Attributes | |
| std::string | preconditioner_type |
| Teuchos::RCP< TpetraTypes::LinearOperator< Number, MemorySpace > > | preconditioner |
| Teuchos::ParameterList | parameter_list |
| The list of preconditioner parameters. | |
Private Types | |
| using | map_value_type |
| using | map_iterator |
Private Member Functions | |
EnableObserverPointer functionality | |
Classes derived from EnableObserverPointer provide a facility to subscribe to this object. This is mostly used by the ObserverPointer class. | |
| void | subscribe (std::atomic< bool > *const validity, const std::string &identifier="") const |
| void | unsubscribe (std::atomic< bool > *const validity, const std::string &identifier="") const |
| void | check_no_subscribers () const noexcept |
Private Attributes | |
| std::atomic< unsigned int > | counter |
| std::map< std::string, unsigned int > | counter_map |
| std::vector< std::atomic< bool > * > | validity_pointers |
| const std::type_info * | object_info |
Static Private Attributes | |
| static std::mutex | mutex |
|
privateinherited |
The data type used in counter_map.
Definition at line 224 of file enable_observer_pointer.h.
|
privateinherited |
The iterator type used in counter_map.
Definition at line 229 of file enable_observer_pointer.h.
| LinearAlgebra::TpetraWrappers::PreconditionChebyshev< Number, MemorySpace >::PreconditionChebyshev | ( | ) |
Constructor.
| void LinearAlgebra::TpetraWrappers::PreconditionChebyshev< Number, MemorySpace >::initialize | ( | const SparseMatrix< Number, MemorySpace > & | A, |
| const AdditionalData & | additional_data = AdditionalData() ) |
Compute the preconditioner based on the given matrix and parameters.
| A | The matrix to base the preconditioner on. |
| additional_data | The set of parameters to tune the preconditioner. |
|
inherited |
Initializes the preconditioner for the matrix A based on the parameter_set.
|
staticinherited |
The chosen preconditioner is not supported or configured with Ifpack2.
|
inherited |
Destructor. Destroys the preconditioner, leaving an object like just after having called the constructor.
|
virtualinherited |
Apply the preconditioner.
| dst | Input vector to apply the preconditioner to |
| src | Result vector |
|
virtualinherited |
Apply the transpose preconditioner.
| dst | Input vector to apply the preconditioner to |
| src | Result vector |
|
inherited |
Access to underlying Trilinos data.
Calling this function from an uninitialized object will cause an exception.
|
inherited |
Access to underlying Trilinos data.
Calling this function from an uninitialized object will cause an exception.
|
inherited |
Return the partitioning of the domain space of this matrix, i.e., the partitioning of the vectors this matrix has to be multiplied with.
|
inherited |
Return the partitioning of the range space of this matrix, i.e., the partitioning of the vectors that are result from matrix-vector products.
|
staticinherited |
The maps of the underlying matrix and one of the vectors do not match.
|
staticinherited |
The chosen preconditioner does not support a transposed apply.
|
inlineinherited |
Return the present number of subscriptions to this object. This allows to use this class for reference counted lifetime determination where the last one to unsubscribe also deletes the object.
Definition at line 129 of file enable_observer_pointer.h.
|
inlineinherited |
List the subscribers to the input stream.
Definition at line 136 of file enable_observer_pointer.h.
|
inherited |
List the subscribers to deallog.
Definition at line 142 of file enable_observer_pointer.cc.
|
staticinherited |
Exception: Object may not be deleted, since it is used.
|
staticinherited |
A subscriber with the identification string given to EnableObserverPointer::unsubscribe() did not subscribe to the object.
|
inlineinherited |
Read or write the data of this object to or from a stream for the purpose of serialization using the BOOST serialization library.
This function does not actually serialize any of the member variables of this class. The reason is that what this class stores is only who subscribes to this object, but who does so at the time of storing the contents of this object does not necessarily have anything to do with who subscribes to the object when it is restored. Consequently, we do not want to overwrite the subscribers at the time of restoring, and then there is no reason to write the subscribers out in the first place.
Definition at line 195 of file enable_observer_pointer.h.
|
privateinherited |
Subscribes a user of the object by storing the pointer validity. The subscriber may be identified by text supplied as identifier.
Definition at line 266 of file enable_observer_pointer.cc.
|
privateinherited |
Unsubscribes a user from the object.
identifier and the validity pointer must be the same as the one supplied to subscribe(). Definition at line 276 of file enable_observer_pointer.cc.
|
privatenoexceptinherited |
Check that there are no objects subscribing to this object. If this check passes then it is safe to destroy the current object. It this check fails then this function will either abort or print an error message to deallog (by using the AssertNothrow mechanism), but will not throw an exception.
Definition at line 293 of file enable_observer_pointer.cc.
|
protectedinherited |
The set preconditioner type to be handed to Ifpack2::Factory::create()
Definition at line 290 of file trilinos_tpetra_precondition.h.
|
protectedinherited |
This is a pointer to the preconditioner object that is used when applying the preconditioner.
Definition at line 189 of file trilinos_tpetra_precondition.h.
|
protectedinherited |
The list of preconditioner parameters.
This structure is Trilinos counterpart to the AdditionalData structures in deal.II. Therefore any initialize will at some point pass this to the preconditioner. Most derived classes will handle building this list based on an AdditionalData object that exposes and defaults the most sensible parameters. But some classes will also offer full customization for experienced Trilinos users.
Definition at line 202 of file trilinos_tpetra_precondition.h.
|
mutableprivateinherited |
Store the number of objects which subscribed to this object. Initially, this number is zero, and upon destruction it shall be zero again (i.e. all objects which subscribed should have unsubscribed again).
The creator (and owner) of an object is counted in the map below if HE manages to supply identification.
We use the mutable keyword in order to allow subscription to constant objects also.
This counter may be read from and written to concurrently in multithreaded code: hence we use the std::atomic class template.
Definition at line 213 of file enable_observer_pointer.h.
|
mutableprivateinherited |
In this map, we count subscriptions for each different identification string supplied to subscribe().
Definition at line 219 of file enable_observer_pointer.h.
|
mutableprivateinherited |
In this vector, we store pointers to the validity bool in the ObserverPointer objects that subscribe to this class.
Definition at line 235 of file enable_observer_pointer.h.
|
mutableprivateinherited |
Pointer to the typeinfo object of this object, from which we can later deduce the class name. Since this information on the derived class is neither available in the destructor, nor in the constructor, we obtain it in between and store it here.
Definition at line 243 of file enable_observer_pointer.h.
|
staticprivateinherited |
A mutex used to ensure data consistency when accessing the mutable members of this class. This lock is used in the subscribe() and unsubscribe() functions, as well as in list_subscribers().
Definition at line 250 of file enable_observer_pointer.h.