Chris@49: // Copyright (C) 2008-2013 NICTA (www.nicta.com.au) Chris@49: // Copyright (C) 2008-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 Row Chris@49: //! @{ Chris@49: Chris@49: //! Class for row vectors (matrices with only one row) Chris@49: Chris@49: template Chris@49: class Row : public 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: Chris@49: static const bool is_col = false; Chris@49: static const bool is_row = true; Chris@49: Chris@49: inline Row(); Chris@49: inline Row(const Row& X); Chris@49: inline explicit Row(const uword N); Chris@49: inline Row(const uword in_rows, const uword in_cols); Chris@49: Chris@49: inline Row(const char* text); Chris@49: inline const Row& operator=(const char* text); Chris@49: Chris@49: inline Row(const std::string& text); Chris@49: inline const Row& operator=(const std::string& text); Chris@49: Chris@49: inline Row(const std::vector& x); Chris@49: inline const Row& operator=(const std::vector& x); Chris@49: Chris@49: #if defined(ARMA_USE_CXX11) Chris@49: inline Row(const std::initializer_list& list); Chris@49: inline const Row& operator=(const std::initializer_list& list); Chris@49: #endif Chris@49: Chris@49: inline explicit Row(const SpRow& X); Chris@49: Chris@49: inline const Row& operator=(const eT val); Chris@49: Chris@49: template inline Row(const Base& X); Chris@49: template inline const Row& operator=(const Base& X); Chris@49: Chris@49: inline Row( eT* aux_mem, const uword aux_length, const bool copy_aux_mem = true, const bool strict = true); Chris@49: inline Row(const eT* aux_mem, const uword aux_length); Chris@49: Chris@49: template Chris@49: inline explicit Row(const Base& A, const Base& B); Chris@49: Chris@49: template inline Row(const BaseCube& X); Chris@49: template inline const Row& operator=(const BaseCube& X); Chris@49: Chris@49: inline Row(const subview_cube& X); Chris@49: inline const Row& operator=(const subview_cube& X); Chris@49: Chris@49: inline mat_injector operator<<(const eT val); Chris@49: Chris@49: arma_inline const Op,op_htrans> t() const; Chris@49: arma_inline const Op,op_htrans> ht() const; Chris@49: arma_inline const Op,op_strans> st() const; Chris@49: Chris@49: arma_inline eT& col(const uword col_num); Chris@49: arma_inline eT col(const uword col_num) const; Chris@49: Chris@49: arma_inline subview_row cols(const uword in_col1, const uword in_col2); Chris@49: arma_inline const subview_row cols(const uword in_col1, const uword in_col2) const; Chris@49: Chris@49: arma_inline subview_row subvec(const uword in_col1, const uword in_col2); Chris@49: arma_inline const subview_row subvec(const uword in_col1, const uword in_col2) const; Chris@49: Chris@49: arma_inline subview_row subvec(const span& col_span); Chris@49: arma_inline const subview_row subvec(const span& col_span) const; Chris@49: Chris@49: using Mat::operator(); Chris@49: Chris@49: arma_inline subview_row operator()(const span& col_span); Chris@49: arma_inline const subview_row operator()(const span& col_span) const; Chris@49: Chris@49: Chris@49: inline void shed_col (const uword col_num); Chris@49: inline void shed_cols(const uword in_col1, const uword in_col2); Chris@49: Chris@49: inline void insert_cols(const uword col_num, const uword N, const bool set_to_zero = true); Chris@49: template inline void insert_cols(const uword col_num, const Base& X); Chris@49: Chris@49: Chris@49: arma_inline arma_warn_unused eT& at(const uword i); Chris@49: arma_inline arma_warn_unused const eT& at(const uword i) const; Chris@49: Chris@49: arma_inline arma_warn_unused eT& at(const uword in_row, const uword in_col); Chris@49: arma_inline arma_warn_unused const eT& at(const uword in_row, const uword in_col) const; Chris@49: Chris@49: Chris@49: typedef eT* row_iterator; Chris@49: typedef const eT* const_row_iterator; Chris@49: Chris@49: inline row_iterator begin_row(const uword row_num); Chris@49: inline const_row_iterator begin_row(const uword row_num) const; Chris@49: Chris@49: inline row_iterator end_row (const uword row_num); Chris@49: inline const_row_iterator end_row (const uword row_num) const; Chris@49: Chris@49: Chris@49: template class fixed; Chris@49: Chris@49: Chris@49: protected: Chris@49: Chris@49: inline Row(const arma_fixed_indicator&, const uword in_n_elem, const eT* in_mem); Chris@49: Chris@49: Chris@49: public: Chris@49: Chris@49: #ifdef ARMA_EXTRA_ROW_PROTO Chris@49: #include ARMA_INCFILE_WRAP(ARMA_EXTRA_ROW_PROTO) Chris@49: #endif Chris@49: }; Chris@49: Chris@49: Chris@49: Chris@49: template Chris@49: template Chris@49: class Row::fixed : public Row Chris@49: { Chris@49: private: Chris@49: Chris@49: static const bool use_extra = (fixed_n_elem > arma_config::mat_prealloc); Chris@49: Chris@49: arma_align_mem eT mem_local_extra[ (use_extra) ? fixed_n_elem : 1 ]; Chris@49: Chris@49: Chris@49: public: Chris@49: Chris@49: typedef fixed Row_fixed_type; Chris@49: Chris@49: typedef eT elem_type; Chris@49: typedef typename get_pod_type::result pod_type; Chris@49: Chris@49: static const bool is_col = false; Chris@49: static const bool is_row = true; Chris@49: Chris@49: static const uword n_rows = 1; Chris@49: static const uword n_cols = fixed_n_elem; Chris@49: static const uword n_elem = fixed_n_elem; Chris@49: Chris@49: arma_inline fixed(); Chris@49: arma_inline fixed(const fixed& X); Chris@49: inline fixed(const subview_cube& X); Chris@49: Chris@49: template inline fixed(const Base& A); Chris@49: template inline fixed(const Base& A, const Base& B); Chris@49: Chris@49: inline fixed(const eT* aux_mem); Chris@49: Chris@49: inline fixed(const char* text); Chris@49: inline fixed(const std::string& text); Chris@49: Chris@49: template inline const Row& operator=(const Base& A); Chris@49: Chris@49: inline const Row& operator=(const eT val); Chris@49: inline const Row& operator=(const char* text); Chris@49: inline const Row& operator=(const std::string& text); Chris@49: inline const Row& operator=(const subview_cube& X); Chris@49: Chris@49: using Row::operator(); Chris@49: Chris@49: #if defined(ARMA_USE_CXX11) Chris@49: inline fixed(const std::initializer_list& list); Chris@49: inline const Row& operator=(const std::initializer_list& list); Chris@49: #endif Chris@49: Chris@49: arma_inline const Op< Row_fixed_type, op_htrans > t() const; Chris@49: arma_inline const Op< Row_fixed_type, op_htrans > ht() const; Chris@49: arma_inline const Op< Row_fixed_type, op_strans > st() const; Chris@49: Chris@49: arma_inline arma_warn_unused const eT& at_alt (const uword i) const; Chris@49: Chris@49: arma_inline arma_warn_unused eT& operator[] (const uword i); Chris@49: arma_inline arma_warn_unused const eT& operator[] (const uword i) const; Chris@49: arma_inline arma_warn_unused eT& at (const uword i); Chris@49: arma_inline arma_warn_unused const eT& at (const uword i) const; Chris@49: arma_inline arma_warn_unused eT& operator() (const uword i); Chris@49: arma_inline arma_warn_unused const eT& operator() (const uword i) const; Chris@49: Chris@49: arma_inline arma_warn_unused eT& at (const uword in_row, const uword in_col); Chris@49: arma_inline arma_warn_unused const eT& at (const uword in_row, const uword in_col) const; Chris@49: arma_inline arma_warn_unused eT& operator() (const uword in_row, const uword in_col); Chris@49: arma_inline arma_warn_unused const eT& operator() (const uword in_row, const uword in_col) const; Chris@49: Chris@49: arma_inline arma_warn_unused eT* memptr(); Chris@49: arma_inline arma_warn_unused const eT* memptr() const; Chris@49: Chris@49: arma_hot inline const Row& fill(const eT val); Chris@49: arma_hot inline const Row& zeros(); Chris@49: arma_hot inline const Row& ones(); Chris@49: }; Chris@49: Chris@49: Chris@49: Chris@49: //! @}