deal.II version 9.7.0
\(\newcommand{\dealvcentcolon}{\mathrel{\mathop{:}}}\) \(\newcommand{\dealcoloneq}{\dealvcentcolon\mathrel{\mkern-1.2mu}=}\) \(\newcommand{\jump}[1]{\left[\!\left[ #1 \right]\!\right]}\) \(\newcommand{\average}[1]{\left\{\!\left\{ #1 \right\}\!\right\}}\)
Loading...
Searching...
No Matches
LinearAlgebra::TpetraWrappers::PreconditionILUT< Number, MemorySpace > Class Template Reference

#include <deal.II/lac/trilinos_tpetra_precondition.h>

Detailed Description

template<typename Number, typename MemorySpace = ::MemorySpace::Host>
class LinearAlgebra::TpetraWrappers::PreconditionILUT< Number, MemorySpace >

The class for the thresholded incomplete LU (ILUT) preconditioner within Ifpack2.

Definition at line 1002 of file trilinos_tpetra_precondition.h.

Inheritance diagram for LinearAlgebra::TpetraWrappers::PreconditionILUT< Number, MemorySpace >:

Classes

struct  AdditionalData
 The set of additional parameters to tune the preconditioner. More...

Public Member Functions

 PreconditionILUT ()
 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.
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 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.
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.
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.
Teuchos::RCP< TpetraTypes::LinearOperator< Number, MemorySpace > > trilinos_rcp () const
 Access to underlying Trilinos data.
void serialize (Archive &ar, const unsigned int version)
void serialize (Archive &ar, const unsigned int version)
Partitioners
IndexSet locally_owned_domain_indices () const
IndexSet locally_owned_domain_indices () const
IndexSet locally_owned_range_indices () const
IndexSet locally_owned_range_indices () const
Querying the observer pointers an object has.
unsigned int n_subscriptions () const
unsigned int n_subscriptions () const
void list_subscribers (StreamType &stream) const
void list_subscribers () const
void list_subscribers (StreamType &stream) const
void list_subscribers () const

Static Public Member Functions

static ::ExceptionBaseExcTrilinosIpack2PreconditionerUnsupported (std::string arg1)
static ::ExceptionBaseExcNonMatchingMaps (std::string arg1)
static ::ExceptionBaseExcNonMatchingMaps (std::string arg1)
static ::ExceptionBaseExcTransposeNotSupported ()
static ::ExceptionBaseExcTransposeNotSupported ()
static ::ExceptionBaseExcInUse (int arg1, std::string arg2, std::string arg3)
static ::ExceptionBaseExcInUse (int arg1, std::string arg2, std::string arg3)
static ::ExceptionBaseExcNoSubscriber (std::string arg1, std::string arg2)
static ::ExceptionBaseExcNoSubscriber (std::string arg1, std::string arg2)

Protected Attributes

std::string preconditioner_type
Teuchos::RCP< TpetraTypes::LinearOperator< Number, MemorySpace > > preconditioner
Teuchos::RCP< TpetraTypes::LinearOperator< Number, MemorySpace > > preconditioner
Teuchos::ParameterList parameter_list
 The list of preconditioner parameters.
Teuchos::ParameterList parameter_list
 The list of preconditioner parameters.

Private Types

using map_value_type
using map_value_type
using map_iterator
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 subscribe (std::atomic< bool > *const validity, const std::string &identifier="") const
void unsubscribe (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
void check_no_subscribers () const noexcept

Private Attributes

std::atomic< unsigned intcounter
std::atomic< unsigned intcounter
std::map< std::string, unsigned intcounter_map
std::map< std::string, unsigned intcounter_map
std::vector< std::atomic< bool > * > validity_pointers
std::vector< std::atomic< bool > * > validity_pointers
const std::type_info * object_info
const std::type_info * object_info

Static Private Attributes

static std::mutex mutex
static std::mutex mutex

Member Typedef Documentation

◆ map_value_type [1/2]

using EnableObserverPointer::map_value_type
privateinherited

The data type used in counter_map.

Definition at line 224 of file enable_observer_pointer.h.

◆ map_value_type [2/2]

using EnableObserverPointer::map_value_type
privateinherited

The data type used in counter_map.

Definition at line 224 of file enable_observer_pointer.h.

◆ map_iterator [1/2]

using EnableObserverPointer::map_iterator
privateinherited

The iterator type used in counter_map.

Definition at line 229 of file enable_observer_pointer.h.

◆ map_iterator [2/2]

using EnableObserverPointer::map_iterator
privateinherited

The iterator type used in counter_map.

Definition at line 229 of file enable_observer_pointer.h.

Constructor & Destructor Documentation

◆ PreconditionILUT()

template<typename Number, typename MemorySpace = ::MemorySpace::Host>
LinearAlgebra::TpetraWrappers::PreconditionILUT< Number, MemorySpace >::PreconditionILUT ( )

Constructor.

Member Function Documentation

◆ initialize() [1/2]

template<typename Number, typename MemorySpace = ::MemorySpace::Host>
void LinearAlgebra::TpetraWrappers::PreconditionILUT< Number, MemorySpace >::initialize ( const SparseMatrix< Number, MemorySpace > & A,
const AdditionalData & additional_data = AdditionalData() )

Compute the preconditioner based on the given matrix and parameters.

Parameters
AThe matrix to base the preconditioner on.
additional_dataThe set of parameters to tune the preconditioner.

◆ initialize() [2/2]

void LinearAlgebra::TpetraWrappers::PreconditionIfpackBase< Number, MemorySpace >::initialize ( const SparseMatrix< Number, MemorySpace > & A)
inherited

Initializes the preconditioner for the matrix A based on the parameter_set.

◆ ExcTrilinosIpack2PreconditionerUnsupported()

::ExceptionBase & LinearAlgebra::TpetraWrappers::PreconditionIfpackBase< Number, MemorySpace >::ExcTrilinosIpack2PreconditionerUnsupported ( std::string arg1)
staticinherited

The chosen preconditioner is not supported or configured with Ifpack2.

Note
The message that will be printed by this exception reads:
<< "You tried to select the preconditioner type <" << arg1 << ">\n" << "but this preconditioner is not supported by Trilinos/Ifpack22\n" << "due to one of the following reasons:\n" << "* This preconditioner does not exist\n" << "* This preconditioner has a specialized constructor not supported by the Ifpack2 Factory.\n" << "* This preconditioner is not (yet) supported by Trilinos/Ifpack2\n" << "* Trilinos/Ifpack2 was not configured for its use."

◆ clear() [1/2]

void LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::clear ( )
inherited

Destructor. Destroys the preconditioner, leaving an object like just after having called the constructor.

◆ clear() [2/2]

void LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::clear ( )
inherited

Destructor. Destroys the preconditioner, leaving an object like just after having called the constructor.

◆ vmult() [1/2]

virtual void LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::vmult ( Vector< Number, MemorySpace > & dst,
const Vector< Number, MemorySpace > & src ) const
virtualinherited

Apply the preconditioner.

Parameters
dstInput vector to apply the preconditioner to
srcResult vector

◆ vmult() [2/2]

virtual void LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::vmult ( Vector< Number, MemorySpace > & dst,
const Vector< Number, MemorySpace > & src ) const
virtualinherited

Apply the preconditioner.

Parameters
dstInput vector to apply the preconditioner to
srcResult vector

◆ Tvmult() [1/2]

virtual void LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::Tvmult ( Vector< Number, MemorySpace > & dst,
const Vector< Number, MemorySpace > & src ) const
virtualinherited

Apply the transpose preconditioner.

Parameters
dstInput vector to apply the preconditioner to
srcResult vector

◆ Tvmult() [2/2]

virtual void LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::Tvmult ( Vector< Number, MemorySpace > & dst,
const Vector< Number, MemorySpace > & src ) const
virtualinherited

Apply the transpose preconditioner.

Parameters
dstInput vector to apply the preconditioner to
srcResult vector

◆ trilinos_operator() [1/2]

const TpetraTypes::LinearOperator< Number, MemorySpace > & LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::trilinos_operator ( ) const
inherited

Access to underlying Trilinos data.

Calling this function from an uninitialized object will cause an exception.

◆ trilinos_operator() [2/2]

const TpetraTypes::LinearOperator< Number, MemorySpace > & LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::trilinos_operator ( ) const
inherited

Access to underlying Trilinos data.

Calling this function from an uninitialized object will cause an exception.

◆ trilinos_rcp() [1/2]

Teuchos::RCP< TpetraTypes::LinearOperator< Number, MemorySpace > > LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::trilinos_rcp ( ) const
inherited

Access to underlying Trilinos data.

Calling this function from an uninitialized object will cause an exception.

◆ trilinos_rcp() [2/2]

Teuchos::RCP< TpetraTypes::LinearOperator< Number, MemorySpace > > LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::trilinos_rcp ( ) const
inherited

Access to underlying Trilinos data.

Calling this function from an uninitialized object will cause an exception.

◆ locally_owned_domain_indices() [1/2]

IndexSet LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::locally_owned_domain_indices ( ) const
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.

Returns
IndexSet of the domain of this preconditioner

◆ locally_owned_domain_indices() [2/2]

IndexSet LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::locally_owned_domain_indices ( ) const
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.

Returns
IndexSet of the domain of this preconditioner

◆ locally_owned_range_indices() [1/2]

IndexSet LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::locally_owned_range_indices ( ) const
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.

Returns
IndexSet of the range of this preconditioner

◆ locally_owned_range_indices() [2/2]

IndexSet LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::locally_owned_range_indices ( ) const
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.

Returns
IndexSet of the range of this preconditioner

◆ ExcNonMatchingMaps() [1/2]

::ExceptionBase & LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::ExcNonMatchingMaps ( std::string arg1)
staticinherited

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."

◆ ExcNonMatchingMaps() [2/2]

::ExceptionBase & LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::ExcNonMatchingMaps ( std::string arg1)
staticinherited

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() [1/2]

::ExceptionBase & LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::ExcTransposeNotSupported ( )
staticinherited

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."

◆ ExcTransposeNotSupported() [2/2]

::ExceptionBase & LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::ExcTransposeNotSupported ( )
staticinherited

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() [1/2]

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.

◆ n_subscriptions() [2/2]

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/4]

void EnableObserverPointer::list_subscribers ( StreamType & stream) const
inlineinherited

List the subscribers to the input stream.

Definition at line 136 of file enable_observer_pointer.h.

◆ list_subscribers() [2/4]

void EnableObserverPointer::list_subscribers ( ) const
inherited

List the subscribers to deallog.

Definition at line 142 of file enable_observer_pointer.cc.

◆ list_subscribers() [3/4]

void EnableObserverPointer::list_subscribers ( StreamType & stream) const
inlineinherited

List the subscribers to the input stream.

Definition at line 136 of file enable_observer_pointer.h.

◆ list_subscribers() [4/4]

void EnableObserverPointer::list_subscribers ( ) const
inherited

List the subscribers to deallog.

Definition at line 142 of file enable_observer_pointer.cc.

◆ ExcInUse() [1/2]

::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."

◆ ExcInUse() [2/2]

::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() [1/2]

::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."

◆ ExcNoSubscriber() [2/2]

::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() [1/2]

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.

◆ serialize() [2/2]

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() [1/2]

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.

◆ subscribe() [2/2]

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() [1/2]

void EnableObserverPointer::unsubscribe ( std::atomic< bool > *const validity,
const std::string & identifier = "" ) const
privateinherited

Unsubscribes a user from the object.

Note
The 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.

◆ unsubscribe() [2/2]

void EnableObserverPointer::unsubscribe ( std::atomic< bool > *const validity,
const std::string & identifier = "" ) const
privateinherited

Unsubscribes a user from the object.

Note
The 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.

◆ check_no_subscribers() [1/2]

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.

◆ check_no_subscribers() [2/2]

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.

Member Data Documentation

◆ preconditioner_type

std::string LinearAlgebra::TpetraWrappers::PreconditionIfpackBase< Number, MemorySpace >::preconditioner_type
protectedinherited

The set preconditioner type to be handed to Ifpack2::Factory::create()

Definition at line 290 of file trilinos_tpetra_precondition.h.

◆ preconditioner [1/2]

Teuchos::RCP<TpetraTypes::LinearOperator<Number, MemorySpace> > LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::preconditioner
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.

◆ preconditioner [2/2]

Teuchos::RCP<TpetraTypes::LinearOperator<Number, MemorySpace> > LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::preconditioner
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.

◆ parameter_list [1/2]

Teuchos::ParameterList LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::parameter_list
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.

◆ parameter_list [2/2]

Teuchos::ParameterList LinearAlgebra::TpetraWrappers::PreconditionBase< Number, MemorySpace >::parameter_list
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.

◆ counter [1/2]

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 [2/2]

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 [1/2]

std::map<std::string, unsigned int> EnableObserverPointer::counter_map
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.

◆ counter_map [2/2]

std::map<std::string, unsigned int> EnableObserverPointer::counter_map
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.

◆ validity_pointers [1/2]

std::vector<std::atomic<bool> *> EnableObserverPointer::validity_pointers
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.

◆ validity_pointers [2/2]

std::vector<std::atomic<bool> *> EnableObserverPointer::validity_pointers
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.

◆ object_info [1/2]

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.

◆ object_info [2/2]

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 [1/2]

std::mutex EnableObserverPointer::mutex
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.

◆ mutex [2/2]

std::mutex EnableObserverPointer::mutex
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.


The documentation for this class was generated from the following file: