// Copyright (C) 2008-2015 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 Op //! @{ //! Class for storing data required for delayed unary operations, //! such as the operand (e.g. the matrix to which the operation is to be applied) and the unary operator (e.g. inverse). //! The operand is stored as a reference (which can be optimised away), //! while the operator is "stored" through the template definition (op_type). //! The operands can be 'Mat', 'Row', 'Col', 'Op', and 'Glue'. //! Note that as 'Glue' can be one of the operands, more than one matrix can be stored. //! //! For example, we could have: //! Op< Glue< Mat, Mat, glue_times >, op_htrans > template class Op : public Base > { public: typedef typename T1::elem_type elem_type; typedef typename get_pod_type::result pod_type; inline explicit Op(const T1& in_m); inline Op(const T1& in_m, const elem_type in_aux); inline Op(const T1& in_m, const elem_type in_aux, const uword in_aux_uword_a, const uword in_aux_uword_b); inline Op(const T1& in_m, const uword in_aux_uword_a, const uword in_aux_uword_b); inline Op(const T1& in_m, const uword in_aux_uword_a, const uword in_aux_uword_b, const uword in_aux_uword_c, const char junk); inline ~Op(); arma_aligned const T1& m; //!< storage of reference to the operand (eg. a matrix) arma_aligned elem_type aux; //!< storage of auxiliary data, user defined format arma_aligned uword aux_uword_a; //!< storage of auxiliary data, uword format arma_aligned uword aux_uword_b; //!< storage of auxiliary data, uword format arma_aligned uword aux_uword_c; //!< storage of auxiliary data, uword format static const bool is_row = \ ( // operations which result in a row vector if the input is a row vector T1::is_row && ( is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes ) ) || ( // operations which result in a row vector if the input is a column vector T1::is_col && ( is_same_type::yes || is_same_type::yes || is_same_type::yes ) ) ; static const bool is_col = \ ( // operations which always result in a column vector is_same_type::yes || is_same_type::yes || is_same_type::yes ) || ( // operations which result in a column vector if the input is a column vector T1::is_col && ( is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes || is_same_type::yes ) ) || ( // operations which result in a column vector if the input is a row vector T1::is_row && ( is_same_type::yes || is_same_type::yes || is_same_type::yes ) ) ; }; //! @}