tesseract  4.00.00dev
ocrblock.h File Reference
#include "ocrpara.h"
#include "ocrrow.h"
#include "pdblock.h"

Go to the source code of this file.

Classes

class  BLOCK
 

Functions

int decreasing_top_order (const void *row1, const void *row2)
 
void PrintSegmentationStats (BLOCK_LIST *block_list)
 
void ExtractBlobsFromSegmentation (BLOCK_LIST *blocks, C_BLOB_LIST *output_blob_list)
 
void RefreshWordBlobsFromNewBlobs (BLOCK_LIST *block_list, C_BLOB_LIST *new_blobs, C_BLOB_LIST *not_found_blobs)
 

Function Documentation

◆ decreasing_top_order()

int decreasing_top_order ( const void *  row1,
const void *  row2 
)

decreasing_top_order

Sort Comparator: Return <0 if row1 top < row2 top

Definition at line 72 of file ocrblock.cpp.

74  {
75  return (*(ROW **) row2)->bounding_box ().top () -
76  (*(ROW **) row1)->bounding_box ().top ();
77 }
Definition: ocrrow.h:32

◆ ExtractBlobsFromSegmentation()

void ExtractBlobsFromSegmentation ( BLOCK_LIST *  blocks,
C_BLOB_LIST *  output_blob_list 
)

Definition at line 443 of file ocrblock.cpp.

444  {
445  C_BLOB_IT return_list_it(output_blob_list);
446  BLOCK_IT block_it(blocks);
447  for (block_it.mark_cycle_pt(); !block_it.cycled_list(); block_it.forward()) {
448  BLOCK* block = block_it.data();
449  ROW_IT row_it(block->row_list());
450  for (row_it.mark_cycle_pt(); !row_it.cycled_list(); row_it.forward()) {
451  ROW* row = row_it.data();
452  // Iterate over all werds in the row.
453  WERD_IT werd_it(row->word_list());
454  for (werd_it.mark_cycle_pt(); !werd_it.cycled_list(); werd_it.forward()) {
455  WERD* werd = werd_it.data();
456  return_list_it.move_to_last();
457  return_list_it.add_list_after(werd->cblob_list());
458  return_list_it.move_to_last();
459  return_list_it.add_list_after(werd->rej_cblob_list());
460  }
461  }
462  }
463 }
WERD_LIST * word_list()
Definition: ocrrow.h:52
C_BLOB_LIST * cblob_list()
Definition: werd.h:100
C_BLOB_LIST * rej_cblob_list()
Definition: werd.h:95
Definition: werd.h:60
Definition: ocrrow.h:32
ROW_LIST * row_list()
get rows
Definition: ocrblock.h:120
Definition: ocrblock.h:30

◆ PrintSegmentationStats()

void PrintSegmentationStats ( BLOCK_LIST *  block_list)

Definition at line 410 of file ocrblock.cpp.

410  {
411  int num_blocks = 0;
412  int num_rows = 0;
413  int num_words = 0;
414  int num_blobs = 0;
415  BLOCK_IT block_it(block_list);
416  for (block_it.mark_cycle_pt(); !block_it.cycled_list(); block_it.forward()) {
417  BLOCK* block = block_it.data();
418  ++num_blocks;
419  ROW_IT row_it(block->row_list());
420  for (row_it.mark_cycle_pt(); !row_it.cycled_list(); row_it.forward()) {
421  ++num_rows;
422  ROW* row = row_it.data();
423  // Iterate over all werds in the row.
424  WERD_IT werd_it(row->word_list());
425  for (werd_it.mark_cycle_pt(); !werd_it.cycled_list(); werd_it.forward()) {
426  WERD* werd = werd_it.data();
427  ++num_words;
428  num_blobs += werd->cblob_list()->length();
429  }
430  }
431  }
432  tprintf("Block list stats:\nBlocks = %d\nRows = %d\nWords = %d\nBlobs = %d\n",
433  num_blocks, num_rows, num_words, num_blobs);
434 }
#define tprintf(...)
Definition: tprintf.h:31
WERD_LIST * word_list()
Definition: ocrrow.h:52
C_BLOB_LIST * cblob_list()
Definition: werd.h:100
Definition: werd.h:60
Definition: ocrrow.h:32
ROW_LIST * row_list()
get rows
Definition: ocrblock.h:120
Definition: ocrblock.h:30

◆ RefreshWordBlobsFromNewBlobs()

void RefreshWordBlobsFromNewBlobs ( BLOCK_LIST *  block_list,
C_BLOB_LIST *  new_blobs,
C_BLOB_LIST *  not_found_blobs 
)

Definition at line 478 of file ocrblock.cpp.

480  {
481  // Now iterate over all the blobs in the segmentation_block_list_, and just
482  // replace the corresponding c-blobs inside the werds.
483  BLOCK_IT block_it(block_list);
484  for (block_it.mark_cycle_pt(); !block_it.cycled_list(); block_it.forward()) {
485  BLOCK* block = block_it.data();
486  if (block->poly_block() != NULL && !block->poly_block()->IsText())
487  continue; // Don't touch non-text blocks.
488  // Iterate over all rows in the block.
489  ROW_IT row_it(block->row_list());
490  for (row_it.mark_cycle_pt(); !row_it.cycled_list(); row_it.forward()) {
491  ROW* row = row_it.data();
492  // Iterate over all werds in the row.
493  WERD_IT werd_it(row->word_list());
494  WERD_LIST new_words;
495  WERD_IT new_words_it(&new_words);
496  for (werd_it.mark_cycle_pt(); !werd_it.cycled_list(); werd_it.forward()) {
497  WERD* werd = werd_it.extract();
498  WERD* new_werd = werd->ConstructWerdWithNewBlobs(new_blobs,
499  not_found_blobs);
500  if (new_werd) {
501  // Insert this new werd into the actual row's werd-list. Remove the
502  // existing one.
503  new_words_it.add_after_then_move(new_werd);
504  delete werd;
505  } else {
506  // Reinsert the older word back, for lack of better options.
507  // This is critical since dropping the words messes up segmentation:
508  // eg. 1st word in the row might otherwise have W_FUZZY_NON turned on.
509  new_words_it.add_after_then_move(werd);
510  }
511  }
512  // Get rid of the old word list & replace it with the new one.
513  row->word_list()->clear();
514  werd_it.move_to_first();
515  werd_it.add_list_after(&new_words);
516  }
517  }
518 }
WERD * ConstructWerdWithNewBlobs(C_BLOB_LIST *all_blobs, C_BLOB_LIST *orphan_blobs)
Definition: werd.cpp:412
WERD_LIST * word_list()
Definition: ocrrow.h:52
bool IsText() const
Definition: polyblk.h:52
POLY_BLOCK * poly_block() const
Definition: pdblock.h:55
Definition: werd.h:60
Definition: ocrrow.h:32
ROW_LIST * row_list()
get rows
Definition: ocrblock.h:120
Definition: ocrblock.h:30