This file is indexed.

/usr/include/libwildmagic/Wm5ContMinSphere3.h is in libwildmagic-dev 5.13-1ubuntu1.

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
// Geometric Tools, LLC
// Copyright (c) 1998-2014
// Distributed under the Boost Software License, Version 1.0.
// http://www.boost.org/LICENSE_1_0.txt
// http://www.geometrictools.com/License/Boost/LICENSE_1_0.txt
//
// File Version: 5.0.1 (2010/10/01)

#ifndef WM5CONTMINSPHERE3_H
#define WM5CONTMINSPHERE3_H

// Compute the minimum volume sphere containing the input set of points.  The
// algorithm randomly permutes the input points so that the construction
// occurs in 'expected' O(N) time.

#include "Wm5MathematicsLIB.h"
#include "Wm5Sphere3.h"

namespace Wm5
{

template <typename Real>
class WM5_MATHEMATICS_ITEM MinSphere3
{
public:
    // The epsilon value is a floating-point tolerance used for various
    // computations.
    MinSphere3 (int numPoints, const Vector3<Real>* points,
        Sphere3<Real>& minimal, Real epsilon = (Real)1e-03);

private:
    // Indices of points that support current minimum volume sphere.
    class Support
    {
    public:
        bool Contains (int index, Vector3<Real>** points, Real epsilon);

        int Quantity;
        int Index[4];
    };

    // Test whether point P is inside sphere S.
    bool Contains (const Vector3<Real>& point, const Sphere3<Real>& sphere,
        Real& distDiff);

    Sphere3<Real> ExactSphere1 (const Vector3<Real>& P);
    Sphere3<Real> ExactSphere2 (const Vector3<Real>& P0,
        const Vector3<Real>& P1);
    Sphere3<Real> ExactSphere3 (const Vector3<Real>& P0,
        const Vector3<Real>& P1, const Vector3<Real>& P2);
    Sphere3<Real> ExactSphere4 (const Vector3<Real>& P0,
        const Vector3<Real>& P1, const Vector3<Real>& P2,
        const Vector3<Real>& P3);

    Sphere3<Real> UpdateSupport1 (int i, Vector3<Real>** permuted,
        Support& support);
    Sphere3<Real> UpdateSupport2 (int i, Vector3<Real>** permuted,
        Support& support);
    Sphere3<Real> UpdateSupport3 (int i, Vector3<Real>** permuted,
        Support& support);
    Sphere3<Real> UpdateSupport4 (int i, Vector3<Real>** permuted,
        Support& support);

    typedef Sphere3<Real> (MinSphere3<Real>::*UpdateFunction)(
        int, Vector3<Real>**, Support&);

    Real mEpsilon;
    UpdateFunction mUpdate[5];
};

typedef MinSphere3<float> MinSphere3f;
typedef MinSphere3<double> MinSphere3d;

}

#endif