tesseract  3.05.02
tesseract::TessLangModEdge Class Reference

#include <tess_lang_mod_edge.h>

Inheritance diagram for tesseract::TessLangModEdge:
tesseract::LangModEdge

Public Member Functions

 TessLangModEdge (CubeRecoContext *cntxt, const Dawg *edge_array, EDGE_REF edge, int class_id)
 
 TessLangModEdge (CubeRecoContext *cntxt, const Dawg *edge_array, EDGE_REF start_edge_idx, EDGE_REF end_edge_idx, int class_id)
 
 TessLangModEdge (CubeRecoContext *cntxt, int class_id)
 
 ~TessLangModEdge ()
 
bool IsRoot () const
 
void SetRoot (bool flag)
 
bool IsOOD () const
 
bool IsNumber () const
 
bool IsEOW () const
 
const DawgGetDawg () const
 
EDGE_REF StartEdge () const
 
EDGE_REF EndEdge () const
 
EDGE_REF EdgeMask () const
 
const char_32EdgeString () const
 
int ClassID () const
 
int PathCost () const
 
void SetEdgeMask (EDGE_REF edge_mask)
 
void SetDawg (Dawg *dawg)
 
void SetStartEdge (EDGE_REF edge_idx)
 
void SetEndEdge (EDGE_REF edge_idx)
 
bool IsTerminal () const
 
int SignalCnt () const
 
double SignalWgt (int signal) const
 
void SetSignalWgt (int signal, double wgt)
 
int Signal (int signal)
 
unsigned int Hash () const
 
char * Description () const
 
bool IsIdentical (LangModEdge *lang_mod_edge) const
 
- Public Member Functions inherited from tesseract::LangModEdge
 LangModEdge ()
 
virtual ~LangModEdge ()
 

Static Public Member Functions

static int CreateChildren (CubeRecoContext *cntxt, const Dawg *edges, NODE_REF edge_reg, LangModEdge **lm_edges)
 

Detailed Description

Definition at line 68 of file tess_lang_mod_edge.h.

Constructor & Destructor Documentation

◆ TessLangModEdge() [1/3]

tesseract::TessLangModEdge::TessLangModEdge ( CubeRecoContext cntxt,
const Dawg dawg,
EDGE_REF  edge_idx,
int  class_id 
)

leading, trailing punc constructor and single byte UTF char

Definition at line 43 of file tess_lang_mod_edge.cpp.

44  {
45  root_ = false;
46  cntxt_ = cntxt;
47  dawg_ = dawg;
48  start_edge_ = edge_idx;
49  end_edge_ = edge_idx;
50  edge_mask_ = 0;
51  class_id_ = class_id;
52  str_ = cntxt_->CharacterSet()->ClassString(class_id);
53  path_cost_ = Cost();
54 }
CharSet * CharacterSet() const
const char_32 * ClassString(int class_id) const
Definition: char_set.h:104

◆ TessLangModEdge() [2/3]

tesseract::TessLangModEdge::TessLangModEdge ( CubeRecoContext cntxt,
const Dawg dawg,
EDGE_REF  start_edge_idx,
EDGE_REF  end_edge_idx,
int  class_id 
)

dict constructor: multi byte UTF char

Definition at line 59 of file tess_lang_mod_edge.cpp.

61  {
62  root_ = false;
63  cntxt_ = cntxt;
64  dawg_ = dawg;
65  start_edge_ = start_edge_idx;
66  end_edge_ = end_edge_idx;
67  edge_mask_ = 0;
68  class_id_ = class_id;
69  str_ = cntxt_->CharacterSet()->ClassString(class_id);
70  path_cost_ = Cost();
71 }
CharSet * CharacterSet() const
const char_32 * ClassString(int class_id) const
Definition: char_set.h:104

◆ TessLangModEdge() [3/3]

tesseract::TessLangModEdge::TessLangModEdge ( CubeRecoContext cntxt,
int  class_id 
)

Definition at line 28 of file tess_lang_mod_edge.cpp.

28  {
29  root_ = false;
30  cntxt_ = cntxt;
31  dawg_ = NULL;
32  start_edge_ = 0;
33  end_edge_ = 0;
34  edge_mask_ = 0;
35  class_id_ = class_id;
36  str_ = cntxt_->CharacterSet()->ClassString(class_id);
37  path_cost_ = Cost();
38 }
CharSet * CharacterSet() const
const char_32 * ClassString(int class_id) const
Definition: char_set.h:104

◆ ~TessLangModEdge()

tesseract::TessLangModEdge::~TessLangModEdge ( )
inline

Definition at line 77 of file tess_lang_mod_edge.h.

77 {}

Member Function Documentation

◆ ClassID()

int tesseract::TessLangModEdge::ClassID ( ) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 102 of file tess_lang_mod_edge.h.

102 { return class_id_; }

◆ CreateChildren()

int tesseract::TessLangModEdge::CreateChildren ( CubeRecoContext cntxt,
const Dawg edges,
NODE_REF  edge_reg,
LangModEdge **  lm_edges 
)
static

Definition at line 105 of file tess_lang_mod_edge.cpp.

108  {
109  int edge_cnt = 0;
110  NodeChildVector vec;
111  dawg->unichar_ids_of(parent_node, &vec, false); // find all children
112  for (int i = 0; i < vec.size(); ++i) {
113  const NodeChild &child = vec[i];
114  if (child.unichar_id == INVALID_UNICHAR_ID) continue;
115  edge_array[edge_cnt++] =
116  new TessLangModEdge(cntxt, dawg, child.edge_ref, child.unichar_id);
117  }
118  return edge_cnt;
119 }
TessLangModEdge(CubeRecoContext *cntxt, const Dawg *edge_array, EDGE_REF edge, int class_id)
GenericVector< NodeChild > NodeChildVector
Definition: dawg.h:67

◆ Description()

char * tesseract::TessLangModEdge::Description ( ) const
virtual

Implements tesseract::LangModEdge.

Definition at line 73 of file tess_lang_mod_edge.cpp.

73  {
74  char *char_ptr = new char[256];
75 
76  char dawg_str[256];
77  char edge_str[32];
78  if (dawg_ == (Dawg *)DAWG_OOD) {
79  strcpy(dawg_str, "OOD");
80  } else if (dawg_ == (Dawg *)DAWG_NUMBER) {
81  strcpy(dawg_str, "NUM");
82  } else if (dawg_->permuter() == SYSTEM_DAWG_PERM) {
83  strcpy(dawg_str, "Main");
84  } else if (dawg_->permuter() == USER_DAWG_PERM) {
85  strcpy(dawg_str, "User");
86  } else if (dawg_->permuter() == DOC_DAWG_PERM) {
87  strcpy(dawg_str, "Doc");
88  } else {
89  strcpy(dawg_str, "N/A");
90  }
91 
92  sprintf(edge_str, "%d", static_cast<int>(start_edge_));
93  if (IsLeadingPuncEdge(edge_mask_)) {
94  strcat(edge_str, "-LP");
95  }
96  if (IsTrailingPuncEdge(edge_mask_)) {
97  strcat(edge_str, "-TP");
98  }
99  sprintf(char_ptr, "%s(%s)%s, Wtd Dawg Cost=%d",
100  dawg_str, edge_str, IsEOW() ? "-EOW-" : "", path_cost_);
101 
102  return char_ptr;
103 }
#define IsLeadingPuncEdge(edge_mask)
#define IsTrailingPuncEdge(edge_mask)
PermuterType permuter() const
Definition: dawg.h:129
#define DAWG_OOD
#define DAWG_NUMBER

◆ EdgeMask()

EDGE_REF tesseract::TessLangModEdge::EdgeMask ( ) const
inline

Definition at line 100 of file tess_lang_mod_edge.h.

100 { return edge_mask_; }

◆ EdgeString()

const char_32* tesseract::TessLangModEdge::EdgeString ( ) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 101 of file tess_lang_mod_edge.h.

101 { return str_; }

◆ EndEdge()

EDGE_REF tesseract::TessLangModEdge::EndEdge ( ) const
inline

Definition at line 99 of file tess_lang_mod_edge.h.

99 { return end_edge_; }

◆ GetDawg()

const Dawg* tesseract::TessLangModEdge::GetDawg ( ) const
inline

Definition at line 97 of file tess_lang_mod_edge.h.

97 { return dawg_; }

◆ Hash()

unsigned int tesseract::TessLangModEdge::Hash ( ) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 178 of file tess_lang_mod_edge.h.

178  {
179  return static_cast<unsigned int>(
180  ((start_edge_ | end_edge_) ^ ((reinterpret_cast<uintptr_t>(dawg_)))) ^
181  ((unsigned int)edge_mask_) ^ class_id_);
182  }

◆ IsEOW()

bool tesseract::TessLangModEdge::IsEOW ( ) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 93 of file tess_lang_mod_edge.h.

93  {
94  return (IsTerminal() || (dawg_->end_of_word(end_edge_) != 0));
95  }
virtual bool end_of_word(EDGE_REF edge_ref) const =0

◆ IsIdentical()

bool tesseract::TessLangModEdge::IsIdentical ( LangModEdge lang_mod_edge) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 188 of file tess_lang_mod_edge.h.

188  {
189  return (class_id_ ==
190  reinterpret_cast<TessLangModEdge *>(lang_mod_edge)->class_id_ &&
191  str_ == reinterpret_cast<TessLangModEdge *>(lang_mod_edge)->str_ &&
192  dawg_ == reinterpret_cast<TessLangModEdge *>(lang_mod_edge)->dawg_ &&
193  start_edge_ ==
194  reinterpret_cast<TessLangModEdge *>(lang_mod_edge)->start_edge_ &&
195  end_edge_ ==
196  reinterpret_cast<TessLangModEdge *>(lang_mod_edge)->end_edge_ &&
197  edge_mask_ ==
198  reinterpret_cast<TessLangModEdge *>(lang_mod_edge)->edge_mask_);
199  }

◆ IsNumber()

bool tesseract::TessLangModEdge::IsNumber ( ) const
inline

Definition at line 89 of file tess_lang_mod_edge.h.

89  {
90  return (dawg_ == (Dawg *)DAWG_NUMBER);
91  }
#define DAWG_NUMBER

◆ IsOOD()

bool tesseract::TessLangModEdge::IsOOD ( ) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 85 of file tess_lang_mod_edge.h.

85  {
86  return (dawg_ == (Dawg *)DAWG_OOD);
87  }
#define DAWG_OOD

◆ IsRoot()

bool tesseract::TessLangModEdge::IsRoot ( ) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 80 of file tess_lang_mod_edge.h.

80  {
81  return root_;
82  }

◆ IsTerminal()

bool tesseract::TessLangModEdge::IsTerminal ( ) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 112 of file tess_lang_mod_edge.h.

112  {
113  return (IsOOD() || IsNumber() || IsTrailingPuncEdge(start_edge_) ||
114  dawg_->next_node(end_edge_) == 0);
115  }
#define IsTrailingPuncEdge(edge_mask)
virtual NODE_REF next_node(EDGE_REF edge_ref) const =0

◆ PathCost()

int tesseract::TessLangModEdge::PathCost ( ) const
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 103 of file tess_lang_mod_edge.h.

103 { return path_cost_; }

◆ SetDawg()

void tesseract::TessLangModEdge::SetDawg ( Dawg dawg)
inline

Definition at line 105 of file tess_lang_mod_edge.h.

105 { dawg_ = dawg; }

◆ SetEdgeMask()

void tesseract::TessLangModEdge::SetEdgeMask ( EDGE_REF  edge_mask)
inline

Definition at line 104 of file tess_lang_mod_edge.h.

104 { edge_mask_ = edge_mask; }

◆ SetEndEdge()

void tesseract::TessLangModEdge::SetEndEdge ( EDGE_REF  edge_idx)
inline

Definition at line 107 of file tess_lang_mod_edge.h.

107 { end_edge_ = edge_idx; }

◆ SetRoot()

void tesseract::TessLangModEdge::SetRoot ( bool  flag)
inlinevirtual

Implements tesseract::LangModEdge.

Definition at line 83 of file tess_lang_mod_edge.h.

83 { root_ = flag; }

◆ SetSignalWgt()

void tesseract::TessLangModEdge::SetSignalWgt ( int  signal,
double  wgt 
)
inline

Definition at line 144 of file tess_lang_mod_edge.h.

144  {
145  CubeTuningParams *params =
146  reinterpret_cast<CubeTuningParams *>(cntxt_->Params());
147  if (params != NULL) {
148  switch (signal) {
149  case 0:
150  params->SetOODWgt(wgt);
151  break;
152 
153  case 1:
154  params->SetNumWgt(wgt);
155  break;
156  }
157  }
158  }
TuningParams * Params() const

◆ SetStartEdge()

void tesseract::TessLangModEdge::SetStartEdge ( EDGE_REF  edge_idx)
inline

Definition at line 106 of file tess_lang_mod_edge.h.

106 { start_edge_ = edge_idx; }

◆ Signal()

int tesseract::TessLangModEdge::Signal ( int  signal)
inline

Definition at line 161 of file tess_lang_mod_edge.h.

161  {
162  switch (signal) {
163  case 0:
164  return IsOOD() ? MIN_PROB_COST : 0;
165  break;
166 
167  case 1:
168  return IsNumber() ? MIN_PROB_COST : 0;
169  break;
170 
171  default:
172  return 0;
173  }
174  }
#define MIN_PROB_COST
Definition: cube_const.h:26

◆ SignalCnt()

int tesseract::TessLangModEdge::SignalCnt ( ) const
inline

Definition at line 120 of file tess_lang_mod_edge.h.

120  {
121  return 2;
122  }

◆ SignalWgt()

double tesseract::TessLangModEdge::SignalWgt ( int  signal) const
inline

Definition at line 125 of file tess_lang_mod_edge.h.

125  {
126  CubeTuningParams *params =
127  reinterpret_cast<CubeTuningParams *>(cntxt_->Params());
128  if (params != NULL) {
129  switch (signal) {
130  case 0:
131  return params->OODWgt();
132  break;
133 
134  case 1:
135  return params->NumWgt();
136  break;
137  }
138  }
139 
140  return 0.0;
141  }
TuningParams * Params() const

◆ StartEdge()

EDGE_REF tesseract::TessLangModEdge::StartEdge ( ) const
inline

Definition at line 98 of file tess_lang_mod_edge.h.

98 { return start_edge_; }

The documentation for this class was generated from the following files: