kie.md 2.2 KB
Newer Older
文幕地方's avatar
文幕地方 已提交
1 2 3 4 5
- [关键信息提取(Key Information Extraction)](#关键信息提取key-information-extraction)
  - [1. 快速使用](#1-快速使用)
  - [2. 执行训练](#2-执行训练)
  - [3. 执行评估](#3-执行评估)
  - [4. 参考文献](#4-参考文献)
L
LDOUBLEV 已提交
6 7 8 9 10 11 12 13 14 15 16 17 18

# 关键信息提取(Key Information Extraction)

本节介绍PaddleOCR中关键信息提取SDMGR方法的快速使用和训练方法。

SDMGR是一个关键信息提取算法,将每个检测到的文本区域分类为预定义的类别,如订单ID、发票号码,金额等。


## 1. 快速使用

训练和测试的数据采用wildreceipt数据集,通过如下指令下载数据集:

```
19
wget https://paddleocr.bj.bcebos.com/ppstructure/dataset/wildreceipt.tar && tar xf wildreceipt.tar
L
LDOUBLEV 已提交
20 21 22 23 24 25 26 27 28 29 30 31 32
```

执行预测:

```
cd PaddleOCR/
wget https://paddleocr.bj.bcebos.com/dygraph_v2.1/kie/kie_vgg16.tar && tar xf kie_vgg16.tar
python3.7 tools/infer_kie.py -c configs/kie/kie_unet_sdmgr.yml -o Global.checkpoints=kie_vgg16/best_accuracy  Global.infer_img=../wildreceipt/1.txt
```

执行预测后的结果保存在`./output/sdmgr_kie/predicts_kie.txt`文件中,可视化结果保存在`/output/sdmgr_kie/kie_results/`目录下。

可视化结果如下图所示:
L
LDOUBLEV 已提交
33 34 35 36

<div align="center">
    <img src="./imgs/0.png" width="800">
</div>
L
LDOUBLEV 已提交
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57

## 2. 执行训练

创建数据集软链到PaddleOCR/train_data目录下:
```
cd PaddleOCR/ && mkdir train_data && cd train_data

ln -s ../../wildreceipt ./
```

训练采用的配置文件是configs/kie/kie_unet_sdmgr.yml,配置文件中默认训练数据路径是`train_data/wildreceipt`,准备好数据后,可以通过如下指令执行训练:
```
python3.7 tools/train.py -c configs/kie/kie_unet_sdmgr.yml -o Global.save_model_dir=./output/kie/
```
## 3. 执行评估

```
python3.7 tools/eval.py -c configs/kie/kie_unet_sdmgr.yml -o Global.checkpoints=./output/kie/best_accuracy
```


文幕地方's avatar
文幕地方 已提交
58
## 4. 参考文献
L
LDOUBLEV 已提交
59 60 61 62 63 64 65 66 67 68 69 70 71

<!-- [ALGORITHM] -->

```bibtex
@misc{sun2021spatial,
      title={Spatial Dual-Modality Graph Reasoning for Key Information Extraction},
      author={Hongbin Sun and Zhanghui Kuang and Xiaoyu Yue and Chenhao Lin and Wayne Zhang},
      year={2021},
      eprint={2103.14470},
      archivePrefix={arXiv},
      primaryClass={cs.CV}
}
```