Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
c1797c88
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
c1797c88
编写于
12月 22, 2020
作者:
W
wuhuanzhou
提交者:
GitHub
12月 22, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Optimize op benchmark ci log (#29586)
上级
3f83ec61
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
76 addition
and
40 deletion
+76
-40
tools/check_op_benchmark_result.py
tools/check_op_benchmark_result.py
+64
-38
tools/test_op_benchmark.sh
tools/test_op_benchmark.sh
+12
-2
未找到文件。
tools/check_op_benchmark_result.py
浏览文件 @
c1797c88
...
@@ -55,10 +55,47 @@ def load_benchmark_result_from_logs_dir(logs_dir):
...
@@ -55,10 +55,47 @@ def load_benchmark_result_from_logs_dir(logs_dir):
return
dict
(
map
(
result_lambda
,
os
.
listdir
(
logs_dir
)))
return
dict
(
map
(
result_lambda
,
os
.
listdir
(
logs_dir
)))
def
compare_benchmark_result
(
develop_result
,
pr_result
):
def
check_speed_result
(
case_name
,
develop_data
,
pr_data
,
pr_result
):
"""Compare the differences between devlop and pr.
"""Check speed differences between develop and pr.
"""
pr_gpu_time
=
pr_data
.
get
(
"gpu_time"
)
develop_gpu_time
=
develop_data
.
get
(
"gpu_time"
)
gpu_time_diff
=
(
pr_gpu_time
-
develop_gpu_time
)
/
develop_gpu_time
pr_total_time
=
pr_data
.
get
(
"total"
)
develop_total_time
=
develop_data
.
get
(
"total"
)
total_time_diff
=
(
pr_total_time
-
develop_total_time
)
/
develop_total_time
logging
.
info
(
"------ OP: %s ------"
%
case_name
)
logging
.
info
(
"GPU time change: %.5f%% (develop: %.7f -> PR: %.7f)"
%
(
gpu_time_diff
*
100
,
develop_gpu_time
,
pr_gpu_time
))
logging
.
info
(
"Total time change: %.5f%% (develop: %.7f -> PR: %.7f)"
%
(
total_time_diff
*
100
,
develop_total_time
,
pr_total_time
))
logging
.
info
(
"backward: %s"
%
pr_result
.
get
(
"backward"
))
logging
.
info
(
"parameters:"
)
for
line
in
pr_result
.
get
(
"parameters"
).
strip
().
split
(
"
\n
"
):
logging
.
info
(
"
\t
%s"
%
line
)
return
gpu_time_diff
>
0.05
def
check_accuracy_result
(
case_name
,
pr_result
):
"""Check accuracy result.
"""
logging
.
info
(
"------ OP: %s ------"
%
case_name
)
logging
.
info
(
"Accuracy diff: %s"
%
pr_result
.
get
(
"diff"
))
logging
.
info
(
"backward: %s"
%
pr_result
.
get
(
"backward"
))
logging
.
info
(
"parameters:"
)
for
line
in
pr_result
.
get
(
"parameters"
).
strip
().
split
(
"
\n
"
):
logging
.
info
(
"
\t
%s"
%
line
)
return
not
pr_result
.
get
(
"consistent"
)
def
compare_benchmark_result
(
case_name
,
develop_result
,
pr_result
,
check_results
):
"""Compare the differences between develop and pr.
"""
"""
status
=
True
develop_speed
=
develop_result
.
get
(
"speed"
)
develop_speed
=
develop_result
.
get
(
"speed"
)
pr_speed
=
pr_result
.
get
(
"speed"
)
pr_speed
=
pr_result
.
get
(
"speed"
)
...
@@ -66,39 +103,27 @@ def compare_benchmark_result(develop_result, pr_result):
...
@@ -66,39 +103,27 @@ def compare_benchmark_result(develop_result, pr_result):
pr_speed
),
"The types of comparison results need to be consistent."
pr_speed
),
"The types of comparison results need to be consistent."
if
isinstance
(
develop_speed
,
dict
)
and
isinstance
(
pr_speed
,
dict
):
if
isinstance
(
develop_speed
,
dict
)
and
isinstance
(
pr_speed
,
dict
):
pr_gpu_time
=
pr_speed
.
get
(
"gpu_time"
)
if
check_speed_result
(
case_name
,
develop_speed
,
pr_speed
,
pr_result
):
develop_gpu_time
=
develop_speed
.
get
(
"gpu_time"
)
check_results
[
"speed"
].
append
(
case_name
)
gpu_time_diff
=
(
pr_gpu_time
-
develop_gpu_time
)
/
develop_gpu_time
pr_total_time
=
pr_speed
.
get
(
"total"
)
develop_total_time
=
develop_speed
.
get
(
"total"
)
total_time_diff
=
(
pr_total_time
-
develop_total_time
)
/
develop_total_time
if
gpu_time_diff
>
0.05
:
status
=
False
# TODO(Avin0323): Print all info for making relu of alart.
logging
.
info
(
"------ OP: %s ------"
%
pr_result
.
get
(
"name"
))
logging
.
info
(
"GPU time change: %.5f%% (develop: %.7f -> PR: %.7f)"
%
(
gpu_time_diff
*
100
,
develop_gpu_time
,
pr_gpu_time
))
logging
.
info
(
"Total time change: %.5f%% (develop: %.7f -> PR: %.7f)"
%
(
total_time_diff
*
100
,
develop_total_time
,
pr_total_time
))
logging
.
info
(
"backward: %s"
%
pr_result
.
get
(
"backward"
))
logging
.
info
(
"parameters:"
)
for
line
in
pr_result
.
get
(
"parameters"
).
strip
().
split
(
"
\n
"
):
logging
.
info
(
"
\t
%s"
%
line
)
else
:
else
:
if
not
pr_result
.
get
(
"consistent"
):
if
check_accuracy_result
(
case_name
,
pr_result
):
status
=
False
check_results
[
"accuracy"
].
append
(
case_name
)
logging
.
info
(
"------ OP: %s ------"
%
pr_result
.
get
(
"name"
))
logging
.
info
(
"Accaury diff: %s"
%
pr_result
.
get
(
"diff"
))
logging
.
info
(
"backward: %s"
%
pr_result
.
get
(
"backward"
))
logging
.
info
(
"parameters:"
)
for
line
in
pr_result
.
get
(
"parameters"
).
strip
().
split
(
"
\n
"
):
logging
.
info
(
"
\t
%s"
%
line
)
return
status
def
summary_results
(
check_results
):
"""Summary results and return exit code.
"""
for
case_name
in
check_results
[
"speed"
]:
logging
.
error
(
"Check speed result with case
\"
%s
\"
failed."
%
case_name
)
for
case_name
in
check_results
[
"accuracy"
]:
logging
.
error
(
"Check accuracy result with case
\"
%s
\"
failed."
%
case_name
)
if
len
(
check_results
[
"speed"
])
or
len
(
check_results
[
"accuracy"
]):
return
8
else
:
return
0
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
...
@@ -121,7 +146,7 @@ if __name__ == "__main__":
...
@@ -121,7 +146,7 @@ if __name__ == "__main__":
help
=
"Specify the benchmark result directory of PR branch."
)
help
=
"Specify the benchmark result directory of PR branch."
)
args
=
parser
.
parse_args
()
args
=
parser
.
parse_args
()
exit_code
=
0
check_results
=
dict
(
accuracy
=
list
(),
speed
=
list
())
develop_result_dict
=
load_benchmark_result_from_logs_dir
(
develop_result_dict
=
load_benchmark_result_from_logs_dir
(
args
.
develop_logs_dir
)
args
.
develop_logs_dir
)
...
@@ -132,7 +157,8 @@ if __name__ == "__main__":
...
@@ -132,7 +157,8 @@ if __name__ == "__main__":
pr_result
=
parse_log_file
(
os
.
path
.
join
(
args
.
pr_logs_dir
,
log_file
))
pr_result
=
parse_log_file
(
os
.
path
.
join
(
args
.
pr_logs_dir
,
log_file
))
if
develop_result
is
None
or
pr_result
is
None
:
if
develop_result
is
None
or
pr_result
is
None
:
continue
continue
if
not
compare_benchmark_result
(
develop_result
,
pr_result
):
case_name
=
log_file
.
split
(
"-"
)[
0
]
exit_code
=
8
compare_benchmark_result
(
case_name
,
develop_result
,
pr_result
,
check_results
)
exit
(
exit_code
)
exit
(
summary_results
(
check_results
)
)
tools/test_op_benchmark.sh
浏览文件 @
c1797c88
...
@@ -27,6 +27,9 @@ declare -A CHANGE_OP_MAP
...
@@ -27,6 +27,9 @@ declare -A CHANGE_OP_MAP
# ops that benchmark repo has
# ops that benchmark repo has
declare
-A
BENCHMARK_OP_MAP
declare
-A
BENCHMARK_OP_MAP
# searched header files
declare
-A
INCLUDE_SEARCH_MAP
function
LOG
{
function
LOG
{
echo
"[
$0
:
${
BASH_LINENO
[0]
}
]
$*
"
>
&2
echo
"[
$0
:
${
BASH_LINENO
[0]
}
]
$*
"
>
&2
}
}
...
@@ -55,7 +58,9 @@ function load_CHANGE_OP_FILES_by_header_file {
...
@@ -55,7 +58,9 @@ function load_CHANGE_OP_FILES_by_header_file {
CHANGE_OP_FILES[
${#
CHANGE_OP_FILES
[@]
}
]=
"
$change_file
"
CHANGE_OP_FILES[
${#
CHANGE_OP_FILES
[@]
}
]=
"
$change_file
"
elif
[[
"
$change_file
"
=
~
".h"
]]
elif
[[
"
$change_file
"
=
~
".h"
]]
then
then
[
-n
"
${
INCLUDE_SEARCH_MAP
[
$change_file
]
}
"
]
&&
continue
LOG
"[INFO] Found
\"
${
1
}
\"
include by
\"
${
change_file
}
\"
, keep searching."
LOG
"[INFO] Found
\"
${
1
}
\"
include by
\"
${
change_file
}
\"
, keep searching."
INCLUDE_SEARCH_MAP[
$change_file
]=
"searched"
load_CHANGE_OP_FILES_by_header_file
$change_file
load_CHANGE_OP_FILES_by_header_file
$change_file
fi
fi
done
done
...
@@ -79,6 +84,7 @@ function load_CHANGE_OP_FILES {
...
@@ -79,6 +84,7 @@ function load_CHANGE_OP_FILES {
elif
[[
"
$change_file
"
=
~
".h"
]]
elif
[[
"
$change_file
"
=
~
".h"
]]
then
then
LOG
"[INFO] Found
\"
${
change_file
}
\"
changed, keep searching."
LOG
"[INFO] Found
\"
${
change_file
}
\"
changed, keep searching."
INCLUDE_SEARCH_MAP[
${
change_file
}
]=
"searched"
load_CHANGE_OP_FILES_by_header_file
$change_file
load_CHANGE_OP_FILES_by_header_file
$change_file
fi
fi
done
done
...
@@ -218,10 +224,14 @@ function summary_problems {
...
@@ -218,10 +224,14 @@ function summary_problems {
if
[
-z
"
${
BENCHMARK_OP_MAP
[
$op_name
]
}
"
]
if
[
-z
"
${
BENCHMARK_OP_MAP
[
$op_name
]
}
"
]
then
then
exit_code
=
8
exit_code
=
8
LOG
"[
WARNING
] Missing test script of
\"
${
op_name
}
\"
(
${
CHANGE_OP_MAP
[
$op_name
]
}
) in benchmark."
LOG
"[
ERROR
] Missing test script of
\"
${
op_name
}
\"
(
${
CHANGE_OP_MAP
[
$op_name
]
}
) in benchmark."
fi
fi
done
done
[
$exit_code
-ne
0
]
&&
exit
$exit_code
if
[
$exit_code
-ne
0
]
;
then
LOG
"[INFO] See https://github.com/PaddlePaddle/Paddle/wiki/PR-CI-OP-benchmark-Manual for details."
LOG
"[INFO] Or you can apply for one RD (GaoWei8(Recommend), Xreki, luotao1) approval to pass this PR."
exit
$exit_code
fi
}
}
function
main
{
function
main
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录