Mercurial > hg > segmenter-vamp-plugin
comparison armadillo-3.900.4/include/armadillo_bits/fn_spones.hpp @ 49:1ec0e2823891
Switch to using subrepo copies of qm-dsp, nnls-chroma, vamp-plugin-sdk; update Armadillo version; assume build without external BLAS/LAPACK
author | Chris Cannam |
---|---|
date | Thu, 13 Jun 2013 10:25:24 +0100 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
48:69251e11a913 | 49:1ec0e2823891 |
---|---|
1 // Copyright (C) 2012 Conrad Sanderson | |
2 // | |
3 // This Source Code Form is subject to the terms of the Mozilla Public | |
4 // License, v. 2.0. If a copy of the MPL was not distributed with this | |
5 // file, You can obtain one at http://mozilla.org/MPL/2.0/. | |
6 | |
7 | |
8 //! \addtogroup fn_spones | |
9 //! @{ | |
10 | |
11 | |
12 | |
13 //! Generate a sparse matrix with the non-zero values in the same locations as in the given sparse matrix X, | |
14 //! with the non-zero values set to one | |
15 template<typename T1> | |
16 inline | |
17 SpMat<typename T1::elem_type> | |
18 spones(const SpBase<typename T1::elem_type, T1>& X) | |
19 { | |
20 arma_extra_debug_sigprint(); | |
21 | |
22 typedef typename T1::elem_type eT; | |
23 | |
24 SpMat<eT> out( X.get_ref() ); | |
25 | |
26 const uword nnz = out.n_nonzero; | |
27 | |
28 eT* values = access::rwp(out.values); | |
29 | |
30 for(uword i=0; i < nnz; ++i) | |
31 { | |
32 values[i] = eT(1); | |
33 } | |
34 | |
35 return out; | |
36 } | |
37 | |
38 | |
39 | |
40 //! @} |