29 #define PLUS '+' //flag states
50 }
else if (*file ==
MINUS) {
56 fp = fopen(file + nameoffset,
"rb");
58 tprintf(
"read_params_file: Can't open %s\n", file + nameoffset);
74 while ((end_offset < 0 || ftell(fp) < end_offset) &&
76 if (line[0] !=
'\n' && line[0] !=
'#') {
78 for (valptr = line; *valptr && *valptr !=
' ' && *valptr !=
'\t';
84 while (*valptr ==
' ' || *valptr ==
'\t');
86 foundit =
SetParam(line, valptr, constraint, member_params);
90 tprintf(
"read_params_file: parameter not found: %s\n", line);
105 if (*value ==
'\0')
return (sp !=
NULL);
118 if (*value ==
'T' || *value ==
't' ||
119 *value ==
'Y' || *value ==
'y' || *value ==
'1') {
121 }
else if (*value ==
'F' || *value ==
'f' ||
122 *value ==
'N' || *value ==
'n' || *value ==
'0') {
135 if (sscanf(value,
"%lf", &doubleval) == 1)
139 return (sp || ip || bp || dp);
157 snprintf(buf,
sizeof(buf),
"%d",
inT32(*ip));
165 *value =
BOOL8(*bp) ?
"1":
"0";
173 snprintf(buf,
sizeof(buf),
"%g",
double(*dp));
182 int num_iterations = (member_params ==
NULL) ? 1 : 2;
183 for (v = 0; v < num_iterations; ++v) {
185 for (i = 0; i < vec->
int_params.size(); ++i) {
186 fprintf(fp,
"%s\t%d\t%s\n", vec->
int_params[i]->name_str(),
190 fprintf(fp,
"%s\t%d\t%s\n", vec->
bool_params[i]->name_str(),
194 fprintf(fp,
"%s\t%s\t%s\n", vec->
string_params[i]->name_str(),
198 fprintf(fp,
"%s\t%g\t%s\n", vec->
double_params[i]->name_str(),
207 int num_iterations = (member_params ==
NULL) ? 1 : 2;
208 for (v = 0; v < num_iterations; ++v) {
210 for (i = 0; i < vec->
int_params.size(); ++i) {
static void ResetToDefaults(ParamsVectors *member_params)
static bool ReadParamsFromFp(FILE *fp, inT64 end_offset, SetParamConstraint constraint, ParamsVectors *member_params)
bool constraint_ok(SetParamConstraint constraint) const
double strtofloat(const char *s)
static void PrintParams(FILE *fp, const ParamsVectors *member_params)
static bool GetParamAsString(const char *name, const ParamsVectors *member_params, STRING *value)
void set_value(BOOL8 value)
void set_value(double value)
void chomp_string(char *str)
GenericVector< IntParam * > int_params
static bool SetParam(const char *name, const char *value, SetParamConstraint constraint, ParamsVectors *member_params)
GenericVector< BoolParam * > bool_params
GenericVector< DoubleParam * > double_params
void set_value(inT32 value)
static bool ReadParamsFile(const char *file, SetParamConstraint constraint, ParamsVectors *member_params)
tesseract::ParamsVectors * GlobalParams()
GenericVector< StringParam * > string_params
const char * string() const
void set_value(const STRING &value)