This file is indexed.

/usr/include/libwildmagic/Wm5MinimizeN.h is in libwildmagic-dev 5.13-1ubuntu3.

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
// 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.2 (2011/03/09)

#ifndef WM5MINIMIZEN_H
#define WM5MINIMIZEN_H

#include "Wm5MathematicsLIB.h"
#include "Wm5Minimize1.h"

namespace Wm5
{

template <typename Real>
class WM5_MATHEMATICS_ITEM MinimizeN
{
public:
    // The type of function to be minimized:  result = f(t,userData), where t
    // is a d-tuple (d is 'dimensions' in the constructor).  The userData is
    // the pointer provided by the constructor or SetUserData(*).  This allows
    // you to pass a class static function that wraps a call to a nonstatic
    // member function, in which case userData is a pointer to the class
    // object.  Naturally, the userData may be as complicated as you need
    // it to ensure that the 'function' has all the information needed to
    // compute it.
    typedef Real (*Function)(const Real*,void*);

    // Construction and destruction.  The Cartesian-product domain provided to
    // GetMinimum(*) has minimum values stored in t0[0..d-1] and maximum
    // values stored in t1[0..d-1], where d is 'dimensions'.  The domain is
    // searched along lines through the current estimate of the minimum
    // location.  Each such line is searched for a minimum using a
    // Minimize1<Real> object.  This is called "Powell's Direction Set
    // Method".  The parameters 'maxLevel' and 'maxBracket' are used by
    // Minimize1<Real>, so read the documentation for that class (in its
    // header file) to understand what these mean.  The input 'maxIterations'
    // is the number of iterations for the direction-set method.
    MinimizeN (int dimensions, Function function, int maxLevel,
        int maxBracket, int maxIterations, void* userData = 0);

    ~MinimizeN ();

    // Find the minimum on the Cartesian-product domain whose minimum values
    // are stored in t0[0..d-1] and whose maximum values are stored in
    // t1[0..d-1], where d is 'dimensions'.  An initial guess is specified in
    // tInitial[0..d-1].  The location of the minimum is tMin[0..d-1] and
    // the value of the minimum is 'fMin'.
    void GetMinimum (const Real* t0, const Real* t1, const Real* tInitial,
        Real* tMin, Real& fMin);

private:
    // The current estimate of the minimum location is mTCurr[0..d-1].  The
    // direction of the current line to search is mDCurr[0..d-1].  This line
    // must be clipped against the Cartesian-product domain, a process
    // implemented in this function.  If the line is mTCurr+s*mDCurr, the
    // clip result is the s-interval [ell0,ell1].
    void ComputeDomain (const Real* t0, const Real* t1, Real& ell0,
        Real& ell1);

    // The Minimize1<Real> object requires a C-style function to perform its
    // 1-dimensionsal search (along the line mTCurr+s*mDCurr).
    static Real LineFunction (Real t, void* userData);

    int mDimensions;
    Function mFunction;
    int mMaxIterations;
    void* mUserData;
    Minimize1<Real> mMinimizer;
    Real* mDirectionStorage;
    Real** mDirection;
    Real* mDConj;
    Real* mDCurr;
    Real* mTSave;
    Real* mTCurr;
    Real mFCurr;
    Real* mLineArg;
};

typedef MinimizeN<float> MinimizeNf;
typedef MinimizeN<double> MinimizeNd;

}

#endif