/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
|