Wrapper class for the IdentitySolver preconditioner of Ifpack2.
More...
#include <deal.II/lac/trilinos_tpetra_precondition.h>
template<typename Number, typename MemorySpace = ::MemorySpace::Host>
class LinearAlgebra::TpetraWrappers::PreconditionIdentity< Number, MemorySpace >
Wrapper class for the IdentitySolver preconditioner of Ifpack2.
- Template Parameters
-
Definition at line 218 of file trilinos_tpetra_precondition.h.
|
| | PreconditionIdentity ()=default |
| | Construct identity preconditioner.
|
| void | initialize (const SparseMatrix< Number, MemorySpace > &A) |
| | Initializes the preconditioner for the matrix 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) |
| IndexSet | locally_owned_domain_indices () const |
| IndexSet | locally_owned_range_indices () const |
| unsigned int | n_subscriptions () const |
| void | list_subscribers (StreamType &stream) const |
| void | list_subscribers () const |
◆ map_value_type
◆ map_iterator
◆ PreconditionIdentity()
template<typename Number, typename MemorySpace = ::MemorySpace::Host>
Construct identity preconditioner.
◆ initialize()
template<typename Number, typename MemorySpace = ::MemorySpace::Host>
Initializes the preconditioner for the matrix A.
Note that this only needs the matrix for information on the parallel distribution of the matrix and will return the original vector on vmult or Tvmult.
- Parameters
-
| A | Matrix to base the preconditioner on. |
◆ clear()
Destructor. Destroys the preconditioner, leaving an object like just after having called the constructor.
◆ vmult()
Apply the preconditioner.
- Parameters
-
| dst | Input vector to apply the preconditioner to |
| src | Result vector |
◆ Tvmult()
Apply the transpose preconditioner.
- Parameters
-
| dst | Input vector to apply the preconditioner to |
| src | Result vector |
◆ trilinos_operator()
Access to underlying Trilinos data.
Calling this function from an uninitialized object will cause an exception.
◆ trilinos_rcp()
Access to underlying Trilinos data.
Calling this function from an uninitialized object will cause an exception.
◆ locally_owned_domain_indices()
Return the partitioning of the domain space of this matrix, i.e., the partitioning of the vectors this matrix has to be multiplied with.
- Returns
- IndexSet of the domain of this preconditioner
◆ locally_owned_range_indices()
Return the partitioning of the range space of this matrix, i.e., the partitioning of the vectors that are result from matrix-vector products.
- Returns
- IndexSet of the range of this preconditioner
◆ ExcNonMatchingMaps()
The maps of the underlying matrix and one of the vectors do not match.
- Note
- The message that will be printed by this exception reads:
<< "The sparse matrix the preconditioner is based on " << "uses a map that is not compatible to the one in vector " << arg1 << ". Check preconditioner and matrix setup."
◆ ExcTransposeNotSupported()
The chosen preconditioner does not support a transposed apply.
- Note
- The message that will be printed by this exception reads:
"The chosen preconditioner does not support transposing the matrix."
◆ n_subscriptions()
| unsigned int EnableObserverPointer::n_subscriptions |
( |
| ) |
const |
|
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.
◆ list_subscribers() [1/2]
| void EnableObserverPointer::list_subscribers |
( |
StreamType & | stream | ) |
const |
|
inlineinherited |
◆ list_subscribers() [2/2]
| void EnableObserverPointer::list_subscribers |
( |
| ) |
const |
|
inherited |
◆ ExcInUse()
| ::ExceptionBase & EnableObserverPointer::ExcInUse |
( |
int | arg1, |
|
|
std::string | arg2, |
|
|
std::string | arg3 ) |
|
staticinherited |
Exception: Object may not be deleted, since it is used.
- Note
- The message that will be printed by this exception reads:
<< "Object of class " << arg2 << " is still used by " << arg1 << " other objects." << "\n\n" << "(Additional information: " << arg3 << ")\n\n" << "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."
◆ ExcNoSubscriber()
| ::ExceptionBase & EnableObserverPointer::ExcNoSubscriber |
( |
std::string | arg1, |
|
|
std::string | arg2 ) |
|
staticinherited |
A subscriber with the identification string given to EnableObserverPointer::unsubscribe() did not subscribe to the object.
- Note
- The message that will be printed by this exception reads:
<< "No subscriber with identifier <" << arg2 << "> subscribes to this object of class " << arg1 << ". Consequently, it cannot be unsubscribed."
◆ serialize()
| void EnableObserverPointer::serialize |
( |
Archive & | ar, |
|
|
const unsigned int | version ) |
|
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.
◆ subscribe()
| void EnableObserverPointer::subscribe |
( |
std::atomic< bool > *const | validity, |
|
|
const std::string & | identifier = "" ) const |
|
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.
◆ unsubscribe()
| void EnableObserverPointer::unsubscribe |
( |
std::atomic< bool > *const | validity, |
|
|
const std::string & | identifier = "" ) const |
|
privateinherited |
◆ check_no_subscribers()
| void EnableObserverPointer::check_no_subscribers |
( |
| ) |
const |
|
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.
- Note
- Since this function is just a consistency check it does nothing in release mode.
-
If this function is called when there is an uncaught exception then, rather than aborting, this function prints an error message to the standard error stream and returns.
Definition at line 293 of file enable_observer_pointer.cc.
◆ preconditioner
◆ parameter_list
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.
◆ counter
| std::atomic<unsigned int> EnableObserverPointer::counter |
|
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.
◆ counter_map
| std::map<std::string, unsigned int> EnableObserverPointer::counter_map |
|
mutableprivateinherited |
◆ validity_pointers
| std::vector<std::atomic<bool> *> EnableObserverPointer::validity_pointers |
|
mutableprivateinherited |
◆ object_info
| const std::type_info* EnableObserverPointer::object_info |
|
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.
◆ mutex
| std::mutex EnableObserverPointer::mutex |
|
staticprivateinherited |
The documentation for this class was generated from the following file: