vaaale-paddleocr


Namevaaale-paddleocr JSON
Version 2.6.1.3.post2 PyPI version JSON
download
home_pagehttps://github.com/alevaaga/unstructured.PaddleOCR
SummaryAwesome OCR toolkits based on PaddlePaddle (8.6M ultra-lightweight pre-trained model, support training and deployment among server, mobile, embeded and IoT devices
upload_time2024-06-12 17:51:22
maintainerNone
docs_urlNone
authorNone
requires_pythonNone
licenseApache License 2.0
keywords ocr textdetection textrecognition paddleocr crnn east star-net rosetta ocrlite db chineseocr chinesetextdetection chinesetextrecognition
VCS
bugtrack_url
requirements shapely scikit-image imgaug pyclipper lmdb tqdm numpy visualdl rapidfuzz opencv-python opencv-contrib-python cython lxml premailer openpyxl attrdict Polygon3 lanms-neo pdf2image
Travis-CI No Travis.
coveralls test coverage No coveralls.
            English | [简体中文](README_ch.md) | [हिन्दी](./doc/doc_i18n/README_हिन्द.md) | [日本語](./doc/doc_i18n/README_日本語.md) | [한국인](./doc/doc_i18n/README_한국어.md) | [Pу́сский язы́к](./doc/doc_i18n/README_Ру́сский_язы́к.md)

<p align="center">
 <img src="./doc/PaddleOCR_log.png" align="middle" width = "600"/>
<p align="center">
<p align="left">
    <a href="./LICENSE"><img src="https://img.shields.io/badge/license-Apache%202-dfd.svg"></a>
    <a href="https://github.com/PaddlePaddle/PaddleOCR/releases"><img src="https://img.shields.io/github/v/release/PaddlePaddle/PaddleOCR?color=ffa"></a>
    <a href=""><img src="https://img.shields.io/badge/python-3.7+-aff.svg"></a>
    <a href=""><img src="https://img.shields.io/badge/os-linux%2C%20win%2C%20mac-pink.svg"></a>
    <a href=""><img src="https://img.shields.io/pypi/format/PaddleOCR?color=c77"></a>
    <a href="https://pypi.org/project/PaddleOCR/"><img src="https://img.shields.io/pypi/dm/PaddleOCR?color=9cf"></a>
    <a href="https://github.com/PaddlePaddle/PaddleOCR/stargazers"><img src="https://img.shields.io/github/stars/PaddlePaddle/PaddleOCR?color=ccf"></a>
</p>

# Note from Maintainer:

This is a fork of the fork of PaddleOCR which makes it compatible with paddle 2.6.1 which enables you to use PaddleOCR with unstructured with a 4x performance increase over using Tesseract.

This is a fork of the PaddleOCR repository, created with the purpose of complying with an Apache license. The original repo contains at least one dependency that is not Apache compliant so this fork was created to remove any non-compliant dependencies.

The original documentation at the time of the fork is found below.

## Introduction

PaddleOCR aims to create multilingual, awesome, leading, and practical OCR tools that help users train better models and apply them into practice.

<div align="center">
    <img src="./doc/imgs_results/PP-OCRv3/en/en_4.png" width="800">
</div>

<div align="center">
    <img src="./doc/imgs_results/ch_ppocr_mobile_v2.0/00006737.jpg" width="800">
</div>

## 📣 Recent updates
- 🔨**2022.11 Add implementation of [4 cutting-edge algorithms](doc/doc_en/algorithm_overview_en.md)**:Text Detection [DRRG](doc/doc_en/algorithm_det_drrg_en.md),  Text Recognition [RFL](./doc/doc_en/algorithm_rec_rfl_en.md), Image Super-Resolution [Text Telescope](doc/doc_en/algorithm_sr_telescope_en.md),Handwritten Mathematical Expression Recognition [CAN](doc/doc_en/algorithm_rec_can_en.md)
- **2022.10 Release [optimized JS version PP-OCRv3 model](./deploy/paddlejs/README.md)** with 4.3M model size, 8x faster inference time, and a ready-to-use web demo

- 💥 **Live Playback: Introduction to PP-StructureV2 optimization strategy**. Scan [the QR code below](#Community) using WeChat, follow the PaddlePaddle official account and fill out the questionnaire to join the WeChat group, get the live link and 20G OCR learning materials (including PDF2Word application, 10 models in vertical scenarios, etc.)


- **🔥2022.8.24 Release PaddleOCR [release/2.6](https://github.com/PaddlePaddle/PaddleOCR/tree/release/2.6)**
  - Release [PP-StructureV2](./ppstructure/),with functions and performance fully upgraded, adapted to Chinese scenes, and new support for [Layout Recovery](./ppstructure/recovery) and **one line command to convert PDF to Word**;
  - [Layout Analysis](./ppstructure/layout) optimization: model storage reduced by 95%, while speed increased by 11 times, and the average CPU time-cost is only 41ms;
  - [Table Recognition](./ppstructure/table) optimization: 3 optimization strategies are designed, and the model accuracy is improved by 6% under comparable time consumption;
  - [Key Information Extraction](./ppstructure/kie) optimization:a visual-independent model structure is designed, the accuracy of semantic entity recognition is increased by 2.8%, and the accuracy of relation extraction is increased by 9.1%.
- **🔥2022.8 Release [OCR scene application collection](./applications/README_en.md)**
    - Release **9 vertical models** such as digital tube, LCD screen, license plate, handwriting recognition model, high-precision SVTR model, etc, covering the main OCR vertical applications in general, manufacturing, finance, and transportation industries.
- **2022.8 Add implementation of [8 cutting-edge algorithms](doc/doc_en/algorithm_overview_en.md)**
  - Text Detection: [FCENet](doc/doc_en/algorithm_det_fcenet_en.md), [DB++](doc/doc_en/algorithm_det_db_en.md)
  - Text Recognition: [ViTSTR](doc/doc_en/algorithm_rec_vitstr_en.md), [ABINet](doc/doc_en/algorithm_rec_abinet_en.md), [VisionLAN](doc/doc_en/algorithm_rec_visionlan_en.md), [SPIN](doc/doc_en/algorithm_rec_spin_en.md), [RobustScanner](doc/doc_en/algorithm_rec_robustscanner_en.md)
  - Table Recognition: [TableMaster](doc/doc_en/algorithm_table_master_en.md)
- **2022.5.9 Release PaddleOCR [release/2.5](https://github.com/PaddlePaddle/PaddleOCR/tree/release/2.5)**
    - Release [PP-OCRv3](./doc/doc_en/ppocr_introduction_en.md#pp-ocrv3): With comparable speed, the effect of Chinese scene is further improved by 5% compared with PP-OCRv2, the effect of English scene is improved by 11%, and the average recognition accuracy of 80 language multilingual models is improved by more than 5%.
    - Release [PPOCRLabelv2](./PPOCRLabel): Add the annotation function for table recognition task, key information extraction task and irregular text image.
    - Release interactive e-book [*"Dive into OCR"*](./doc/doc_en/ocr_book_en.md), covers the cutting-edge theory and code practice of OCR full stack technology.
- [more](./doc/doc_en/update_en.md)


## 🌟 Features

PaddleOCR support a variety of cutting-edge algorithms related to OCR, and developed industrial featured models/solution [PP-OCR](./doc/doc_en/ppocr_introduction_en.md) and [PP-Structure](./ppstructure/README.md) on this basis, and get through the whole process of data production, model training, compression, inference and deployment.

<div align="center">
    <img src="https://user-images.githubusercontent.com/25809855/186171245-40abc4d7-904f-4949-ade1-250f86ed3a90.png">
</div>

> It is recommended to start with the “quick experience” in the document tutorial


## ⚡ Quick Experience

- Web online experience for the ultra-lightweight OCR: [Online Experience](https://www.paddlepaddle.org.cn/hub/scene/ocr)
- Mobile DEMO experience (based on EasyEdge and Paddle-Lite, supports iOS and Android systems): [Sign in to the website to obtain the QR code for  installing the App](https://ai.baidu.com/easyedge/app/openSource?from=paddlelite)
- One line of code quick use: [Quick Start](./doc/doc_en/quickstart_en.md)


<a name="book"></a>
## 📚 E-book: *Dive Into OCR*
- [Dive Into OCR ](./doc/doc_en/ocr_book_en.md)

<a name="Community"></a>

## 👫 Community

- For international developers, we regard [PaddleOCR Discussions](https://github.com/PaddlePaddle/PaddleOCR/discussions) as our international community platform. All ideas and questions can be discussed here in English.

- For Chinese develops, Scan the QR code below with your Wechat, you can join the official technical discussion group. For richer community content, please refer to [中文README](README_ch.md), looking forward to your participation.

<div align="center">
<img src="https://raw.githubusercontent.com/PaddlePaddle/PaddleOCR/dygraph/doc/joinus.PNG"  width = "150" height = "150" />
</div>

<a name="Supported-Chinese-model-list"></a>

## 🛠️ PP-OCR Series Model List(Update on September 8th)

| Model introduction                                           | Model name                   | Recommended scene | Detection model                                              | Direction classifier                                         | Recognition model                                            |
| ------------------------------------------------------------ | ---------------------------- | ----------------- | ------------------------------------------------------------ | ------------------------------------------------------------ | ------------------------------------------------------------ |
| Chinese and English ultra-lightweight PP-OCRv3 model(16.2M)     | ch_PP-OCRv3_xx          | Mobile & Server | [inference model](https://paddleocr.bj.bcebos.com/PP-OCRv3/chinese/ch_PP-OCRv3_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv3/chinese/ch_PP-OCRv3_det_distill_train.tar) | [inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar) | [inference model](https://paddleocr.bj.bcebos.com/PP-OCRv3/chinese/ch_PP-OCRv3_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv3/chinese/ch_PP-OCRv3_rec_train.tar) |
| English ultra-lightweight PP-OCRv3 model(13.4M)     | en_PP-OCRv3_xx          | Mobile & Server | [inference model](https://paddleocr.bj.bcebos.com/PP-OCRv3/english/en_PP-OCRv3_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv3/english/en_PP-OCRv3_det_distill_train.tar) | [inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar) | [inference model](https://paddleocr.bj.bcebos.com/PP-OCRv3/english/en_PP-OCRv3_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv3/english/en_PP-OCRv3_rec_train.tar) |
| Chinese and English ultra-lightweight PP-OCRv2 model(11.6M) |  ch_PP-OCRv2_xx |Mobile & Server|[inference model](https://paddleocr.bj.bcebos.com/PP-OCRv2/chinese/ch_PP-OCRv2_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv2/chinese/ch_PP-OCRv2_det_distill_train.tar)| [inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar) |[inference model](https://paddleocr.bj.bcebos.com/PP-OCRv2/chinese/ch_PP-OCRv2_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv2/chinese/ch_PP-OCRv2_rec_train.tar)|
| Chinese and English ultra-lightweight PP-OCR model (9.4M)       | ch_ppocr_mobile_v2.0_xx      | Mobile & server   |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_det_train.tar)|[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar) |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_train.tar)      |
| Chinese and English general PP-OCR model (143.4M)               | ch_ppocr_server_v2.0_xx      | Server            |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_det_train.tar)    |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar)    |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_rec_train.tar)  |


- For more model downloads (including multiple languages), please refer to [PP-OCR series model downloads](./doc/doc_en/models_list_en.md).
- For a new language request, please refer to [Guideline for new language_requests](#language_requests).
- For structural document analysis models, please refer to [PP-Structure models](./ppstructure/docs/models_list_en.md).

## 📖 Tutorials
- [Environment Preparation](./doc/doc_en/environment_en.md)
- [PP-OCR 🔥](./doc/doc_en/ppocr_introduction_en.md)
    - [Quick Start](./doc/doc_en/quickstart_en.md)
    - [Model Zoo](./doc/doc_en/models_en.md)
    - [Model training](./doc/doc_en/training_en.md)
        - [Text Detection](./doc/doc_en/detection_en.md)
        - [Text Recognition](./doc/doc_en/recognition_en.md)
        - [Text Direction Classification](./doc/doc_en/angle_class_en.md)
    - Model Compression
        - [Model Quantization](./deploy/slim/quantization/README_en.md)
        - [Model Pruning](./deploy/slim/prune/README_en.md)
        - [Knowledge Distillation](./doc/doc_en/knowledge_distillation_en.md)
    - [Inference and Deployment](./deploy/README.md)
        - [Python Inference](./doc/doc_en/inference_ppocr_en.md)
        - [C++ Inference](./deploy/cpp_infer/readme.md)
        - [Serving](./deploy/pdserving/README.md)
        - [Mobile](./deploy/lite/readme.md)
        - [Paddle2ONNX](./deploy/paddle2onnx/readme.md)
        - [PaddleCloud](./deploy/paddlecloud/README.md)
        - [Benchmark](./doc/doc_en/benchmark_en.md)  
- [PP-Structure 🔥](./ppstructure/README.md)
    - [Quick Start](./ppstructure/docs/quickstart_en.md)
    - [Model Zoo](./ppstructure/docs/models_list_en.md)
    - [Model training](./doc/doc_en/training_en.md)  
        - [Layout Analysis](./ppstructure/layout/README.md)
        - [Table Recognition](./ppstructure/table/README.md)
        - [Key Information Extraction](./ppstructure/kie/README.md)
    - [Inference and Deployment](./deploy/README.md)
        - [Python Inference](./ppstructure/docs/inference_en.md)
        - [C++ Inference](./deploy/cpp_infer/readme.md)
        - [Serving](./deploy/hubserving/readme_en.md)
- [Academic Algorithms](./doc/doc_en/algorithm_overview_en.md)
    - [Text detection](./doc/doc_en/algorithm_overview_en.md)
    - [Text recognition](./doc/doc_en/algorithm_overview_en.md)
    - [End-to-end OCR](./doc/doc_en/algorithm_overview_en.md)
    - [Table Recognition](./doc/doc_en/algorithm_overview_en.md)
    - [Key Information Extraction](./doc/doc_en/algorithm_overview_en.md)  
    - [Add New Algorithms to PaddleOCR](./doc/doc_en/add_new_algorithm_en.md)
- Data Annotation and Synthesis
    - [Semi-automatic Annotation Tool: PPOCRLabel](./PPOCRLabel/README.md)
    - [Data Synthesis Tool: Style-Text](./StyleText/README.md)
    - [Other Data Annotation Tools](./doc/doc_en/data_annotation_en.md)
    - [Other Data Synthesis Tools](./doc/doc_en/data_synthesis_en.md)
- Datasets
    - [General OCR Datasets(Chinese/English)](doc/doc_en/dataset/datasets_en.md)
    - [HandWritten_OCR_Datasets(Chinese)](doc/doc_en/dataset/handwritten_datasets_en.md)
    - [Various OCR Datasets(multilingual)](doc/doc_en/dataset/vertical_and_multilingual_datasets_en.md)
    - [Layout Analysis](doc/doc_en/dataset/layout_datasets_en.md)
    - [Table Recognition](doc/doc_en/dataset/table_datasets_en.md)
    - [Key Information Extraction](doc/doc_en/dataset/kie_datasets_en.md)
- [Code Structure](./doc/doc_en/tree_en.md)
- [Visualization](#Visualization)
- [Community](#Community)
- [New language requests](#language_requests)
- [FAQ](./doc/doc_en/FAQ_en.md)
- [References](./doc/doc_en/reference_en.md)
- [License](#LICENSE)


<a name="Visualization"></a>
## 👀 Visualization [more](./doc/doc_en/visualization_en.md)

<details open>
<summary>PP-OCRv3 Chinese model</summary>
<div align="center">
    <img src="doc/imgs_results/PP-OCRv3/ch/PP-OCRv3-pic001.jpg" width="800">
    <img src="doc/imgs_results/PP-OCRv3/ch/PP-OCRv3-pic002.jpg" width="800">
    <img src="doc/imgs_results/PP-OCRv3/ch/PP-OCRv3-pic003.jpg" width="800">
</div>
</details>

<details open>
<summary>PP-OCRv3 English model</summary>
<div align="center">
    <img src="doc/imgs_results/PP-OCRv3/en/en_1.png" width="800">
    <img src="doc/imgs_results/PP-OCRv3/en/en_2.png" width="800">
</div>
</details>

<details open>
<summary>PP-OCRv3 Multilingual model</summary>
<div align="center">
    <img src="doc/imgs_results/PP-OCRv3/multi_lang/japan_2.jpg" width="800">
    <img src="doc/imgs_results/PP-OCRv3/multi_lang/korean_1.jpg" width="800">
</div>
</details>

<details open>
<summary>PP-StructureV2</summary>

- layout analysis + table recognition  
<div align="center">
    <img src="./ppstructure/docs/table/ppstructure.GIF" width="800">
</div>

- SER (Semantic entity recognition)
<div align="center">
    <img src="https://user-images.githubusercontent.com/14270174/197464552-69de557f-edff-4c7f-acbf-069df1ba097f.png" width="600">
</div>

<div align="center">
    <img src="https://user-images.githubusercontent.com/14270174/185310636-6ce02f7c-790d-479f-b163-ea97a5a04808.jpg" width="600">
</div>

<div align="center">
    <img src="https://user-images.githubusercontent.com/14270174/185539517-ccf2372a-f026-4a7c-ad28-c741c770f60a.png" width="600">
</div>

- RE (Relation Extraction)
<div align="center">
    <img src="https://user-images.githubusercontent.com/25809855/186094813-3a8e16cc-42e5-4982-b9f4-0134dfb5688d.png" width="600">
</div>  

<div align="center">
    <img src="https://user-images.githubusercontent.com/14270174/185393805-c67ff571-cf7e-4217-a4b0-8b396c4f22bb.jpg" width="600">
</div>

<div align="center">
    <img src="https://user-images.githubusercontent.com/14270174/185540080-0431e006-9235-4b6d-b63d-0b3c6e1de48f.jpg" width="600">
</div>

</details>

<a name="language_requests"></a>
## 🇺🇳 Guideline for New Language Requests

If you want to request a new language support, a PR with 1 following files are needed:

1. In folder [ppocr/utils/dict](./ppocr/utils/dict),
it is necessary to submit the dict text to this path and name it with `{language}_dict.txt` that contains a list of all characters. Please see the format example from other files in that folder.

If your language has unique elements, please tell me in advance within any way, such as useful links, wikipedia and so on.

More details, please refer to [Multilingual OCR Development Plan](https://github.com/PaddlePaddle/PaddleOCR/issues/1048).


<a name="LICENSE"></a>
## 📄 License
This project is released under <a href="https://github.com/PaddlePaddle/PaddleOCR/blob/master/LICENSE">Apache 2.0 license</a>

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/alevaaga/unstructured.PaddleOCR",
    "name": "vaaale-paddleocr",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "ocr textdetection textrecognition paddleocr crnn east star-net rosetta ocrlite db chineseocr chinesetextdetection chinesetextrecognition",
    "author": null,
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/5e/ca/41c697aea32b0150f20d5ff0ce826ccebf57765b9b379c4bfade34e6db09/vaaale_paddleocr-2.6.1.3.post2.tar.gz",
    "platform": null,
    "description": "English | [\u7b80\u4f53\u4e2d\u6587](README_ch.md) | [\u0939\u093f\u0928\u094d\u0926\u0940](./doc/doc_i18n/README_\u0939\u093f\u0928\u094d\u0926.md) | [\u65e5\u672c\u8a9e](./doc/doc_i18n/README_\u65e5\u672c\u8a9e.md) | [\ud55c\uad6d\uc778](./doc/doc_i18n/README_\ud55c\uad6d\uc5b4.md) | [P\u0443\u0301\u0441\u0441\u043a\u0438\u0439 \u044f\u0437\u044b\u0301\u043a](./doc/doc_i18n/README_\u0420\u0443\u0301\u0441\u0441\u043a\u0438\u0439_\u044f\u0437\u044b\u0301\u043a.md)\n\n<p align=\"center\">\n <img src=\"./doc/PaddleOCR_log.png\" align=\"middle\" width = \"600\"/>\n<p align=\"center\">\n<p align=\"left\">\n    <a href=\"./LICENSE\"><img src=\"https://img.shields.io/badge/license-Apache%202-dfd.svg\"></a>\n    <a href=\"https://github.com/PaddlePaddle/PaddleOCR/releases\"><img src=\"https://img.shields.io/github/v/release/PaddlePaddle/PaddleOCR?color=ffa\"></a>\n    <a href=\"\"><img src=\"https://img.shields.io/badge/python-3.7+-aff.svg\"></a>\n    <a href=\"\"><img src=\"https://img.shields.io/badge/os-linux%2C%20win%2C%20mac-pink.svg\"></a>\n    <a href=\"\"><img src=\"https://img.shields.io/pypi/format/PaddleOCR?color=c77\"></a>\n    <a href=\"https://pypi.org/project/PaddleOCR/\"><img src=\"https://img.shields.io/pypi/dm/PaddleOCR?color=9cf\"></a>\n    <a href=\"https://github.com/PaddlePaddle/PaddleOCR/stargazers\"><img src=\"https://img.shields.io/github/stars/PaddlePaddle/PaddleOCR?color=ccf\"></a>\n</p>\n\n# Note from Maintainer:\n\nThis is a fork of the fork of PaddleOCR which makes it compatible with paddle 2.6.1 which enables you to use PaddleOCR with unstructured with a 4x performance increase over using Tesseract.\n\nThis is a fork of the PaddleOCR repository, created with the purpose of complying with an Apache license. The original repo contains at least one dependency that is not Apache compliant so this fork was created to remove any non-compliant dependencies.\n\nThe original documentation at the time of the fork is found below.\n\n## Introduction\n\nPaddleOCR aims to create multilingual, awesome, leading, and practical OCR tools that help users train better models and apply them into practice.\n\n<div align=\"center\">\n    <img src=\"./doc/imgs_results/PP-OCRv3/en/en_4.png\" width=\"800\">\n</div>\n\n<div align=\"center\">\n    <img src=\"./doc/imgs_results/ch_ppocr_mobile_v2.0/00006737.jpg\" width=\"800\">\n</div>\n\n## \ud83d\udce3 Recent updates\n- \ud83d\udd28**2022.11 Add implementation of [4 cutting-edge algorithms](doc/doc_en/algorithm_overview_en.md)**\uff1aText Detection [DRRG](doc/doc_en/algorithm_det_drrg_en.md),  Text Recognition [RFL](./doc/doc_en/algorithm_rec_rfl_en.md), Image Super-Resolution [Text Telescope](doc/doc_en/algorithm_sr_telescope_en.md)\uff0cHandwritten Mathematical Expression Recognition [CAN](doc/doc_en/algorithm_rec_can_en.md)\n- **2022.10 Release [optimized JS version PP-OCRv3 model](./deploy/paddlejs/README.md)** with 4.3M model size, 8x faster inference time, and a ready-to-use web demo\n\n- \ud83d\udca5 **Live Playback: Introduction to PP-StructureV2 optimization strategy**. Scan [the QR code below](#Community) using WeChat, follow the PaddlePaddle official account and fill out the questionnaire to join the WeChat group, get the live link and 20G OCR learning materials (including PDF2Word application, 10 models in vertical scenarios, etc.)\n\n\n- **\ud83d\udd252022.8.24 Release PaddleOCR [release/2.6](https://github.com/PaddlePaddle/PaddleOCR/tree/release/2.6)**\n  - Release [PP-StructureV2](./ppstructure/)\uff0cwith functions and performance fully upgraded, adapted to Chinese scenes, and new support for [Layout Recovery](./ppstructure/recovery) and **one line command to convert PDF to Word**;\n  - [Layout Analysis](./ppstructure/layout) optimization: model storage reduced by 95%, while speed increased by 11 times, and the average CPU time-cost is only 41ms;\n  - [Table Recognition](./ppstructure/table) optimization: 3 optimization strategies are designed, and the model accuracy is improved by 6% under comparable time consumption;\n  - [Key Information Extraction](./ppstructure/kie) optimization\uff1aa visual-independent model structure is designed, the accuracy of semantic entity recognition is increased by 2.8%, and the accuracy of relation extraction is increased by 9.1%.\n- **\ud83d\udd252022.8 Release [OCR scene application collection](./applications/README_en.md)**\n    - Release **9 vertical models** such as digital tube, LCD screen, license plate, handwriting recognition model, high-precision SVTR model, etc, covering the main OCR vertical applications in general, manufacturing, finance, and transportation industries.\n- **2022.8 Add implementation of [8 cutting-edge algorithms](doc/doc_en/algorithm_overview_en.md)**\n  - Text Detection: [FCENet](doc/doc_en/algorithm_det_fcenet_en.md), [DB++](doc/doc_en/algorithm_det_db_en.md)\n  - Text Recognition: [ViTSTR](doc/doc_en/algorithm_rec_vitstr_en.md), [ABINet](doc/doc_en/algorithm_rec_abinet_en.md), [VisionLAN](doc/doc_en/algorithm_rec_visionlan_en.md), [SPIN](doc/doc_en/algorithm_rec_spin_en.md), [RobustScanner](doc/doc_en/algorithm_rec_robustscanner_en.md)\n  - Table Recognition: [TableMaster](doc/doc_en/algorithm_table_master_en.md)\n- **2022.5.9 Release PaddleOCR [release/2.5](https://github.com/PaddlePaddle/PaddleOCR/tree/release/2.5)**\n    - Release [PP-OCRv3](./doc/doc_en/ppocr_introduction_en.md#pp-ocrv3): With comparable speed, the effect of Chinese scene is further improved by 5% compared with PP-OCRv2, the effect of English scene is improved by 11%, and the average recognition accuracy of 80 language multilingual models is improved by more than 5%.\n    - Release [PPOCRLabelv2](./PPOCRLabel): Add the annotation function for table recognition task, key information extraction task and irregular text image.\n    - Release interactive e-book [*\"Dive into OCR\"*](./doc/doc_en/ocr_book_en.md), covers the cutting-edge theory and code practice of OCR full stack technology.\n- [more](./doc/doc_en/update_en.md)\n\n\n## \ud83c\udf1f Features\n\nPaddleOCR support a variety of cutting-edge algorithms related to OCR, and developed industrial featured models/solution [PP-OCR](./doc/doc_en/ppocr_introduction_en.md) and [PP-Structure](./ppstructure/README.md) on this basis, and get through the whole process of data production, model training, compression, inference and deployment.\n\n<div align=\"center\">\n    <img src=\"https://user-images.githubusercontent.com/25809855/186171245-40abc4d7-904f-4949-ade1-250f86ed3a90.png\">\n</div>\n\n> It is recommended to start with the \u201cquick experience\u201d in the document tutorial\n\n\n## \u26a1 Quick Experience\n\n- Web online experience for the ultra-lightweight OCR: [Online Experience](https://www.paddlepaddle.org.cn/hub/scene/ocr)\n- Mobile DEMO experience (based on EasyEdge and Paddle-Lite, supports iOS and Android systems): [Sign in to the website to obtain the QR code for  installing the App](https://ai.baidu.com/easyedge/app/openSource?from=paddlelite)\n- One line of code quick use: [Quick Start](./doc/doc_en/quickstart_en.md)\n\n\n<a name=\"book\"></a>\n## \ud83d\udcda E-book: *Dive Into OCR*\n- [Dive Into OCR ](./doc/doc_en/ocr_book_en.md)\n\n<a name=\"Community\"></a>\n\n## \ud83d\udc6b Community\n\n- For international developers, we regard [PaddleOCR Discussions](https://github.com/PaddlePaddle/PaddleOCR/discussions) as our international community platform. All ideas and questions can be discussed here in English.\n\n- For Chinese develops, Scan the QR code below with your Wechat, you can join the official technical discussion group. For richer community content, please refer to [\u4e2d\u6587README](README_ch.md), looking forward to your participation.\n\n<div align=\"center\">\n<img src=\"https://raw.githubusercontent.com/PaddlePaddle/PaddleOCR/dygraph/doc/joinus.PNG\"  width = \"150\" height = \"150\" />\n</div>\n\n<a name=\"Supported-Chinese-model-list\"></a>\n\n## \ud83d\udee0\ufe0f PP-OCR Series Model List\uff08Update on September 8th\uff09\n\n| Model introduction                                           | Model name                   | Recommended scene | Detection model                                              | Direction classifier                                         | Recognition model                                            |\n| ------------------------------------------------------------ | ---------------------------- | ----------------- | ------------------------------------------------------------ | ------------------------------------------------------------ | ------------------------------------------------------------ |\n| Chinese and English ultra-lightweight PP-OCRv3 model\uff0816.2M\uff09     | ch_PP-OCRv3_xx          | Mobile & Server | [inference model](https://paddleocr.bj.bcebos.com/PP-OCRv3/chinese/ch_PP-OCRv3_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv3/chinese/ch_PP-OCRv3_det_distill_train.tar) | [inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar) | [inference model](https://paddleocr.bj.bcebos.com/PP-OCRv3/chinese/ch_PP-OCRv3_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv3/chinese/ch_PP-OCRv3_rec_train.tar) |\n| English ultra-lightweight PP-OCRv3 model\uff0813.4M\uff09     | en_PP-OCRv3_xx          | Mobile & Server | [inference model](https://paddleocr.bj.bcebos.com/PP-OCRv3/english/en_PP-OCRv3_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv3/english/en_PP-OCRv3_det_distill_train.tar) | [inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar) | [inference model](https://paddleocr.bj.bcebos.com/PP-OCRv3/english/en_PP-OCRv3_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv3/english/en_PP-OCRv3_rec_train.tar) |\n| Chinese and English ultra-lightweight PP-OCRv2 model\uff0811.6M\uff09 |  ch_PP-OCRv2_xx |Mobile & Server|[inference model](https://paddleocr.bj.bcebos.com/PP-OCRv2/chinese/ch_PP-OCRv2_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv2/chinese/ch_PP-OCRv2_det_distill_train.tar)| [inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar) |[inference model](https://paddleocr.bj.bcebos.com/PP-OCRv2/chinese/ch_PP-OCRv2_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/PP-OCRv2/chinese/ch_PP-OCRv2_rec_train.tar)|\n| Chinese and English ultra-lightweight PP-OCR model (9.4M)       | ch_ppocr_mobile_v2.0_xx      | Mobile & server   |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_det_train.tar)|[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar) |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_train.tar)      |\n| Chinese and English general PP-OCR model (143.4M)               | ch_ppocr_server_v2.0_xx      | Server            |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_det_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_det_train.tar)    |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_train.tar)    |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_rec_infer.tar) / [trained model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_rec_train.tar)  |\n\n\n- For more model downloads (including multiple languages), please refer to [PP-OCR series model downloads](./doc/doc_en/models_list_en.md).\n- For a new language request, please refer to [Guideline for new language_requests](#language_requests).\n- For structural document analysis models, please refer to [PP-Structure models](./ppstructure/docs/models_list_en.md).\n\n## \ud83d\udcd6 Tutorials\n- [Environment Preparation](./doc/doc_en/environment_en.md)\n- [PP-OCR \ud83d\udd25](./doc/doc_en/ppocr_introduction_en.md)\n    - [Quick Start](./doc/doc_en/quickstart_en.md)\n    - [Model Zoo](./doc/doc_en/models_en.md)\n    - [Model training](./doc/doc_en/training_en.md)\n        - [Text Detection](./doc/doc_en/detection_en.md)\n        - [Text Recognition](./doc/doc_en/recognition_en.md)\n        - [Text Direction Classification](./doc/doc_en/angle_class_en.md)\n    - Model Compression\n        - [Model Quantization](./deploy/slim/quantization/README_en.md)\n        - [Model Pruning](./deploy/slim/prune/README_en.md)\n        - [Knowledge Distillation](./doc/doc_en/knowledge_distillation_en.md)\n    - [Inference and Deployment](./deploy/README.md)\n        - [Python Inference](./doc/doc_en/inference_ppocr_en.md)\n        - [C++ Inference](./deploy/cpp_infer/readme.md)\n        - [Serving](./deploy/pdserving/README.md)\n        - [Mobile](./deploy/lite/readme.md)\n        - [Paddle2ONNX](./deploy/paddle2onnx/readme.md)\n        - [PaddleCloud](./deploy/paddlecloud/README.md)\n        - [Benchmark](./doc/doc_en/benchmark_en.md)  \n- [PP-Structure \ud83d\udd25](./ppstructure/README.md)\n    - [Quick Start](./ppstructure/docs/quickstart_en.md)\n    - [Model Zoo](./ppstructure/docs/models_list_en.md)\n    - [Model training](./doc/doc_en/training_en.md)  \n        - [Layout Analysis](./ppstructure/layout/README.md)\n        - [Table Recognition](./ppstructure/table/README.md)\n        - [Key Information Extraction](./ppstructure/kie/README.md)\n    - [Inference and Deployment](./deploy/README.md)\n        - [Python Inference](./ppstructure/docs/inference_en.md)\n        - [C++ Inference](./deploy/cpp_infer/readme.md)\n        - [Serving](./deploy/hubserving/readme_en.md)\n- [Academic Algorithms](./doc/doc_en/algorithm_overview_en.md)\n    - [Text detection](./doc/doc_en/algorithm_overview_en.md)\n    - [Text recognition](./doc/doc_en/algorithm_overview_en.md)\n    - [End-to-end OCR](./doc/doc_en/algorithm_overview_en.md)\n    - [Table Recognition](./doc/doc_en/algorithm_overview_en.md)\n    - [Key Information Extraction](./doc/doc_en/algorithm_overview_en.md)  \n    - [Add New Algorithms to PaddleOCR](./doc/doc_en/add_new_algorithm_en.md)\n- Data Annotation and Synthesis\n    - [Semi-automatic Annotation Tool: PPOCRLabel](./PPOCRLabel/README.md)\n    - [Data Synthesis Tool: Style-Text](./StyleText/README.md)\n    - [Other Data Annotation Tools](./doc/doc_en/data_annotation_en.md)\n    - [Other Data Synthesis Tools](./doc/doc_en/data_synthesis_en.md)\n- Datasets\n    - [General OCR Datasets(Chinese/English)](doc/doc_en/dataset/datasets_en.md)\n    - [HandWritten_OCR_Datasets(Chinese)](doc/doc_en/dataset/handwritten_datasets_en.md)\n    - [Various OCR Datasets(multilingual)](doc/doc_en/dataset/vertical_and_multilingual_datasets_en.md)\n    - [Layout Analysis](doc/doc_en/dataset/layout_datasets_en.md)\n    - [Table Recognition](doc/doc_en/dataset/table_datasets_en.md)\n    - [Key Information Extraction](doc/doc_en/dataset/kie_datasets_en.md)\n- [Code Structure](./doc/doc_en/tree_en.md)\n- [Visualization](#Visualization)\n- [Community](#Community)\n- [New language requests](#language_requests)\n- [FAQ](./doc/doc_en/FAQ_en.md)\n- [References](./doc/doc_en/reference_en.md)\n- [License](#LICENSE)\n\n\n<a name=\"Visualization\"></a>\n## \ud83d\udc40 Visualization [more](./doc/doc_en/visualization_en.md)\n\n<details open>\n<summary>PP-OCRv3 Chinese model</summary>\n<div align=\"center\">\n    <img src=\"doc/imgs_results/PP-OCRv3/ch/PP-OCRv3-pic001.jpg\" width=\"800\">\n    <img src=\"doc/imgs_results/PP-OCRv3/ch/PP-OCRv3-pic002.jpg\" width=\"800\">\n    <img src=\"doc/imgs_results/PP-OCRv3/ch/PP-OCRv3-pic003.jpg\" width=\"800\">\n</div>\n</details>\n\n<details open>\n<summary>PP-OCRv3 English model</summary>\n<div align=\"center\">\n    <img src=\"doc/imgs_results/PP-OCRv3/en/en_1.png\" width=\"800\">\n    <img src=\"doc/imgs_results/PP-OCRv3/en/en_2.png\" width=\"800\">\n</div>\n</details>\n\n<details open>\n<summary>PP-OCRv3 Multilingual model</summary>\n<div align=\"center\">\n    <img src=\"doc/imgs_results/PP-OCRv3/multi_lang/japan_2.jpg\" width=\"800\">\n    <img src=\"doc/imgs_results/PP-OCRv3/multi_lang/korean_1.jpg\" width=\"800\">\n</div>\n</details>\n\n<details open>\n<summary>PP-StructureV2</summary>\n\n- layout analysis + table recognition  \n<div align=\"center\">\n    <img src=\"./ppstructure/docs/table/ppstructure.GIF\" width=\"800\">\n</div>\n\n- SER (Semantic entity recognition)\n<div align=\"center\">\n    <img src=\"https://user-images.githubusercontent.com/14270174/197464552-69de557f-edff-4c7f-acbf-069df1ba097f.png\" width=\"600\">\n</div>\n\n<div align=\"center\">\n    <img src=\"https://user-images.githubusercontent.com/14270174/185310636-6ce02f7c-790d-479f-b163-ea97a5a04808.jpg\" width=\"600\">\n</div>\n\n<div align=\"center\">\n    <img src=\"https://user-images.githubusercontent.com/14270174/185539517-ccf2372a-f026-4a7c-ad28-c741c770f60a.png\" width=\"600\">\n</div>\n\n- RE (Relation Extraction)\n<div align=\"center\">\n    <img src=\"https://user-images.githubusercontent.com/25809855/186094813-3a8e16cc-42e5-4982-b9f4-0134dfb5688d.png\" width=\"600\">\n</div>  \n\n<div align=\"center\">\n    <img src=\"https://user-images.githubusercontent.com/14270174/185393805-c67ff571-cf7e-4217-a4b0-8b396c4f22bb.jpg\" width=\"600\">\n</div>\n\n<div align=\"center\">\n    <img src=\"https://user-images.githubusercontent.com/14270174/185540080-0431e006-9235-4b6d-b63d-0b3c6e1de48f.jpg\" width=\"600\">\n</div>\n\n</details>\n\n<a name=\"language_requests\"></a>\n## \ud83c\uddfa\ud83c\uddf3 Guideline for New Language Requests\n\nIf you want to request a new language support, a PR with 1 following files are needed\uff1a\n\n1. In folder [ppocr/utils/dict](./ppocr/utils/dict),\nit is necessary to submit the dict text to this path and name it with `{language}_dict.txt` that contains a list of all characters. Please see the format example from other files in that folder.\n\nIf your language has unique elements, please tell me in advance within any way, such as useful links, wikipedia and so on.\n\nMore details, please refer to [Multilingual OCR Development Plan](https://github.com/PaddlePaddle/PaddleOCR/issues/1048).\n\n\n<a name=\"LICENSE\"></a>\n## \ud83d\udcc4 License\nThis project is released under <a href=\"https://github.com/PaddlePaddle/PaddleOCR/blob/master/LICENSE\">Apache 2.0 license</a>\n",
    "bugtrack_url": null,
    "license": "Apache License 2.0",
    "summary": "Awesome OCR toolkits based on PaddlePaddle \uff088.6M ultra-lightweight pre-trained model, support training and deployment among server, mobile, embeded and IoT devices",
    "version": "2.6.1.3.post2",
    "project_urls": {
        "Download": "https://github.com/alevaaga/unstructured.PaddleOCR.git",
        "Homepage": "https://github.com/alevaaga/unstructured.PaddleOCR"
    },
    "split_keywords": [
        "ocr",
        "textdetection",
        "textrecognition",
        "paddleocr",
        "crnn",
        "east",
        "star-net",
        "rosetta",
        "ocrlite",
        "db",
        "chineseocr",
        "chinesetextdetection",
        "chinesetextrecognition"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "cff214ff8913716f94670a07343ef387f34356c0e0d87becd6835b2da6c90c7f",
                "md5": "a481efcc40c2636c29cc18c7363edccb",
                "sha256": "1e8618b134b3a3a9be07ee58e46034669c71af2f015b2abb5acb1196873779fe"
            },
            "downloads": -1,
            "filename": "vaaale_paddleocr-2.6.1.3.post2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "a481efcc40c2636c29cc18c7363edccb",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 918983,
            "upload_time": "2024-06-12T17:51:19",
            "upload_time_iso_8601": "2024-06-12T17:51:19.710664Z",
            "url": "https://files.pythonhosted.org/packages/cf/f2/14ff8913716f94670a07343ef387f34356c0e0d87becd6835b2da6c90c7f/vaaale_paddleocr-2.6.1.3.post2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "5eca41c697aea32b0150f20d5ff0ce826ccebf57765b9b379c4bfade34e6db09",
                "md5": "b84b3f6d3bca074df933d7460e997705",
                "sha256": "2846fe35c22399171c11a57dc695045d91aa04675967d1eb02f7a89f37c6a0b9"
            },
            "downloads": -1,
            "filename": "vaaale_paddleocr-2.6.1.3.post2.tar.gz",
            "has_sig": false,
            "md5_digest": "b84b3f6d3bca074df933d7460e997705",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 719371,
            "upload_time": "2024-06-12T17:51:22",
            "upload_time_iso_8601": "2024-06-12T17:51:22.392178Z",
            "url": "https://files.pythonhosted.org/packages/5e/ca/41c697aea32b0150f20d5ff0ce826ccebf57765b9b379c4bfade34e6db09/vaaale_paddleocr-2.6.1.3.post2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-06-12 17:51:22",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "alevaaga",
    "github_project": "unstructured.PaddleOCR",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [
        {
            "name": "shapely",
            "specs": []
        },
        {
            "name": "scikit-image",
            "specs": []
        },
        {
            "name": "imgaug",
            "specs": []
        },
        {
            "name": "pyclipper",
            "specs": []
        },
        {
            "name": "lmdb",
            "specs": []
        },
        {
            "name": "tqdm",
            "specs": []
        },
        {
            "name": "numpy",
            "specs": []
        },
        {
            "name": "visualdl",
            "specs": []
        },
        {
            "name": "rapidfuzz",
            "specs": []
        },
        {
            "name": "opencv-python",
            "specs": [
                [
                    "==",
                    "4.8.0.76"
                ]
            ]
        },
        {
            "name": "opencv-contrib-python",
            "specs": [
                [
                    "==",
                    "4.8.0.76"
                ]
            ]
        },
        {
            "name": "cython",
            "specs": []
        },
        {
            "name": "lxml",
            "specs": []
        },
        {
            "name": "premailer",
            "specs": []
        },
        {
            "name": "openpyxl",
            "specs": []
        },
        {
            "name": "attrdict",
            "specs": []
        },
        {
            "name": "Polygon3",
            "specs": []
        },
        {
            "name": "lanms-neo",
            "specs": [
                [
                    "==",
                    "1.0.2"
                ]
            ]
        },
        {
            "name": "pdf2image",
            "specs": []
        }
    ],
    "lcname": "vaaale-paddleocr"
}
        
Elapsed time: 3.30103s