2020-06-08 12:48:13 +08:00
|
|
|
|
## FAQ
|
|
|
|
|
|
|
|
|
|
1. **预测报错:got an unexpected keyword argument 'gradient_clip'**
|
|
|
|
|
安装的paddle版本不对,目前本项目仅支持paddle1.7,近期会适配到1.8。
|
|
|
|
|
|
|
|
|
|
2. **转换attention识别模型时报错:KeyError: 'predict'**
|
2020-06-11 11:15:34 +08:00
|
|
|
|
问题已解决,请更新到最新代码。
|
2020-06-08 12:48:13 +08:00
|
|
|
|
|
|
|
|
|
3. **关于推理速度**
|
|
|
|
|
图片中的文字较多时,预测时间会增,可以使用--rec_batch_num设置更小预测batch num,默认值为30,可以改为10或其他数值。
|
|
|
|
|
|
|
|
|
|
4. **服务部署与移动端部署**
|
|
|
|
|
预计6月中下旬会先后发布基于Serving的服务部署方案和基于Paddle Lite的移动端部署方案,欢迎持续关注。
|
|
|
|
|
|
|
|
|
|
5. **自研算法发布时间**
|
|
|
|
|
自研算法SAST、SRN、End2End-PSL都将在6-7月陆续发布,敬请期待。
|
2020-06-09 20:03:49 +08:00
|
|
|
|
|
2020-06-08 12:48:13 +08:00
|
|
|
|
6. **如何在Windows或Mac系统上运行**
|
2020-06-09 20:03:49 +08:00
|
|
|
|
PaddleOCR已完成Windows和Mac系统适配,运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。
|
2020-06-08 12:48:13 +08:00
|
|
|
|
|
|
|
|
|
7. **超轻量模型和通用OCR模型的区别**
|
|
|
|
|
目前PaddleOCR开源了2个中文模型,分别是8.6M超轻量中文模型和通用中文OCR模型。两者对比信息如下:
|
|
|
|
|
- 相同点:两者使用相同的**算法**和**训练数据**;
|
2020-06-08 13:51:48 +08:00
|
|
|
|
- 不同点:不同之处在于**骨干网络**和**通道参数**,超轻量模型使用MobileNetV3作为骨干网络,通用模型使用Resnet50_vd作为检测模型backbone,Resnet34_vd作为识别模型backbone,具体参数差异可对比两种模型训练的配置文件.
|
2020-06-09 20:03:49 +08:00
|
|
|
|
|
2020-06-08 12:48:13 +08:00
|
|
|
|
|模型|骨干网络|检测训练配置|识别训练配置|
|
|
|
|
|
|-|-|-|-|
|
|
|
|
|
|8.6M超轻量中文OCR模型|MobileNetV3+MobileNetV3|det_mv3_db.yml|rec_chinese_lite_train.yml|
|
|
|
|
|
|通用中文OCR模型|Resnet50_vd+Resnet34_vd|det_r50_vd_db.yml|rec_chinese_common_train.yml|
|
|
|
|
|
|
|
|
|
|
8. **是否有计划开源仅识别数字或仅识别英文+数字的模型**
|
|
|
|
|
暂不计划开源仅数字、仅数字+英文、或其他小垂类专用模型。PaddleOCR开源了多种检测、识别算法供用户自定义训练,两种中文模型也是基于开源的算法库训练产出,有小垂类需求的小伙伴,可以按照教程准备好数据,选择合适的配置文件,自行训练,相信能有不错的效果。训练有任何问题欢迎提issue或在交流群提问,我们会及时解答。
|
|
|
|
|
|
|
|
|
|
9. **开源模型使用的训练数据是什么,能否开源**
|
|
|
|
|
目前开源的模型,数据集和量级如下:
|
|
|
|
|
- 检测:
|
|
|
|
|
英文数据集,ICDAR2015
|
|
|
|
|
中文数据集,LSVT街景数据集训练数据3w张图片
|
|
|
|
|
- 识别:
|
|
|
|
|
英文数据集,MJSynth和SynthText合成数据,数据量上千万。
|
2020-06-24 18:27:40 +08:00
|
|
|
|
中文数据集,LSVT街景数据集根据真值将图crop出来,并进行位置校准,总共30w张图像。此外基于LSVT的语料,合成数据500w。
|
2020-06-24 18:28:03 +08:00
|
|
|
|
|
2020-06-09 20:03:49 +08:00
|
|
|
|
其中,公开数据集都是开源的,用户可自行搜索下载,也可参考[中文数据集](./datasets.md),合成数据暂不开源,用户可使用开源合成工具自行合成,可参考的合成工具包括[text_renderer](https://github.com/Sanster/text_renderer)、[SynthText](https://github.com/ankush-me/SynthText)、[TextRecognitionDataGenerator](https://github.com/Belval/TextRecognitionDataGenerator)等。
|
2020-06-11 11:15:34 +08:00
|
|
|
|
|
2020-06-24 18:27:02 +08:00
|
|
|
|
10. **使用带TPS的识别模型预测报错**
|
2020-06-24 18:27:40 +08:00
|
|
|
|
报错信息:Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100)
|
2020-06-11 11:15:34 +08:00
|
|
|
|
原因:TPS模块暂时无法支持变长的输入,请设置 --rec_image_shape='3,32,100' --rec_char_type='en' 固定输入shape
|
2020-06-16 12:55:27 +08:00
|
|
|
|
|
2020-06-24 18:27:02 +08:00
|
|
|
|
11. **自定义字典训练的模型,识别结果出现字典里没出现的字**
|
2020-06-16 12:55:27 +08:00
|
|
|
|
预测时没有设置采用的自定义字典路径。设置方法是在预测时,通过增加输入参数rec_char_dict_path来设置。
|
2020-07-12 11:21:25 +08:00
|
|
|
|
|
|
|
|
|
12. **服务器CPU预测时内存一直涨**
|
|
|
|
|
主要有由于开启了MKL数学库和多线程加速导致的问题,该问题我们已经在跟进修复。
|
|
|
|
|
临时解决方案有两种:
|
|
|
|
|
(1)注释掉数学库的使用,但是速度慢一倍,注释方法,https://github.com/PaddlePaddle/PaddleOCR/blob/develop/tools/infer/utility.py 文件中,注释掉94,95行
|
|
|
|
|
![image](https://user-images.githubusercontent.com/10047064/87238071-5c0c3680-c430-11ea-93ef-f21ad80cfbed.png)
|
|
|
|
|
|
|
|
|
|
(2)定期释放和初始化TextSystem这个类,速度略微受影响。
|
|
|
|
|
可以参考如下代码,修改 https://github.com/PaddlePaddle/PaddleOCR/blob/develop/tools/infer/predict_system.py 中main函数代码,
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
def main(args):
|
|
|
|
|
image_file_list = get_image_file_list(args.image_dir)
|
|
|
|
|
text_sys = TextSystem(args)
|
|
|
|
|
is_visualize = True
|
|
|
|
|
count = 0
|
|
|
|
|
for image_file in image_file_list:
|
|
|
|
|
img = cv2.imread(image_file)
|
|
|
|
|
if img is None:
|
|
|
|
|
logger.info("error in loading image:{}".format(image_file))
|
|
|
|
|
continue
|
|
|
|
|
count += 1
|
|
|
|
|
if count % 10 == 0:
|
|
|
|
|
text_sys = TextSystem(args)
|
|
|
|
|
starttime = time.time()
|
|
|
|
|
dt_boxes, rec_res = text_sys(img)
|
|
|
|
|
elapse = time.time() - starttime
|
|
|
|
|
```
|