File: sparse2csr.m

package info (click to toggle)
rocsolver 6.4.3-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 17,876 kB
  • sloc: cpp: 151,850; python: 2,275; sh: 875; objc: 642; ansic: 402; makefile: 71; xml: 26
file content (74 lines) | stat: -rw-r--r-- 1,528 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
function [Ap, Ai, Ax] = sparse2csr(A, is_one_based_in)
%
% [Ap, Ai, Ax] = sparse2csr(A, [is_one_based])
%
% convert matlab sparse matrix to
% Compressed sparse row format
%
is_one_based = 0;
if (nargin >= 2),
  is_one_based = is_one_based_in;
end;
is_zero_based = ~is_one_based;


nrow = size(A,1);
ncol = size(A,2);

nnzA = nnz(A);

Ap = zeros( 1,nrow+1);
Ai = zeros( 1,nnzA);
Ax = zeros( 1,nnzA);

% -----------------
% coordinate format
% -----------------
[ii,jj,aa] = find(A);

% ---------------------------
% sort to group rows together
% ---------------------------
[dummy, iperm] = sort( jj  + (ii-1) * ncol);
clear dummy;

ii = ii(iperm);
jj = jj(iperm);
aa = aa(iperm);

% -------------------------
% compute non-zeros per row
% -------------------------
nz_per_row = sum( A ~= 0, 2);

% -------------------------
% setup Ap(:) pointer array
% -------------------------
Ap(1) = 1;
Ap(2:(nrow+1)) = 1+cumsum( nz_per_row(1:nrow) );


% ------------------------------------------
% fill Ai(:) column indices and Ax(:) values
% ------------------------------------------
istart=1;
for irow=1:nrow,
 if (nz_per_row(irow) >= 1),
  iend = istart + nz_per_row(irow)-1;
  is_same_row = all( ii(istart:iend) == irow );
  if (~is_same_row),
    error(sprintf('sparse2csr: irow=%g,istart=%g,iend=%g', ...
                               irow,   istart,   iend ));
  end;
  Ai(istart:iend) = jj(istart:iend);
  Ax(istart:iend) = aa(istart:iend);

  istart = iend + 1;
 end;
end;


if (is_zero_based),
  Ap = Ap-1;
  Ai = Ai-1;
end;