root 079379557a init 1 年之前
..
convert_ppocr_label.py 079379557a init 1 年之前
draw_html.py 079379557a init 1 年之前
eval_end2end.py 079379557a init 1 年之前
readme.md 079379557a init 1 年之前

readme.md

简介

tools/end2end目录下存放了文本检测+文本识别pipeline串联预测的指标评测代码以及可视化工具。本节介绍文本检测+文本识别的端对端指标评估方式。

端对端评测步骤

步骤一:

运行tools/infer/predict_system.py,得到保存的结果:

python3 tools/infer/predict_system.py  --det_model_dir=./ch_PP-OCRv2_det_infer/ --rec_model_dir=./ch_PP-OCRv2_rec_infer/  --image_dir=./datasets/img_dir/ --draw_img_save_dir=./ch_PP-OCRv2_results/ --is_visualize=True

文本检测识别可视化图默认保存在./ch_PP-OCRv2_results/目录下,预测结果默认保存在./ch_PP-OCRv2_results/system_results.txt中,格式如下:

all-sum-510/00224225.jpg        [{"transcription": "超赞", "points": [[8.0, 48.0], [157.0, 44.0], [159.0, 115.0], [10.0, 119.0]], "score": "0.99396634"}, {"transcription": "中", "points": [[202.0, 152.0], [230.0, 152.0], [230.0, 163.0], [202.0, 163.0]], "score": "0.09310734"}, {"transcription": "58.0m", "points": [[196.0, 192.0], [444.0, 192.0], [444.0, 240.0], [196.0, 240.0]], "score": "0.44041982"}, {"transcription": "汽配", "points": [[55.0, 263.0], [95.0, 263.0], [95.0, 281.0], [55.0, 281.0]], "score": "0.9986651"}, {"transcription": "成总店", "points": [[120.0, 262.0], [176.0, 262.0], [176.0, 283.0], [120.0, 283.0]], "score": "0.9929402"}, {"transcription": "K", "points": [[237.0, 286.0], [311.0, 286.0], [311.0, 345.0], [237.0, 345.0]], "score": "0.6074794"}, {"transcription": "88:-8", "points": [[203.0, 405.0], [477.0, 414.0], [475.0, 459.0], [201.0, 450.0]], "score": "0.7106863"}]

步骤二:

将步骤一保存的数据转换为端对端评测需要的数据格式:

修改 tools/end2end/convert_ppocr_label.py中的代码,convert_label函数中设置输入标签路径,Mode,保存标签路径等,对预测数据的GTlabel和预测结果的label格式进行转换。

python3 tools/end2end/convert_ppocr_label.py --mode=gt --label_path=path/to/label_txt --save_folder=save_gt_label

python3 tools/end2end/convert_ppocr_label.py --mode=pred --label_path=path/to/pred_txt --save_folder=save_PPOCRV2_infer

得到如下结果:

├── ./save_gt_label/
├── ./save_PPOCRV2_infer/

步骤三:

执行端对端评测,运行tools/eval_end2end.py计算端对端指标,运行方式如下:

python3 tools/eval_end2end.py "gt_label_dir"  "predict_label_dir"

比如:

python3 tools/eval_end2end.py ./save_gt_label/ ./save_PPOCRV2_infer/

将得到如下结果,fmeasure为主要关注的指标:

hit, dt_count, gt_count 1557 2693 3283
character_acc: 61.77%
avg_edit_dist_field: 3.08
avg_edit_dist_img: 51.82
precision: 57.82%
recall: 47.43%
fmeasure: 52.11%