Index map based sparse vector. More...
#include <vector_sparse.hpp>
Classes | |
class | const_iterator |
class | iterator |
Public Types | |
typedef A::size_type | size_type |
typedef A::difference_type | difference_type |
typedef T | value_type |
typedef A | array_type |
typedef const value_type & | const_reference |
typedef detail::map_traits< A, T >::reference | reference |
typedef const vector_reference < const self_type > | const_closure_type |
typedef vector_reference < self_type > | closure_type |
typedef self_type | vector_temporary_type |
typedef sparse_tag | storage_category |
typedef reverse_iterator_base < const_iterator > | const_reverse_iterator |
typedef reverse_iterator_base < iterator > | reverse_iterator |
typedef mapped_vector< T, A > | container_type |
typedef vector_tag | type_category |
typedef E | expression_type |
Public Member Functions | |
BOOST_UBLAS_INLINE | mapped_vector () |
BOOST_UBLAS_INLINE | mapped_vector (size_type size, size_type non_zeros=0) |
BOOST_UBLAS_INLINE | mapped_vector (const mapped_vector &v) |
template<class AE > | |
BOOST_UBLAS_INLINE | mapped_vector (const vector_expression< AE > &ae, size_type non_zeros=0) |
BOOST_UBLAS_INLINE size_type | size () const |
BOOST_UBLAS_INLINE size_type | nnz_capacity () const |
BOOST_UBLAS_INLINE size_type | nnz () const |
BOOST_UBLAS_INLINE const array_type & | data () const |
BOOST_UBLAS_INLINE array_type & | data () |
BOOST_UBLAS_INLINE void | resize (size_type size, bool preserve=true) |
BOOST_UBLAS_INLINE void | reserve (size_type non_zeros=0, bool preserve=true) |
BOOST_UBLAS_INLINE pointer | find_element (size_type i) |
BOOST_UBLAS_INLINE const_pointer | find_element (size_type i) const |
BOOST_UBLAS_INLINE const_reference | operator() (size_type i) const |
BOOST_UBLAS_INLINE true_reference | ref (size_type i) |
BOOST_UBLAS_INLINE reference | operator() (size_type i) |
BOOST_UBLAS_INLINE const_reference | operator[] (size_type i) const |
BOOST_UBLAS_INLINE reference | operator[] (size_type i) |
BOOST_UBLAS_INLINE true_reference | insert_element (size_type i, const_reference t) |
BOOST_UBLAS_INLINE void | erase_element (size_type i) |
BOOST_UBLAS_INLINE void | clear () |
BOOST_UBLAS_INLINE mapped_vector & | operator= (const mapped_vector &v) |
template<class C > | |
BOOST_UBLAS_INLINE mapped_vector & | operator= (const vector_container< C > &v) |
BOOST_UBLAS_INLINE mapped_vector & | assign_temporary (mapped_vector &v) |
template<class AE > | |
BOOST_UBLAS_INLINE mapped_vector & | operator= (const vector_expression< AE > &ae) |
template<class AE > | |
BOOST_UBLAS_INLINE mapped_vector & | assign (const vector_expression< AE > &ae) |
template<class AE > | |
BOOST_UBLAS_INLINE mapped_vector & | operator+= (const vector_expression< AE > &ae) |
template<class C > | |
BOOST_UBLAS_INLINE mapped_vector & | operator+= (const vector_container< C > &v) |
template<class AE > | |
BOOST_UBLAS_INLINE mapped_vector & | plus_assign (const vector_expression< AE > &ae) |
template<class AE > | |
BOOST_UBLAS_INLINE mapped_vector & | operator-= (const vector_expression< AE > &ae) |
template<class C > | |
BOOST_UBLAS_INLINE mapped_vector & | operator-= (const vector_container< C > &v) |
template<class AE > | |
BOOST_UBLAS_INLINE mapped_vector & | minus_assign (const vector_expression< AE > &ae) |
template<class AT > | |
BOOST_UBLAS_INLINE mapped_vector & | operator*= (const AT &at) |
template<class AT > | |
BOOST_UBLAS_INLINE mapped_vector & | operator/= (const AT &at) |
BOOST_UBLAS_INLINE void | swap (mapped_vector &v) |
const_iterator | find (size_type i) const |
iterator | find (size_type i) |
BOOST_UBLAS_INLINE const_iterator | begin () const |
BOOST_UBLAS_INLINE const_iterator | cbegin () const |
BOOST_UBLAS_INLINE const_iterator | end () const |
BOOST_UBLAS_INLINE const_iterator | cend () const |
BOOST_UBLAS_INLINE iterator | begin () |
BOOST_UBLAS_INLINE iterator | end () |
BOOST_UBLAS_INLINE const_reverse_iterator | rbegin () const |
BOOST_UBLAS_INLINE const_reverse_iterator | crbegin () const |
BOOST_UBLAS_INLINE const_reverse_iterator | rend () const |
BOOST_UBLAS_INLINE const_reverse_iterator | crend () const |
BOOST_UBLAS_INLINE reverse_iterator | rbegin () |
BOOST_UBLAS_INLINE reverse_iterator | rend () |
template<class Archive > | |
void | serialize (Archive &ar, const unsigned int) |
BOOST_UBLAS_INLINE const container_type & | operator() () const |
BOOST_UBLAS_INLINE container_type & | operator() () |
Static Public Attributes | |
static const unsigned | complexity |
Friends | |
BOOST_UBLAS_INLINE friend void | swap (mapped_vector &v1, mapped_vector &v2) |
Index map based sparse vector.
A sparse vector of values of type T of variable size. The sparse storage type A can be std::map<size_t, T>
or map_array<size_t, T>
. This means that only non-zero elements are effectively stored.
For a -dimensional sparse vector, and 0 <= i < n the non-zero elements are mapped to consecutive elements of the associative container, i.e. for elements and of the container, holds .
Supported parameters for the adapted array are map_array<std::size_t, T>
and map_std<std::size_t, T>
. The latter is equivalent to std::map<std::size_t, T>
.
T | the type of object stored in the vector (like double, float, complex, etc...) |
A | the type of Storage array |
typedef A boost::numeric::ublas::mapped_vector< T, A >::array_type |
typedef vector_reference<self_type> boost::numeric::ublas::mapped_vector< T, A >::closure_type |
typedef const vector_reference<const self_type> boost::numeric::ublas::mapped_vector< T, A >::const_closure_type |
typedef const value_type& boost::numeric::ublas::mapped_vector< T, A >::const_reference |
typedef reverse_iterator_base<const_iterator> boost::numeric::ublas::mapped_vector< T, A >::const_reverse_iterator |
|
inherited |
typedef A::difference_type boost::numeric::ublas::mapped_vector< T, A >::difference_type |
|
inherited |
typedef detail::map_traits<A,T>::reference boost::numeric::ublas::mapped_vector< T, A >::reference |
typedef reverse_iterator_base<iterator> boost::numeric::ublas::mapped_vector< T, A >::reverse_iterator |
typedef A::size_type boost::numeric::ublas::mapped_vector< T, A >::size_type |
typedef sparse_tag boost::numeric::ublas::mapped_vector< T, A >::storage_category |
|
inherited |
typedef T boost::numeric::ublas::mapped_vector< T, A >::value_type |
typedef self_type boost::numeric::ublas::mapped_vector< T, A >::vector_temporary_type |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Referenced by boost::numeric::ublas::mapped_vector< T, A >::operator=().
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Referenced by boost::numeric::ublas::mapped_vector< T, A >::begin(), boost::numeric::ublas::mapped_vector< T, A >::clear(), boost::numeric::ublas::mapped_vector< T, A >::end(), boost::numeric::ublas::mapped_vector< T, A >::erase_element(), boost::numeric::ublas::mapped_vector< T, A >::find(), boost::numeric::ublas::mapped_vector< T, A >::find_element(), boost::numeric::ublas::mapped_vector< T, A >::insert_element(), boost::numeric::ublas::mapped_vector< T, A >::mapped_vector(), boost::numeric::ublas::mapped_vector< T, A >::nnz(), boost::numeric::ublas::mapped_vector< T, A >::nnz_capacity(), boost::numeric::ublas::mapped_vector< T, A >::operator()(), boost::numeric::ublas::mapped_vector< T, A >::operator+=(), boost::numeric::ublas::mapped_vector< T, A >::operator-=(), boost::numeric::ublas::mapped_vector< T, A >::operator=(), boost::numeric::ublas::mapped_vector< T, A >::ref(), boost::numeric::ublas::mapped_vector< T, A >::reserve(), boost::numeric::ublas::mapped_vector< T, A >::resize(), and boost::numeric::ublas::mapped_vector< T, A >::swap().
|
inline |
|
inline |
References boost::numeric::ublas::mapped_vector< T, A >::data().
Referenced by boost::numeric::ublas::mapped_vector< T, A >::cend(), boost::numeric::ublas::mapped_vector< T, A >::end(), boost::numeric::ublas::mapped_vector< T, A >::erase_element(), boost::numeric::ublas::mapped_vector< T, A >::find_element(), boost::numeric::ublas::mapped_vector< T, A >::const_iterator::index(), boost::numeric::ublas::mapped_vector< T, A >::iterator::index(), boost::numeric::ublas::mapped_vector< T, A >::operator()(), boost::numeric::ublas::mapped_vector< T, A >::rbegin(), and boost::numeric::ublas::mapped_vector< T, A >::resize().
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Referenced by boost::numeric::ublas::mapped_vector< T, A >::operator-=().
|
inline |
|
inline |
|
inlineinherited |
|
inlineinherited |
|
inline |
|
inline |
References BOOST_UBLAS_CHECK, and boost::numeric::ublas::mapped_vector< T, A >::ref().
|
inline |
References boost::xpressive::at.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
References boost::xpressive::at.
|
inline |
|
inline |
|
inline |
|
inline |
References boost::multiprecision::backends::i.
|
inline |
References boost::multiprecision::backends::i.
|
inline |
Referenced by boost::numeric::ublas::mapped_vector< T, A >::operator+=().
|
inline |
References boost::numeric::ublas::mapped_vector< T, A >::end().
Referenced by boost::numeric::ublas::mapped_vector< T, A >::crbegin().
|
inline |
|
inline |
|
inline |
References boost::numeric::ublas::mapped_vector< T, A >::begin().
Referenced by boost::numeric::ublas::mapped_vector< T, A >::crend().
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Referenced by boost::numeric::ublas::mapped_vector< T, A >::nnz(), boost::numeric::ublas::mapped_vector< T, A >::const_iterator::operator*(), boost::numeric::ublas::mapped_vector< T, A >::iterator::operator*(), boost::numeric::ublas::mapped_vector< T, A >::operator=(), and boost::numeric::ublas::mapped_vector< T, A >::resize().
|
inline |
References boost::numeric::ublas::mapped_vector< T, A >::data(), and boost::swap.
Referenced by boost::numeric::ublas::mapped_vector< T, A >::assign_temporary().
|
friend |
|
staticinherited |