This file is indexed.

/usr/include/qgis/qgshistogram.h is in libqgis-dev 2.18.17+dfsg-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
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
/***************************************************************************
                          qgshistogram.h
                          --------------
    begin                : May 2015
    copyright            : (C) 2015 by Nyall Dawson
    email                : nyall dot dawson at gmail dot com
 ***************************************************************************/

/***************************************************************************
 *                                                                         *
 *   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 2 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 ***************************************************************************/

#ifndef QGSHISTOGRAM_H
#define QGSHISTOGRAM_H

#include <QList>

class QgsVectorLayer;


/** \ingroup core
 * \class QgsHistogram
 * \brief Calculator for a numeric histogram from a list of values.
 *
 * \note Added in version 2.9
 */

class CORE_EXPORT QgsHistogram
{
  public:

    QgsHistogram();

    virtual ~QgsHistogram();

    /** Assigns numeric source values for the histogram.
     * @param values list of doubles
     */
    void setValues( const QList<double>& values );

    /** Assigns numeric source values for the histogram from a vector layer's field or as the
     * result of an expression.
     * @param layer vector layer
     * @param fieldOrExpression field name or expression to be evaluated
     * @returns true if values were successfully set
     */
    bool setValues( QgsVectorLayer* layer, const QString& fieldOrExpression );

    /** Calculates the optimal bin width using the Freedman-Diaconis rule. Bins widths are
     * determined by the inter-quartile range of values and the number of values.
     * @returns optimal width for bins
     * @see optimalNumberBins
     * @note values must first be specified using @link setValues @endlink
     */
    double optimalBinWidth() const;

    /** Returns the optimal number of bins for the source values, calculated using the
     * Freedman-Diaconis rule. The number of bins are determined by the inter-quartile range
     * of values and the number of values.
     * @returns optimal number of bins
     * @see optimalBinWidth
     * @note values must first be specified using @link setValues @endlink
     */
    int optimalNumberBins() const;

    /** Returns a list of edges for the histogram for a specified number of bins. This list
     * will be length bins + 1, as both the first and last value are also included.
     * @param bins number of bins
     * @return list of bin edges
     * @note values must first be specified using @link setValues @endlink
     */
    QList<double> binEdges( int bins ) const;

    /** Returns the calculated list of the counts for the histogram bins.
     * @param bins number of histogram bins
     * @return list of histogram counts
     * @note values must first be specified using @link setValues @endlink
     */
    QList<int> counts( int bins ) const;

  private:

    QList<double> mValues;
    double mMax;
    double mMin;
    double mIQR;

    void prepareValues();

};

#endif // QGSHISTOGRAM_H