16 #ifndef dealii_petsc_block_vector_h
17 #define dealii_petsc_block_vector_h
20 #include <deal.II/base/config.h>
22 #ifdef DEAL_II_WITH_PETSC
24 # include <deal.II/lac/block_indices.h>
25 # include <deal.II/lac/block_vector_base.h>
26 # include <deal.II/lac/exceptions.h>
27 # include <deal.II/lac/petsc_vector.h>
28 # include <deal.II/lac/vector_type_traits.h>
30 DEAL_II_NAMESPACE_OPEN
78 using pointer = BaseClass::pointer;
79 using const_pointer = BaseClass::const_pointer;
80 using reference = BaseClass::reference;
81 using const_reference = BaseClass::const_reference;
82 using size_type = BaseClass::size_type;
98 const MPI_Comm & communicator,
99 const size_type block_size,
100 const size_type local_size);
115 BlockVector(
const std::vector<size_type> &block_sizes,
116 const MPI_Comm & communicator,
117 const std::vector<size_type> &local_elements);
123 explicit BlockVector(
const std::vector<IndexSet> ¶llel_partitioning,
124 const MPI_Comm &communicator = MPI_COMM_WORLD);
129 BlockVector(
const std::vector<IndexSet> ¶llel_partitioning,
130 const std::vector<IndexSet> &ghost_indices,
131 const MPI_Comm & communicator);
164 const MPI_Comm & communicator,
165 const size_type block_size,
166 const size_type local_size,
167 const bool omit_zeroing_entries =
false);
190 reinit(
const std::vector<size_type> &block_sizes,
191 const MPI_Comm & communicator,
192 const std::vector<size_type> &local_sizes,
193 const bool omit_zeroing_entries =
false);
217 reinit(
const std::vector<IndexSet> ¶llel_partitioning,
218 const MPI_Comm & communicator);
224 reinit(
const std::vector<IndexSet> ¶llel_partitioning,
225 const std::vector<IndexSet> &ghost_entries,
226 const MPI_Comm & communicator);
235 reinit(
const unsigned int num_blocks);
274 print(std::ostream & out,
275 const unsigned int precision = 3,
276 const bool scientific =
true,
277 const bool across =
true)
const;
294 const MPI_Comm & communicator,
295 const size_type block_size,
296 const size_type local_size)
304 const std::vector<size_type> &block_sizes,
305 const MPI_Comm & communicator,
306 const std::vector<size_type> &local_elements)
308 reinit(block_sizes, communicator, local_elements,
false);
318 for (
unsigned int i = 0; i < this->
n_blocks(); ++i)
323 const std::vector<IndexSet> ¶llel_partitioning,
324 const MPI_Comm & communicator)
326 reinit(parallel_partitioning, communicator);
330 const std::vector<IndexSet> ¶llel_partitioning,
331 const std::vector<IndexSet> &ghost_indices,
332 const MPI_Comm & communicator)
334 reinit(parallel_partitioning, ghost_indices, communicator);
355 for (size_type i = 0; i < this->
n_blocks(); ++i)
367 const MPI_Comm & communicator,
368 const size_type block_size,
369 const size_type local_size,
370 const bool omit_zeroing_entries)
374 std::vector<size_type>(
n_blocks, local_size),
375 omit_zeroing_entries);
382 const MPI_Comm & communicator,
383 const std::vector<size_type> &local_sizes,
384 const bool omit_zeroing_entries)
390 for (
unsigned int i = 0; i < this->
n_blocks(); ++i)
394 omit_zeroing_entries);
405 for (
unsigned int i = 0; i < this->
n_blocks(); ++i)
406 block(i).reinit(v.
block(i), omit_zeroing_entries);
411 const MPI_Comm & communicator)
413 std::vector<size_type> sizes(parallel_partitioning.size());
414 for (
unsigned int i = 0; i < parallel_partitioning.size(); ++i)
415 sizes[i] = parallel_partitioning[i].
size();
421 for (
unsigned int i = 0; i < this->
n_blocks(); ++i)
422 block(i).reinit(parallel_partitioning[i], communicator);
427 const std::vector<IndexSet> &ghost_entries,
428 const MPI_Comm & communicator)
430 std::vector<types::global_dof_index> sizes(parallel_partitioning.size());
431 for (
unsigned int i = 0; i < parallel_partitioning.size(); ++i)
432 sizes[i] = parallel_partitioning[i].
size();
438 for (
unsigned int i = 0; i < this->
n_blocks(); ++i)
439 block(i).reinit(parallel_partitioning[i],
446 inline const MPI_Comm &
449 return block(0).get_mpi_communicator();
455 bool ghosted =
block(0).has_ghost_elements();
457 for (
unsigned int i = 0; i < this->
n_blocks(); ++i)
476 const unsigned int precision,
477 const bool scientific,
478 const bool across)
const
480 for (
unsigned int i = 0; i < this->
n_blocks(); ++i)
483 out <<
'C' << i <<
':';
485 out <<
"Component " << i << std::endl;
486 this->
components[i].print(out, precision, scientific, across);
512 namespace LinearOperatorImplementation
525 template <
typename Matrix>
531 v.
reinit(matrix.locally_owned_range_indices(),
532 matrix.get_mpi_communicator());
535 template <
typename Matrix>
541 v.
reinit(matrix.locally_owned_domain_indices(),
542 matrix.get_mpi_communicator());
560 DEAL_II_NAMESPACE_CLOSE
562 #endif // DEAL_II_WITH_PETSC