This file is indexed.

/usr/share/octave/packages/nan-2.5.9/cat2bin.m is in octave-nan 2.5.9-2.

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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
function [B,BLab]=cat2bin(D, Label, MODE)
% CAT2BIN converts categorial into binary data 
%   each category of each column in D is converted into a logical column
% 
%   B = cat2bin(C); 
%   [B,BinLabel] = cat2bin(C,Label); 
%   [B,BinLabel] = cat2bin(C,Label,MODE)
%
%  C        categorial data 
%  B        binary data 
%  Label    description of each column in C
%  BinLabel description of each column in B
%  MODE     default [], ignores NaN
%           'notIgnoreNAN' includes binary column for NaN 
%           'IgnoreZeros'  zeros do not get a separate category 
%           'IgnoreZeros+NaN' zeros and NaN are ignored
%
%  example: 
%     cat2bin([1;2;5;1;5]) results in 
%             1     0     0
%             0     1     0
%             0     0     1
%             1     0     0
%             0     0     1

%	$Id: cat2bin.m 9033 2011-11-08 20:58:07Z schloegl $
%	Copyright (C) 2009 by Alois Schloegl <alois.schloegl@gmail.com>
%       This function is part of the NaN-toolbox
%       http://pub.ist.ac.at/~schloegl/matlab/NaN/

% 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, write to the Free Software
% Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.

if nargin<3,
         MODE = []; 
end; 

% convert data 
B = []; 

c     = 0; 
k1    = 0; 
BLab  = [];
for m = 1:size(D,2) 
        h = histo_mex(D(:,m));
        x = h.X(h.H>0);
        if strcmpi(MODE,'notIgnoreNaN')
                ;
        elseif strcmpi(MODE,'IgnoreZeros')
                x = x(x~=0);
        elseif strcmpi(MODE,'IgnoreZeros+NaN')
                x = x((x~=0) & (x==x));
        else 
                x = x(x==x);
        end; 
        for k = 1:size(D,1),
                if ~isnan(D(k,m))
                        B(k, c + find(D(k,m)==x)) = 1;
                elseif isnan(x(end)),
                        B(k, c + length(x)) = 1;
                end;
        end;

        c = c + length(x);
        if nargout>1,
                for k = 1:length(x),
                        k1 = k1+1;
                        if isempty(Label)
                                BLab{k1} = ['#',int2str(m),':',int2str(x(k))];
                        else
                                BLab{k1} = [Label{m},':',int2str(x(k))];
                        end;
                end;
        end;
end;


%!assert(cat2bin([1;2;5;1;5]),[1,0,0;0,1,0;0,0,1;1,0,0;0,0,1])