Mercurial > hg > segmenter-vamp-plugin
comparison armadillo-2.4.4/include/armadillo_bits/Glue_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-2010 NICTA (www.nicta.com.au) | |
2 // Copyright (C) 2008-2010 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 Glue | |
15 //! @{ | |
16 | |
17 | |
18 | |
19 //! Class for storing data required for delayed binary operations, | |
20 //! such as the operands (e.g. two matrices) and the binary operator (e.g. addition). | |
21 //! The operands are stored as references (which can be optimised away), | |
22 //! while the operator is "stored" through the template definition (glue_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 two matrices can be stored. | |
25 //! | |
26 //! For example, we could have: Glue<Mat, Mat, glue_times> | |
27 //! | |
28 //! Another example is: Glue< Op<Mat, op_htrans>, Op<Mat, op_inv>, glue_times > | |
29 | |
30 | |
31 | |
32 template<typename T1, typename T2, typename glue_type> | |
33 class Glue : public Base<typename T1::elem_type, Glue<T1, T2, glue_type> > | |
34 { | |
35 public: | |
36 | |
37 typedef typename T1::elem_type elem_type; | |
38 typedef typename get_pod_type<elem_type>::result pod_type; | |
39 | |
40 arma_inline Glue(const T1& in_A, const T2& in_B); | |
41 arma_inline Glue(const T1& in_A, const T2& in_B, const uword in_aux_uword); | |
42 arma_inline ~Glue(); | |
43 | |
44 const T1& A; //!< first operand | |
45 const T2& B; //!< second operand | |
46 uword aux_uword; //!< storage of auxiliary data, uword format | |
47 }; | |
48 | |
49 | |
50 | |
51 //! @} |