Go to file
Gerber, Mike d2c843aa3f 📦 v0.0.5
.circleci 🐛 CircleCI: Try upgrading pip
.idea 🔧 Add PyCharm project files
ocrd_calamari 📦 v0.0.5
test Allow controlling of output hierarchy level, e.g. only line, not words+glyphs
.coveragerc Only do the coverage on our code
.gitignore 📝 README: Provide a complete example using real data and other processors
Dockerfile 🐳 Docker: Run pip3 check for good measure
LICENSE Initial commit
Makefile 📝 Document make targets
README-DEV.md 📝 README-DEV: Improve info about releasing
README.md 📝 README: Add a missing `cd`
ocrd-tool.json .
requirements-test.txt Use GT segmentation to test
requirements.txt Do word segmentation as expected by OCR-D PAGE specs
setup.py 📦 v0.0.5

README.md

ocrd_calamari

Recognize text using Calamari OCR.

image image image

Introduction

This offers a OCR-D compliant workspace processor for the functionality of Calamari OCR.

This processor only operates on the text line level and so needs a line segmentation (and by extension a binarized image) as its input.

In addition to the line text it may also output word and glyph segmentation including per-glyph confidence values and per-glyph alternative predictions as provided by the Calamari OCR engine, using a textequiv_level of word or glyph. Note that while Calamari does not provide word segmentation, this processor produces word segmentation inferred from text segmentation and the glyph positions. The provided glyph and word segmentation can be used for text extraction and highlighting, but is probably not useful for further image-based processing.

Installation

From PyPI

pip install ocrd_calamari

From Repo

pip install .

Install models

Download models trained on GT4HistOCR data:

make gt4histocr-calamari
ls gt4histocr-calamari

Example Usage

Before using ocrd-calamari-recognize get some example data and model, and prepare the document for OCR:

# Download model and example data
make gt4histocr-calamari
make actevedef_718448162

# Create binarized images and line segmentation using other OCR-D projects
cd actevedef_718448162
ocrd-olena-binarize -p '{ "impl": "sauvola-ms-split" }' -I OCR-D-IMG -O OCR-D-IMG-BINPAGE,OCR-D-IMG-BIN
ocrd-tesserocr-segment-region -I OCR-D-IMG-BINPAGE -O OCR-D-SEG-REGION
ocrd-tesserocr-segment-line -I OCR-D-SEG-REGION -O OCR-D-SEG-LINE

Finally recognize the text using ocrd_calamari and the downloaded model:

ocrd-calamari-recognize -p '{ "checkpoint": "../gt4histocr-calamari/*.ckpt.json" }' -I OCR-D-SEG-LINE -O OCR-D-OCR-CALAMARI

You may want to have a look at the ocrd-tool.json descriptions for additional parameters and default values.

Development & Testing

For information regarding development and testing, please see README-DEV.md.