Project Icon

keras-ocr

基于Keras的开源文本检测和OCR解决方案

keras-ocr是一个开源的文本检测和OCR工具包,集成了CRAFT检测模型和CRNN识别模型。该项目提供高级API用于训练和部署OCR流程,支持Python 3.6+和TensorFlow 2.0.0+环境。keras-ocr自带预训练模型,在COCO-Text验证集上表现接近主流云服务。它为开发者提供了一个灵活、高效且易于使用的OCR开发平台。

keras-ocr 文档状态

这是对Keras CRNN实现和发布的CRAFT文本检测模型的略微完善和打包版本。它提供了一个高级API,用于训练文本检测和OCR流程。

请查看文档以获取更多示例,包括如何训练自定义模型。

入门

安装

keras-ocr支持Python >= 3.6和TensorFlow >= 2.0.0。

# 从master分支安装
pip install git+https://github.com/faustomorales/keras-ocr.git#egg=keras-ocr

# 从PyPi安装
pip install keras-ocr

使用

该软件包附带了一个易于使用的CRAFT文本检测模型实现,来自此仓库,以及CRNN识别模型,来自此仓库

import matplotlib.pyplot as plt

import keras_ocr

# keras-ocr将自动下载检测器和识别器的预训练权重
pipeline = keras_ocr.pipeline.Pipeline()

# 获取三个示例图像
images = [
    keras_ocr.tools.read(url) for url in [
        'https://upload.wikimedia.org/wikipedia/commons/b/bd/Army_Reserves_Recruitment_Banner_MOD_45156284.jpg',
        'https://upload.wikimedia.org/wikipedia/commons/e/e8/FseeG2QeLXo.jpg',
        'https://upload.wikimedia.org/wikipedia/commons/b/b4/EUBanana-500x112.jpg'
    ]
]

# prediction_groups中的每个预测列表都是(单词, 边界框)元组的列表
prediction_groups = pipeline.recognize(images)

# 绘制预测结果
fig, axs = plt.subplots(nrows=len(images), figsize=(20, 20))
for ax, image, predictions in zip(axs, images, prediction_groups):
    keras_ocr.tools.drawAnnotations(image=image, predictions=predictions, ax=ax)

标注图像示例

比较keras-ocr与其他OCR方法

您可能想知道此软件包中的模型与现有的云OCR API相比如何。我们提供了一些指标,以及用于计算这些指标的notebook,使用COCO-Text验证集中的前1,000张图像。我们将其限制在1,000张,因为在撰写本文时,Google Cloud的免费层每月提供1,000次调用。如往常一样,有一些注意事项:

  • 这些数字不提供任何保证 -- 请注意并独立计算您自己的指标以验证它们。截至目前,它们应被视为非常粗略的初稿。如果您发现任何错误,请提出问题。特别是,云API有各种可用于提高性能的选项,响应可以以不同方式解析。我在配置或解析方面可能犯了一些错误。再次强调,如果您发现任何错误,请提出问题!

  • 我们忽略了标点符号和字母大小写,因为keras-ocr中开箱即用的识别器(由这个独立仓库提供)不支持这两者。请注意,AWS Rekognition和Google Cloud Vision都支持标点符号以及大小写字母。

  • 我们忽略了非英语文本。

  • 我们忽略了无法辨认的文本。 | 模型 | 延迟 | 精确度 | 召回率 | | ------------------------------------------------------------------------------------------------------------------------------- | ------ | ------ | ------ | | AWS | 719毫秒 | 0.45 | 0.48 | | GCP | 388毫秒 | 0.53 | 0.58 | | keras-ocr (缩放比例=2) | 417毫秒 | 0.53 | 0.54 | | keras-ocr (缩放比例=3) | 699毫秒 | 0.5 | 0.59 |

  • 精确度和召回率的计算基于交并比大于等于50%且与真实值的文本相似度大于等于50%。

  • keras-ocr的延迟值是在Google Colab上使用Tesla P4 GPU计算得出的。scale指的是提供给keras_ocr.pipelines.Pipeline()的参数,用于确定在推理前应用于图像的上采样比例。

  • 云服务提供商的延迟是通过顺序请求测量的,因此通过同时发送多个API请求,可以显著提高速度。

  • 每个条目都提供了一个链接,指向包含每次处理的注释的JSON文件。你可以使用这些文件和笔记本来计算指标,而无需自己进行API调用(不过我们鼓励你独立复现结果)!

为什么不与Tesseract比较? 在我尝试的每种配置中,Tesseract在这个测试中表现都很差。Tesseract在书籍扫描上表现最佳,而不是在这个数据集中的偶然场景文本上。

高级配置

默认情况下,如果GPU可用,Tensorflow会尝试占用几乎所有可用的显存,这在你同时运行多个Tensorflow和Pytorch模型时会造成问题。设置任何值的MEMORY_GROWTH环境变量将强制Tensorflow仅动态分配所需的GPU内存。

你还可以通过设置MEMORY_ALLOCATED环境变量为任何浮点数来指定每个Tensorflow进程的限制,这个值是VRAM与总量的浮点比率。

要应用这些更改,请在导入keras_ocr的文件顶部调用keras_ocr.config.configure()

贡献

要参与项目开发,请先执行以下操作。这些说明可能还不适用于Windows,但如果有Windows用户有修复建议,我们将非常感激(我目前没有Windows机器来测试)。

# 安装本地依赖项,用于
# 代码补全等
make init

# 构建Docker容器以运行
# 测试等
make build
  • 你可以使用make lab运行JupyterLab服务器进行实验。
  • 在提交代码前运行检查,可以使用make format-check type-check lint-check test
  • 要查看文档,请使用make docs

要实现新功能,请先提交一个issue来讨论你的改动建议。

要报告问题,请提交一个issue,并附上样例代码、预期结果、实际结果和完整的错误追踪。

故障排除

  • 这个包安装了opencv-python-headless,但我更喜欢其他opencv版本。 这是由于aleju/imgaug#473引起的。你可以在安装keras-ocr后卸载不需要的OpenCV版本。我们对此造成的不便表示歉意。
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号