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 mtOpCube
|
max@0
|
15 //! @{
|
max@0
|
16
|
max@0
|
17
|
max@0
|
18
|
max@0
|
19 template<typename out_eT, typename T1, typename op_type>
|
max@0
|
20 class mtOpCube : public BaseCube<out_eT, mtOpCube<out_eT, T1, op_type> >
|
max@0
|
21 {
|
max@0
|
22 public:
|
max@0
|
23
|
max@0
|
24 typedef out_eT elem_type;
|
max@0
|
25 typedef typename get_pod_type<out_eT>::result pod_type;
|
max@0
|
26
|
max@0
|
27 typedef typename T1::elem_type in_eT;
|
max@0
|
28
|
max@0
|
29 inline explicit mtOpCube(const T1& in_m);
|
max@0
|
30 inline mtOpCube(const T1& in_m, const in_eT in_aux);
|
max@0
|
31 inline mtOpCube(const T1& in_m, const uword in_aux_uword_a, const uword in_aux_uword_b, const uword in_aux_uword_c);
|
max@0
|
32 inline mtOpCube(const T1& in_m, const in_eT in_aux, const uword in_aux_uword_a, const uword in_aux_uword_b, const uword in_aux_uword_c);
|
max@0
|
33
|
max@0
|
34 inline mtOpCube(const char junk, const T1& in_m, const out_eT in_aux);
|
max@0
|
35
|
max@0
|
36 inline ~mtOpCube();
|
max@0
|
37
|
max@0
|
38
|
max@0
|
39 arma_aligned const T1& m; //!< storage of reference to the operand (eg. a matrix)
|
max@0
|
40 arma_aligned in_eT aux; //!< storage of auxiliary data, using the element type as used by T1
|
max@0
|
41 arma_aligned out_eT aux_out_eT; //!< storage of auxiliary data, using the element type as specified by the out_eT template parameter
|
max@0
|
42 arma_aligned uword aux_uword_a; //!< storage of auxiliary data, uword format
|
max@0
|
43 arma_aligned uword aux_uword_b; //!< storage of auxiliary data, uword format
|
max@0
|
44 arma_aligned uword aux_uword_c; //!< storage of auxiliary data, uword format
|
max@0
|
45
|
max@0
|
46 };
|
max@0
|
47
|
max@0
|
48
|
max@0
|
49
|
max@0
|
50 //! @}
|