15#ifndef dealii_trilinos_sparsity_pattern_h
16#define dealii_trilinos_sparsity_pattern_h
20#ifdef DEAL_II_WITH_TRILINOS
31# include <Epetra_FECrsGraph.h>
32# include <Epetra_Map.h>
33# include <Epetra_MpiComm.h>
120 <<
"You tried to access row " << arg1
121 <<
" of a distributed sparsity pattern, "
122 <<
" but only rows " << arg2 <<
" through " << arg3
123 <<
" are stored locally and can be accessed.");
244 <<
"Attempt to access element " << arg2 <<
" of row "
245 << arg1 <<
" which doesn't have that many elements.");
326 const std::vector<size_type> &n_entries_per_row);
372 const std::vector<size_type> &n_entries_per_row);
386 template <
typename SparsityPatternType>
388 copy_from(
const SparsityPatternType &nontrilinos_sparsity_pattern);
439 const MPI_Comm communicator = MPI_COMM_WORLD,
454 const std::vector<size_type> &n_entries_per_row);
471 const IndexSet &col_parallel_partitioning,
472 const MPI_Comm communicator = MPI_COMM_WORLD,
487 const IndexSet &col_parallel_partitioning,
489 const std::vector<size_type> &n_entries_per_row);
518 const IndexSet &col_parallel_partitioning,
520 const MPI_Comm communicator = MPI_COMM_WORLD,
540 const MPI_Comm communicator = MPI_COMM_WORLD,
556 const std::vector<size_type> &n_entries_per_row);
576 const IndexSet &col_parallel_partitioning,
577 const MPI_Comm communicator = MPI_COMM_WORLD,
607 const IndexSet &col_parallel_partitioning,
609 const MPI_Comm communicator = MPI_COMM_WORLD,
618 const IndexSet &col_parallel_partitioning,
620 const std::vector<size_type> &n_entries_per_row);
631 template <
typename SparsityPatternType>
634 const IndexSet &col_parallel_partitioning,
635 const SparsityPatternType &nontrilinos_sparsity_pattern,
636 const MPI_Comm communicator = MPI_COMM_WORLD,
637 const bool exchange_data =
false);
647 template <
typename SparsityPatternType>
650 const SparsityPatternType &nontrilinos_sparsity_pattern,
651 const MPI_Comm communicator = MPI_COMM_WORLD,
652 const bool exchange_data =
false);
692 std::pair<size_type, size_type>
771 template <
typename ForwardIterator>
774 ForwardIterator
begin,
776 const bool indices_are_sorted =
false);
781 const bool indices_are_sorted =
false)
override;
795 const Epetra_FECrsGraph &
908 print(std::ostream &out,
909 const bool write_extended_trilinos_info =
false)
const;
938 <<
"An error with error number " << arg1
939 <<
" occurred while calling a Trilinos function");
947 <<
"The entry with index <" << arg1 <<
',' << arg2
948 <<
"> does not exist.");
958 <<
"You tried to access element (" << arg1 <<
'/' << arg2
960 <<
" of a distributed matrix, but only rows in range ["
961 << arg3 <<
',' << arg4
962 <<
"] are stored locally and can be accessed.");
970 <<
"You tried to access element (" << arg1 <<
'/' << arg2
971 <<
')' <<
" of a sparse matrix, but it appears to not"
972 <<
" exist in the Trilinos sparsity pattern.");
986 std::unique_ptr<Epetra_FECrsGraph>
graph;
1011 const size_type row,
1012 const size_type index)
1017 visit_present_row();
1022 inline Accessor::size_type
1023 Accessor::row()
const
1025 Assert(a_row < sparsity_pattern->n_rows(),
1026 ExcBeyondEndOfSparsityPattern());
1032 inline Accessor::size_type
1033 Accessor::column()
const
1035 Assert(a_row < sparsity_pattern->n_rows(),
1036 ExcBeyondEndOfSparsityPattern());
1037 return (*colnum_cache)[a_index];
1042 inline Accessor::size_type
1043 Accessor::index()
const
1045 Assert(a_row < sparsity_pattern->n_rows(),
1046 ExcBeyondEndOfSparsityPattern());
1053 const size_type row,
1054 const size_type index)
1055 : accessor(sp, row,
index)
1060 inline Iterator::Iterator(
const Iterator &) =
default;
1065 Iterator::operator++()
1067 Assert(accessor.a_row < accessor.sparsity_pattern->n_rows(),
1074 if (accessor.a_index >= accessor.colnum_cache->size())
1076 accessor.a_index = 0;
1079 while (accessor.a_row < accessor.sparsity_pattern->n_rows())
1081 const auto row_length =
1082 accessor.sparsity_pattern->row_length(accessor.a_row);
1083 if (row_length == 0 ||
1084 !accessor.sparsity_pattern->row_is_stored_locally(
1091 accessor.visit_present_row();
1099 Iterator::operator++(
int)
1101 const Iterator old_state = *
this;
1108 inline const Accessor &
1109 Iterator::operator*()
const
1116 inline const Accessor *
1117 Iterator::operator->()
const
1125 Iterator::operator==(
const Iterator &other)
const
1127 return (accessor.a_row == other.accessor.a_row &&
1128 accessor.a_index == other.accessor.a_index);
1134 Iterator::operator!=(
const Iterator &other)
const
1136 return !(*
this == other);
1142 Iterator::operator<(
const Iterator &other)
const
1144 return (accessor.row() < other.accessor.row() ||
1145 (accessor.row() == other.accessor.row() &&
1146 accessor.index() < other.accessor.index()));
1156 const size_type first_valid_row = this->local_range().first;
1202 SparsityPattern::in_local_range(
const size_type index)
const
1205# ifndef DEAL_II_WITH_64BIT_INDICES
1206 begin = graph->RowMap().MinMyGID();
1207 end = graph->RowMap().MaxMyGID() + 1;
1209 begin = graph->RowMap().MinMyGID64();
1210 end = graph->RowMap().MaxMyGID64() + 1;
1222 return graph->Filled();
1243 template <
typename ForwardIterator>
1246 ForwardIterator begin,
1247 ForwardIterator end,
1266 const_cast<std::decay_t<decltype(*
begin)
> *>(&*
begin));
1273 if (row_is_stored_locally(row))
1275 graph->InsertGlobalIndices(trilinos_row_index,
n_cols, col_index_ptr);
1276 else if (nonlocal_graph.get() !=
nullptr)
1281 Assert(nonlocal_graph->RowMap().LID(
1283 ExcMessage(
"Attempted to write into off-processor matrix row " +
1285 " that has not been specified as being writable upon "
1286 "initialization."));
1287 ierr = nonlocal_graph->InsertGlobalIndices(trilinos_row_index,
1292 ierr = graph->InsertGlobalIndices(1,
1293 &trilinos_row_index,
1302 inline const Epetra_FECrsGraph &
1303 SparsityPattern::trilinos_sparsity_pattern()
const
1311 SparsityPattern::locally_owned_domain_indices()
const
1313 return IndexSet(graph->DomainMap());
1319 SparsityPattern::locally_owned_range_indices()
const
1321 return IndexSet(graph->RangeMap());
virtual void add_entries(const ArrayView< const std::pair< size_type, size_type > > &entries)
void add_entries(const size_type row, ForwardIterator begin, ForwardIterator end, const bool indices_are_sorted=false)
bool is_compressed() const
void add(const size_type i, const size_type j)
SparsityPatternIterators::Iterator const_iterator
types::global_dof_index size_type
unsigned int row_length(const size_type row) const
std::shared_ptr< const std::vector< size_type > > colnum_cache
Accessor(const SparsityPattern *sparsity_pattern, const size_type row, const size_type index)
::types::global_dof_index size_type
SparsityPattern * sparsity_pattern
bool operator==(const Iterator &) const
::types::global_dof_index size_type
const Accessor & operator*() const
bool operator<(const Iterator &) const
friend class TrilinosWrappers::SparsityPattern
Iterator(const SparsityPattern *sparsity_pattern, const size_type row, const size_type index)
bool operator!=(const Iterator &) const
const Accessor * operator->() const
Iterator(const Iterator &i)
IndexSet locally_owned_domain_indices() const
size_type row_length(const size_type row) const
std::unique_ptr< Epetra_FECrsGraph > graph
void add(const size_type i, const size_type j)
void print(std::ostream &out, const bool write_extended_trilinos_info=false) const
unsigned int max_entries_per_row() const
size_type bandwidth() const
void print_gnuplot(std::ostream &out) const
const_iterator end() const
MPI_Comm get_mpi_communicator() const
virtual void add_row_entries(const size_type &row, const ArrayView< const size_type > &columns, const bool indices_are_sorted=false) override
const_iterator begin(const size_type r) const
std::uint64_t n_nonzero_elements() const
std::unique_ptr< Epetra_CrsGraph > nonlocal_graph
bool exists(const size_type i, const size_type j) const
const Epetra_Map & domain_partitioner() const
std::pair< size_type, size_type > local_range() const
::types::global_dof_index size_type
const Epetra_FECrsGraph & trilinos_sparsity_pattern() const
void add_entries(const size_type row, ForwardIterator begin, ForwardIterator end, const bool indices_are_sorted=false)
bool is_compressed() const
unsigned int local_size() const
void copy_from(const SparsityPattern &input_sparsity_pattern)
IndexSet locally_owned_range_indices() const
std::unique_ptr< Epetra_Map > column_space_map
const Epetra_Map & range_partitioner() const
const_iterator begin() const
const_iterator end(const size_type r) const
SparsityPatternIterators::Iterator const_iterator
bool in_local_range(const size_type index) const
virtual ~SparsityPattern() override=default
std::size_t memory_consumption() const
SparsityPattern & operator=(const SparsityPattern &input_sparsity_pattern)
bool row_is_stored_locally(const size_type i) const
void reinit(const size_type m, const size_type n, const size_type n_entries_per_row=0)
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_DISABLE_EXTRA_DIAGNOSTICS
#define DEAL_II_NAMESPACE_CLOSE
#define DEAL_II_ENABLE_EXTRA_DIAGNOSTICS
static ::ExceptionBase & ExcAccessToNonPresentElement(size_type arg1, size_type arg2)
#define DeclException0(Exception0)
static ::ExceptionBase & ExcBeyondEndOfSparsityPattern()
#define DeclException4(Exception4, type1, type2, type3, type4, outsequence)
static ::ExceptionBase & ExcNotImplemented()
static ::ExceptionBase & ExcInvalidIndexWithinRow(size_type arg1, size_type arg2)
#define Assert(cond, exc)
static ::ExceptionBase & ExcIteratorPastEnd()
static ::ExceptionBase & ExcAccessToNonlocalRow(size_type arg1, size_type arg2, size_type arg3)
#define DeclException2(Exception2, type1, type2, outsequence)
#define AssertDimension(dim1, dim2)
static ::ExceptionBase & ExcAccessToNonLocalElement(size_type arg1, size_type arg2, size_type arg3, size_type arg4)
static ::ExceptionBase & ExcInvalidIndex(size_type arg1, size_type arg2)
#define AssertIndexRange(index, range)
#define DeclException3(Exception3, type1, type2, type3, outsequence)
#define DeclException1(Exception1, type1, outsequence)
static ::ExceptionBase & ExcTrilinosError(int arg1)
static ::ExceptionBase & ExcTrilinosError(int arg1)
static ::ExceptionBase & ExcMessage(std::string arg1)
#define AssertThrow(cond, exc)
std::string to_string(const number value, const unsigned int digits=numbers::invalid_unsigned_int)
unsigned int global_dof_index