This file is indexed.

/usr/include/BALL/QSAR/validation.h is in libball1.4-dev 1.4.3~beta1-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
 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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
// -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
//

#ifndef VALIDATION
#define VALIDATION

#ifndef QSARDATA
#include <BALL/QSAR/QSARData.h>
#endif

#include <iterator>


namespace BALL
{	
	namespace QSAR
	{
		class Model;
		
		/** interface class for validation of QSAR-models */
		class BALL_EXPORT Validation
		{
			public:
				/** @name Constructors and Destructors
				 */
				//@{	
				Validation(Model* m);

				virtual ~Validation();

				EIGEN_MAKE_ALIGNED_OPERATOR_NEW
				//@}
				
				
				/** @name Accessors
				 */
				//@{
				/** Starts cross-validation with k steps. \n
				Data is taken from QSARData.descriptor_matrix and is in each step divided into training- and test-data. \n
				(Data having already been copied into Model.descriptor_matrix will be deleted) */
				virtual void crossValidation(int k, bool restore=1) = 0;
				
				/** fetches the result of cross-validation */
				virtual double getCVRes() = 0;
				
				/** fetches the quality of fit to the input data, as calculated by testInputData() */
				virtual double getFitRes() = 0;
		
				/** set the result of cross-validation to the given value */
				virtual void setCVRes(double d) = 0;
				
				/** return the result of the previous response permutation test .\n
				The return matrix is empty if no such test has been run yet */	
				const Eigen::MatrixXd& getYRandResults() const;
				
				/** Fetches input data from QSARData and tests the current (unchanged) model with all these new substances (without cross-validation!). \n
				@param transform if transform==1, the test data is transformed in the same way that the training data was transformed before predicting activities. \n
				If training and test substances are taken from the same input file, set transform to 0 */
				virtual void testInputData(bool transform=0) = 0;
				
				virtual void bootstrap(int k,  bool restore=1) = 0;
				
				virtual const Eigen::MatrixXd& yRandomizationTest(int runs, int k) = 0;
				
				/** select the desired statistic to be used for validating the models
				@param s if (s==1) R^2 and Q^2 are used \n
				if(s==2) F_regr and F_cv are used. */
				virtual void selectStat(int s) = 0;
				
				/** return the ID of selected validation statistic */
				int getStat() const;
				
				/** save the result of the applied validation methods to a file */
				virtual void saveToFile(string filename) const = 0;
				
				/** restore validation-results from a file */
				virtual void readFromFile(string filename) = 0;
				//@}
				
				
			protected:
				
				/** @name Accessors
				 */
				//@{
				/** copies one substance (=one line from class QSARData) and its activity into the training data set */
				void setTrainingLine(int train_line, int current_line);
			
				/** copies one substance (=one line from class QSARData) and its activity into the test data set 
				@param back_transform descriptor values are transformed back to in order to un-do centering */
				void setTestLine(int test_line, int current_line, bool back_transform=0);
				
				/** randomizes all columns of Model.Y_ */
				void yRand();
				//@}
				
				
				/** @name Attributes
				 */
				//@{
				/** contains all substances whose activities are to be predicted by the next call of testAllSubstances() */ 
				vector<vector<double> > test_substances_;
				
				/** contains the experimentally determined results (activities) for all current test-substances in one column for each activity */
				Eigen::MatrixXd test_Y_;
				
				/** contains the names of all current test-substances */
				vector<string> substances_names_;
				
				
				/** pointer to the model, which the object of this class should test */
				Model* model_;
				
				/** the selected validation statistic */
				int validation_statistic_;
				
				Eigen::MatrixXd yRand_results_;
				//@}
			
		};
	}
}



#endif // VALIDATION