This file is indexed.

/usr/include/rdkit/DataManip/MetricMatrixCalc/MetricMatrixCalc.h is in librdkit-dev 201603.5-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
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
// $Id$
//
//  Copyright (C) 2003-2006 Rational Discovery LLC
//
//  @@ All Rights Reserved @@
//  This file is part of the RDKit.
//  The contents are covered by the terms of the BSD license
//  which is included in the file license.txt, found at the root
//  of the RDKit source tree.
//
#ifndef __RD_METRICMATRIXCAL_H__
#define __RD_METRICMATRIXCAL_H__

#include "MetricFuncs.h"
#include <RDGeneral/Invariant.h>

namespace RDDataManip {

/*! \brief A generic metric matrix calculator (e.g similarity matrix or
 *         distance matrix)
 *
 *  This templated class needs some explanation
 *    vectType is a container that can support [] operator
 *    entryType is the type of entry that is returned by the [] operator
 *  Examples of the container include PySequenceHolder which is wrapper around
 *  a python sequence objects like lists and tuples.
 *  Examples of the entryType include a sequence of double, floats, and
 *ExplicitBitVects
 *
 */
template <class vectType, class entryType>
class MetricMatrixCalc {
 public:
  /*! \brief Default Constructor
   *
   */
  MetricMatrixCalc(){};

  /*! \brief Set the metric function
   *
   * Set the pointer to the mertic funvtion to be used by the metric calculator
   *
   * ARGUMENTS:
   *
   *  mFunc - pointer to the metric funtion
   */
  void setMetricFunc(double (*mFunc)(const entryType &, const entryType &,
                                     unsigned int)) {
    dp_metricFunc = mFunc;
  }

  /*! \brief The calculator function
   *
   * ARGUMENTS:
   *
   *  descrips - vectType container with a entryType for each item
   *  nItems - the number of item in the descripts.
   *           In several cases this argument is irrelvant since vectType
   *probably supports
   *           a size() member function, But we would like this interface to
   *take for example
   *           a double** and correctly parse the row and columns.
   *  dim - the dimension of the sequences
   *  distMat - pointer to an array to write the distance matrix to
   *            it is assumed that the right sized array has already be
   *allocated.
   *
   * FIX: we can probably make this function create the correct sized distMat
   *and return
   * it to the caller, but when pushing he result out to a python array not sure
   *how to
   * avoid copy the entire distance matrix in that case
   *
   * RETURNS:
   *
   *  pointer to a 1D array of doubles. Only the lower triangle elements are
   *  included in the array
   */
  void calcMetricMatrix(const vectType &descripts, unsigned int nItems,
                        unsigned int dim, double *distMat) {
    CHECK_INVARIANT(distMat, "invalid pointer to a distance matix");

    for (unsigned int i = 1; i < nItems; i++) {
      unsigned int itab = i * (i - 1) / 2;
      for (unsigned int j = 0; j < i; j++) {
        distMat[itab + j] = dp_metricFunc(descripts[i], descripts[j], dim);
      }
    }
  };

 private:
  // pointer to the metric function
  /*! \brief pointer to the metric function
   *
   * In several cases the last argument 'dim' should be irrelevant,
   * For example when entryType is a bit vector the size is of the vector
   * or the dimension can be obtained by asking the bit vector itself. However
   * we woul like this interface to support other containers lines double*
   * in which case the 'dim' value is useful in cumputing the metric.
   */
  double (*dp_metricFunc)(const entryType &, const entryType &, unsigned int);
};
};

#endif