#include <ReplicatableVector.hpp>
Public Member Functions | |
ReplicatableVector () | |
ReplicatableVector (Vec vec) | |
ReplicatableVector (unsigned size) | |
~ReplicatableVector () | |
unsigned | GetSize () |
void | Resize (unsigned size) |
double & | operator[] (unsigned index) |
void | Replicate (unsigned lo, unsigned hi) |
void | ReplicatePetscVector (Vec vec) |
Private Member Functions | |
void | RemovePetscContext () |
Private Attributes | |
double * | mpData |
unsigned | mSize |
VecScatter | mToAll |
Vec | mReplicated |
Definition at line 39 of file ReplicatableVector.hpp.
ReplicatableVector::ReplicatableVector | ( | ) |
Default constructor. Note that the vector will need to be resized before it can be used.
Definition at line 61 of file ReplicatableVector.cpp.
ReplicatableVector::ReplicatableVector | ( | Vec | vec | ) |
Constructor taking in Petsc vector, which is immediately replicated into the internal data
vec | a Petsc vector |
Definition at line 69 of file ReplicatableVector.cpp.
References ReplicatePetscVector().
ReplicatableVector::ReplicatableVector | ( | unsigned | size | ) |
Constructor to make a vector of given size.
size | the size of the vector |
Definition at line 78 of file ReplicatableVector.cpp.
References Resize().
ReplicatableVector::~ReplicatableVector | ( | ) |
Default destructor. Remove PETSc context.
Definition at line 87 of file ReplicatableVector.cpp.
References RemovePetscContext().
void ReplicatableVector::RemovePetscContext | ( | ) | [private] |
Clear data. Used in resize method and destructor.
Definition at line 38 of file ReplicatableVector.cpp.
References mpData, mReplicated, and mToAll.
Referenced by Resize(), and ~ReplicatableVector().
unsigned ReplicatableVector::GetSize | ( | ) |
Return the size of the vector.
Definition at line 95 of file ReplicatableVector.cpp.
References mSize.
Referenced by AbstractFeObjectAssembler< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM, CAN_ASSEMBLE_VECTOR, CAN_ASSEMBLE_MATRIX, INTERPOLATION_LEVEL >::AssembleOnElement(), AbstractFunctionalCalculator< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM >::Calculate(), Replicate(), ReplicatePetscVector(), AbstractFeObjectAssembler< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM, CAN_ASSEMBLE_VECTOR, CAN_ASSEMBLE_MATRIX, INTERPOLATION_LEVEL >::SetCurrentSolution(), AbstractNonlinearElasticitySolver< DIM >::VectorSum(), Hdf5ToMeshalyzerConverter< ELEMENT_DIM, SPACE_DIM >::Write(), and Hdf5ToCmguiConverter< ELEMENT_DIM, SPACE_DIM >::Write().
void ReplicatableVector::Resize | ( | unsigned | size | ) |
Resize the vector.
size | The number of elements to allocate memory for. |
Definition at line 100 of file ReplicatableVector.cpp.
References mpData, mSize, RemovePetscContext(), and PetscTools::ReplicateException().
Referenced by AbstractCardiacTissue< ELEMENT_DIM, SPACE_DIM >::AbstractCardiacTissue(), ReplicatableVector(), and ReplicatePetscVector().
double & ReplicatableVector::operator[] | ( | unsigned | index | ) |
Access the vector.
index | the index of the vector to return |
Definition at line 122 of file ReplicatableVector.cpp.
void ReplicatableVector::Replicate | ( | unsigned | lo, | |
unsigned | hi | |||
) |
Replicate this vector over all processes.
Each process knows its local part of the vector. This method shares that knowledge across all the processes.
lo | The start of our ownership range | |
hi | One past the end of our ownership range |
Definition at line 131 of file ReplicatableVector.cpp.
References GetSize(), mpData, and ReplicatePetscVector().
Referenced by AbstractCardiacTissue< ELEMENT_DIM, SPACE_DIM >::ReplicateCaches().
void ReplicatableVector::ReplicatePetscVector | ( | Vec | vec | ) |
Replicate the given PETSc vector over all processes.
Each process knows its local part of the vector. This method shares that knowledge across all the processes, storing it in this object.
Our data vector will automatically be resized to fit the whole PETSc vector.
vec | The PETSc vector to replicate. |
Definition at line 144 of file ReplicatableVector.cpp.
References GetSize(), mpData, mReplicated, mToAll, and Resize().
Referenced by AbstractFunctionalCalculator< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM >::Calculate(), ReplicatableVector(), Replicate(), AbstractFeObjectAssembler< ELEMENT_DIM, SPACE_DIM, PROBLEM_DIM, CAN_ASSEMBLE_VECTOR, CAN_ASSEMBLE_MATRIX, INTERPOLATION_LEVEL >::SetCurrentSolution(), and Hdf5ToMeshalyzerConverter< ELEMENT_DIM, SPACE_DIM >::Write().
double* ReplicatableVector::mpData [private] |
The wrapped PeTSc vector.
Definition at line 43 of file ReplicatableVector.hpp.
Referenced by operator[](), RemovePetscContext(), Replicate(), ReplicatePetscVector(), and Resize().
unsigned ReplicatableVector::mSize [private] |
The length of the vector.
Definition at line 44 of file ReplicatableVector.hpp.
Referenced by GetSize(), operator[](), and Resize().
VecScatter ReplicatableVector::mToAll [private] |
Variable holding information for replicating a PETSc vector.
Definition at line 45 of file ReplicatableVector.hpp.
Referenced by RemovePetscContext(), and ReplicatePetscVector().
Vec ReplicatableVector::mReplicated [private] |
Vector to hold concentrated copy of replicated vector.
Definition at line 46 of file ReplicatableVector.hpp.
Referenced by RemovePetscContext(), and ReplicatePetscVector().