op_strans_bones.hpp
Go to the documentation of this file.
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 
16 
17 
19 
20 class op_strans
21  {
22  public:
23 
24  template<const bool do_flip, const uword row, const uword col>
25  struct pos
26  {
27  static const uword n2 = (do_flip == false) ? (row + col*2) : (col + row*2);
28  static const uword n3 = (do_flip == false) ? (row + col*3) : (col + row*3);
29  static const uword n4 = (do_flip == false) ? (row + col*4) : (col + row*4);
30  };
31 
32  template<typename eT>
33  inline static void apply_noalias_tinysq(Mat<eT>& out, const Mat<eT>& A);
34 
35  template<typename eT>
36  inline static void apply_noalias(Mat<eT>& out, const Mat<eT>& A);
37 
38  template<typename eT>
39  inline static void apply(Mat<eT>& out, const Mat<eT>& A);
40 
41  template<typename T1>
42  inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_strans>& in);
43 
44 
45  // inline static void apply_inplace(mat &out);
46 
47  };
48 
49 
50 
static void apply(Mat< eT > &out, const Mat< eT > &A)
&#39;matrix transpose&#39; operation
static void apply_noalias_tinysq(Mat< eT > &out, const Mat< eT > &A)
for tiny square matrices (size <= 4x4)
u32 uword
Definition: typedef.hpp:85
static const uword n2
Dense matrix class.
static const uword n4
static const uword n3
static void apply_noalias(Mat< eT > &out, const Mat< eT > &A)
Immediate transpose of a dense matrix.


armadillo_matrix
Author(s):
autogenerated on Fri Apr 16 2021 02:31:58