Mercurial > hg > segmenter-vamp-plugin
comparison armadillo-2.4.4/include/armadillo_bits/Op_bones.hpp @ 0:8b6102e2a9b0
Armadillo Library
author | maxzanoni76 <max.zanoni@eecs.qmul.ac.uk> |
---|---|
date | Wed, 11 Apr 2012 09:27:06 +0100 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:8b6102e2a9b0 |
---|---|
1 // Copyright (C) 2008-2011 NICTA (www.nicta.com.au) | |
2 // Copyright (C) 2008-2011 Conrad Sanderson | |
3 // | |
4 // This file is part of the Armadillo C++ library. | |
5 // It is provided without any warranty of fitness | |
6 // for any purpose. You can redistribute this file | |
7 // and/or modify it under the terms of the GNU | |
8 // Lesser General Public License (LGPL) as published | |
9 // by the Free Software Foundation, either version 3 | |
10 // of the License or (at your option) any later version. | |
11 // (see http://www.opensource.org/licenses for more info) | |
12 | |
13 | |
14 //! \addtogroup Op | |
15 //! @{ | |
16 | |
17 | |
18 | |
19 //! Class for storing data required for delayed unary operations, | |
20 //! such as the operand (e.g. the matrix to which the operation is to be applied) and the unary operator (e.g. inverse). | |
21 //! The operand is stored as a reference (which can be optimised away), | |
22 //! while the operator is "stored" through the template definition (op_type). | |
23 //! The operands can be 'Mat', 'Row', 'Col', 'Op', and 'Glue'. | |
24 //! Note that as 'Glue' can be one of the operands, more than one matrix can be stored. | |
25 //! | |
26 //! For example, we could have: | |
27 //! Op< Glue< Mat, Mat, glue_times >, op_htrans > | |
28 | |
29 template<typename T1, typename op_type> | |
30 class Op : public Base<typename T1::elem_type, Op<T1, op_type> > | |
31 { | |
32 public: | |
33 | |
34 typedef typename T1::elem_type elem_type; | |
35 typedef typename get_pod_type<elem_type>::result pod_type; | |
36 | |
37 inline explicit Op(const T1& in_m); | |
38 inline Op(const T1& in_m, const elem_type in_aux); | |
39 inline Op(const T1& in_m, const elem_type in_aux, const uword in_aux_uword_a, const uword in_aux_uword_b); | |
40 inline Op(const T1& in_m, const uword in_aux_uword_a, const uword in_aux_uword_b); | |
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); | |
42 inline ~Op(); | |
43 | |
44 | |
45 arma_aligned const T1& m; //!< storage of reference to the operand (eg. a matrix) | |
46 arma_aligned elem_type aux; //!< storage of auxiliary data, user defined format | |
47 arma_aligned uword aux_uword_a; //!< storage of auxiliary data, uword format | |
48 arma_aligned uword aux_uword_b; //!< storage of auxiliary data, uword format | |
49 arma_aligned uword aux_uword_c; //!< storage of auxiliary data, uword format | |
50 | |
51 }; | |
52 | |
53 | |
54 | |
55 //! @} |