annotate armadillo-2.4.4/include/armadillo_bits/Op_bones.hpp @ 18:8d046a9d36aa slimline

Back out rev 13:ac07c60aa798. Like an idiot, I committed a whole pile of unrelated changes in the guise of a single typo fix. Will re-commit in stages
author Chris Cannam
date Thu, 10 May 2012 10:45:44 +0100
parents 8b6102e2a9b0
children
rev   line source
max@0 1 // Copyright (C) 2008-2011 NICTA (www.nicta.com.au)
max@0 2 // Copyright (C) 2008-2011 Conrad Sanderson
max@0 3 //
max@0 4 // This file is part of the Armadillo C++ library.
max@0 5 // It is provided without any warranty of fitness
max@0 6 // for any purpose. You can redistribute this file
max@0 7 // and/or modify it under the terms of the GNU
max@0 8 // Lesser General Public License (LGPL) as published
max@0 9 // by the Free Software Foundation, either version 3
max@0 10 // of the License or (at your option) any later version.
max@0 11 // (see http://www.opensource.org/licenses for more info)
max@0 12
max@0 13
max@0 14 //! \addtogroup Op
max@0 15 //! @{
max@0 16
max@0 17
max@0 18
max@0 19 //! Class for storing data required for delayed unary operations,
max@0 20 //! such as the operand (e.g. the matrix to which the operation is to be applied) and the unary operator (e.g. inverse).
max@0 21 //! The operand is stored as a reference (which can be optimised away),
max@0 22 //! while the operator is "stored" through the template definition (op_type).
max@0 23 //! The operands can be 'Mat', 'Row', 'Col', 'Op', and 'Glue'.
max@0 24 //! Note that as 'Glue' can be one of the operands, more than one matrix can be stored.
max@0 25 //!
max@0 26 //! For example, we could have:
max@0 27 //! Op< Glue< Mat, Mat, glue_times >, op_htrans >
max@0 28
max@0 29 template<typename T1, typename op_type>
max@0 30 class Op : public Base<typename T1::elem_type, Op<T1, op_type> >
max@0 31 {
max@0 32 public:
max@0 33
max@0 34 typedef typename T1::elem_type elem_type;
max@0 35 typedef typename get_pod_type<elem_type>::result pod_type;
max@0 36
max@0 37 inline explicit Op(const T1& in_m);
max@0 38 inline Op(const T1& in_m, const elem_type in_aux);
max@0 39 inline Op(const T1& in_m, const elem_type in_aux, const uword in_aux_uword_a, const uword in_aux_uword_b);
max@0 40 inline Op(const T1& in_m, const uword in_aux_uword_a, const uword in_aux_uword_b);
max@0 41 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);
max@0 42 inline ~Op();
max@0 43
max@0 44
max@0 45 arma_aligned const T1& m; //!< storage of reference to the operand (eg. a matrix)
max@0 46 arma_aligned elem_type aux; //!< storage of auxiliary data, user defined format
max@0 47 arma_aligned uword aux_uword_a; //!< storage of auxiliary data, uword format
max@0 48 arma_aligned uword aux_uword_b; //!< storage of auxiliary data, uword format
max@0 49 arma_aligned uword aux_uword_c; //!< storage of auxiliary data, uword format
max@0 50
max@0 51 };
max@0 52
max@0 53
max@0 54
max@0 55 //! @}