This file is indexed.

/usr/include/osl/move_probability/featureSet.h is in libosl-dev 0.6.0-3.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/* featureSet.h
 */
#ifndef OSL_MOVE_PROBABILITY_FEATURESET_H
#define OSL_MOVE_PROBABILITY_FEATURESET_H

#include "osl/move_probability/stateInfo.h"
#include "osl/state/numEffectState.h"
#include "osl/container/moveLogProbVector.h"
#include "osl/stl/vector.h"
#include <boost/ptr_container/ptr_vector.hpp>
#include <boost/scoped_array.hpp>

namespace osl
{
  namespace move_probability
  {
    class Feature;
    typedef std::pair<double,Move> WeightedMove;
    typedef FixedCapacityVector<WeightedMove,Move::MaxUniqMoves> WeightedMoveVector;

    class FeatureSet
    {
      boost::ptr_vector<Feature> features;
      osl::vector<int> offsets, light_features;
    protected:
      FeatureSet();
    public:
      ~FeatureSet();
      void pushBack(Feature *, bool light=false);
      void addFinished();
      int dimension() const { return offsets.back(); }
    public:
      double matchExp(const StateInfo&, Move, const double *weights) const;
      double matchNoExp(const StateInfo&, Move, const double *weights) const;    
      void generateLogProb(const StateInfo& state,
			   MoveLogProbVector& out, const double *weights) const;
      double matchLight(const StateInfo&, Move, const double *weights) const;

      bool load(const char *base_filename, double *weights) const;
      bool load_binary(const char *base_filename, double *weights) const;
      void showSummary(const double *weights) const;
      void analyze(const StateInfo& state, Move move, const double *weights) const;
      // for fine control
      double generateRating(const StateInfo& state,
			    WeightedMoveVector& out, const double *weights) const;
      static void ratingToLogProb(const WeightedMoveVector& rating,
				  double sum, MoveLogProbVector& out);
    };

    class StandardFeatureSet : public FeatureSet
    {
      static boost::scoped_array<double> weights, tactical_weights;
      bool initialized;
    public:
      StandardFeatureSet();
      ~StandardFeatureSet();
      
      static const StandardFeatureSet& instance(bool verbose=false);
      static bool healthCheck();
      void generateLogProb(const StateInfo& state, MoveLogProbVector& out) const;
      void generateLogProb2(const StateInfo& state, MoveLogProbVector& out) const;
      void generateLogProb(const StateInfo& state, int limit, MoveLogProbVector& out, bool in_pv) const;
      int logProbTakeBack(const StateInfo& state, Move target) const;
      int logProbSeePlus(const StateInfo& state, Move target) const;      
      double matchLight(const StateInfo&, Move) const;    
      double matchExp(const StateInfo&, Move) const;
      double matchNoExp(const StateInfo&, Move) const;
      bool setUp(bool verbose=false);
      bool ok() const { return initialized; }
    private:
      int tacticalLogProb(int offset, double sum) const;
    };
  }
}
#endif /* OSL_MOVE_PROBABILITY_FEATURESET_H */
// ;;; Local Variables:
// ;;; mode:c++
// ;;; c-basic-offset:2
// ;;; End: