18#ifdef DEAL_II_WITH_TRILINOS
28# include <boost/io/ios_state.hpp>
30# include <Epetra_Export.h>
31# include <Epetra_Import.h>
32# include <Epetra_Vector.h>
54 vector.vector->Map().LID(
60 vector.vector->Map().MinMyGID(),
61 vector.vector->Map().MaxMyGID()));
76 , vector(
new Epetra_FEVector(
77 Epetra_Map(0, 0, 0,
Utilities::Trilinos::comm_self())))
123 vector = std::make_unique<Epetra_FEVector>(
135 reinit(local, ghost, communicator,
false);
148 vector = std::make_unique<Epetra_FEVector>(map);
167 vector = std::make_unique<Epetra_FEVector>(map);
211 const Epetra_MpiComm *
my_comm =
212 dynamic_cast<const Epetra_MpiComm *
>(&
vector->Comm());
213 const Epetra_MpiComm *
v_comm =
214 dynamic_cast<const Epetra_MpiComm *
>(&v.
vector->Comm());
221 vector = std::make_unique<Epetra_FEVector>(v.
vector->Map());
250 "It is not possible to exchange data with the "
251 "option 'omit_zeroing_entries' set, which would not write "
266 dynamic_cast<const Epetra_MpiComm *
>(&(v.
vector->Comm()));
293 n_elements += v.
block(block).local_size();
294 std::vector<TrilinosWrappers::types::int_type>
global_ids(n_elements, -1);
299 v.
block(block).trilinos_partitioner());
312 v.
block(0).trilinos_partitioner().Comm());
319 v.
block(block).trilinos_vector().ExtractCopy(entries, 0);
320 entries += v.
block(block).local_size();
323 if (import_data ==
true)
342 dynamic_cast<const Epetra_MpiComm *
>(&(
vector->Comm()));
367 vector = std::make_unique<Epetra_FEVector>(map);
374 ExcMessage(
"A writable vector must not have ghost entries in "
375 "its parallel partitioning"));
377 if (
vector->Map().SameAs(map) ==
false)
378 vector = std::make_unique<Epetra_FEVector>(map);
413 const std::shared_ptr<const Utilities::MPI::Partitioner> &partitioner,
419 Assert(partitioner->ghost_indices_initialized(),
420 ExcMessage(
"You asked to create a ghosted vector, but the "
421 "partitioner does not provide ghost indices."));
423 this->
reinit(partitioner->locally_owned_range(),
424 partitioner->ghost_indices(),
425 partitioner->get_mpi_communicator(),
430 this->
reinit(partitioner->locally_owned_range(),
431 partitioner->get_mpi_communicator());
441 ExcMessage(
"Vector is not constructed properly."));
445 const Epetra_MpiComm *
my_comm =
446 dynamic_cast<const Epetra_MpiComm *
>(&
vector->Comm());
447 const Epetra_MpiComm *
v_comm =
448 dynamic_cast<const Epetra_MpiComm *
>(&v.
vector->Comm());
490 (v.
vector->Map().UniqueGIDs() ||
vector->Map().UniqueGIDs()))
523 template <
typename number>
549 "Cannot find exchange information!"));
551 ExcMessage(
"The input vector has overlapping data, "
552 "which is not allowed."));
574 "Both vectors need to have the same size for import_elements() to work!"));
584 (*
this)[idx] =
rwv[idx];
589 (*
this)[idx] +=
rwv[idx];
617 "compress() can only be called with VectorOperation add, insert, or unknown"));
627 "The last operation on the Vector and the given last action in the compress() call do not agree!"));
644 "Not all processors agree whether the last operation on "
645 "this vector was an addition or a set operation. This will "
646 "prevent the compress() operation from succeeding."));
685 vector->Map().MaxMyGID()));
706# if DEAL_II_TRILINOS_VERSION_GTE(11, 11, 0)
739 if ((*(v.
vector))[0][i] != (*vector)[0][i])
752 return (!(*
this == v));
764 unsigned int flag = 0;
778 dynamic_cast<const Epetra_MpiComm *
>(&
vector->Map().Comm());
793 unsigned int flag = 0;
815 const unsigned int precision,
816 const bool scientific,
823 out.precision(precision);
825 out.setf(std::ios::scientific, std::ios::floatfield);
827 out.setf(std::ios::fixed, std::ios::floatfield);
834 out <<
"size:" <<
size() <<
" local_size:" <<
local_size() <<
" :"
849 out <<
static_cast<double>(val[i]) <<
' ';
852 out <<
static_cast<double>(val[i]) << std::endl;
882 return sizeof(*this) +
889# include "trilinos_vector.inst"
value_type * data() const noexcept
unsigned int n_blocks() const
BlockType & block(const unsigned int i)
size_type n_elements() const
void set_size(const size_type size)
void add_indices(const ForwardIterator &begin, const ForwardIterator &end)
const IndexSet & get_stored_elements() const
void compress(VectorOperation::values operation)
void add(const std::vector< size_type > &indices, const std::vector< TrilinosScalar > &values)
std::unique_ptr< Epetra_MultiVector > nonlocal_vector
void import_elements(const LinearAlgebra::ReadWriteVector< double > &rwv, const VectorOperation::values operation)
MPI_Comm get_mpi_communicator() const
const Epetra_BlockMap & trilinos_partitioner() const
reference operator()(const size_type index)
void import_nonlocal_data_for_fe(const ::TrilinosWrappers::SparseMatrix &matrix, const Vector &vector)
std::unique_ptr< Epetra_FEVector > vector
size_type local_size() const
void print(std::ostream &out, const unsigned int precision=3, const bool scientific=true, const bool across=true) const
IndexSet locally_owned_elements() const
void reinit(const Vector &v, const bool omit_zeroing_entries=false, const bool allow_different_maps=false)
bool has_ghost_elements() const
std::pair< size_type, size_type > local_range() const
bool operator!=(const Vector &v) const
bool operator==(const Vector &v) const
Epetra_CombineMode last_action
Vector & operator=(const TrilinosScalar s)
bool is_non_negative() const
std::size_t memory_consumption() const
const Epetra_CrsMatrix & trilinos_matrix() const
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
static ::ExceptionBase & ExcIO()
static ::ExceptionBase & ExcGhostsPresent()
static ::ExceptionBase & ExcNotImplemented()
static ::ExceptionBase & ExcAccessToNonLocalElement(size_type arg1, size_type arg2, size_type arg3, size_type arg4)
#define Assert(cond, exc)
#define AssertIndexRange(index, range)
static ::ExceptionBase & ExcTrilinosError(int arg1)
static ::ExceptionBase & ExcInternalError()
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
static ::ExceptionBase & ExcMessage(std::string arg1)
#define AssertThrow(cond, exc)
void swap(BlockVector &u, BlockVector &v)
TrilinosWrappers::types::int_type global_length(const Epetra_MultiVector &vector)
int gid(const Epetra_BlockMap &map, int i)
TrilinosWrappers::types::int_type * my_global_elements(const Epetra_BlockMap &map)
TrilinosWrappers::types::int64_type n_global_elements(const Epetra_BlockMap &map)
T sum(const T &t, const MPI_Comm mpi_communicator)
unsigned int n_mpi_processes(const MPI_Comm mpi_communicator)
T max(const T &t, const MPI_Comm mpi_communicator)
MinMaxAvg min_max_avg(const double my_value, const MPI_Comm mpi_communicator)