mirror of
https://gitlab.com/libeigen/eigen.git
synced 2025-09-13 09:53:13 +08:00
Factorize RowsProxy/ColsProxy and related iterators using subVector<>(Index)
This commit is contained in:
parent
12487531ce
commit
8c38528168
@ -578,10 +578,10 @@ template<typename Derived> class DenseBase
|
|||||||
inline DenseStlIterator<Derived> end();
|
inline DenseStlIterator<Derived> end();
|
||||||
inline DenseStlIterator<const Derived> end() const;
|
inline DenseStlIterator<const Derived> end() const;
|
||||||
inline DenseStlIterator<const Derived> cend() const;
|
inline DenseStlIterator<const Derived> cend() const;
|
||||||
inline ColsProxy<Derived> allCols();
|
inline SubVectorsProxy<Derived,Vertical> allCols();
|
||||||
inline ColsProxy<const Derived> allCols() const;
|
inline SubVectorsProxy<const Derived,Vertical> allCols() const;
|
||||||
inline RowsProxy<Derived> allRows();
|
inline SubVectorsProxy<Derived,Horizontal> allRows();
|
||||||
inline RowsProxy<const Derived> allRows() const;
|
inline SubVectorsProxy<const Derived,Horizontal> allRows() const;
|
||||||
|
|
||||||
#define EIGEN_CURRENT_STORAGE_BASE_CLASS Eigen::DenseBase
|
#define EIGEN_CURRENT_STORAGE_BASE_CLASS Eigen::DenseBase
|
||||||
#define EIGEN_DOC_BLOCK_ADDONS_NOT_INNER_PANEL
|
#define EIGEN_DOC_BLOCK_ADDONS_NOT_INNER_PANEL
|
||||||
|
@ -10,16 +10,16 @@
|
|||||||
namespace Eigen {
|
namespace Eigen {
|
||||||
|
|
||||||
template<typename XprType,typename Derived>
|
template<typename XprType,typename Derived>
|
||||||
class DenseStlIteratorBase
|
class IndexedBasedStlIteratorBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
typedef Index difference_type;
|
typedef Index difference_type;
|
||||||
typedef std::random_access_iterator_tag iterator_category;
|
typedef std::random_access_iterator_tag iterator_category;
|
||||||
|
|
||||||
DenseStlIteratorBase() : mp_xpr(0), m_index(0) {}
|
IndexedBasedStlIteratorBase() : mp_xpr(0), m_index(0) {}
|
||||||
DenseStlIteratorBase(XprType& xpr, Index index) : mp_xpr(&xpr), m_index(index) {}
|
IndexedBasedStlIteratorBase(XprType& xpr, Index index) : mp_xpr(&xpr), m_index(index) {}
|
||||||
|
|
||||||
void swap(DenseStlIteratorBase& other) {
|
void swap(IndexedBasedStlIteratorBase& other) {
|
||||||
std::swap(mp_xpr,other.mp_xpr);
|
std::swap(mp_xpr,other.mp_xpr);
|
||||||
std::swap(m_index,other.m_index);
|
std::swap(m_index,other.m_index);
|
||||||
}
|
}
|
||||||
@ -30,22 +30,22 @@ public:
|
|||||||
Derived operator++(int) { Derived prev(derived()); operator++(); return prev;}
|
Derived operator++(int) { Derived prev(derived()); operator++(); return prev;}
|
||||||
Derived operator--(int) { Derived prev(derived()); operator--(); return prev;}
|
Derived operator--(int) { Derived prev(derived()); operator--(); return prev;}
|
||||||
|
|
||||||
friend Derived operator+(const DenseStlIteratorBase& a, Index b) { Derived ret(a.derived()); ret += b; return ret; }
|
friend Derived operator+(const IndexedBasedStlIteratorBase& a, Index b) { Derived ret(a.derived()); ret += b; return ret; }
|
||||||
friend Derived operator-(const DenseStlIteratorBase& a, Index b) { Derived ret(a.derived()); ret -= b; return ret; }
|
friend Derived operator-(const IndexedBasedStlIteratorBase& a, Index b) { Derived ret(a.derived()); ret -= b; return ret; }
|
||||||
friend Derived operator+(Index a, const DenseStlIteratorBase& b) { Derived ret(b.derived()); ret += a; return ret; }
|
friend Derived operator+(Index a, const IndexedBasedStlIteratorBase& b) { Derived ret(b.derived()); ret += a; return ret; }
|
||||||
friend Derived operator-(Index a, const DenseStlIteratorBase& b) { Derived ret(b.derived()); ret -= a; return ret; }
|
friend Derived operator-(Index a, const IndexedBasedStlIteratorBase& b) { Derived ret(b.derived()); ret -= a; return ret; }
|
||||||
|
|
||||||
Derived& operator+=(Index b) { m_index += b; return derived(); }
|
Derived& operator+=(Index b) { m_index += b; return derived(); }
|
||||||
Derived& operator-=(Index b) { m_index -= b; return derived(); }
|
Derived& operator-=(Index b) { m_index -= b; return derived(); }
|
||||||
|
|
||||||
difference_type operator-(const DenseStlIteratorBase& other) const { eigen_assert(mp_xpr == other.mp_xpr);return m_index - other.m_index; }
|
difference_type operator-(const IndexedBasedStlIteratorBase& other) const { eigen_assert(mp_xpr == other.mp_xpr);return m_index - other.m_index; }
|
||||||
|
|
||||||
bool operator==(const DenseStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index == other.m_index; }
|
bool operator==(const IndexedBasedStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index == other.m_index; }
|
||||||
bool operator!=(const DenseStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index != other.m_index; }
|
bool operator!=(const IndexedBasedStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index != other.m_index; }
|
||||||
bool operator< (const DenseStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index < other.m_index; }
|
bool operator< (const IndexedBasedStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index < other.m_index; }
|
||||||
bool operator<=(const DenseStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index <= other.m_index; }
|
bool operator<=(const IndexedBasedStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index <= other.m_index; }
|
||||||
bool operator> (const DenseStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index > other.m_index; }
|
bool operator> (const IndexedBasedStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index > other.m_index; }
|
||||||
bool operator>=(const DenseStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index >= other.m_index; }
|
bool operator>=(const IndexedBasedStlIteratorBase& other) { eigen_assert(mp_xpr == other.mp_xpr); return m_index >= other.m_index; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
@ -57,7 +57,7 @@ protected:
|
|||||||
};
|
};
|
||||||
|
|
||||||
template<typename XprType>
|
template<typename XprType>
|
||||||
class DenseStlIterator : public DenseStlIteratorBase<XprType, DenseStlIterator<XprType> >
|
class DenseStlIterator : public IndexedBasedStlIteratorBase<XprType, DenseStlIterator<XprType> >
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
typedef typename XprType::Scalar value_type;
|
typedef typename XprType::Scalar value_type;
|
||||||
@ -69,7 +69,7 @@ protected:
|
|||||||
has_write_access = internal::is_lvalue<XprType>::value
|
has_write_access = internal::is_lvalue<XprType>::value
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef DenseStlIteratorBase<XprType,DenseStlIterator> Base;
|
typedef IndexedBasedStlIteratorBase<XprType,DenseStlIterator> Base;
|
||||||
using Base::m_index;
|
using Base::m_index;
|
||||||
using Base::mp_xpr;
|
using Base::mp_xpr;
|
||||||
|
|
||||||
@ -80,7 +80,6 @@ public:
|
|||||||
typedef typename internal::conditional<bool(has_write_access), value_type *, const value_type *>::type pointer;
|
typedef typename internal::conditional<bool(has_write_access), value_type *, const value_type *>::type pointer;
|
||||||
typedef typename internal::conditional<bool(has_write_access), value_type&, read_only_ref_t>::type reference;
|
typedef typename internal::conditional<bool(has_write_access), value_type&, read_only_ref_t>::type reference;
|
||||||
|
|
||||||
|
|
||||||
DenseStlIterator() : Base() {}
|
DenseStlIterator() : Base() {}
|
||||||
DenseStlIterator(XprType& xpr, Index index) : Base(xpr,index) {}
|
DenseStlIterator(XprType& xpr, Index index) : Base(xpr,index) {}
|
||||||
|
|
||||||
@ -90,7 +89,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
template<typename XprType,typename Derived>
|
template<typename XprType,typename Derived>
|
||||||
void swap(DenseStlIteratorBase<XprType,Derived>& a, DenseStlIteratorBase<XprType,Derived>& b) {
|
void swap(IndexedBasedStlIteratorBase<XprType,Derived>& a, IndexedBasedStlIteratorBase<XprType,Derived>& b) {
|
||||||
a.swap(b);
|
a.swap(b);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -134,99 +133,66 @@ inline DenseStlIterator<const Derived> DenseBase<Derived>::cend() const
|
|||||||
return DenseStlIterator<const Derived>(derived(), size());
|
return DenseStlIterator<const Derived>(derived(), size());
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename XprType>
|
template<typename XprType, DirectionType Direction>
|
||||||
class DenseColStlIterator : public DenseStlIteratorBase<XprType, DenseColStlIterator<XprType> >
|
class SubVectorStlIterator : public IndexedBasedStlIteratorBase<XprType, SubVectorStlIterator<XprType,Direction> >
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
enum { is_lvalue = internal::is_lvalue<XprType>::value };
|
enum { is_lvalue = internal::is_lvalue<XprType>::value };
|
||||||
|
|
||||||
typedef DenseStlIteratorBase<XprType,DenseColStlIterator> Base;
|
typedef IndexedBasedStlIteratorBase<XprType,SubVectorStlIterator> Base;
|
||||||
using Base::m_index;
|
using Base::m_index;
|
||||||
using Base::mp_xpr;
|
using Base::mp_xpr;
|
||||||
|
|
||||||
|
typedef typename internal::conditional<Direction==Vertical,typename XprType::ColXpr,typename XprType::RowXpr>::type SubVectorType;
|
||||||
|
typedef typename internal::conditional<Direction==Vertical,typename XprType::ConstColXpr,typename XprType::ConstRowXpr>::type ConstSubVectorType;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef typename internal::conditional<bool(is_lvalue), typename XprType::ColXpr, typename XprType::ConstColXpr>::type value_type;
|
typedef typename internal::conditional<bool(is_lvalue), SubVectorType, ConstSubVectorType>::type value_type;
|
||||||
typedef value_type* pointer;
|
typedef value_type* pointer;
|
||||||
typedef value_type reference;
|
typedef value_type reference;
|
||||||
|
|
||||||
DenseColStlIterator() : Base() {}
|
SubVectorStlIterator() : Base() {}
|
||||||
DenseColStlIterator(XprType& xpr, Index index) : Base(xpr,index) {}
|
SubVectorStlIterator(XprType& xpr, Index index) : Base(xpr,index) {}
|
||||||
|
|
||||||
reference operator*() const { return (*mp_xpr).col(m_index); }
|
reference operator*() const { return (*mp_xpr).template subVector<Direction>(m_index); }
|
||||||
reference operator[](Index i) const { return (*mp_xpr).col(m_index+i); }
|
reference operator[](Index i) const { return (*mp_xpr).template subVector<Direction>(m_index+i); }
|
||||||
pointer operator->() const { return &((*mp_xpr).col(m_index)); }
|
pointer operator->() const { return &((*mp_xpr).template subVector<Direction>(m_index)); }
|
||||||
};
|
};
|
||||||
|
|
||||||
template<typename XprType>
|
template<typename XprType, DirectionType Direction>
|
||||||
class DenseRowStlIterator : public DenseStlIteratorBase<XprType, DenseRowStlIterator<XprType> >
|
class SubVectorsProxy
|
||||||
{
|
|
||||||
protected:
|
|
||||||
|
|
||||||
enum { is_lvalue = internal::is_lvalue<XprType>::value };
|
|
||||||
|
|
||||||
typedef DenseStlIteratorBase<XprType,DenseRowStlIterator> Base;
|
|
||||||
using Base::m_index;
|
|
||||||
using Base::mp_xpr;
|
|
||||||
|
|
||||||
public:
|
|
||||||
typedef typename internal::conditional<bool(is_lvalue), typename XprType::RowXpr, typename XprType::ConstRowXpr>::type value_type;
|
|
||||||
typedef value_type* pointer;
|
|
||||||
typedef value_type reference;
|
|
||||||
|
|
||||||
DenseRowStlIterator() : Base() {}
|
|
||||||
DenseRowStlIterator(XprType& xpr, Index index) : Base(xpr,index) {}
|
|
||||||
|
|
||||||
reference operator*() const { return (*mp_xpr).row(m_index); }
|
|
||||||
reference operator[](Index i) const { return (*mp_xpr).row(m_index+i); }
|
|
||||||
pointer operator->() const { return &((*mp_xpr).row(m_index)); }
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
template<typename Xpr>
|
|
||||||
class ColsProxy
|
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ColsProxy(Xpr& xpr) : m_xpr(xpr) {}
|
typedef SubVectorStlIterator<XprType, Direction> iterator;
|
||||||
DenseColStlIterator<Xpr> begin() const { return DenseColStlIterator<Xpr>(m_xpr, 0); }
|
typedef SubVectorStlIterator<const XprType, Direction> const_iterator;
|
||||||
DenseColStlIterator<const Xpr> cbegin() const { return DenseColStlIterator<const Xpr>(m_xpr, 0); }
|
|
||||||
|
|
||||||
DenseColStlIterator<Xpr> end() const { return DenseColStlIterator<Xpr>(m_xpr, m_xpr.cols()); }
|
SubVectorsProxy(XprType& xpr) : m_xpr(xpr) {}
|
||||||
DenseColStlIterator<const Xpr> cend() const { return DenseColStlIterator<const Xpr>(m_xpr, m_xpr.cols()); }
|
|
||||||
|
iterator begin() const { return iterator (m_xpr, 0); }
|
||||||
|
const_iterator cbegin() const { return const_iterator(m_xpr, 0); }
|
||||||
|
|
||||||
|
iterator end() const { return iterator (m_xpr, m_xpr.template subVectors<Direction>()); }
|
||||||
|
const_iterator cend() const { return const_iterator(m_xpr, m_xpr.template subVectors<Direction>()); }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Xpr& m_xpr;
|
XprType& m_xpr;
|
||||||
};
|
|
||||||
|
|
||||||
template<typename Xpr>
|
|
||||||
class RowsProxy
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
RowsProxy(Xpr& xpr) : m_xpr(xpr) {}
|
|
||||||
DenseRowStlIterator<Xpr> begin() const { return DenseRowStlIterator<Xpr>(m_xpr, 0); }
|
|
||||||
DenseRowStlIterator<const Xpr> cbegin() const { return DenseRowStlIterator<const Xpr>(m_xpr, 0); }
|
|
||||||
|
|
||||||
DenseRowStlIterator<Xpr> end() const { return DenseRowStlIterator<Xpr>(m_xpr, m_xpr.rows()); }
|
|
||||||
DenseRowStlIterator<const Xpr> cend() const { return DenseRowStlIterator<const Xpr>(m_xpr, m_xpr.rows()); }
|
|
||||||
|
|
||||||
protected:
|
|
||||||
Xpr& m_xpr;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
template<typename Derived>
|
template<typename Derived>
|
||||||
ColsProxy<Derived> DenseBase<Derived>::allCols()
|
SubVectorsProxy<Derived,Vertical> DenseBase<Derived>::allCols()
|
||||||
{ return ColsProxy<Derived>(derived()); }
|
{ return SubVectorsProxy<Derived,Vertical>(derived()); }
|
||||||
|
|
||||||
template<typename Derived>
|
template<typename Derived>
|
||||||
ColsProxy<const Derived> DenseBase<Derived>::allCols() const
|
SubVectorsProxy<const Derived,Vertical> DenseBase<Derived>::allCols() const
|
||||||
{ return ColsProxy<const Derived>(derived()); }
|
{ return SubVectorsProxy<const Derived,Vertical>(derived()); }
|
||||||
|
|
||||||
template<typename Derived>
|
template<typename Derived>
|
||||||
RowsProxy<Derived> DenseBase<Derived>::allRows()
|
SubVectorsProxy<Derived,Horizontal> DenseBase<Derived>::allRows()
|
||||||
{ return RowsProxy<Derived>(derived()); }
|
{ return SubVectorsProxy<Derived,Horizontal>(derived()); }
|
||||||
|
|
||||||
template<typename Derived>
|
template<typename Derived>
|
||||||
RowsProxy<const Derived> DenseBase<Derived>::allRows() const
|
SubVectorsProxy<const Derived,Horizontal> DenseBase<Derived>::allRows() const
|
||||||
{ return RowsProxy<const Derived>(derived()); }
|
{ return SubVectorsProxy<const Derived,Horizontal>(derived()); }
|
||||||
|
|
||||||
} // namespace Eigen
|
} // namespace Eigen
|
||||||
|
@ -134,8 +134,7 @@ template<typename ExpressionType> class MatrixWrapper;
|
|||||||
template<typename Derived> class SolverBase;
|
template<typename Derived> class SolverBase;
|
||||||
template<typename XprType> class InnerIterator;
|
template<typename XprType> class InnerIterator;
|
||||||
template<typename XprType> class DenseStlIterator;
|
template<typename XprType> class DenseStlIterator;
|
||||||
template<typename XprType> class ColsProxy;
|
template<typename XprType, DirectionType Direction> class SubVectorsProxy;
|
||||||
template<typename XprType> class RowsProxy;
|
|
||||||
|
|
||||||
namespace internal {
|
namespace internal {
|
||||||
template<typename DecompositionType> struct kernel_retval_base;
|
template<typename DecompositionType> struct kernel_retval_base;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user