AnalysisSystemForRadionucli.../include/armadillo_bits/Proxy.hpp
2024-06-04 15:25:02 +08:00

1911 lines
65 KiB
C++

// Copyright (C) 2010-2014 National ICT Australia (NICTA)
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
// -------------------------------------------------------------------
//
// Written by Conrad Sanderson - http://conradsanderson.id.au
//! \addtogroup Proxy
//! @{
// ea_type is the "element accessor" type,
// which can provide access to elements via operator[]
template<typename T1>
struct Proxy_default
{
inline Proxy_default(const T1&)
{
arma_type_check(( is_arma_type<T1>::value == false ));
}
};
template<typename T1>
struct Proxy_fixed
{
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef T1 stored_type;
typedef const elem_type* ea_type;
typedef const T1& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = T1::is_row;
static const bool is_col = T1::is_col;
arma_aligned const T1& Q;
inline explicit Proxy_fixed(const T1& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline static uword get_n_rows() { return T1::n_rows; }
arma_inline static uword get_n_cols() { return T1::n_cols; }
arma_inline static uword get_n_elem() { return T1::n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&Q) == void_ptr(&X)); }
arma_inline bool is_aligned() const
{
#if defined(ARMA_HAVE_ALIGNED_ATTRIBUTE)
return true;
#else
return memory::is_aligned(Q.memptr());
#endif
}
};
template<typename T1, bool condition>
struct Proxy_redirect {};
template<typename T1>
struct Proxy_redirect<T1, false> { typedef Proxy_default<T1> result; };
template<typename T1>
struct Proxy_redirect<T1, true> { typedef Proxy_fixed<T1> result; };
template<typename T1>
class Proxy : public Proxy_redirect<T1, is_Mat_fixed<T1>::value >::result
{
public:
inline Proxy(const T1& A)
: Proxy_redirect< T1, is_Mat_fixed<T1>::value >::result(A)
{
}
};
template<typename eT>
class Proxy< Mat<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<eT> stored_type;
typedef const eT* ea_type;
typedef const Mat<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = false;
arma_aligned const Mat<eT>& Q;
inline explicit Proxy(const Mat<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&Q) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename eT>
class Proxy< Col<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Col<eT> stored_type;
typedef const eT* ea_type;
typedef const Col<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const Col<eT>& Q;
inline explicit Proxy(const Col<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q[row]; }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&Q) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename eT>
class Proxy< Row<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Row<eT> stored_type;
typedef const eT* ea_type;
typedef const Row<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = true;
static const bool is_col = false;
arma_aligned const Row<eT>& Q;
inline explicit Proxy(const Row<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return 1; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword, const uword col) const { return Q[col]; }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&Q) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename T1, typename gen_type>
class Proxy< Gen<T1, gen_type > >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Gen<T1, gen_type> stored_type;
typedef const Gen<T1, gen_type>& ea_type;
typedef const Gen<T1, gen_type>& aligned_ea_type;
static const bool prefer_at_accessor = Gen<T1, gen_type>::prefer_at_accessor;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = Gen<T1, gen_type>::is_row;
static const bool is_col = Gen<T1, gen_type>::is_col;
arma_aligned const Gen<T1, gen_type>& Q;
inline explicit Proxy(const Gen<T1, gen_type>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return (is_row ? 1 : Q.n_rows); }
arma_inline uword get_n_cols() const { return (is_col ? 1 : Q.n_cols); }
arma_inline uword get_n_elem() const { return (is_row ? 1 : Q.n_rows) * (is_col ? 1 : Q.n_cols); }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return Gen<T1, gen_type>::is_simple; }
};
template<typename T1, typename op_type>
class Proxy< Op<T1, op_type> >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<elem_type> stored_type;
typedef const elem_type* ea_type;
typedef const Mat<elem_type>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = Op<T1, op_type>::is_row;
static const bool is_col = Op<T1, op_type>::is_col;
arma_aligned const Mat<elem_type> Q;
inline explicit Proxy(const Op<T1, op_type>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.n_rows; }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename T1>
class Proxy_diagvec_mat
{
inline Proxy_diagvec_mat(const T1&) {}
};
template<typename T1>
class Proxy_diagvec_mat< Op<T1, op_diagvec> >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef diagview<elem_type> stored_type;
typedef const diagview<elem_type>& ea_type;
typedef const diagview<elem_type>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const Mat<elem_type>& R;
arma_aligned const diagview<elem_type> Q;
inline explicit Proxy_diagvec_mat(const Op<T1, op_diagvec>& A)
: R(A.m), Q( R.diag( (A.aux_uword_b > 0) ? -sword(A.aux_uword_a) : sword(A.aux_uword_a) ) )
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q.at(row, 0); }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&R) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return false; }
};
template<typename T1>
class Proxy_diagvec_expr
{
inline Proxy_diagvec_expr(const T1&) {}
};
template<typename T1>
class Proxy_diagvec_expr< Op<T1, op_diagvec> >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<elem_type> stored_type;
typedef const elem_type* ea_type;
typedef const Mat<elem_type>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const Mat<elem_type> Q;
inline explicit Proxy_diagvec_expr(const Op<T1, op_diagvec>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q.at(row, 0); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename T1, bool condition>
struct Proxy_diagvec_redirect {};
template<typename T1>
struct Proxy_diagvec_redirect< Op<T1, op_diagvec>, true > { typedef Proxy_diagvec_mat < Op<T1, op_diagvec> > result; };
template<typename T1>
struct Proxy_diagvec_redirect< Op<T1, op_diagvec>, false> { typedef Proxy_diagvec_expr< Op<T1, op_diagvec> > result; };
template<typename T1>
class Proxy< Op<T1, op_diagvec> >
: public Proxy_diagvec_redirect< Op<T1, op_diagvec>, is_Mat<T1>::value >::result
{
public:
typedef typename Proxy_diagvec_redirect< Op<T1, op_diagvec>, is_Mat<T1>::value >::result Proxy_diagvec;
inline explicit Proxy(const Op<T1, op_diagvec>& A)
: Proxy_diagvec(A)
{
arma_extra_debug_sigprint();
}
};
template<typename T1>
struct Proxy_xtrans_default
{
inline Proxy_xtrans_default(const T1&) {}
};
template<typename T1>
struct Proxy_xtrans_default< Op<T1, op_htrans> >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef xtrans_mat<elem_type,true> stored_type;
typedef const xtrans_mat<elem_type,true>& ea_type;
typedef const xtrans_mat<elem_type,true>& aligned_ea_type;
static const bool prefer_at_accessor = true;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = false;
const unwrap<T1> U;
const xtrans_mat<elem_type,true> Q;
inline explicit Proxy_xtrans_default(const Op<T1, op_htrans>& A)
: U(A.m)
, Q(U.M)
{
arma_extra_debug_sigprint();
}
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return void_ptr(&(U.M)) == void_ptr(&X); }
arma_inline bool is_aligned() const { return false; }
};
template<typename T1>
struct Proxy_xtrans_default< Op<T1, op_strans> >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef xtrans_mat<elem_type,false> stored_type;
typedef const xtrans_mat<elem_type,false>& ea_type;
typedef const xtrans_mat<elem_type,false>& aligned_ea_type;
static const bool prefer_at_accessor = true;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = false;
const unwrap<T1> U;
const xtrans_mat<elem_type,false> Q;
inline explicit Proxy_xtrans_default(const Op<T1, op_strans>& A)
: U(A.m)
, Q(U.M)
{
arma_extra_debug_sigprint();
}
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return void_ptr(&(U.M)) == void_ptr(&X); }
arma_inline bool is_aligned() const { return false; }
};
template<typename T1>
struct Proxy_xtrans_vector
{
inline Proxy_xtrans_vector(const T1&) {}
};
template<typename T1>
struct Proxy_xtrans_vector< Op<T1, op_htrans> >
{
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<elem_type> stored_type;
typedef const elem_type* ea_type;
typedef const Mat<elem_type>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = quasi_unwrap<T1>::has_subview;
static const bool fake_mat = true;
// NOTE: the Op class takes care of swapping row and col for op_htrans
static const bool is_row = Op<T1, op_htrans>::is_row;
static const bool is_col = Op<T1, op_htrans>::is_col;
arma_aligned const quasi_unwrap<T1> U; // avoid copy if T1 is a Row, Col or subview_col
arma_aligned const Mat<elem_type> Q;
inline Proxy_xtrans_vector(const Op<T1, op_htrans>& A)
: U(A.m)
, Q(const_cast<elem_type*>(U.M.memptr()), U.M.n_cols, U.M.n_rows, false, false)
{
arma_extra_debug_sigprint();
}
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return U.is_alias(X); }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename T1>
struct Proxy_xtrans_vector< Op<T1, op_strans> >
{
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<elem_type> stored_type;
typedef const elem_type* ea_type;
typedef const Mat<elem_type>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = quasi_unwrap<T1>::has_subview;
static const bool fake_mat = true;
// NOTE: the Op class takes care of swapping row and col for op_htrans
static const bool is_row = Op<T1, op_htrans>::is_row;
static const bool is_col = Op<T1, op_htrans>::is_col;
arma_aligned const quasi_unwrap<T1> U; // avoid copy if T1 is a Row, Col or subview_col
arma_aligned const Mat<elem_type> Q;
inline Proxy_xtrans_vector(const Op<T1, op_strans>& A)
: U(A.m)
, Q(const_cast<elem_type*>(U.M.memptr()), U.M.n_cols, U.M.n_rows, false, false)
{
arma_extra_debug_sigprint();
}
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return U.is_alias(X); }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename T1, bool condition>
struct Proxy_xtrans_redirect {};
template<typename T1>
struct Proxy_xtrans_redirect<T1, false> { typedef Proxy_xtrans_default<T1> result; };
template<typename T1>
struct Proxy_xtrans_redirect<T1, true> { typedef Proxy_xtrans_vector<T1> result; };
template<typename T1>
class Proxy< Op<T1, op_htrans> >
: public
Proxy_xtrans_redirect
<
Op<T1, op_htrans>,
((is_complex<typename T1::elem_type>::value == false) && ((Op<T1, op_htrans>::is_row) || (Op<T1, op_htrans>::is_col)) )
>::result
{
public:
typedef
typename
Proxy_xtrans_redirect
<
Op<T1, op_htrans>,
((is_complex<typename T1::elem_type>::value == false) && ((Op<T1, op_htrans>::is_row) || (Op<T1, op_htrans>::is_col)) )
>::result
Proxy_xtrans;
typedef typename Proxy_xtrans::elem_type elem_type;
typedef typename Proxy_xtrans::pod_type pod_type;
typedef typename Proxy_xtrans::stored_type stored_type;
typedef typename Proxy_xtrans::ea_type ea_type;
typedef typename Proxy_xtrans::aligned_ea_type aligned_ea_type;
static const bool prefer_at_accessor = Proxy_xtrans::prefer_at_accessor;
static const bool has_subview = Proxy_xtrans::has_subview;
static const bool fake_mat = Proxy_xtrans::fake_mat;
static const bool is_row = Proxy_xtrans::is_row;
static const bool is_col = Proxy_xtrans::is_col;
using Proxy_xtrans::Q;
inline explicit Proxy(const Op<T1, op_htrans>& A)
: Proxy_xtrans(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.n_rows; }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Proxy_xtrans::get_ea(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Proxy_xtrans::get_aligned_ea(); }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return Proxy_xtrans::is_alias(X); }
arma_inline bool is_aligned() const { return Proxy_xtrans::is_aligned(); }
};
template<typename T1>
class Proxy< Op<T1, op_strans> >
: public
Proxy_xtrans_redirect
<
Op<T1, op_strans>,
( (Op<T1, op_strans>::is_row) || (Op<T1, op_strans>::is_col) )
>::result
{
public:
typedef
typename
Proxy_xtrans_redirect
<
Op<T1, op_strans>,
( (Op<T1, op_strans>::is_row) || (Op<T1, op_strans>::is_col) )
>::result
Proxy_xtrans;
typedef typename Proxy_xtrans::elem_type elem_type;
typedef typename Proxy_xtrans::pod_type pod_type;
typedef typename Proxy_xtrans::stored_type stored_type;
typedef typename Proxy_xtrans::ea_type ea_type;
typedef typename Proxy_xtrans::aligned_ea_type aligned_ea_type;
static const bool prefer_at_accessor = Proxy_xtrans::prefer_at_accessor;
static const bool has_subview = Proxy_xtrans::has_subview;
static const bool fake_mat = Proxy_xtrans::fake_mat;
static const bool is_row = Proxy_xtrans::is_row;
static const bool is_col = Proxy_xtrans::is_col;
using Proxy_xtrans::Q;
inline explicit Proxy(const Op<T1, op_strans>& A)
: Proxy_xtrans(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.n_rows; }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Proxy_xtrans::get_ea(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Proxy_xtrans::get_aligned_ea(); }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return Proxy_xtrans::is_alias(X); }
arma_inline bool is_aligned() const { return Proxy_xtrans::is_aligned(); }
};
template<typename eT>
struct Proxy_subview_row_htrans_cx
{
typedef eT elem_type;
typedef typename get_pod_type<eT>::result pod_type;
typedef subview_row_htrans<eT> stored_type;
typedef const subview_row_htrans<eT>& ea_type;
typedef const subview_row_htrans<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const subview_row_htrans<eT> Q;
inline explicit Proxy_subview_row_htrans_cx(const Op<subview_row<eT>, op_htrans>& A)
: Q(A.m)
{
arma_extra_debug_sigprint();
}
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.sv_row.m)) == void_ptr(&X)); }
};
template<typename eT>
struct Proxy_subview_row_htrans_non_cx
{
typedef eT elem_type;
typedef typename get_pod_type<eT>::result pod_type;
typedef subview_row_strans<eT> stored_type;
typedef const subview_row_strans<eT>& ea_type;
typedef const subview_row_strans<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const subview_row_strans<eT> Q;
inline explicit Proxy_subview_row_htrans_non_cx(const Op<subview_row<eT>, op_htrans>& A)
: Q(A.m)
{
arma_extra_debug_sigprint();
}
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.sv_row.m)) == void_ptr(&X)); }
};
template<typename eT, bool condition>
struct Proxy_subview_row_htrans_redirect {};
template<typename eT>
struct Proxy_subview_row_htrans_redirect<eT, true> { typedef Proxy_subview_row_htrans_cx<eT> result; };
template<typename eT>
struct Proxy_subview_row_htrans_redirect<eT, false> { typedef Proxy_subview_row_htrans_non_cx<eT> result; };
template<typename eT>
class Proxy< Op<subview_row<eT>, op_htrans> >
: public
Proxy_subview_row_htrans_redirect
<
eT,
is_complex<eT>::value
>::result
{
public:
typedef
typename
Proxy_subview_row_htrans_redirect
<
eT,
is_complex<eT>::value
>::result
Proxy_sv_row_ht;
typedef typename Proxy_sv_row_ht::elem_type elem_type;
typedef typename Proxy_sv_row_ht::pod_type pod_type;
typedef typename Proxy_sv_row_ht::stored_type stored_type;
typedef typename Proxy_sv_row_ht::ea_type ea_type;
typedef typename Proxy_sv_row_ht::ea_type aligned_ea_type;
static const bool prefer_at_accessor = Proxy_sv_row_ht::prefer_at_accessor;
static const bool has_subview = Proxy_sv_row_ht::has_subview;
static const bool fake_mat = Proxy_sv_row_ht::fake_mat;
static const bool is_row = false;
static const bool is_col = true;
using Proxy_sv_row_ht::Q;
inline explicit Proxy(const Op<subview_row<eT>, op_htrans>& A)
: Proxy_sv_row_ht(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q[row]; }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return Proxy_sv_row_ht::is_alias(X); }
arma_inline bool is_aligned() const { return false; }
};
template<typename eT>
class Proxy< Op<subview_row<eT>, op_strans> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<eT>::result pod_type;
typedef subview_row_strans<eT> stored_type;
typedef const subview_row_strans<eT>& ea_type;
typedef const subview_row_strans<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const subview_row_strans<eT> Q;
inline explicit Proxy(const Op<subview_row<eT>, op_strans>& A)
: Q(A.m)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q[row]; }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.sv_row.m)) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return false; }
};
template<typename T>
class Proxy< Op< Row< std::complex<T> >, op_htrans> >
{
public:
typedef typename std::complex<T> eT;
typedef typename std::complex<T> elem_type;
typedef T pod_type;
typedef xvec_htrans<eT> stored_type;
typedef const xvec_htrans<eT>& ea_type;
typedef const xvec_htrans<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
const xvec_htrans<eT> Q;
const Row<eT>& src;
inline explicit Proxy(const Op< Row< std::complex<T> >, op_htrans>& A)
: Q (A.m.memptr(), A.m.n_rows, A.m.n_cols)
, src(A.m)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q[row]; }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return void_ptr(&src) == void_ptr(&X); }
arma_inline bool is_aligned() const { return false; }
};
template<typename T>
class Proxy< Op< Col< std::complex<T> >, op_htrans> >
{
public:
typedef typename std::complex<T> eT;
typedef typename std::complex<T> elem_type;
typedef T pod_type;
typedef xvec_htrans<eT> stored_type;
typedef const xvec_htrans<eT>& ea_type;
typedef const xvec_htrans<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = true;
static const bool is_col = false;
const xvec_htrans<eT> Q;
const Col<eT>& src;
inline explicit Proxy(const Op< Col< std::complex<T> >, op_htrans>& A)
: Q (A.m.memptr(), A.m.n_rows, A.m.n_cols)
, src(A.m)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return 1; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword, const uword col) const { return Q[col]; }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return void_ptr(&src) == void_ptr(&X); }
arma_inline bool is_aligned() const { return false; }
};
template<typename T>
class Proxy< Op< subview_col< std::complex<T> >, op_htrans> >
{
public:
typedef typename std::complex<T> eT;
typedef typename std::complex<T> elem_type;
typedef T pod_type;
typedef xvec_htrans<eT> stored_type;
typedef const xvec_htrans<eT>& ea_type;
typedef const xvec_htrans<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = true;
static const bool is_col = false;
const xvec_htrans<eT> Q;
const subview_col<eT>& src;
inline explicit Proxy(const Op< subview_col< std::complex<T> >, op_htrans>& A)
: Q (A.m.colptr(0), A.m.n_rows, A.m.n_cols)
, src(A.m)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return 1; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword, const uword col) const { return Q[col]; }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return void_ptr(&src.m) == void_ptr(&X); }
arma_inline bool is_aligned() const { return false; }
};
template<typename T1>
class Proxy< Op<T1, op_htrans2> >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef eOp< Op<T1, op_htrans>, eop_scalar_times> stored_type;
typedef const eOp< Op<T1, op_htrans>, eop_scalar_times>& ea_type;
typedef const eOp< Op<T1, op_htrans>, eop_scalar_times>& aligned_ea_type;
static const bool prefer_at_accessor = eOp< Op<T1, op_htrans>, eop_scalar_times>::prefer_at_accessor;
static const bool has_subview = eOp< Op<T1, op_htrans>, eop_scalar_times>::has_subview;
static const bool fake_mat = eOp< Op<T1, op_htrans>, eop_scalar_times>::fake_mat;
// NOTE: the Op class takes care of swapping row and col for op_htrans
static const bool is_row = eOp< Op<T1, op_htrans>, eop_scalar_times>::is_row;
static const bool is_col = eOp< Op<T1, op_htrans>, eop_scalar_times>::is_col;
arma_aligned const Op<T1, op_htrans> R;
arma_aligned const eOp< Op<T1, op_htrans>, eop_scalar_times > Q;
inline explicit Proxy(const Op<T1, op_htrans2>& A)
: R(A.m)
, Q(R, A.aux)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.get_n_rows(); }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.get_n_cols(); }
arma_inline uword get_n_elem() const { return Q.get_n_elem(); }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return Q.P.is_alias(X); }
arma_inline bool is_aligned() const { return Q.P.is_aligned(); }
};
template<typename T1>
class Proxy< Op<T1, op_vectorise_col> >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<elem_type> stored_type;
typedef const elem_type* ea_type;
typedef const Mat<elem_type>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = true;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const unwrap<T1> U;
arma_aligned const Mat<elem_type> Q;
inline explicit Proxy(const Op<T1, op_vectorise_col>& A)
: U(A.m)
, Q(const_cast<elem_type*>(U.M.memptr()), U.M.n_elem, 1, false, false)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q[row]; }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return ( void_ptr(&X) == void_ptr(&(U.M)) ); }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename T1, typename T2, typename glue_type>
class Proxy< Glue<T1, T2, glue_type> >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<elem_type> stored_type;
typedef const elem_type* ea_type;
typedef const Mat<elem_type>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = Glue<T1, T2, glue_type>::is_row;
static const bool is_col = Glue<T1, T2, glue_type>::is_col;
arma_aligned const Mat<elem_type> Q;
inline explicit Proxy(const Glue<T1, T2, glue_type>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.n_rows; }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename eT>
class Proxy< subview<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef subview<eT> stored_type;
typedef const subview<eT>& ea_type;
typedef const subview<eT>& aligned_ea_type;
static const bool prefer_at_accessor = true;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = false;
arma_aligned const subview<eT>& Q;
inline explicit Proxy(const subview<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.m)) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return false; }
};
template<typename eT>
class Proxy< subview_col<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef subview_col<eT> stored_type;
typedef const eT* ea_type;
typedef const subview_col<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const subview_col<eT>& Q;
inline explicit Proxy(const subview_col<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q[row]; }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.colmem; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.m)) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.colmem); }
};
template<typename eT>
class Proxy< subview_row<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef subview_row<eT> stored_type;
typedef const subview_row<eT>& ea_type;
typedef const subview_row<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = true;
static const bool is_col = false;
arma_aligned const subview_row<eT>& Q;
inline explicit Proxy(const subview_row<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return 1; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword, const uword col) const { return Q[col]; }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.m)) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return false; }
};
template<typename eT>
class Proxy< subview_row_strans<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef subview_row_strans<eT> stored_type;
typedef const subview_row_strans<eT>& ea_type;
typedef const subview_row_strans<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const subview_row_strans<eT>& Q;
inline explicit Proxy(const subview_row_strans<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q[row]; }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.sv_row.m)) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return false; }
};
template<typename eT>
class Proxy< subview_row_htrans<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef subview_row_htrans<eT> stored_type;
typedef const subview_row_htrans<eT>& ea_type;
typedef const subview_row_htrans<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const subview_row_htrans<eT>& Q;
inline explicit Proxy(const subview_row_htrans<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q[row]; }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.sv_row.m)) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return false; }
};
template<typename eT, bool do_conj>
class Proxy< xtrans_mat<eT, do_conj> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<eT> stored_type;
typedef const eT* ea_type;
typedef const Mat<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = false;
arma_aligned const Mat<eT> Q;
inline explicit Proxy(const xtrans_mat<eT, do_conj>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row,col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename eT>
class Proxy< xvec_htrans<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<eT> stored_type;
typedef const eT* ea_type;
typedef const Mat<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = false;
arma_aligned const Mat<eT> Q;
inline explicit Proxy(const xvec_htrans<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row,col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename eT, typename T1>
class Proxy< subview_elem1<eT,T1> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef subview_elem1<eT,T1> stored_type;
typedef const Proxy< subview_elem1<eT,T1> >& ea_type;
typedef const Proxy< subview_elem1<eT,T1> >& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const subview_elem1<eT,T1>& Q;
arma_aligned const Proxy<T1> R;
inline explicit Proxy(const subview_elem1<eT,T1>& A)
: Q(A)
, R(A.a.get_ref())
{
arma_extra_debug_sigprint();
const bool R_is_vec = ((R.get_n_rows() == 1) || (R.get_n_cols() == 1));
const bool R_is_empty = (R.get_n_elem() == 0);
arma_debug_check( ((R_is_vec == false) && (R_is_empty == false)), "Mat::elem(): given object is not a vector" );
}
arma_inline uword get_n_rows() const { return R.get_n_elem(); }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return R.get_n_elem(); }
arma_inline elem_type operator[] (const uword i) const { const uword ii = (Proxy<T1>::prefer_at_accessor) ? R.at(i, 0) : R[i ]; arma_debug_check( (ii >= Q.m.n_elem), "Mat::elem(): index out of bounds" ); return Q.m[ii]; }
arma_inline elem_type at (const uword row, const uword) const { const uword ii = (Proxy<T1>::prefer_at_accessor) ? R.at(row,0) : R[row]; arma_debug_check( (ii >= Q.m.n_elem), "Mat::elem(): index out of bounds" ); return Q.m[ii]; }
arma_inline elem_type at_alt (const uword i) const { const uword ii = (Proxy<T1>::prefer_at_accessor) ? R.at(i, 0) : R[i ]; arma_debug_check( (ii >= Q.m.n_elem), "Mat::elem(): index out of bounds" ); return Q.m[ii]; }
arma_inline ea_type get_ea() const { return (*this); }
arma_inline aligned_ea_type get_aligned_ea() const { return (*this); }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return ( (void_ptr(&X) == void_ptr(&(Q.m))) || (R.is_alias(X)) ); }
arma_inline bool is_aligned() const { return false; }
};
template<typename eT, typename T1, typename T2>
class Proxy< subview_elem2<eT,T1,T2> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef Mat<eT> stored_type;
typedef const eT* ea_type;
typedef const Mat<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = false;
arma_aligned const Mat<eT> Q;
inline explicit Proxy(const subview_elem2<eT,T1,T2>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename eT>
class Proxy< diagview<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef diagview<eT> stored_type;
typedef const diagview<eT>& ea_type;
typedef const diagview<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = true;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const diagview<eT>& Q;
inline explicit Proxy(const diagview<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q.at(row, 0); }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (void_ptr(&(Q.m)) == void_ptr(&X)); }
arma_inline bool is_aligned() const { return false; }
};
template<typename eT>
class Proxy< spdiagview<eT> >
{
public:
typedef eT elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef spdiagview<eT> stored_type;
typedef const spdiagview<eT>& ea_type;
typedef const spdiagview<eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = false;
static const bool is_col = true;
arma_aligned const spdiagview<eT>& Q;
inline explicit Proxy(const spdiagview<eT>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return Q.n_rows; }
arma_inline uword get_n_cols() const { return 1; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword) const { return Q.at(row, 0); }
arma_inline elem_type at_alt (const uword i) const { return Q[i]; }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return false; }
};
template<typename T1, typename eop_type>
class Proxy< eOp<T1, eop_type > >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef eOp<T1, eop_type> stored_type;
typedef const eOp<T1, eop_type>& ea_type;
typedef const eOp<T1, eop_type>& aligned_ea_type;
static const bool prefer_at_accessor = eOp<T1, eop_type>::prefer_at_accessor;
static const bool has_subview = eOp<T1, eop_type>::has_subview;
static const bool fake_mat = eOp<T1, eop_type>::fake_mat;
static const bool is_row = eOp<T1, eop_type>::is_row;
static const bool is_col = eOp<T1, eop_type>::is_col;
arma_aligned const eOp<T1, eop_type>& Q;
inline explicit Proxy(const eOp<T1, eop_type>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.get_n_rows(); }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.get_n_cols(); }
arma_inline uword get_n_elem() const { return Q.get_n_elem(); }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return Q.P.is_alias(X); }
arma_inline bool is_aligned() const { return Q.P.is_aligned(); }
};
template<typename T1, typename T2, typename eglue_type>
class Proxy< eGlue<T1, T2, eglue_type > >
{
public:
typedef typename T1::elem_type elem_type;
typedef typename get_pod_type<elem_type>::result pod_type;
typedef eGlue<T1, T2, eglue_type> stored_type;
typedef const eGlue<T1, T2, eglue_type>& ea_type;
typedef const eGlue<T1, T2, eglue_type>& aligned_ea_type;
static const bool prefer_at_accessor = eGlue<T1, T2, eglue_type>::prefer_at_accessor;
static const bool has_subview = eGlue<T1, T2, eglue_type>::has_subview;
static const bool fake_mat = eGlue<T1, T2, eglue_type>::fake_mat;
static const bool is_row = eGlue<T1, T2, eglue_type>::is_row;
static const bool is_col = eGlue<T1, T2, eglue_type>::is_col;
arma_aligned const eGlue<T1, T2, eglue_type>& Q;
inline explicit Proxy(const eGlue<T1, T2, eglue_type>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.get_n_rows(); }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.get_n_cols(); }
arma_inline uword get_n_elem() const { return Q.get_n_elem(); }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row, col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q; }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>& X) const { return (Q.P1.is_alias(X) || Q.P2.is_alias(X)); }
arma_inline bool is_aligned() const { return (Q.P1.is_aligned() && Q.P2.is_aligned()); }
};
template<typename out_eT, typename T1, typename op_type>
class Proxy< mtOp<out_eT, T1, op_type> >
{
public:
typedef out_eT elem_type;
typedef typename get_pod_type<out_eT>::result pod_type;
typedef Mat<out_eT> stored_type;
typedef const elem_type* ea_type;
typedef const Mat<out_eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = mtOp<out_eT, T1, op_type>::is_row;
static const bool is_col = mtOp<out_eT, T1, op_type>::is_col;
arma_aligned const Mat<out_eT> Q;
inline explicit Proxy(const mtOp<out_eT, T1, op_type>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.n_rows; }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row,col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
template<typename out_eT, typename T1, typename T2, typename glue_type>
class Proxy< mtGlue<out_eT, T1, T2, glue_type > >
{
public:
typedef out_eT elem_type;
typedef typename get_pod_type<out_eT>::result pod_type;
typedef Mat<out_eT> stored_type;
typedef const elem_type* ea_type;
typedef const Mat<out_eT>& aligned_ea_type;
static const bool prefer_at_accessor = false;
static const bool has_subview = false;
static const bool fake_mat = false;
static const bool is_row = mtGlue<out_eT, T1, T2, glue_type>::is_row;
static const bool is_col = mtGlue<out_eT, T1, T2, glue_type>::is_col;
arma_aligned const Mat<out_eT> Q;
inline explicit Proxy(const mtGlue<out_eT, T1, T2, glue_type>& A)
: Q(A)
{
arma_extra_debug_sigprint();
}
arma_inline uword get_n_rows() const { return is_row ? 1 : Q.n_rows; }
arma_inline uword get_n_cols() const { return is_col ? 1 : Q.n_cols; }
arma_inline uword get_n_elem() const { return Q.n_elem; }
arma_inline elem_type operator[] (const uword i) const { return Q[i]; }
arma_inline elem_type at (const uword row, const uword col) const { return Q.at(row,col); }
arma_inline elem_type at_alt (const uword i) const { return Q.at_alt(i); }
arma_inline ea_type get_ea() const { return Q.memptr(); }
arma_inline aligned_ea_type get_aligned_ea() const { return Q; }
template<typename eT2>
arma_inline bool is_alias(const Mat<eT2>&) const { return false; }
arma_inline bool is_aligned() const { return memory::is_aligned(Q.memptr()); }
};
//! @}