PaddleOCR/doc/doc_ch/PP-OCRv3_introduction.md

4.5 KiB
Raw Blame History

English | 简体中文

PP-OCR

1. 简介

PP-OCR是PaddleOCR自研的实用的超轻量OCR系统。在实现前沿算法的基础上,考虑精度与速度的平衡,进行模型瘦身深度优化,使其尽可能满足产业落地需求。

PP-OCR

PP-OCR是一个两阶段的OCR系统其中文本检测算法选用DB,文本识别算法选用CRNN,并在检测和识别模块之间添加文本方向分类器,以应对不同方向的文本识别。

PP-OCRv2系统pipeline如下

PP-OCR系统在持续迭代优化目前已发布PP-OCR、PP-OCRv2、PP-OCRv3三个版本

PP-OCR从骨干网络选择和调整、预测头部的设计、数据增强、学习率变换策略、正则化参数选择、预训练模型使用以及模型自动裁剪量化8个方面采用19个有效策略对各个模块的模型进行效果调优和瘦身(如绿框所示)最终得到整体大小为3.5M的超轻量中英文OCR和2.8M的英文数字OCR。更多细节请参考PP-OCR技术方案 https://arxiv.org/abs/2009.09941

PP-OCRv3策略简介

PP-OCRv3文本检测模型优化策略

PP-OCRv3采用PP-OCRv2的CML蒸馏策略在蒸馏的student模型、teacher模型精度提升CML蒸馏策略上分别做了优化。

  • 在蒸馏student模型精度提升方面提出了基于残差结构的通道注意力模块RSEFPNResidual Squeeze-and-Excitation FPN用于提升student模型精度和召回。

RSEFPN的网络结构如下图所示RSEFPN在PP-OCRv2的FPN基础上将FPN中的卷积层更换为了通道注意力结构的RSEConv层。

RSEFPN将PP-OCR检测模型的精度hmean从81.3%提升到84.5%。模型大小从3M变为3.6M。

PP-OCRv2的FPN通道数仅为96和24如果直接用SE模块代替FPN的卷积会导致精度下降RSEConv引入残差结构可以防止训练中包含重要特征的通道被抑制。

  • 在蒸馏的teacher模型精度提升方面提出了LKPAN结构替换PP-OCRv2的FPN结构并且使用ResNet50作为Backbone更大的模型带来更多的精度提升。另外对teacher模型使用DML蒸馏策略进一步提升teacher模型的精度。最终teacher的模型指标相比ppocr_server_v2.0从83.2%提升到了86.0%。

注:PP-OCRv2的FPN结构对DB算法FPN结构做了轻量级设计

LKPAN的网络结构如下图所示

LKPAN(Large Kernel PAN)是一个具有更大感受野的轻量级PAN结构。在LKPAN的path augmentation中使用kernel size为9*9的卷积更大的kernel size意味着更大的感受野更容易检测大字体的文字以及极端长宽比的文字。LKPAN将PP-OCR检测模型的精度hmean从81.3%提升到84.9%。

LKPAN相比RSEFPN有更多的精度提升但是考虑到模型大小和预测速度等因素在student模型中使用RSEFPN。

采用上述策略PP-OCRv3相比PP-OCRv2hmean指标从83.3%提升到85.4%预测速度从平均117ms/image变为124ms/image。

  1. PP-OCRv3检测模型消融实验
序号 策略 模型大小 hmean Intel Gold 6148CPU+mkldnn预测耗时
0 PP-OCR 3M 81.3% 117ms
1 PP-OCRV2 3M 83.3% 117ms
2 0 + RESFPN 3.6M 84.5% 124ms
3 0 + LKPAN 4.6M 84.9% 156ms
4 ppocr_server_v2.0 124M 83.2%
5 teacher + DML + LKPAN 124M 86.0% 396ms
6 0 + 2 + 5 + CML 3.6M 85.4% 124ms

2. 特性

  • 超轻量PP-OCRv2系列检测3.1M+ 方向分类器1.4M+ 识别8.5M= 13.0M
  • 超轻量PP-OCR mobile移动端系列检测3.0M+方向分类器1.4M+ 识别5.0M= 9.4M
  • 通用PP-OCR server系列检测47.1M+方向分类器1.4M+ 识别94.9M= 143.4M
  • 支持中英文数字组合识别、竖排文本识别、长文本识别
  • 支持多语言识别韩语、日语、德语、法语等约80种语言

3. benchmark

关于PP-OCR系列模型之间的性能对比请查看benchmark文档。