Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
6b89154a
O
Opencv
项目概览
Greenplum
/
Opencv
11 个月 前同步成功
通知
7
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
Opencv
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
6b89154a
编写于
5月 26, 2020
作者:
A
Alexander Alekhin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
dnn(test): add YOLOv4 tests
上级
d5e8792f
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
113 addition
and
14 deletion
+113
-14
modules/dnn/perf/perf_net.cpp
modules/dnn/perf/perf_net.cpp
+16
-2
modules/dnn/test/test_darknet_importer.cpp
modules/dnn/test/test_darknet_importer.cpp
+97
-12
未找到文件。
modules/dnn/perf/perf_net.cpp
浏览文件 @
6b89154a
...
...
@@ -197,9 +197,23 @@ PERF_TEST_P_(DNNTestNetwork, YOLOv3)
if
(
backend
==
DNN_BACKEND_HALIDE
)
throw
SkipTestException
(
""
);
Mat
sample
=
imread
(
findDataFile
(
"dnn/dog416.png"
));
cvtColor
(
sample
,
sample
,
COLOR_BGR2RGB
);
Mat
inp
;
sample
.
convertTo
(
inp
,
CV_32FC3
);
processNet
(
"dnn/yolov3.weights"
,
"dnn/yolov3.cfg"
,
""
,
inp
/
255
);
sample
.
convertTo
(
inp
,
CV_32FC3
,
1.0
f
/
255
,
0
);
processNet
(
"dnn/yolov3.weights"
,
"dnn/yolov3.cfg"
,
""
,
inp
);
}
PERF_TEST_P_
(
DNNTestNetwork
,
YOLOv4
)
{
if
(
backend
==
DNN_BACKEND_HALIDE
)
throw
SkipTestException
(
""
);
if
(
target
==
DNN_TARGET_MYRIAD
)
throw
SkipTestException
(
""
);
Mat
sample
=
imread
(
findDataFile
(
"dnn/dog416.png"
));
cvtColor
(
sample
,
sample
,
COLOR_BGR2RGB
);
Mat
inp
;
sample
.
convertTo
(
inp
,
CV_32FC3
,
1.0
f
/
255
,
0
);
processNet
(
"dnn/yolov4.weights"
,
"dnn/yolov4.cfg"
,
""
,
inp
);
}
PERF_TEST_P_
(
DNNTestNetwork
,
EAST_text_detection
)
...
...
modules/dnn/test/test_darknet_importer.cpp
浏览文件 @
6b89154a
...
...
@@ -245,6 +245,13 @@ public:
nms_boxes
.
push_back
(
box
);
nms_confidences
.
push_back
(
conf
);
nms_classIds
.
push_back
(
class_id
);
#if 0 // use to update test reference data
std::cout << b << ", " << class_id << ", " << conf << "f, "
<< box.x << "f, " << box.y << "f, "
<< box.x + box.width << "f, " << box.y + box.height << "f,"
<< std::endl;
#endif
}
normAssertDetections
(
refClassIds
[
b
],
refConfidences
[
b
],
refBoxes
[
b
],
nms_classIds
,
...
...
@@ -395,6 +402,9 @@ TEST_P(Test_Darknet_nets_async, Accuracy)
std
::
string
prefix
=
get
<
0
>
(
GetParam
());
if
(
targetId
==
DNN_TARGET_MYRIAD
&&
prefix
==
"yolov4"
)
// NC_OUT_OF_MEMORY
applyTestTag
(
CV_TEST_TAG_DNN_SKIP_IE_MYRIAD
,
CV_TEST_TAG_DNN_SKIP_IE_VERSION
);
if
(
backendId
!=
DNN_BACKEND_INFERENCE_ENGINE_NN_BUILDER_2019
&&
backendId
!=
DNN_BACKEND_INFERENCE_ENGINE_NGRAPH
)
throw
SkipTestException
(
"No support for async forward"
);
...
...
@@ -439,7 +449,7 @@ TEST_P(Test_Darknet_nets_async, Accuracy)
}
INSTANTIATE_TEST_CASE_P
(
/**/
,
Test_Darknet_nets_async
,
Combine
(
Values
(
"yolo-voc"
,
"tiny-yolo-voc"
,
"yolov3"
),
Values
(
"yolo-voc"
,
"tiny-yolo-voc"
,
"yolov3"
,
"yolov4"
),
dnnBackendsAndTargets
()
));
...
...
@@ -453,15 +463,21 @@ TEST_P(Test_Darknet_nets, YOLOv3)
applyTestTag
(
CV_TEST_TAG_DNN_SKIP_IE_MYRIAD
,
CV_TEST_TAG_DNN_SKIP_IE_NGRAPH
);
// batchId, classId, confidence, left, top, right, bottom
Mat
ref
=
(
Mat_
<
float
>
(
9
,
7
)
<<
0
,
7
,
0.952983
f
,
0.614622
f
,
0.150257
f
,
0.901369
f
,
0.289251
f
,
// a truck
0
,
1
,
0.987908
f
,
0.150913
f
,
0.221933
f
,
0.742255
f
,
0.74626
f
,
// a bicycle
0
,
16
,
0.998836
f
,
0.160024
f
,
0.389964
f
,
0.417885
f
,
0.943716
f
,
// a dog (COCO)
1
,
9
,
0.384801
f
,
0.659824
f
,
0.372389
f
,
0.673926
f
,
0.429412
f
,
// a traffic light
1
,
9
,
0.733283
f
,
0.376029
f
,
0.315694
f
,
0.401776
f
,
0.395165
f
,
// a traffic light
1
,
9
,
0.785352
f
,
0.665503
f
,
0.373543
f
,
0.688893
f
,
0.439245
f
,
// a traffic light
1
,
0
,
0.980052
f
,
0.195856
f
,
0.378454
f
,
0.258626
f
,
0.629258
f
,
// a person
1
,
2
,
0.989633
f
,
0.450719
f
,
0.463353
f
,
0.496305
f
,
0.522258
f
,
// a car
1
,
2
,
0.997412
f
,
0.647584
f
,
0.459939
f
,
0.821038
f
,
0.663947
f
);
// a car
const
int
N0
=
3
;
const
int
N1
=
6
;
static
const
float
ref_
[
/* (N0 + N1) * 7 */
]
=
{
0
,
16
,
0.998836
f
,
0.160024
f
,
0.389964
f
,
0.417885
f
,
0.943716
f
,
0
,
1
,
0.987908
f
,
0.150913
f
,
0.221933
f
,
0.742255
f
,
0.746261
f
,
0
,
7
,
0.952983
f
,
0.614621
f
,
0.150257
f
,
0.901368
f
,
0.289251
f
,
1
,
2
,
0.997412
f
,
0.647584
f
,
0.459939
f
,
0.821037
f
,
0.663947
f
,
1
,
2
,
0.989633
f
,
0.450719
f
,
0.463353
f
,
0.496306
f
,
0.522258
f
,
1
,
0
,
0.980053
f
,
0.195856
f
,
0.378454
f
,
0.258626
f
,
0.629257
f
,
1
,
9
,
0.785341
f
,
0.665503
f
,
0.373543
f
,
0.688893
f
,
0.439244
f
,
1
,
9
,
0.733275
f
,
0.376029
f
,
0.315694
f
,
0.401776
f
,
0.395165
f
,
1
,
9
,
0.384815
f
,
0.659824
f
,
0.372389
f
,
0.673927
f
,
0.429412
f
,
};
Mat
ref
(
N0
+
N1
,
7
,
CV_32FC1
,
(
void
*
)
ref_
);
double
scoreDiff
=
(
target
==
DNN_TARGET_OPENCL_FP16
||
target
==
DNN_TARGET_MYRIAD
)
?
0.006
:
8e-5
;
double
iouDiff
=
(
target
==
DNN_TARGET_OPENCL_FP16
||
target
==
DNN_TARGET_MYRIAD
)
?
0.042
:
3e-4
;
...
...
@@ -480,8 +496,8 @@ TEST_P(Test_Darknet_nets, YOLOv3)
#endif
{
SCOPED_TRACE
(
"batch size 1"
);
testDarknetModel
(
config_file
,
weights_file
,
ref
.
rowRange
(
0
,
3
),
scoreDiff
,
iouDiff
);
SCOPED_TRACE
(
"batch size 1"
);
testDarknetModel
(
config_file
,
weights_file
,
ref
.
rowRange
(
0
,
N0
),
scoreDiff
,
iouDiff
);
}
#if defined(INF_ENGINE_RELEASE)
...
...
@@ -503,6 +519,75 @@ TEST_P(Test_Darknet_nets, YOLOv3)
}
}
TEST_P
(
Test_Darknet_nets
,
YOLOv4
)
{
applyTestTag
(
CV_TEST_TAG_LONG
,
(
target
==
DNN_TARGET_CPU
?
CV_TEST_TAG_MEMORY_1GB
:
CV_TEST_TAG_MEMORY_2GB
));
#if defined(INF_ENGINE_RELEASE)
if
(
target
==
DNN_TARGET_MYRIAD
)
// NC_OUT_OF_MEMORY
applyTestTag
(
CV_TEST_TAG_DNN_SKIP_IE_MYRIAD
,
CV_TEST_TAG_DNN_SKIP_IE_VERSION
);
#endif
// batchId, classId, confidence, left, top, right, bottom
const
int
N0
=
3
;
const
int
N1
=
7
;
static
const
float
ref_
[
/* (N0 + N1) * 7 */
]
=
{
0
,
16
,
0.992194
f
,
0.172375
f
,
0.402458
f
,
0.403918
f
,
0.932801
f
,
0
,
1
,
0.988326
f
,
0.166708
f
,
0.228236
f
,
0.737208
f
,
0.735803
f
,
0
,
7
,
0.94639
f
,
0.602523
f
,
0.130399
f
,
0.901623
f
,
0.298452
f
,
1
,
2
,
0.99761
f
,
0.646556
f
,
0.45985
f
,
0.816041
f
,
0.659067
f
,
1
,
0
,
0.988913
f
,
0.201726
f
,
0.360282
f
,
0.266181
f
,
0.631728
f
,
1
,
2
,
0.98233
f
,
0.452007
f
,
0.462217
f
,
0.495612
f
,
0.521687
f
,
1
,
9
,
0.919195
f
,
0.374642
f
,
0.316524
f
,
0.398126
f
,
0.393714
f
,
1
,
9
,
0.856303
f
,
0.666842
f
,
0.372215
f
,
0.685539
f
,
0.44141
f
,
1
,
9
,
0.313516
f
,
0.656791
f
,
0.374734
f
,
0.671959
f
,
0.438371
f
,
1
,
9
,
0.256625
f
,
0.940232
f
,
0.326931
f
,
0.967586
f
,
0.374002
f
,
};
Mat
ref
(
N0
+
N1
,
7
,
CV_32FC1
,
(
void
*
)
ref_
);
double
scoreDiff
=
(
target
==
DNN_TARGET_OPENCL_FP16
||
target
==
DNN_TARGET_MYRIAD
)
?
0.006
:
8e-5
;
double
iouDiff
=
(
target
==
DNN_TARGET_OPENCL_FP16
||
target
==
DNN_TARGET_MYRIAD
)
?
0.042
:
3e-4
;
std
::
string
config_file
=
"yolov4.cfg"
;
std
::
string
weights_file
=
"yolov4.weights"
;
#if defined(INF_ENGINE_RELEASE)
if
((
backend
==
DNN_BACKEND_INFERENCE_ENGINE_NN_BUILDER_2019
||
backend
==
DNN_BACKEND_INFERENCE_ENGINE_NGRAPH
)
&&
target
==
DNN_TARGET_MYRIAD
&&
getInferenceEngineVPUType
()
==
CV_DNN_INFERENCE_ENGINE_VPU_TYPE_MYRIAD_X
)
{
scoreDiff
=
0.04
;
iouDiff
=
0.2
;
}
#endif
{
SCOPED_TRACE
(
"batch size 1"
);
testDarknetModel
(
config_file
,
weights_file
,
ref
.
rowRange
(
0
,
N0
),
scoreDiff
,
iouDiff
);
}
{
SCOPED_TRACE
(
"batch size 2"
);
#if defined(INF_ENGINE_RELEASE)
if
(
backend
==
DNN_BACKEND_INFERENCE_ENGINE_NN_BUILDER_2019
)
{
if
(
target
==
DNN_TARGET_OPENCL
)
applyTestTag
(
CV_TEST_TAG_DNN_SKIP_IE_OPENCL
,
CV_TEST_TAG_DNN_SKIP_IE_VERSION
);
else
if
(
target
==
DNN_TARGET_OPENCL_FP16
&&
INF_ENGINE_VER_MAJOR_LE
(
202010000
))
applyTestTag
(
CV_TEST_TAG_DNN_SKIP_IE_OPENCL_FP16
,
CV_TEST_TAG_DNN_SKIP_IE_VERSION
);
else
if
(
target
==
DNN_TARGET_MYRIAD
&&
getInferenceEngineVPUType
()
==
CV_DNN_INFERENCE_ENGINE_VPU_TYPE_MYRIAD_X
)
applyTestTag
(
CV_TEST_TAG_DNN_SKIP_IE_MYRIAD_X
);
}
#endif
testDarknetModel
(
config_file
,
weights_file
,
ref
,
scoreDiff
,
iouDiff
);
}
}
INSTANTIATE_TEST_CASE_P
(
/**/
,
Test_Darknet_nets
,
dnnBackendsAndTargets
());
TEST_P
(
Test_Darknet_layers
,
shortcut
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录