2020-07-17 11:51:19 +08:00
2021-05-13 14:12:19 +08:00
# Quick Start of Chinese OCR Model
2020-07-17 11:51:19 +08:00
2021-05-13 14:12:19 +08:00
## 1. Environment Preparation
2020-07-17 11:51:19 +08:00
Please refer to [quick installation ](./installation_en.md ) to configure the PaddleOCR operating environment.
2021-05-13 14:12:19 +08:00
* Note: Support the use of PaddleOCR through whl package installation, please refer [PaddleOCR Package ](./whl_en.md ).
2020-07-17 11:51:19 +08:00
2021-05-13 14:12:19 +08:00
## 2. Inference Models
2020-07-17 11:51:19 +08:00
2021-05-24 17:55:43 +08:00
The detection and recognition models on the mobile and server sides are as follows. For more models (including multiple languages), please refer to [PP-OCR v2.0 series model list ](./models_list_en.md )
2020-07-17 11:51:19 +08:00
2020-12-11 18:48:23 +08:00
| Model introduction | Model name | Recommended scene | Detection model | Direction Classifier | Recognition model |
2020-10-13 17:49:16 +08:00
| ------------ | --------------- | ----------------|---- | ---------- | -------- |
2020-12-12 10:54:40 +08:00
| Ultra-lightweight Chinese OCR model (8.1M) | ch_ppocr_mobile_v2.0_xx |Mobile-side/Server-side|[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_det_infer.tar) / [pretrained 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) / [pretrained 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) / [pretrained model ](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_pre.tar ) |
| Universal Chinese OCR model (143M) | ch_ppocr_server_v2.0_xx |Server-side |[inference model](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_det_infer.tar) / [pretrained 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) / [pretrained 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) / [pretrained model ](https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_rec_pre.tar ) |
2020-12-11 18:48:23 +08:00
2020-10-13 17:49:16 +08:00
* If `wget` is not installed in the windows environment, you can copy the link to the browser to download when downloading the model, then uncompress it and place it in the corresponding directory.
2020-07-17 11:51:19 +08:00
Copy the download address of the `inference model` for detection and recognition in the table above, and uncompress them.
```
mkdir inference & & cd inference
# Download the detection model and unzip
wget {url/of/detection/inference_model} & & tar xf {name/of/detection/inference_model/package}
# Download the recognition model and unzip
wget {url/of/recognition/inference_model} & & tar xf {name/of/recognition/inference_model/package}
2020-10-13 17:49:16 +08:00
# Download the direction classifier model and unzip
wget {url/of/classification/inference_model} & & tar xf {name/of/classification/inference_model/package}
2020-07-17 11:51:19 +08:00
cd ..
```
Take the ultra-lightweight model as an example:
```
mkdir inference & & cd inference
# Download the detection model of the ultra-lightweight Chinese OCR model and uncompress it
2020-12-11 18:48:23 +08:00
wget https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_det_infer.tar & & tar xf ch_ppocr_mobile_v2.0_det_infer.tar
2020-07-17 11:51:19 +08:00
# Download the recognition model of the ultra-lightweight Chinese OCR model and uncompress it
2020-12-11 18:48:23 +08:00
wget https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_infer.tar & & tar xf ch_ppocr_mobile_v2.0_rec_infer.tar
# Download the angle classifier model of the ultra-lightweight Chinese OCR model and uncompress it
wget https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_cls_infer.tar & & tar xf ch_ppocr_mobile_v2.0_cls_infer.tar
2020-07-17 11:51:19 +08:00
cd ..
```
After decompression, the file structure should be as follows:
```
2020-12-11 18:48:23 +08:00
├── ch_ppocr_mobile_v2.0_cls_infer
│ ├── inference.pdiparams
│ ├── inference.pdiparams.info
│ └── inference.pdmodel
├── ch_ppocr_mobile_v2.0_det_infer
│ ├── inference.pdiparams
│ ├── inference.pdiparams.info
│ └── inference.pdmodel
├── ch_ppocr_mobile_v2.0_rec_infer
├── inference.pdiparams
├── inference.pdiparams.info
└── inference.pdmodel
2020-07-17 11:51:19 +08:00
```
2021-05-13 14:12:19 +08:00
## 3. Single Image or Image Set Prediction
2020-07-17 11:51:19 +08:00
2021-05-13 14:12:19 +08:00
* The following code implements text detection、angle class and recognition process. When performing prediction, you need to specify the path of a single image or image set through the parameter `image_dir` , the parameter `det_model_dir` specifies the path to the detection inference model, the parameter `rec_model_dir` specifies the path to the recognition inference model, the parameter `use_angle_cls` specifies whether to use the direction classifier, the parameter `cls_model_dir` specifies the path to the direction classifier model, the parameter `use_space_char` specifies whether to predict the space char. The visual results are saved to the `./inference_results` folder by default.
2020-07-17 11:51:19 +08:00
```bash
# Predict a single image specified by image_dir
2020-12-11 18:48:23 +08:00
python3 tools/infer/predict_system.py --image_dir="./doc/imgs/11.jpg" --det_model_dir="./inference/ch_ppocr_mobile_v2.0_det_infer/" --rec_model_dir="./inference/ch_ppocr_mobile_v2.0_rec_infer/" --cls_model_dir="./inference/ch_ppocr_mobile_v2.0_cls_infer/" --use_angle_cls=True --use_space_char=True
2020-07-17 11:51:19 +08:00
# Predict imageset specified by image_dir
2020-12-11 18:48:23 +08:00
python3 tools/infer/predict_system.py --image_dir="./doc/imgs/" --det_model_dir="./inference/ch_ppocr_mobile_v2.0_det_infer/" --rec_model_dir="./inference/ch_ppocr_mobile_v2.0_rec_infer/" --cls_model_dir="./inference/ch_ppocr_mobile_v2.0_cls_infer/" --use_angle_cls=True --use_space_char=True
2020-07-17 11:51:19 +08:00
# If you want to use the CPU for prediction, you need to set the use_gpu parameter to False
2020-12-11 18:48:23 +08:00
python3 tools/infer/predict_system.py --image_dir="./doc/imgs/11.jpg" --det_model_dir="./inference/ch_ppocr_mobile_v2.0_det_infer/" --rec_model_dir="./inference/ch_ppocr_mobile_v2.0_rec_infer/" --cls_model_dir="./inference/ch_ppocr_mobile_v2.0_cls_infer/" --use_angle_cls=True --use_space_char=True --use_gpu=False
2020-07-17 11:51:19 +08:00
```
- Universal Chinese OCR model
Please follow the above steps to download the corresponding models and update the relevant parameters, The example is as follows.
```
# Predict a single image specified by image_dir
2020-12-11 18:48:23 +08:00
python3 tools/infer/predict_system.py --image_dir="./doc/imgs/11.jpg" --det_model_dir="./inference/ch_ppocr_server_v2.0_det_infer/" --rec_model_dir="./inference/ch_ppocr_server_v2.0_rec_infer/" --cls_model_dir="./inference/ch_ppocr_mobile_v2.0_cls_infer/" --use_angle_cls=True --use_space_char=True
2020-07-17 11:51:19 +08:00
```
2020-10-13 17:49:16 +08:00
* Note
- If you want to use the recognition model which does not support space char recognition, please update the source code to the latest version and add parameters `--use_space_char=False` .
- If you do not want to use direction classifier, please update the source code to the latest version and add parameters `--use_angle_cls=False` .
2020-07-17 11:51:19 +08:00
2021-05-13 14:12:19 +08:00
For more text detection and recognition tandem inferring, please refer to the document tutorial
2020-07-17 11:51:19 +08:00
: [Inference with Python inference engine ](./inference_en.md )。
In addition, the tutorial also provides other deployment methods for the Chinese OCR model:
- [Server-side C++ inference ](../../deploy/cpp_infer/readme_en.md )
2021-01-04 12:49:17 +08:00
- [Service deployment ](../../deploy/hubserving )
- [End-to-end deployment ](https://github.com/PaddlePaddle/PaddleOCR/tree/develop/deploy/lite )