faustomorales / keras-ocr
- вторник, 7 января 2020 г. в 00:18:23
Python
A packaged and flexible version of the CRAFT text detector and Keras CRNN recognition model.
This is a slightly polished and packaged version of the Keras CRNN implementation and the published CRAFT text detection model. It provides a high level API for training a text detection and OCR pipeline.
Please see the documentation for more examples, including for training a custom model.
keras-ocr supports Python >= 3.6 and TensorFlow >= 2.0.0.
# To install from master
pip install git+https://github.com/faustomorales/keras-ocr.git#egg=keras-ocr
# To install from PyPi
pip install keras-ocrThe package ships with an easy-to-use implementation of the CRAFT text detection model from this repository and the CRNN recognition model from this repository.
import keras_ocr
# keras-ocr will automatically download pretrained
# weights for the detector and recognizer.
pipeline = keras_ocr.pipeline.Pipeline()
# Predictions is a list of (string, box) tuples.
predictions = pipeline.recognize(image='tests/test_image.jpg')You may be wondering how the models in this package compare to existing cloud OCR APIs. We provide some metrics below and the notebook used to compute them using the first 1,000 images in the COCO-Text validation set. We limited it to 1,000 because the Google Cloud free tier is for 1,000 calls a month at the time of this writing. As always, caveats apply:
| model | latency | precision | recall |
|---|---|---|---|
| AWS | 719ms | 0.45 | 0.48 |
| GCP | 388ms | 0.53 | 0.58 |
| keras-ocr (scale=2) | 417ms | 0.53 | 0.54 |
| keras-ocr (scale=3) | 699ms | 0.5 | 0.59 |
keras-ocr latency values were computed using a Tesla P4 GPU on Google Colab. scale refers to the argument provided to keras_ocr.pipelines.Pipeline() which determines the upscaling applied to the image prior to inference.Why not compare to Tesseract? In every configuration I tried, Tesseract did very poorly on this test. Tesseract performs best on scans of books, not on incidental scene text like that in this dataset.
To work on the project, start by doing the following. These instructions probably do not yet work for Windows but if a Windows user has some ideas for how to fix that it would be greatly appreciated (I don't have a Windows machine to test on at the moment).
# Install local dependencies for
# code completion, etc.
make init
# Build the Docker container to run
# tests and such.
make buildlab-server.make precommit.make documentation-server.To implement new features, please first file an issue proposing your change for discussion.
To report problems, please file an issue with sample code, expected results, actual results, and a complete traceback.