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