Tesseract (Software)

Software für Texterkennung (OCR)

Tesseract ist eine freie Software zur Texterkennung. Schwerpunkt ist die Erkennung von Textzeichen bzw. Textzeilen, aber auch die Zerlegung eines Textes in Textblöcke (Layoutanalyse) kann Tesseract übernehmen. Zur Verbesserung der Erkennungsraten verwendet Tesseract Sprachmodelle wie beispielsweise Wörterbücher.

Tesseract

Basisdaten

Entwickler Ray Smith, Google, Hewlett-Packard, University of Nevada, Las Vegas, Freie-Software-Gemeinde
Aktuelle Version 5.5.0[1]
(10. November 2024)
Betriebssystem GNU/Linux, Microsoft Windows[2], macOS[2], BSD-Betriebssystem[2], GNU/Hurd[2], Android[2], iOS[2], Plattformunabhängig
Programmier­sprache C++[3]
Kategorie Texterkennung
Lizenz Apache-Lizenz, Version 2.0[2][4]
deutschsprachig ja
github.com/tesseract-ocr
Tesseract 3.03 in einer Linux-Konsole

Für weit mehr als 100 Sprachen und Sprachvarianten sind bereits Texterkennungsdaten in Zusatzmodulen vorhanden. Tesseract unterstützt dabei nicht nur lateinische Antiqua-Schriften, sondern auch Fraktur-Schrift, Devanagari (indische Schrift), chinesische, arabische, griechische, hebräische, kyrillische und weitere Schriften.[5][6]

Geschichte

Bearbeiten

Ursprünglich wurde die Software zwischen 1984 und 1994 bei Hewlett-Packard für deren Scanner entwickelt, dort aber nie in einem Produkt verwendet.[7] Aus einem Test der University of Nevada, Las Vegas (UNLV) ging sie 1995 als einer der drei präzisesten Testkandidaten hervor. Nach dem Ausstieg von HP aus dem OCR-Markt lag die Entwicklung weitgehend brach, bis der Code 2005 an das Information Science Research Institute der UNLV übergeben wurde. Hier wurde festgestellt, dass der ehemalige Entwickler Ray Smith mittlerweile bei Google arbeitete. Nach einer Nachfrage bei Google, ob Interesse an dem Code bestünde, nahm sich Google des Quelltextes an, brachte ihn auf einen aktuellen Stand und gab ihn noch im selben Jahr unter der Apache-Lizenz über SourceForge frei.

Dies bedeutete in der Welt der freien Software einen großen Qualitätssprung im Bereich der Texterkennung. Das Projekt migrierte von SourceForge auf Googles eigene Software-Entwickler-Plattform Google Code, wo es unter Betreuung von Google weiterentwickelt wurde. Seit 2015 findet die Weiterentwicklung auf GitHub statt.[8]

Seit 2006 wurde das Programm als Grundlage von Google Books weiterentwickelt. Ab Version 3.0 vom September 2010 können Ergebnisse direkt in das hOCR-Format ausgegeben werden und es wurde ein neues Modul zur Analyse der Seitengestaltung eingeführt.

Das Projekt tesseractindic widmete sich der Aufgabe, das Programm mit Sprachen aus der indischen Sprachenfamilie verwendbar zu machen.[9] Diese Sprachen werden seit Tesseract 3.01 unterstützt.

In der Version 3.02 vom 28. Oktober 2012 wurde u. a. die Erkennung arabischer und hebräischer Texte im bidirektionalen Modus eingeführt.

Ende 2016 führte Tesseract ein neuronales Netz zur Texterkennung ein. Version 4 unterstützt diese neue Methode, kann aber auch weiterhin mit dem Mustervergleich der Vorgängerversionen arbeiten.

Google verwendete nach eigener Aussage Tesseract für die Texterkennung auf mobilen Geräten und in Videos sowie bei der Erkennung von Spam in E-Mail-Bildern.[10], ist aber seit 2018 nicht mehr aktiv an der Weiterentwicklung von Tesseract beteiligt. Diese wird seitdem von einer kleinen Gruppe von Hauptentwicklern und vielen Beiträgen einzelner Entwickler getragen.[11]

Seit Dezember 2018 kann Tesseract die OCR-Ergebnisse im standardisierten ALTO-Format ausgeben. Dieses Format ist insbesondere für Archive und Bibliotheken relevant, die Archivgut und historische Drucke nach den DFG-Praxisregeln Digitalisierung veröffentlichen möchten.[12] Mit Förderung durch die Deutsche Forschungsgemeinschaft im Rahmen des Projektes OCR-D arbeitet die Universitätsbibliothek Mannheim seit 2018 daran, Tesseract für den Einsatz in der Retrodigitalisierung tauglich zu machen.[13]

Ende 2020 stellte das Internet Archive die automatisierte Texterkennung von ABBYY FineReader auf Tesseract um[14] und verarbeitet damit mehr als 2 Millionen Seiten pro Tag.[15]

Anwendung

Bearbeiten

Tesseract wird nach den unter Unix üblichen Konventionen auch unter Windows von der Kommandozeile aus gesteuert und hat folgendes Format:[16]

tesseract imagename outputbase [-l lang] [--oem ocrenginemode] [--psm pagesegmode] [configfiles...]

Tesseract liest das Bild im Tagged Image File Format (TIFF) ein und gibt den Text in die Ausgabedatei weiter. Ältere Versionen von Tesseract hatten keine eigene Layoutanalyse, waren also auf externe Software wie beispielsweise OCRopus angewiesen, um Textspalten auf einzelne Bilddateien zu verteilen. Aktuelle Versionen nutzen die Programmbibliothek Leptonica für die Analyse der Seitengestaltung, aber auch für die direkte Verarbeitung aller gängigen Bildformate.[17]

Eine automatisierte Verarbeitung lässt sich zum Beispiel mit ImageMagick verwirklichen.

Tesseract kann ab Version 3 die Scan-Ergebnisse im hOCR-Format speichern, wodurch die Seitengestaltung erhalten bleibt.[18] Auch durchsuchbare PDF-Dateien lassen sich mit dieser Version direkt erzeugen.[19]

Es existiert eine Reihe Software, die Tesseract als Backend einbindet. Tesseract kann als Zeichenerkennungsmodul in OCRopus verwendet werden, das zusätzlich noch Analyse der Dokumentgliederung und statistische Sprachmodelle bietet.[20] Allerdings benutzt OCRopus ab Version 0.4 standardmäßig ein eigenes Zeichenerkennungsmodul basierend auf neuronalen Netzen[21]. In früheren Versionen wurde Tesseract als Standardmodul in OCRopus verwendet. Neben weiteren möglichen Backends kann es in der Desktop-OCR-Lösung OCRFeeder zur Zeichenerkennung genutzt werden. Mittels hocr2pdf dient es zum Beispiel in dem Linux-basierten Dokumentenmanagement-System Archivista der Erzeugung einer Text-Schicht zu rastergraphischen Abbildern eingescannter Papierdokumente, um diese maschinell durchsuchbar zu machen.

Verfügbarkeit

Bearbeiten

Tesseract wird als freie Software auch im Quelltext unter den Bedingungen von Version 2.0 der Apache-Lizenz (Apache Software License, ASL) verbreitet. In praktisch allen gängigen Linux-Distributionen kann es direkt aus den Standard-Paketquellen installiert werden.[6][22][23][24][25] Installationsprogramme für Windows gibt es von mehreren Anbietern.[26]

Tesseract dient u. a. bei folgenden Programmen als Basis der Texterkennung:

  • Apache Tika verwendet Tesseract, um Text in Bilddateien zu finden.[27]
  • bitfarm-Archiv benutzt im gleichnamigen Open-Source DMS Tesseract zusammen mit MySQL für eine schnelle Volltextsuche mit Positionsmarkierung in eingescannten Dokumenten.[28]
  • capella-scan ist eine kommerzielle Software, die Scans von Partituren verarbeitet und dabei Texte mit Hilfe von Tesseract erkennt.[29]
  • iText pdfOCR erkennt Text in gescannten PDF-Dateien.[30]
  • PDF24 Creator ist ein Windows-Programm zum Erzeugen von PDF-Dateien.[31]
  • VueScan ist eine Software zum Scannen und zur Rohdaten-Bildbearbeitung, die Tesseract zur Texterkennung (OCR) verwendet.[32]

Siehe auch

Bearbeiten
Bearbeiten
Commons: Tesseract (software) – Sammlung von Bildern, Videos und Audiodateien
  • Kurzanleitung, ubuntu Deutschland e. V.
  • Ray Smith: Tesseract OCR Engine. (PDF) Vortrag über die Geschichte von Tesseract, OSCON 2007. Google Inc., 2007, archiviert vom Original (nicht mehr online verfügbar) am 19. August 2016; (englisch).

Einzelnachweise

Bearbeiten
  1. Release 5.5.0 · tesseract-ocr/tesseract. (englisch, abgerufen am 11. November 2024).
  2. a b c d e f g In: Free Software Directory.
  3. The tesseract-ocr Open Source Project on Open Hub: Languages Page. In: Open Hub. (abgerufen am 14. Juli 2018).
  4. www.isri.unlv.edu.
  5. tesseract-ocr/tessdata_best: Best (most accurate) trained LSTM models. GitHub, 15. September 2017, abgerufen am 25. September 2017 (englisch).
  6. a b Erik Bärwaldt: Buchstabensalat. Texterkennung mit Tesseract. In: LinuxUser. Nr. 5. Linux New Media AG, 8. April 2011.
  7. Ray Smith: An Overview of the Tesseract OCR Engine. In: Ninth International Conference on Document Analysis and Recognition. ICDAR 2007. Band 2. IEEE, September 2007, S. 629–633 (englisch, github.com [PDF]).
  8. Tesseract moved to github.com. Google Groups, 14. Juni 2015, abgerufen am 20. März 2018 (englisch).
  9. Tesseractindic. GitHub, 27. November 2009, abgerufen am 19. April 2016 (englisch).
  10. Tesseract OCR. Google Open Source, archiviert vom Original am 9. Juli 2021; abgerufen am 12. Januar 2017 (englisch).
  11. Contributors to tesseract-ocr/tesseract. GitHub, abgerufen am 3. Januar 2023 (englisch).
  12. DFG-Praxisregeln „Digitalisierung“. DFG, abgerufen am 3. Januar 2023.
  13. Optimierter Einsatz von OCR-Verfahren – Tesseract als Komponente im OCR-D-Workflow. DFG, abgerufen am 3. Januar 2023.
  14. Merlijn Wajer: OCR at the Internet Archive with Tesseract and hOCR. Internet Archive, abgerufen am 15. August 2021 (englisch).
  15. Merlijn Wajer: Internet Archive OCR Stack in 2021. Internet Archive, abgerufen am 23. August 2021 (englisch).
  16. Running Tesseract. GitHub, abgerufen am 12. November 2018 (englisch).
  17. Selected papers on image processing and image analysis. 7. Juli 2007, abgerufen am 19. April 2016 (englisch).
  18. Adnan Vatandas: Tesseract 3 und hOCR. Oktober 2010, abgerufen am 28. Oktober 2010.
  19. Tesseract Wiki. Abgerufen am 7. November 2015 (englisch).
  20. ocropus - Google Code. Archiviert vom Original am 14. Mai 2008; abgerufen am 19. April 2016 (englisch).
  21. OCRopus doesn’t even link with Tesseract by default. 17. August 2009, abgerufen am 19. April 2016 (englisch).
  22. Debian - Informationen über Paket tesseract-ocr in sid. Abgerufen am 19. April 2016.
  23. Debian-Paketsuche. Abgerufen am 19. April 2016.
  24. Package tesseract. Archiviert vom Original am 25. Januar 2016; abgerufen am 19. April 2016 (englisch).  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/apps.fedoraproject.org
  25. openSUSE-Paketsuche. Abgerufen am 19. April 2016.
  26. Downloads. In: Tesseract documentation. GitHub, abgerufen am 2. Februar 2021 (englisch).
  27. TikaOCR. Apache Tika, 26. März 2019, abgerufen am 2. Dezember 2019 (englisch).
  28. OCR-Leistung-im-Vergleich-Tesseract-Omnipage.pdf. Abgerufen am 25. Juli 2023.
  29. Neuerungen von capella-scan. capella-Software AG, abgerufen am 24. November 2021.
  30. pdfOCR. iText Group, abgerufen am 10. November 2021.
  31. PDF Creator Changelog. geek software GmbH, abgerufen am 18. Februar 2021.
  32. VueScan Release Notes. Abgerufen am 24. Juli 2024 (englisch).