-
Notifications
You must be signed in to change notification settings - Fork 23
/
parameters.h
138 lines (124 loc) · 8.44 KB
/
parameters.h
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
/*
* parameters.h
*
* This file is just used to declare the parameters that are shared across
* several files.
*
* Created on: 11 Nov 2011
* Author: dan
*/
#ifndef PARAMETERS_H_
#define PARAMETERS_H_
#include "numerics.h"
enum type_t {FLOAT = 'f', INT = 'd', BOOLEAN = 'b', STRING = 's'};
#define FLOAT_PARAM(name) add_param(FLOAT, #name, &name)
#define INT_PARAM(name) add_param(INT, #name, &name)
#define BOOLEAN_PARAM(name) add_param(BOOLEAN, #name, &name)
#define STRING_PARAM(name) add_param(STRING, #name, name)
#define STRLEN 10000
// This parameters table gives the command line parameters that are loaded into
// global variables. The Param type is the macro used to load the parameter from
// the command line, defined above. The Name is the variable name. The
// Definition is the standard C++ definition of the variable without the default
// value which is given by Default. This table is used in three places, below
// the parameters are defined with an extern so that multiple files can access
// the same global variables, e.g. extern integer ElecNo;. In parameters.cpp the
// variables are instantiated and given their default values, e.g.
// integer ElecNo = 1;. In parameters.cpp the parameters are read from the command
// line, e.g. INT_PARAM(ElecNo).
// F(Documentation,
// Param type, Name, Definition, Default)
#define PARAMETERS_TABLE(F) \
F("Filename base, files are of the form FileBase.fet.ElecNo, etc.", \
STRING_PARAM, FileBase, char FileBase[STRLEN], "electrode")\
F("Electrode number, files are of the form FileBase.fet.ElecNo, etc.", \
INT_PARAM, ElecNo, integer ElecNo, 1 )\
F("String of 0s and 1s indicating which features to use. "" indicates, `use all features' ", \
STRING_PARAM, UseFeatures, char UseFeatures[STRLEN], "")\
F("Drop the last N features in UseFeatures (works only when using "" for Usefeatures).",\
INT_PARAM, DropLastNFeatures, integer DropLastNFeatures, 0 )\
F("Use distributional EM steps", \
BOOLEAN_PARAM, UseDistributional, char UseDistributional, 1 )\
F("Run Mask starts with this many starting clusters", \
INT_PARAM, MaskStarts, integer MaskStarts, 500 )\
F("Minimum number of clusters to be used without splitting.", \
INT_PARAM, MinClusters, integer MinClusters, 100 )\
F("Maximum number of clusters to be used without splitting.", \
INT_PARAM, MaxClusters, integer MaxClusters, 110 )\
F("Maximum possible number of clusters to be used after splitting.", \
INT_PARAM, MaxPossibleClusters, integer MaxPossibleClusters, 1000 )\
F("Number of times to start count from each number of clusters.", \
INT_PARAM, nStarts, integer nStarts, 1 )\
F("An intermediate cluster file to use as a starting point.", \
STRING_PARAM, StartCluFile, char StartCluFile[STRLEN], "" )\
F("Allow cluster splitting after this many iterations after initial split.",\
INT_PARAM, SplitEvery, integer SplitEvery, 40 )\
F("Allow first cluster splitting after this many iterations.", \
INT_PARAM, SplitFirst, integer SplitFirst, 20 )\
F("Coefficient of num_params to use in penalty (1 for AIC).", \
FLOAT_PARAM, PenaltyK, scalar PenaltyK, 0.0 )\
F("Coefficient of num_params*log(num_points)/2 to use in penalty (1 for BIC).",\
FLOAT_PARAM, PenaltyKLogN, scalar PenaltyKLogN, 1.0 )\
F("Do clustering on 1/Subset points, and then generalise to whole set.", \
INT_PARAM, Subset, integer Subset, 1 )\
F("There is a full E step recomputation at least after this many iterations.",\
INT_PARAM, FullStepEvery, integer FullStepEvery, 20 )\
F("Maximum number of iterations.", \
INT_PARAM, MaxIter, integer MaxIter, 10000 )\
F("Specify random seed for reproducible results, or leave for random.", \
INT_PARAM, RandomSeed, integer RandomSeed, 1 )\
F("Whether or not to run in debug mode (prints lots of detail). 0 = None, 1 = Partial info, 2=Full Info",\
INT_PARAM, Debug, char Debug, 0 )\
F("Whether or not give spilt iteration info. 0 = Partial split info, 1 = Full split info",\
INT_PARAM, SplitInfo, char SplitInfo, 1 )\
F("Whether or not to print information as the program runs.", \
INT_PARAM, Verbose, integer Verbose, 1 )\
F("???", \
INT_PARAM, DistDump, integer DistDump, 0 )\
F("Points this far from best do not get an E step recomputation.", \
FLOAT_PARAM, DistThresh, scalar DistThresh, (scalar)log(1000.0))\
F("If this fraction of points changed class last time, do a full step.", \
FLOAT_PARAM, ChangedThresh, scalar ChangedThresh, .05 )\
F("Whether or not to save information to a log file.", \
BOOLEAN_PARAM, Log, char Log, 1 )\
F("Whether or not to save temp clu files on every iteration instead of before every split.",\
BOOLEAN_PARAM, SaveTempCluEveryIter, char SaveTempCluEveryIter, 0 )\
F("Log output to screen.", \
BOOLEAN_PARAM, Screen, char Screen, 1 )\
F("Number of 'PriorPoints'", \
INT_PARAM, PriorPoint, integer PriorPoint, 1 )\
F("Save FileBase.sorted.*.ElecNo data files (data in sorted order).", \
BOOLEAN_PARAM, SaveSorted, char SaveSorted, false )\
F("Save covariance and means", \
BOOLEAN_PARAM, SaveCovarianceMeans, char SaveCovarianceMeans, false )\
F("Use mask based initial conditions", \
BOOLEAN_PARAM, UseMaskedInitialConditions, char UseMaskedInitialConditions, false)\
F("Assign to first closest mask in mask based initial conditions", \
BOOLEAN_PARAM, AssignToFirstClosestMask, char AssignToFirstClosestMask, false)\
F("Set RAM usage limit (0 for available memory, -1 for no limit)", \
FLOAT_PARAM, RamLimitGB, scalar RamLimitGB, 0.0 )\
F("Always split bimodal clusters (can save time)", \
BOOLEAN_PARAM, AlwaysSplitBimodal,char AlwaysSplitBimodal, false )\
F("Minimum number of points required for cluster mask.", \
FLOAT_PARAM, PointsForClusterMask, scalar PointsForClusterMask, 10 )\
F("Minimum point to cluster mask overlap.", \
FLOAT_PARAM, MinMaskOverlap, scalar MinMaskOverlap, 0.0 )\
//TODO: Implement the two Debug modes, one less verbose than the other
#define STRINGIFY(x) #x
// These four lines define how to make the extern definitions, the full
// instantiation of the variables, the inputting of the
// parameters and the documentation (in parameters.cpp)
#define EXTERN_PARAMETERS(DOC, TYPE, NAME, DEF, VAL) extern DEF;
#define DEFINE_PARAMETERS(DOC, TYPE, NAME, DEF, VAL) DEF = VAL;
#define INPUT_PARAMETERS(DOC, TYPE, NAME, DEF, VAL) TYPE(NAME);
#define PRINT_PARAMETERS(DOC, TYPE, NAME, DEF, VAL) \
fprintf(stderr, "- " STRINGIFY(NAME) " = " STRINGIFY(VAL) "\n" \
" " DOC "\n\n");
PARAMETERS_TABLE(EXTERN_PARAMETERS)
//////////// FUNCTIONS TO READ PARAMETERS FROM COMMAND LINE ////////////////////
void add_param(integer t, char *name, void *addr);
integer change_param(char *name, char *value);
void init_params(integer argc, char **argv);
void print_params(FILE *fp);
void SetupParams(integer argc, char **argv);
#endif /* PARAMETERS_H_ */