Reference documentation for deal.II version 9.1.0-pre
Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes | List of all members
LinearAlgebra::EpetraWrappers::Vector Class Reference

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

Inheritance diagram for LinearAlgebra::EpetraWrappers::Vector:
[legend]

Public Member Functions

 Vector ()
 
 Vector (const Vector &V)
 
 Vector (const IndexSet &parallel_partitioner, const MPI_Comm &communicator)
 
void reinit (const IndexSet &parallel_partitioner, const MPI_Comm &communicator, const bool omit_zeroing_entries=false)
 
virtual void reinit (const VectorSpaceVector< double > &V, const bool omit_zeroing_entries=false) override
 
Vectoroperator= (const Vector &V)
 
virtual Vectoroperator= (const double s) override
 
virtual void import (const ReadWriteVector< double > &V, VectorOperation::values operation, std::shared_ptr< const CommunicationPatternBase > communication_pattern=std::shared_ptr< const CommunicationPatternBase >()) override
 
virtual Vectoroperator*= (const double factor) override
 
virtual Vectoroperator/= (const double factor) override
 
virtual Vectoroperator+= (const VectorSpaceVector< double > &V) override
 
virtual Vectoroperator-= (const VectorSpaceVector< double > &V) override
 
virtual double operator* (const VectorSpaceVector< double > &V) const override
 
virtual void add (const double a) override
 
virtual void add (const double a, const VectorSpaceVector< double > &V) override
 
virtual void add (const double a, const VectorSpaceVector< double > &V, const double b, const VectorSpaceVector< double > &W) override
 
virtual void sadd (const double s, const double a, const VectorSpaceVector< double > &V) override
 
virtual void scale (const VectorSpaceVector< double > &scaling_factors) override
 
virtual void equ (const double a, const VectorSpaceVector< double > &V) override
 
virtual bool all_zero () const override
 
virtual double mean_value () const override
 
virtual double l1_norm () const override
 
virtual double l2_norm () const override
 
virtual double linfty_norm () const override
 
virtual double add_and_dot (const double a, const VectorSpaceVector< double > &V, const VectorSpaceVector< double > &W) override
 
bool has_ghost_elements () const
 
virtual size_type size () const override
 
MPI_Comm get_mpi_communicator () const
 
virtual ::IndexSet locally_owned_elements () const override
 
const Epetra_FEVector & trilinos_vector () const
 
Epetra_FEVector & trilinos_vector ()
 
virtual void print (std::ostream &out, const unsigned int precision=3, const bool scientific=true, const bool across=true) const override
 
virtual std::size_t memory_consumption () const override
 
- Public Member Functions inherited from LinearAlgebra::VectorSpaceVector< double >
virtual void compress (VectorOperation::values)
 
virtual ~VectorSpaceVector ()=default
 
- Public Member Functions inherited from Subscriptor
 Subscriptor ()
 
 Subscriptor (const Subscriptor &)
 
 Subscriptor (Subscriptor &&) noexcept
 
virtual ~Subscriptor ()
 
Subscriptoroperator= (const Subscriptor &)
 
Subscriptoroperator= (Subscriptor &&) noexcept
 
void subscribe (const char *identifier=nullptr) const
 
void unsubscribe (const char *identifier=nullptr) const
 
unsigned int n_subscriptions () const
 
template<typename StreamType >
void list_subscribers (StreamType &stream) const
 
void list_subscribers () const
 
template<class Archive >
void serialize (Archive &ar, const unsigned int version)
 

Static Public Member Functions

static::ExceptionBase & ExcDifferentParallelPartitioning ()
 
static::ExceptionBase & ExcVectorTypeNotCompatible ()
 
static::ExceptionBase & ExcTrilinosError (int arg1)
 
- Static Public Member Functions inherited from Subscriptor
static::ExceptionBase & ExcInUse (int arg1, std::string arg2, std::string arg3)
 
static::ExceptionBase & ExcNoSubscriber (std::string arg1, std::string arg2)
 

Private Member Functions

void create_epetra_comm_pattern (const IndexSet &source_index_set, const MPI_Comm &mpi_comm)
 

Private Attributes

std::unique_ptr< Epetra_FEVector > vector
 
::IndexSet source_stored_elements
 
std::shared_ptr< const CommunicationPatternepetra_comm_pattern
 

Detailed Description

This class implements a wrapper to the Trilinos distributed vector class Epetra_FEVector. This class is derived from the LinearAlgebra::VectorSpaceVector class. Note however that Epetra only works with Number = double.

Author
Bruno Turcksin, 2015

Definition at line 57 of file trilinos_epetra_vector.h.

Constructor & Destructor Documentation

Vector< Number >::Vector ( )

Constructor. Create a vector of dimension zero.

Definition at line 43 of file trilinos_epetra_vector.cc.

Vector< Number >::Vector ( const Vector V)

Copy constructor. Sets the dimension and the partitioning to that of the given vector and copies all elements.

Definition at line 50 of file trilinos_epetra_vector.cc.

Vector< Number >::Vector ( const IndexSet parallel_partitioner,
const MPI_Comm &  communicator 
)
explicit

This constructor takes an IndexSet that defines how to distribute the individual components among the MPI processors. Since it also includes information about the size of the vector, this is all we need to generate a parallel vector.

Definition at line 57 of file trilinos_epetra_vector.cc.

Member Function Documentation

void Vector< Number >::reinit ( const IndexSet parallel_partitioner,
const MPI_Comm &  communicator,
const bool  omit_zeroing_entries = false 
)

Reinit functionality. This function destroys the old vector content and generates a new one based on the input partitioning. The flag omit_zeroing_entries determines whether the vector should be filled with zero (false) or left untouched (true).

Definition at line 66 of file trilinos_epetra_vector.cc.

void Vector< Number >::reinit ( const VectorSpaceVector< double > &  V,
const bool  omit_zeroing_entries = false 
)
overridevirtual

Change the dimension to that of the vector V. The elements of V are not copied.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 85 of file trilinos_epetra_vector.cc.

Vector & Vector< Number >::operator= ( const Vector V)

Copy function. This function takes a Vector and copies all the elements. The Vector will have the same parallel distribution as V.

Definition at line 103 of file trilinos_epetra_vector.cc.

Vector & Vector< Number >::operator= ( const double  s)
overridevirtual

Sets all elements of the vector to the scalar s. This operation is only allowed if s is equal to zero.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 134 of file trilinos_epetra_vector.cc.

void Vector< Number >::import ( const ReadWriteVector< double > &  V,
VectorOperation::values  operation,
std::shared_ptr< const CommunicationPatternBase communication_pattern = std::shared_ptr<const CommunicationPatternBase>() 
)
overridevirtual

Imports all the elements present in the vector's IndexSet from the input vector V. VectorOperation::values operation is used to decide if the elements in V should be added to the current vector or replace the current elements. The last parameter can be used if the same communication pattern is used multiple times. This can be used to improve performance.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 148 of file trilinos_epetra_vector.cc.

Vector & Vector< Number >::operator*= ( const double  factor)
overridevirtual

Multiply the entire vector by a fixed factor.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 203 of file trilinos_epetra_vector.cc.

Vector & Vector< Number >::operator/= ( const double  factor)
overridevirtual

Divide the entire vector by a fixed factor.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 214 of file trilinos_epetra_vector.cc.

Vector & Vector< Number >::operator+= ( const VectorSpaceVector< double > &  V)
overridevirtual

Add the vector V to the present one.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 226 of file trilinos_epetra_vector.cc.

Vector & Vector< Number >::operator-= ( const VectorSpaceVector< double > &  V)
overridevirtual

Subtract the vector V from the present one.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 278 of file trilinos_epetra_vector.cc.

double Vector< Number >::operator* ( const VectorSpaceVector< double > &  V) const
overridevirtual

Return the scalar product of two vectors. The vectors need to have the same layout.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 287 of file trilinos_epetra_vector.cc.

void Vector< Number >::add ( const double  a)
overridevirtual

Add a to all components. Note that is a scalar not a vector.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 311 of file trilinos_epetra_vector.cc.

void Vector< Number >::add ( const double  a,
const VectorSpaceVector< double > &  V 
)
overridevirtual

Simple addition of a multiple of a vector, i.e. *this += a*V. The vectors need to have the same layout.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 322 of file trilinos_epetra_vector.cc.

void Vector< Number >::add ( const double  a,
const VectorSpaceVector< double > &  V,
const double  b,
const VectorSpaceVector< double > &  W 
)
overridevirtual

Multiple addition of multiple of a vector, i.e. *this> += a*V+b*W. The vectors need to have the same layout.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 342 of file trilinos_epetra_vector.cc.

void Vector< Number >::sadd ( const double  s,
const double  a,
const VectorSpaceVector< double > &  V 
)
overridevirtual

Scaling and simple addition of a multiple of a vector, i.e. *this = s*(*this)+a*V.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 374 of file trilinos_epetra_vector.cc.

void Vector< Number >::scale ( const VectorSpaceVector< double > &  scaling_factors)
overridevirtual

Scale each element of this vector by the corresponding element in the argument. This function is mostly meant to simulate multiplication (and immediate re-assignment) by a diagonal scaling matrix. The vectors need to have the same layout.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 393 of file trilinos_epetra_vector.cc.

void Vector< Number >::equ ( const double  a,
const VectorSpaceVector< double > &  V 
)
overridevirtual

Assignment *this = a*V.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 416 of file trilinos_epetra_vector.cc.

bool Vector< Number >::all_zero ( ) const
overridevirtual

Return whether the vector contains only elements with value zero.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 439 of file trilinos_epetra_vector.cc.

double Vector< Number >::mean_value ( ) const
overridevirtual

Return the mean value of the element of this vector.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 468 of file trilinos_epetra_vector.cc.

double Vector< Number >::l1_norm ( ) const
overridevirtual

Return the l1 norm of the vector (i.e., the sum of the absolute values of all entries among all processors).

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 482 of file trilinos_epetra_vector.cc.

double Vector< Number >::l2_norm ( ) const
overridevirtual

Return the l2 norm of the vector (i.e., the square root of the sum of the square of all entries among all processors).

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 495 of file trilinos_epetra_vector.cc.

double Vector< Number >::linfty_norm ( ) const
overridevirtual

Return the maximum norm of the vector (i.e., the maximum absolute value among all entries and among all processors).

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 508 of file trilinos_epetra_vector.cc.

double Vector< Number >::add_and_dot ( const double  a,
const VectorSpaceVector< double > &  V,
const VectorSpaceVector< double > &  W 
)
overridevirtual

Performs a combined operation of a vector addition and a subsequent inner product, returning the value of the inner product. In other words, the result of this function is the same as if the user called

this->add(a, V);
return_value = *this * W;

The reason this function exists is that this operation involves less memory transfer than calling the two functions separately. This method only needs to load three vectors, this, V, W, whereas calling separate methods means to load the calling vector this twice. Since most vector operations are memory transfer limited, this reduces the time by 25% (or 50% if W equals this).

The vectors need to have the same layout.

For complex-valued vectors, the scalar product in the second step is implemented as \(\left<v,w\right>=\sum_i v_i \bar{w_i}\).

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 521 of file trilinos_epetra_vector.cc.

bool Vector< Number >::has_ghost_elements ( ) const
inline

This function always returns false and is present only for backward compatibility.

Definition at line 382 of file trilinos_epetra_vector.h.

Vector::size_type Vector< Number >::size ( ) const
overridevirtual

Return the global size of the vector, equal to the sum of the number of locally owned indices among all processors.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 533 of file trilinos_epetra_vector.cc.

MPI_Comm Vector< Number >::get_mpi_communicator ( ) const

Return the MPI communicator object in use with this object.

Definition at line 545 of file trilinos_epetra_vector.cc.

IndexSet Vector< Number >::locally_owned_elements ( ) const
overridevirtual

Return an index set that describes which elements of this vector are owned by the current processor. As a consequence, the index sets returned on different processors if this is a distributed vector will form disjoint sets that add up to the complete index set. Obviously, if a vector is created on only one processor, then the result would satisfy

vec.locally_owned_elements() == complete_index_set(vec.size())

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 556 of file trilinos_epetra_vector.cc.

const Epetra_FEVector & Vector< Number >::trilinos_vector ( ) const

Return a const reference to the underlying Trilinos Epetra_FEVector class.

Definition at line 590 of file trilinos_epetra_vector.cc.

Epetra_FEVector & Vector< Number >::trilinos_vector ( )

Return a (modifyable) reference to the underlying Trilinos Epetra_FEVector class.

Definition at line 598 of file trilinos_epetra_vector.cc.

void Vector< Number >::print ( std::ostream &  out,
const unsigned int  precision = 3,
const bool  scientific = true,
const bool  across = true 
) const
overridevirtual

Prints the vector to the output stream out.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 606 of file trilinos_epetra_vector.cc.

std::size_t Vector< Number >::memory_consumption ( ) const
overridevirtual

Return the memory consumption of this class in bytes.

Implements LinearAlgebra::VectorSpaceVector< double >.

Definition at line 644 of file trilinos_epetra_vector.cc.

void Vector< Number >::create_epetra_comm_pattern ( const IndexSet source_index_set,
const MPI_Comm &  mpi_comm 
)
private

Create the CommunicationPattern for the communication between the IndexSet source_index_set and the current vector based on the communicator mpi_comm.

Definition at line 654 of file trilinos_epetra_vector.cc.

Member Data Documentation

std::unique_ptr<Epetra_FEVector> LinearAlgebra::EpetraWrappers::Vector::vector
private

Pointer to the actual Epetra vector object.

Definition at line 366 of file trilinos_epetra_vector.h.

::IndexSet LinearAlgebra::EpetraWrappers::Vector::source_stored_elements
private

IndexSet of the elements of the last imported vector.

Definition at line 371 of file trilinos_epetra_vector.h.

std::shared_ptr<const CommunicationPattern> LinearAlgebra::EpetraWrappers::Vector::epetra_comm_pattern
private

CommunicationPattern for the communication between the source_stored_elements IndexSet and the current vector.

Definition at line 377 of file trilinos_epetra_vector.h.


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