16 #ifndef dealii_la_vector_h 17 #define dealii_la_vector_h 20 #include <deal.II/base/config.h> 22 #include <deal.II/base/exceptions.h> 23 #include <deal.II/base/index_set.h> 24 #include <deal.II/base/logstream.h> 26 #include <deal.II/lac/read_write_vector.h> 27 #include <deal.II/lac/vector_operation.h> 28 #include <deal.II/lac/vector_space_vector.h> 29 #include <deal.II/lac/vector_type_traits.h> 33 #include <boost/version.hpp> 34 #if BOOST_VERSION >= 106400 35 # include <boost/serialization/array_wrapper.hpp> 37 # include <boost/serialization/array.hpp> 39 #include <boost/serialization/split_member.hpp> 47 DEAL_II_NAMESPACE_OPEN
64 template <
typename Number>
93 explicit Vector(
const size_type n);
99 template <
typename InputIterator>
100 Vector(
const InputIterator first,
const InputIterator last);
112 const bool omit_zeroing_entries =
false)
override;
122 template <
typename Number2>
125 const bool omit_zeroing_entries =
false);
138 const bool omit_zeroing_entries =
false)
override;
147 const bool omit_zeroing_entries =
false)
override;
158 template <
typename Number2>
205 std::shared_ptr<const CommunicationPatternBase> communication_pattern =
206 std::shared_ptr<const CommunicationPatternBase>())
override;
212 add(
const Number a)
override;
269 virtual typename VectorSpaceVector<Number>::real_type
276 virtual typename VectorSpaceVector<Number>::real_type
283 virtual typename VectorSpaceVector<Number>::real_type
316 size()
const override;
336 print(std::ostream & out,
337 const unsigned int precision = 3,
338 const bool scientific =
true,
339 const bool across =
true)
const override;
382 template <
typename Archive>
384 serialize(Archive &ar,
const unsigned int version);
386 friend class boost::serialization::access;
391 template <
typename Number2>
398 template <
typename Number>
405 template <
typename Number>
412 template <
typename Number>
413 template <
typename InputIterator>
415 const InputIterator last)
417 this->
reinit(complete_index_set(std::distance(first, last)),
true);
418 std::copy(first, last, this->
begin());
423 template <
typename Number>
424 inline typename Vector<Number>::size_type
432 template <
typename Number>
441 template <
typename Number>
444 const unsigned int precision,
445 const bool scientific,
453 template <
typename Number>
454 template <
typename Archive>
458 size_type current_size = this->
size();
462 if (this->
size() != current_size)
464 ar &boost::serialization::make_array(this->
values.get(), this->
size());
469 template <
typename Number>
483 template <
typename Number>
488 DEAL_II_NAMESPACE_CLOSE
491 # include <deal.II/lac/la_vector.templates.h> virtual VectorSpaceVector< Number >::real_type linfty_norm() const override
virtual void add(const Number a) override
std::size_t memory_consumption() const
Vector< Number > & operator=(const Vector< Number > &in_vector)
virtual Vector< Number > & operator*=(const Number factor) override
virtual std::size_t memory_consumption() const override
virtual Number operator*(const VectorSpaceVector< Number > &V) const override
virtual Vector< Number > & operator+=(const VectorSpaceVector< Number > &V) override
static::ExceptionBase & ExcVectorTypeNotCompatible()
unsigned long long int global_dof_index
virtual void equ(const Number a, const VectorSpaceVector< Number > &V) override
void block_write(std::ostream &out) const
virtual ::IndexSet locally_owned_elements() const override
virtual Vector< Number > & operator-=(const VectorSpaceVector< Number > &V) override
virtual void sadd(const Number s, const Number a, const VectorSpaceVector< Number > &V) override
std::unique_ptr< Number[], decltype(free)* > values
virtual void reinit(const size_type size, const bool omit_zeroing_entries=false) override
virtual void print(std::ostream &out, const unsigned int precision=3, const bool scientific=true, const bool across=true) const override
void print(std::ostream &out, const unsigned int precision=3, const bool scientific=true) const
#define DeclException0(Exception0)
virtual Vector< Number > & operator/=(const Number factor) override
virtual void scale(const VectorSpaceVector< Number > &scaling_factors) override
virtual bool all_zero() const override
virtual size_type size() const override
virtual VectorSpaceVector< Number >::real_type l1_norm() const override
virtual VectorSpaceVector< Number >::real_type l2_norm() const override
void block_read(std::istream &in)
virtual value_type mean_value() const override
virtual Number add_and_dot(const Number a, const VectorSpaceVector< Number > &V, const VectorSpaceVector< Number > &W) override
void serialize(Archive &ar, const unsigned int version)