16 #ifndef dealii__petsc_vector_h 17 #define dealii__petsc_vector_h 20 #include <deal.II/base/config.h> 22 #ifdef DEAL_II_WITH_PETSC 24 # include <deal.II/base/subscriptor.h> 25 # include <deal.II/lac/exceptions.h> 26 # include <deal.II/lac/petsc_vector_base.h> 27 # include <deal.II/lac/petsc_parallel_vector.h> 28 # include <deal.II/lac/vector.h> 30 DEAL_II_NAMESPACE_OPEN
88 explicit Vector (
const size_type n);
94 template <
typename Number>
95 explicit Vector (const ::Vector<Number> &v);
103 explicit Vector (
const Vec &v);
160 template <
typename number>
173 void reinit (
const size_type N,
174 const bool omit_zeroing_entries =
false);
184 const bool omit_zeroing_entries =
false);
216 template <
typename number>
270 #if DEAL_II_PETSC_VERSION_LT(3,2,0) 271 ierr = VecDestroy (
vector);
273 ierr = VecDestroy (&
vector);
287 #if DEAL_II_PETSC_VERSION_LT(2,2,0) 288 ierr = VecConvertMPIToSeqAll (static_cast<const Vec &>(v),
296 ierr = VecScatterCreateToAll (static_cast<const Vec &>(v), &ctx, &
vector);
299 #if ((PETSC_VERSION_MAJOR == 2) && \ 300 ((PETSC_VERSION_MINOR < 3) || \ 301 ((PETSC_VERSION_MINOR == 3) && \ 302 (PETSC_VERSION_SUBMINOR < 3)))) 303 ierr = VecScatterBegin (static_cast<const Vec &>(v),
vector,
304 INSERT_VALUES, SCATTER_FORWARD, ctx);
307 ierr = VecScatterEnd (static_cast<const Vec &>(v),
vector,
308 INSERT_VALUES, SCATTER_FORWARD, ctx);
312 ierr = VecScatterBegin (ctx,static_cast<const Vec &>(v),
vector,
313 INSERT_VALUES, SCATTER_FORWARD);
316 ierr = VecScatterEnd (ctx, static_cast<const Vec &>(v),
vector,
317 INSERT_VALUES, SCATTER_FORWARD);
322 #if DEAL_II_PETSC_VERSION_LT(3,2,0) 323 ierr = VecScatterDestroy (ctx);
325 ierr = VecScatterDestroy (&ctx);
335 template <
typename number>
386 compress (::VectorOperation::insert);
394 DEAL_II_NAMESPACE_CLOSE
396 #endif // DEAL_II_WITH_PETSC
types::global_dof_index size_type
#define AssertThrow(cond, exc)
VectorBase & operator=(const PetscScalar s)
Vector & operator=(const Vector &v)
BlockDynamicSparsityPattern BlockCompressedSparsityPattern DEAL_II_DEPRECATED
static const bool supports_distributed_data
void compress(const VectorOperation::values operation)
unsigned int global_dof_index
void create_vector(const size_type n)
void swap(Vector &u, Vector &v)
void reinit(const size_type N, const bool omit_zeroing_entries=false)