tesseract  4.00.00dev
blamer.h File Reference
#include <stdio.h>
#include "boxword.h"
#include "genericvector.h"
#include "matrix.h"
#include "params_training_featdef.h"
#include "ratngs.h"
#include "strngs.h"
#include "tesscallback.h"

Go to the source code of this file.

Classes

struct  BlamerBundle
 

Enumerations

enum  IncorrectResultReason {
  IRR_CORRECT, IRR_CLASSIFIER, IRR_CHOPPER, IRR_CLASS_LM_TRADEOFF,
  IRR_PAGE_LAYOUT, IRR_SEGSEARCH_HEUR, IRR_SEGSEARCH_PP, IRR_CLASS_OLD_LM_TRADEOFF,
  IRR_ADAPTION, IRR_NO_TRUTH_SPLIT, IRR_NO_TRUTH, IRR_UNKNOWN,
  IRR_NUM_REASONS
}
 

Enumeration Type Documentation

◆ IncorrectResultReason

Enumerator
IRR_CORRECT 
IRR_CLASSIFIER 
IRR_CHOPPER 
IRR_CLASS_LM_TRADEOFF 
IRR_PAGE_LAYOUT 
IRR_SEGSEARCH_HEUR 
IRR_SEGSEARCH_PP 
IRR_CLASS_OLD_LM_TRADEOFF 
IRR_ADAPTION 
IRR_NO_TRUTH_SPLIT 
IRR_NO_TRUTH 
IRR_UNKNOWN 
IRR_NUM_REASONS 

Definition at line 37 of file blamer.h.

37  {
38  // The text recorded in best choice == truth text
40  // Either: Top choice is incorrect and is a dictionary word (language model
41  // is unlikely to help correct such errors, so blame the classifier).
42  // Or: the correct unichar was not included in shortlist produced by the
43  // classifier at all.
45  // Chopper have not found one or more splits that correspond to the correct
46  // character bounding boxes recorded in BlamerBundle::truth_word.
48  // Classifier did include correct unichars for each blob in the correct
49  // segmentation, however its rating could have been too bad to allow the
50  // language model to pull out the correct choice. On the other hand the
51  // strength of the language model might have been too weak to favor the
52  // correct answer, this we call this case a classifier-language model
53  // tradeoff error.
55  // Page layout failed to produce the correct bounding box. Blame page layout
56  // if the truth was not found for the word, which implies that the bounding
57  // box of the word was incorrect (no truth word had a similar bounding box).
59  // SegSearch heuristic prevented one or more blobs from the correct
60  // segmentation state to be classified (e.g. the blob was too wide).
62  // The correct segmentaiton state was not explored because of poor SegSearch
63  // pain point prioritization. We blame SegSearch pain point prioritization
64  // if the best rating of a choice constructed from correct segmentation is
65  // better than that of the best choice (i.e. if we got to explore the correct
66  // segmentation state, language model would have picked the correct choice).
68  // Same as IRR_CLASS_LM_TRADEOFF, but used when we only run chopper on a word,
69  // and thus use the old language model (permuters).
70  // TODO(antonova): integrate the new language mode with chopper
72  // If there is an incorrect adaptive template match with a better score than
73  // a correct one (either pre-trained or adapted), mark this as adaption error.
75  // split_and_recog_word() failed to find a suitable split in truth.
77  // Truth is not available for this word (e.g. when words in corrected content
78  // file are turned into ~~~~ because an appropriate alignment was not found.
80  // The text recorded in best choice != truth text, but none of the above
81  // reasons are set.
83 
85 };