Chris@49
|
1 // Copyright (C) 2010-2012 NICTA (www.nicta.com.au)
|
Chris@49
|
2 // Copyright (C) 2010-2012 Conrad Sanderson
|
Chris@49
|
3 //
|
Chris@49
|
4 // This Source Code Form is subject to the terms of the Mozilla Public
|
Chris@49
|
5 // License, v. 2.0. If a copy of the MPL was not distributed with this
|
Chris@49
|
6 // file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
Chris@49
|
7
|
Chris@49
|
8
|
Chris@49
|
9 //! \addtogroup op_cumsum
|
Chris@49
|
10 //! @{
|
Chris@49
|
11
|
Chris@49
|
12
|
Chris@49
|
13 template<typename T1>
|
Chris@49
|
14 inline
|
Chris@49
|
15 void
|
Chris@49
|
16 op_cumsum_mat::apply(Mat<typename T1::elem_type>& out, const Op<T1,op_cumsum_mat>& in)
|
Chris@49
|
17 {
|
Chris@49
|
18 arma_extra_debug_sigprint();
|
Chris@49
|
19
|
Chris@49
|
20 typedef typename T1::elem_type eT;
|
Chris@49
|
21
|
Chris@49
|
22 const unwrap_check<T1> tmp(in.m, out);
|
Chris@49
|
23 const Mat<eT>& X = tmp.M;
|
Chris@49
|
24
|
Chris@49
|
25 const uword dim = in.aux_uword_a;
|
Chris@49
|
26 arma_debug_check( (dim > 1), "cumsum(): incorrect usage. dim must be 0 or 1");
|
Chris@49
|
27
|
Chris@49
|
28 out.copy_size(X);
|
Chris@49
|
29
|
Chris@49
|
30 const uword X_n_rows = X.n_rows;
|
Chris@49
|
31 const uword X_n_cols = X.n_cols;
|
Chris@49
|
32
|
Chris@49
|
33 if(dim == 0)
|
Chris@49
|
34 {
|
Chris@49
|
35 arma_extra_debug_print("op_cumsum::apply(), dim = 0");
|
Chris@49
|
36
|
Chris@49
|
37 for(uword col=0; col<X_n_cols; ++col)
|
Chris@49
|
38 {
|
Chris@49
|
39 eT* out_colmem = out.colptr(col);
|
Chris@49
|
40 const eT* X_colmem = X.colptr(col);
|
Chris@49
|
41
|
Chris@49
|
42 eT acc = eT(0);
|
Chris@49
|
43
|
Chris@49
|
44 for(uword row=0; row<X_n_rows; ++row)
|
Chris@49
|
45 {
|
Chris@49
|
46 acc += X_colmem[row];
|
Chris@49
|
47
|
Chris@49
|
48 out_colmem[row] = acc;
|
Chris@49
|
49 }
|
Chris@49
|
50 }
|
Chris@49
|
51 }
|
Chris@49
|
52 else
|
Chris@49
|
53 if(dim == 1)
|
Chris@49
|
54 {
|
Chris@49
|
55 arma_extra_debug_print("op_cumsum::apply(), dim = 1");
|
Chris@49
|
56
|
Chris@49
|
57 for(uword row=0; row<X_n_rows; ++row)
|
Chris@49
|
58 {
|
Chris@49
|
59 eT acc = eT(0);
|
Chris@49
|
60
|
Chris@49
|
61 for(uword col=0; col<X_n_cols; ++col)
|
Chris@49
|
62 {
|
Chris@49
|
63 acc += X.at(row,col);
|
Chris@49
|
64
|
Chris@49
|
65 out.at(row,col) = acc;
|
Chris@49
|
66 }
|
Chris@49
|
67 }
|
Chris@49
|
68 }
|
Chris@49
|
69 }
|
Chris@49
|
70
|
Chris@49
|
71
|
Chris@49
|
72
|
Chris@49
|
73 template<typename T1>
|
Chris@49
|
74 inline
|
Chris@49
|
75 void
|
Chris@49
|
76 op_cumsum_vec::apply(Mat<typename T1::elem_type>& out, const Op<T1,op_cumsum_vec>& in)
|
Chris@49
|
77 {
|
Chris@49
|
78 arma_extra_debug_sigprint();
|
Chris@49
|
79
|
Chris@49
|
80 typedef typename T1::elem_type eT;
|
Chris@49
|
81
|
Chris@49
|
82 const unwrap_check<T1> tmp(in.m, out);
|
Chris@49
|
83 const Mat<eT>& X = tmp.M;
|
Chris@49
|
84
|
Chris@49
|
85 const uword n_elem = X.n_elem;
|
Chris@49
|
86
|
Chris@49
|
87 out.copy_size(X);
|
Chris@49
|
88
|
Chris@49
|
89 eT* out_mem = out.memptr();
|
Chris@49
|
90 const eT* X_mem = X.memptr();
|
Chris@49
|
91
|
Chris@49
|
92 eT acc = eT(0);
|
Chris@49
|
93
|
Chris@49
|
94 for(uword i=0; i<n_elem; ++i)
|
Chris@49
|
95 {
|
Chris@49
|
96 acc += X_mem[i];
|
Chris@49
|
97
|
Chris@49
|
98 out_mem[i] = acc;
|
Chris@49
|
99 }
|
Chris@49
|
100 }
|
Chris@49
|
101
|
Chris@49
|
102
|
Chris@49
|
103
|
Chris@49
|
104 //! @}
|
Chris@49
|
105
|