2007-03-08 04:03:40 +08:00
|
|
|
/******************************************************************************
|
|
|
|
** Filename: cutoffs.c
|
|
|
|
** Purpose: Routines to manipulate an array of class cutoffs.
|
|
|
|
** Author: Dan Johnson
|
|
|
|
** History: Wed Feb 20 09:28:51 1991, DSJ, Created.
|
|
|
|
**
|
|
|
|
** (c) Copyright Hewlett-Packard Company, 1988.
|
|
|
|
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
** you may not use this file except in compliance with the License.
|
|
|
|
** You may obtain a copy of the License at
|
|
|
|
** http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
** Unless required by applicable law or agreed to in writing, software
|
|
|
|
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
** See the License for the specific language governing permissions and
|
|
|
|
** limitations under the License.
|
|
|
|
******************************************************************************/
|
2014-09-13 04:41:19 +08:00
|
|
|
/*----------------------------------------------------------------------------
|
2007-03-08 04:03:40 +08:00
|
|
|
Include Files and Type Defines
|
2014-09-13 04:41:19 +08:00
|
|
|
----------------------------------------------------------------------------*/
|
2007-03-08 04:03:40 +08:00
|
|
|
#include "cutoffs.h"
|
2009-07-11 10:17:36 +08:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "classify.h"
|
2007-03-08 04:03:40 +08:00
|
|
|
#include "efio.h"
|
2009-07-11 10:17:36 +08:00
|
|
|
#include "globals.h"
|
|
|
|
#include "helpers.h"
|
2007-03-08 04:03:40 +08:00
|
|
|
#include "scanutils.h"
|
2007-07-18 09:15:07 +08:00
|
|
|
#include "serialis.h"
|
|
|
|
#include "unichar.h"
|
2007-03-08 04:03:40 +08:00
|
|
|
|
2007-07-18 09:15:07 +08:00
|
|
|
#define REALLY_QUOTE_IT(x) QUOTE_IT(x)
|
|
|
|
|
2007-03-08 04:03:40 +08:00
|
|
|
#define MAX_CUTOFF 1000
|
|
|
|
|
2009-07-11 10:17:36 +08:00
|
|
|
namespace tesseract {
|
2014-09-13 04:41:19 +08:00
|
|
|
/**
|
|
|
|
* Open Filename, read in all of the class-id/cutoff pairs
|
|
|
|
* and insert them into the Cutoffs array. Cutoffs are
|
|
|
|
* indexed in the array by class id. Unused entries in the
|
|
|
|
* array are set to an arbitrarily high cutoff value.
|
|
|
|
* @param CutoffFile name of file containing cutoff definitions
|
|
|
|
* @param Cutoffs array to put cutoffs into
|
|
|
|
* @param swap
|
|
|
|
* @param end_offset
|
|
|
|
* @return none
|
|
|
|
* @note Globals: none
|
|
|
|
* @note Exceptions: none
|
|
|
|
* @note History: Wed Feb 20 09:38:26 1991, DSJ, Created.
|
|
|
|
*/
|
2012-02-02 10:57:42 +08:00
|
|
|
void Classify::ReadNewCutoffs(FILE *CutoffFile, bool swap, inT64 end_offset,
|
2009-07-11 10:17:36 +08:00
|
|
|
CLASS_CUTOFF_ARRAY Cutoffs) {
|
2007-07-18 09:15:07 +08:00
|
|
|
char Class[UNICHAR_LEN + 1];
|
2007-03-08 04:03:40 +08:00
|
|
|
CLASS_ID ClassId;
|
|
|
|
int Cutoff;
|
|
|
|
int i;
|
|
|
|
|
2012-02-02 10:57:42 +08:00
|
|
|
if (shape_table_ != NULL) {
|
|
|
|
if (!shapetable_cutoffs_.DeSerialize(swap, CutoffFile)) {
|
|
|
|
tprintf("Error during read of shapetable pffmtable!\n");
|
|
|
|
}
|
|
|
|
}
|
2007-03-08 04:03:40 +08:00
|
|
|
for (i = 0; i < MAX_NUM_CLASSES; i++)
|
|
|
|
Cutoffs[i] = MAX_CUTOFF;
|
|
|
|
|
2009-07-11 10:17:36 +08:00
|
|
|
while ((end_offset < 0 || ftell(CutoffFile) < end_offset) &&
|
2014-04-24 07:12:53 +08:00
|
|
|
tfscanf(CutoffFile, "%" REALLY_QUOTE_IT(UNICHAR_LEN) "s %d",
|
2009-07-11 10:17:36 +08:00
|
|
|
Class, &Cutoff) == 2) {
|
|
|
|
if (strcmp(Class, "NULL") == 0) {
|
|
|
|
ClassId = unicharset.unichar_to_id(" ");
|
|
|
|
} else {
|
|
|
|
ClassId = unicharset.unichar_to_id(Class);
|
|
|
|
}
|
|
|
|
Cutoffs[ClassId] = Cutoff;
|
|
|
|
SkipNewline(CutoffFile);
|
2007-03-08 04:03:40 +08:00
|
|
|
}
|
2014-09-13 04:41:19 +08:00
|
|
|
}
|
2009-07-11 10:17:36 +08:00
|
|
|
|
|
|
|
} // namespace tesseract
|