This file is indexed.

/usr/share/octave/packages/nurbs-1.3.10/curvederivcpts.m is in octave-nurbs 1.3.10-1.

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
function pk = curvederivcpts (n, p, U, P, d, r1, r2) 
% Compute control points of n-th derivatives of a B-spline curve.
% 
% usage: pk = curvederivcpts (n, p, U, P, d) 
%        pk = curvederivcpts (n, p, U, P, d, r1, r2) 
%
% If r1, r2 are not given, all the control points are computed.
%
%  INPUT:
%         n+1 = number of control points
%         p   = degree of the spline
%         d   = maximum derivative order (d<=p)
%         U   = knots
%         P   = control points
%         r1  = first control point to compute
%         r2  = auxiliary index for the last control point to compute
%  OUTPUT:
%         pk(k,i) = i-th control point of (k-1)-th derivative, r1 <= i <= r2-k
%
% Adaptation of algorithm A3.3 from the NURBS book, pg98.
%
%    Copyright (C) 2009 Carlo de Falco
%
%    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/>.

  if (nargin <= 5)
    r1 = 0;
    r2 = n;
  end

  r = r2 - r1;
  for i=0:r
    pk(1, i+1) = P(r1+i+1);
  end
  
  for k=1:d
    tmp = p - k + 1;
    for i=0:r-k
      pk (k+1, i+1) = tmp * (pk(k,i+2)-pk(k,i+1)) / ...
	  (U(r1+i+p+2)-U(r1+i+k+1));
    end
  end
end

%!test
%! line = nrbmak([0.0 1.5; 0.0 3.0],[0.0 0.0 1.0 1.0]);
%! pk   = curvederivcpts (line.number-1, line.order-1, line.knots,...
%!                        line.coefs(1,:), 2);
%! assert (pk, [0 3/2; 3/2 0], 100*eps);