tesseract  3.05.02
adaptmatch.cpp File Reference
#include <ctype.h>
#include "shapeclassifier.h"
#include "ambigs.h"
#include "blobclass.h"
#include "blobs.h"
#include "callcpp.h"
#include "classify.h"
#include "const.h"
#include "dict.h"
#include "efio.h"
#include "emalloc.h"
#include "featdefs.h"
#include "float2int.h"
#include "genericvector.h"
#include "globals.h"
#include "helpers.h"
#include "intfx.h"
#include "intproto.h"
#include "mfoutline.h"
#include "ndminx.h"
#include "normfeat.h"
#include "normmatch.h"
#include "outfeat.h"
#include "pageres.h"
#include "params.h"
#include "picofeat.h"
#include "shapetable.h"
#include "tessclassifier.h"
#include "trainingsample.h"
#include "unicharset.h"
#include "werd.h"
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>

Go to the source code of this file.

Classes

struct  ADAPT_RESULTS
 
struct  PROTO_KEY
 

Namespaces

 tesseract
 

Macros

#define ADAPT_TEMPLATE_SUFFIX   ".a"
 
#define MAX_MATCHES   10
 
#define UNLIKELY_NUM_FEAT   200
 
#define NO_DEBUG   0
 
#define MAX_ADAPTABLE_WERD_SIZE   40
 
#define ADAPTABLE_WERD_ADJUSTMENT   (0.05)
 
#define Y_DIM_OFFSET   (Y_SHIFT - BASELINE_Y_SHIFT)
 
#define WORST_POSSIBLE_RATING   (0.0f)
 

Functions

bool MarginalMatch (float confidence, float matcher_great_threshold)
 
void InitMatcherRatings (register FLOAT32 *Rating)
 
int MakeTempProtoPerm (void *item1, void *item2)
 
void SetAdaptiveThreshold (FLOAT32 Threshold)
 

Macro Definition Documentation

◆ ADAPT_TEMPLATE_SUFFIX

#define ADAPT_TEMPLATE_SUFFIX   ".a"

Definition at line 66 of file adaptmatch.cpp.

◆ ADAPTABLE_WERD_ADJUSTMENT

#define ADAPTABLE_WERD_ADJUSTMENT   (0.05)

Definition at line 73 of file adaptmatch.cpp.

◆ MAX_ADAPTABLE_WERD_SIZE

#define MAX_ADAPTABLE_WERD_SIZE   40

Definition at line 71 of file adaptmatch.cpp.

◆ MAX_MATCHES

#define MAX_MATCHES   10

Definition at line 68 of file adaptmatch.cpp.

◆ NO_DEBUG

#define NO_DEBUG   0

Definition at line 70 of file adaptmatch.cpp.

◆ UNLIKELY_NUM_FEAT

#define UNLIKELY_NUM_FEAT   200

Definition at line 69 of file adaptmatch.cpp.

◆ WORST_POSSIBLE_RATING

#define WORST_POSSIBLE_RATING   (0.0f)

Definition at line 77 of file adaptmatch.cpp.

◆ Y_DIM_OFFSET

#define Y_DIM_OFFSET   (Y_SHIFT - BASELINE_Y_SHIFT)

Definition at line 75 of file adaptmatch.cpp.

Function Documentation

◆ InitMatcherRatings()

void InitMatcherRatings ( register FLOAT32 Rating)

◆ MakeTempProtoPerm()

int MakeTempProtoPerm ( void *  item1,
void *  item2 
)

This routine converts TempProto to be permanent if its proto id is used by the configuration specified in ProtoKey.

Parameters
item1(TEMP_PROTO) temporary proto to compare to key
item2(PROTO_KEY) defines which protos to make permanent

Globals: none

Returns
TRUE if TempProto is converted, FALSE otherwise
Note
Exceptions: none
History: Thu Mar 14 18:49:54 1991, DSJ, Created.

Definition at line 2041 of file adaptmatch.cpp.

2041  {
2042  ADAPT_CLASS Class;
2044  TEMP_PROTO TempProto;
2045  PROTO_KEY *ProtoKey;
2046 
2047  TempProto = (TEMP_PROTO) item1;
2048  ProtoKey = (PROTO_KEY *) item2;
2049 
2050  Class = ProtoKey->Templates->Class[ProtoKey->ClassId];
2051  Config = TempConfigFor(Class, ProtoKey->ConfigId);
2052 
2053  if (TempProto->ProtoId > Config->MaxProtoId ||
2054  !test_bit (Config->Protos, TempProto->ProtoId))
2055  return FALSE;
2056 
2057  MakeProtoPermanent(Class, TempProto->ProtoId);
2058  AddProtoToClassPruner(&(TempProto->Proto), ProtoKey->ClassId,
2059  ProtoKey->Templates->Templates);
2060  FreeTempProto(TempProto);
2061 
2062  return TRUE;
2063 } /* MakeTempProtoPerm */
#define TRUE
Definition: capi.h:45
#define TempConfigFor(Class, ConfigId)
Definition: adaptive.h:102
void AddProtoToClassPruner(PROTO Proto, CLASS_ID ClassId, INT_TEMPLATES Templates)
Definition: intproto.cpp:342
uinT16 ProtoId
Definition: adaptive.h:30
CLUSTERCONFIG Config
PROTO_STRUCT Proto
Definition: adaptive.h:32
TEMP_PROTO_STRUCT * TEMP_PROTO
Definition: adaptive.h:37
#define FALSE
Definition: capi.h:46
#define MakeProtoPermanent(Class, ProtoId)
Definition: adaptive.h:99
INT_TEMPLATES Templates
Definition: adaptive.h:77
CLASS_ID ClassId
Definition: adaptmatch.cpp:115
ADAPT_TEMPLATES Templates
Definition: adaptmatch.cpp:114
void FreeTempProto(void *arg)
Definition: adaptive.cpp:90
#define test_bit(array, bit)
Definition: bitvec.h:61
ADAPT_CLASS Class[MAX_NUM_CLASSES]
Definition: adaptive.h:81

◆ MarginalMatch()

bool MarginalMatch ( float  confidence,
float  matcher_great_threshold 
)
inline

Definition at line 122 of file adaptmatch.cpp.

122  {
123  return (1.0f - confidence) > matcher_great_threshold;
124 }

◆ SetAdaptiveThreshold()

void SetAdaptiveThreshold ( FLOAT32  Threshold)