This file is indexed.

/usr/share/octave/packages/sparsersb-1.0.5/matlabbench.m is in octave-sparsersb 1.0.5-3.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
# 
#  Copyright (C) 2011-2015   Michele Martone   <michelemartone _AT_ users.sourceforge.net>
# 
#  This program is free software; you can redistribute it and/or modify
#  it under the terms of the GNU General Public License as published by
#  the Free Software Foundation; either version 3 of the License, or
#  (at your option) any later version.
# 
#  This program is distributed in the hope that it will be useful,
#  but WITHOUT ANY WARRANTY; without even the implied warranty of
#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#  GNU General Public License for more details.
# 
#  You should have received a copy of the GNU General Public License
#  along with this program; if not, see <http://www.gnu.org/licenses/>.
# 
# Undocumented
# function mbench(fname)
function matlabbench(fname)
addpath ext/
mp=matlabpath();
n=10;
for f=1:nargin
	MB=1024*1024;
	mmn=fname';
	mn=strtrim(mmn');
	tic();
	matlabpath('ext');
	mn;
	nm=mmreadm(mn);
	matlabpath(mp);
	%fsz=stat(mn).size;
	rnz=nnz(nm);
	rt=toc();
	[ia,ja,va]=find(nm);
	%printf('%s: %.2f MBytes read in  %.4f s (%10.2f MB/s)\n',mn',fsz/MB,rt,fsz/(rt*MB));
	%ia=ia'; ja=ja'; va=va';
for ski=1:1
	% FIXME: what about symmetry ?
	sparsekw='sparse';
	if(ski==2)sparsekw='sparsersb';end
	tic();
	for i=1:n;  om=sparse(ia,ja,va); end
	at=toc();
	mnz=nnz(om);
	amflops=n*2.0*mnz/(10^6 * at);
	%printf('%s (%s) %d spBLD for %d nnz in  %.4f secs, so %10.2f Mflops\n',mn',sparsekw,n,rnz,at,amflops);
	amflops
	%rm=sparsersb(ia,ja,va);% UNFINISHED
	v=linspace(1,1,size(om,1))';
	r=v;
	tic(); for i=1:n r=r+om*v; end ; umt=toc();
	UMflops=n*2.0*mnz/(10^6 * umt);
	UMflops
	%printf('%s (%s) %d spMV  for %d nnz in  %.4f secs, so %10.2f Mflops\n',mn',sparsekw,n,mnz,umt, UMflops);
	tic(); for i=1:n r=r+om.'*v; end ; tmt=toc();
	TMflops=n*2.0*mnz/(10^6 * tmt);
	TMflops
	%printf('%s (%s) %d spMV  for %d nnz in  %.4f secs, so %10.2f Mflops\n',mn',sparsekw,n,mnz,tmt, TMflops);
end 
end 
%printf('benchmark terminated successfully\n');
quit
end