This file is indexed.

/usr/include/BALL/QSAR/registry.h is in libball1.4-dev 1.4.3~beta1-4.

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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
#ifndef BALL_QSAR_REGISTRY_H
#define BALL_QSAR_REGISTRY_H

#ifndef MODEL_FACTORY_H
#include <BALL/QSAR/modelFactory.h>
#endif

#include <map>

#ifdef BALL_HAS_LIBSVM
# include <BALL/QSAR/libsvmModel.h>
#endif

namespace BALL
{
	namespace QSAR
	{
		class QSARData;

		typedef Model* (*CreateMethod) (const QSARData& q);
		typedef Model* (*CreateKernel1) (const QSARData& q, int k, double p1, double p2);
		typedef Model* (*CreateKernel2) (const QSARData& q, String s1, String s2);
		
		class Registry;
		
		class BALL_EXPORT RegistryEntry
		{
			public:
			
				/** Constructor for a RegistryEntry for a linear model.
				@param ID *unique* identifier for the model
				@param n the name of the model 
				@param ab *unique* abbreviation of the model-name */
				RegistryEntry(bool k, bool r, String n, String ab, CreateMethod c0);
				
				/** Constructor for a RegistryEntry for a non-linear model.
				@param ID *unique* identifier for the model 
				@param n the name of the model 
				@param ab *unique* abbreviation of the model-name */
				RegistryEntry(bool k, bool r, String n, String ab, CreateKernel1 c1, CreateKernel2 c2);
				
				RegistryEntry(const RegistryEntry& entry);
				
				~RegistryEntry();
				
				const std::map<unsigned int,String>* getStatistics();
				String getStatName(int s);

				bool kernel;
				bool regression; // regression or classification?!
				bool latent_variables; // is this a latent variable model?!
				std::multiset<int> optimizableParameters;
				//bool optimizable;
				String name; // name of the Model
				String name_abreviation;
				CreateMethod create;
				CreateKernel1 createKernel1;
				CreateKernel2 createKernel2;
				vector<String> parameterNames;
				vector<double> parameterDefaults;
				Registry* getRegistry();
				
			private:
				Registry* registry_;
				
				friend class Registry;
		};
		
		
		typedef std::map<int,RegistryEntry>::iterator RegistryEntryIterator;
		
		class BALL_EXPORT Registry
		{
			public:
				Registry();

				~Registry();
				
				/** default value for first parameter of non-rbf kernels */
				double default_kernel_par1;
				
				/** default value for second parameter of non-rbf kernels */
				double default_kernel_par2;
				
				/** default value for parameter of rbf kernels */
				double default_rbf_par;
				
				/** default value for k-fold cross validation */
				int default_k;
				
				/** the default number of permutations to be done during response permutation testing */
				int default_no_permutations;
				
				/** the default number of boostrap samples */
				int default_no_boostrap_samples;
				
				/** the default value for the fraction of the input data that should be set aside in case of external/nested validation */ 
				double default_valdition_fraction;
				
				/** the default number of nested validation folds */
				int default_nested_folds;
				
				/** the default value for the absolute value of the correlation coefficient for removing of nearly colinear features */
				double default_correlation_cutoff;
				
				double default_gridsearch_stepwidth;
				int default_gridsearch_recursion;
				int default_gridsearch_steps;
				double default_gridsearch_par1_start;
				double default_gridsearch_par2_start;
				
				void addEntry(RegistryEntry entry, int uniqueID);
				
				/** returns the RegistryEntry for a given model name */
				RegistryEntry* getEntry(String model_name);
				
				/** returns the RegistryEntry for a given model ID */
				RegistryEntry* getEntry(int ID);
				
				/** return the ID of a specified model */
				int getModelNo(String model_name);
				
				String getClassificationStatisticName(unsigned int no);
				String getRegressionStatisticName(unsigned int no);
				String getFeatureSelectionName(unsigned int no);
				String getValidationName(unsigned int no);
				const std::map<unsigned int,String>* getClassificationStatistics();
				const std::map<unsigned int,String>* getRegressionStatistics();
				
				/** returns an iterator to the first model in model_map */
				RegistryEntryIterator beginEntry();
				
				/** returns an iterator past the last model of model_map */
				RegistryEntryIterator endEntry();
				
				
			private:
				std::map<int,RegistryEntry> registered_models;
				
				/** enable fast finding of a RegistryEntry for a given model name */
				std::map<String,int> model_map;
				
				std::map<unsigned int,String> classification_statistics;
				std::map<unsigned int,String> regression_statistics;
				std::map<unsigned int,String> feature_selection_names;
				std::map<unsigned int,String> validation_names;
				
				friend class RegistryEntry;
		};
		

	}
}

#endif // BALL_QSAR_REGISTRY_H