Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
ebc7ffc3
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看板
未验证
提交
ebc7ffc3
编写于
2月 28, 2020
作者:
K
Kaipeng Deng
提交者:
GitHub
2月 28, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix detection_map. test=develop (#22705)
上级
ee8b22fb
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
34 addition
and
3 deletion
+34
-3
paddle/fluid/operators/detection_map_op.h
paddle/fluid/operators/detection_map_op.h
+5
-2
python/paddle/fluid/tests/unittests/test_detection_map_op.py
python/paddle/fluid/tests/unittests/test_detection_map_op.py
+29
-1
未找到文件。
paddle/fluid/operators/detection_map_op.h
浏览文件 @
ebc7ffc3
...
...
@@ -420,8 +420,11 @@ class DetectionMAPOpKernel : public framework::OpKernel<T> {
for
(
auto
it
=
label_pos_count
.
begin
();
it
!=
label_pos_count
.
end
();
++
it
)
{
int
label
=
it
->
first
;
int
label_num_pos
=
it
->
second
;
if
(
label_num_pos
==
background_label
||
true_pos
.
find
(
label
)
==
true_pos
.
end
())
{
if
(
label_num_pos
==
background_label
)
{
continue
;
}
if
(
true_pos
.
find
(
label
)
==
true_pos
.
end
())
{
count
++
;
continue
;
}
auto
label_true_pos
=
true_pos
.
find
(
label
)
->
second
;
...
...
python/paddle/fluid/tests/unittests/test_detection_map_op.py
浏览文件 @
ebc7ffc3
...
...
@@ -181,7 +181,10 @@ class TestDetectionMAPOp(OpTest):
false_pos
[
label
].
append
([
score
,
fp
])
for
(
label
,
label_pos_num
)
in
six
.
iteritems
(
label_count
):
if
label_pos_num
==
0
or
label
not
in
true_pos
:
continue
if
label_pos_num
==
0
:
continue
if
label
not
in
true_pos
:
count
+=
1
continue
label_true_pos
=
true_pos
[
label
]
label_false_pos
=
false_pos
[
label
]
...
...
@@ -281,5 +284,30 @@ class TestDetectionMAPOpMultiBatch(TestDetectionMAPOp):
self
.
false_pos
=
[[
0.7
,
0.
],
[
0.3
,
1.
],
[
0.2
,
0.
],
[
0.8
,
1.
],
[
0.1
,
0.
]]
class
TestDetectionMAPOp11PointWithClassNoTP
(
TestDetectionMAPOp
):
def
init_test_case
(
self
):
self
.
overlap_threshold
=
0.3
self
.
evaluate_difficult
=
True
self
.
ap_type
=
"11point"
self
.
label_lod
=
[[
2
]]
# label difficult xmin ymin xmax ymax
self
.
label
=
[[
2
,
0
,
0.3
,
0.3
,
0.6
,
0.5
],
[
1
,
0
,
0.7
,
0.1
,
0.9
,
0.3
]]
# label score xmin ymin xmax ymax difficult
self
.
detect_lod
=
[[
1
]]
self
.
detect
=
[[
1
,
0.2
,
0.8
,
0.1
,
1.0
,
0.3
]]
# label score true_pos false_pos
self
.
tf_pos_lod
=
[[
3
,
4
]]
self
.
tf_pos
=
[[
1
,
0.2
,
1
,
0
]]
self
.
class_pos_count
=
[]
self
.
true_pos_lod
=
[[]]
self
.
true_pos
=
[[]]
self
.
false_pos_lod
=
[[]]
self
.
false_pos
=
[[]]
if
__name__
==
'__main__'
:
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录