Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleOCR
提交
a66f856e
P
PaddleOCR
项目概览
PaddlePaddle
/
PaddleOCR
1 年多 前同步成功
通知
1534
Star
32963
Fork
6643
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
108
列表
看板
标记
里程碑
合并请求
7
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleOCR
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
108
Issue
108
列表
看板
标记
里程碑
合并请求
7
合并请求
7
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
a66f856e
编写于
8月 26, 2021
作者:
L
LDOUBLEV
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
opt code
上级
6b8d6cc3
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
57 addition
and
6 deletion
+57
-6
tests/compare_results.py
tests/compare_results.py
+57
-6
未找到文件。
tests/compare_results.py
浏览文件 @
a66f856e
...
...
@@ -3,6 +3,7 @@ import os
import
subprocess
import
json
import
argparse
import
glob
def
init_args
():
...
...
@@ -12,6 +13,7 @@ def init_args():
parser
.
add_argument
(
"--rtol"
,
type
=
float
,
default
=
1e-3
)
parser
.
add_argument
(
"--gt_file"
,
type
=
str
,
default
=
""
)
parser
.
add_argument
(
"--log_file"
,
type
=
str
,
default
=
""
)
parser
.
add_argument
(
"--precision"
,
type
=
str
,
default
=
"fp32"
)
return
parser
...
...
@@ -63,6 +65,34 @@ def load_gt_from_file(gt_file):
return
parser_gt
def
load_gt_from_txts
(
gt_file
):
gt_list
=
glob
.
glob
(
gt_file
)
gt_collection
=
{}
for
gt_f
in
gt_list
:
gt_dict
=
load_gt_from_file
(
gt_f
)
basename
=
os
.
path
.
basename
(
gt_f
)
if
"fp32"
in
basename
:
gt_collection
[
"fp32"
]
=
[
gt_dict
,
gt_f
]
elif
"fp16"
in
basename
:
gt_collection
[
"fp16"
]
=
[
gt_dict
,
gt_f
]
elif
"int8"
in
basename
:
gt_collection
[
"int8"
]
=
[
gt_dict
,
gt_f
]
else
:
continue
return
gt_collection
def
collect_predict_from_logs
(
log_path
,
key_list
):
log_list
=
glob
.
glob
(
log_path
)
pred_collection
=
{}
for
log_f
in
log_list
:
pred_dict
=
parser_results_from_log_by_name
(
log_f
,
key_list
)
key
=
os
.
path
.
basename
(
log_f
)
pred_collection
[
key
]
=
pred_dict
return
pred_collection
def
testing_assert_allclose
(
dict_x
,
dict_y
,
atol
=
1e-7
,
rtol
=
1e-7
):
for
k
in
dict_x
:
np
.
testing
.
assert_allclose
(
...
...
@@ -71,12 +101,33 @@ def testing_assert_allclose(dict_x, dict_y, atol=1e-7, rtol=1e-7):
if
__name__
==
"__main__"
:
# Usage:
# python3.7 tests/compare_results.py --gt_file=./
det_results_gpu_fp32.txt --log_file=./test_log
.log
# python3.7 tests/compare_results.py --gt_file=./
tests/results/*.txt --log_file=./tests/output/infer_*
.log
args
=
parse_args
()
gt_dict
=
load_gt_from_file
(
args
.
gt_file
)
key_list
=
list
(
gt_dict
.
keys
())
pred_dict
=
parser_results_from_log_by_name
(
args
.
log_file
,
key_list
)
testing_assert_allclose
(
gt_dict
,
pred_dict
,
atol
=
args
.
atol
,
rtol
=
args
.
rtol
)
gt_collection
=
load_gt_from_txts
(
args
.
gt_file
)
key_list
=
gt_collection
[
"fp32"
][
0
].
keys
()
pred_collection
=
collect_predict_from_logs
(
args
.
log_file
,
key_list
)
for
filename
in
pred_collection
.
keys
():
if
"fp32"
in
filename
:
gt_dict
,
gt_filename
=
gt_collection
[
"fp32"
]
elif
"fp16"
in
filename
:
gt_dict
,
gt_filename
=
gt_collection
[
"fp16"
]
elif
"int8"
in
filename
:
gt_dict
,
gt_filename
=
gt_collection
[
"int8"
]
else
:
continue
pred_dict
=
pred_collection
[
filename
]
try
:
testing_assert_allclose
(
gt_dict
,
pred_dict
,
atol
=
args
.
atol
,
rtol
=
args
.
rtol
)
print
(
"Assert allclose passed! The results of {} and {} are consistent!"
.
format
(
filename
,
gt_filename
))
except
Exception
as
E
:
print
(
E
)
raise
ValueError
(
"The results of {} and the results of {} are inconsistent!"
.
format
(
filename
,
gt_filename
))
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录