Mercurial > hg > segmenter-vamp-plugin
comparison armadillo-2.4.4/include/armadillo_bits/op_flip_meat.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) 2010 NICTA (www.nicta.com.au) | |
2 // Copyright (C) 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 op_flip | |
15 //! @{ | |
16 | |
17 | |
18 | |
19 template<typename T1> | |
20 inline | |
21 void | |
22 op_flipud::apply(Mat<typename T1::elem_type>& out, const Op<T1,op_flipud>& in) | |
23 { | |
24 arma_extra_debug_sigprint(); | |
25 | |
26 typedef typename T1::elem_type eT; | |
27 | |
28 const unwrap<T1> tmp(in.m); | |
29 const Mat<eT> X = tmp.M; | |
30 | |
31 if(&out != &X) | |
32 { | |
33 out.copy_size(X); | |
34 | |
35 for(uword i=0; i<X.n_rows; ++i) | |
36 { | |
37 out.row(i) = X.row(X.n_rows-1 - i); | |
38 } | |
39 } | |
40 else | |
41 { | |
42 const uword N = X.n_rows / 2; | |
43 | |
44 for(uword i=0; i<N; ++i) | |
45 { | |
46 out.swap_rows(i, X.n_rows-1 - i); | |
47 } | |
48 } | |
49 } | |
50 | |
51 | |
52 | |
53 template<typename T1> | |
54 inline | |
55 void | |
56 op_fliplr::apply(Mat<typename T1::elem_type>& out, const Op<T1,op_fliplr>& in) | |
57 { | |
58 arma_extra_debug_sigprint(); | |
59 | |
60 typedef typename T1::elem_type eT; | |
61 | |
62 const unwrap<T1> tmp(in.m); | |
63 const Mat<eT> X = tmp.M; | |
64 | |
65 if(&out != &X) | |
66 { | |
67 out.copy_size(X); | |
68 | |
69 for(uword i=0; i<X.n_cols; ++i) | |
70 { | |
71 out.col(i) = X.col(X.n_cols-1 - i); | |
72 } | |
73 } | |
74 else | |
75 { | |
76 const uword N = X.n_cols / 2; | |
77 | |
78 for(uword i=0; i<N; ++i) | |
79 { | |
80 out.swap_cols(i, X.n_cols-1 - i); | |
81 } | |
82 } | |
83 } | |
84 | |
85 | |
86 | |
87 //! @} |