Skip to main content

OCR/HTR engine for all the languages

Project description

Description

https://github.com/mittagessen/kraken/actions/workflows/test.yml/badge.svg

kraken is a turn-key OCR system optimized for historical and non-Latin script material.

kraken’s main features are:

  • Fully trainable layout analysis, reading order, and character recognition

  • Right-to-Left, BiDi, and Top-to-Bottom script support

  • ALTO, PageXML, abbyyXML, and hOCR output

  • Word bounding boxes and character cuts

  • Multi-script recognition support

  • Public repository of model files

  • Variable recognition network architecture

Installation

Kraken can be run on Linux or Mac OS X (both x64 and ARM). Installation is through the on-board pip utility. To not pollute the global state of your distribution’s package manager it is recommended to use virtual environments. If you do not have a setup or do not wish to handle virtual environments yourself you can use pipx.

$ sudo apt install pipx
$ pipx install kraken

kraken works both on Linux and Mac OS X and with any python interpreter between 3.10 and 3.13. It is possible the installation fails because pipx defaults to an unsupported interpreter version. In that case you need to install a compatible interpreter version such as 3.11 and then specify this version explicitly:

$ sudo apt install python3.13-full
$ pipx install --python python3.13 kraken

Installation using pip

Create and activate a separate virtual environment using whatever tool you like.

$ pip install kraken

or by running pip in the git repository:

$ pip install .

If you want direct PDF and multi-image TIFF/JPEG2000 support it is necessary to install the pdf extras package for PyPi:

$ pip install kraken[pdf]

Finally you’ll have to scrounge up a model to do the actual recognition of characters. To download the default model for printed French text and place it in the kraken directory for the current user:

$ kraken get 10.5281/zenodo.10592716

A list of libre models available in the central repository can be retrieved by running:

$ kraken list

Quickstart

Recognizing text on an image using the default parameters including the prerequisite steps of binarization and page segmentation:

$ kraken -i image.tif image.txt binarize segment ocr

To binarize a single image using the nlbin algorithm:

$ kraken -i image.tif bw.png binarize

To segment an image (binarized or not) with the new baseline segmenter:

$ kraken -i image.tif lines.json segment -bl

To segment and OCR an image using the default model(s):

$ kraken -i image.tif image.txt segment -bl ocr -m catmus-print-fondue-large.mlmodel

All subcommands and options are documented. Use the help option to get more information.

Documentation

Have a look at the docs.

Funding

kraken is developed at the École Pratique des Hautes Études, Université PSL.

Co-financed by the European Union

This project was funded in part by the European Union (ATRIUM, project number 101132163). This project was funded in part by the European Union (ERC, MiDRASH, project number 101071829). This project was partially funded through the RESILIENCE project, funded from the European Union’s Horizon 2020 Framework Programme for Research and Innovation.

Received funding from the Programme d’investissements d’Avenir

Ce travail a bénéficié d’une aide de l’État gérée par l’Agence Nationale de la Recherche au titre du Programme d’Investissements d’Avenir portant la référence ANR-21-ESRE-0005 (Biblissima+).

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kraken-7.0.0b6.tar.gz (5.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kraken-7.0.0b6-py3-none-any.whl (5.0 MB view details)

Uploaded Python 3

File details

Details for the file kraken-7.0.0b6.tar.gz.

File metadata

  • Download URL: kraken-7.0.0b6.tar.gz
  • Upload date:
  • Size: 5.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kraken-7.0.0b6.tar.gz
Algorithm Hash digest
SHA256 fd0e489ad79d12b6b3ccc38dfe04db3973dd833cef22ca9f817946315976084e
MD5 e17b7c38d0de4ceca51450565826ebb7
BLAKE2b-256 2d5d0f75fe9c7d2aa62de2c248d1aa131fe345f5b185006a7949aea16c5365d2

See more details on using hashes here.

Provenance

The following attestation bundles were made for kraken-7.0.0b6.tar.gz:

Publisher: test.yml on mittagessen/kraken

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kraken-7.0.0b6-py3-none-any.whl.

File metadata

  • Download URL: kraken-7.0.0b6-py3-none-any.whl
  • Upload date:
  • Size: 5.0 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kraken-7.0.0b6-py3-none-any.whl
Algorithm Hash digest
SHA256 8e38f177e8e5d4edb283eed8f129c836ea353cb5594a812d3a633eecf31cd815
MD5 de30b332c9edb37aed6dc97d3bba5f07
BLAKE2b-256 0327502c0f7652b8c5a732448eb3659256da97d06eae7afb679db3201e56489a

See more details on using hashes here.

Provenance

The following attestation bundles were made for kraken-7.0.0b6-py3-none-any.whl:

Publisher: test.yml on mittagessen/kraken

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page