Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
f8a27d26
O
Opencv
项目概览
Greenplum
/
Opencv
大约 1 年 前同步成功
通知
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,发现更多精彩内容 >>
提交
f8a27d26
编写于
10月 15, 2018
作者:
A
Alexander Alekhin
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #12775 from radomsak:radomsak_dnn_fix_caffe_importer_reused_layers
上级
f185640e
70177143
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
26 addition
and
2 deletion
+26
-2
modules/dnn/src/caffe/caffe_importer.cpp
modules/dnn/src/caffe/caffe_importer.cpp
+4
-2
modules/dnn/test/test_caffe_importer.cpp
modules/dnn/test/test_caffe_importer.cpp
+22
-0
未找到文件。
modules/dnn/src/caffe/caffe_importer.cpp
浏览文件 @
f8a27d26
...
...
@@ -278,11 +278,13 @@ public:
int
li
;
for
(
li
=
0
;
li
!=
netBinary
.
layer_size
();
li
++
)
{
if
(
netBinary
.
layer
(
li
).
name
()
==
name
)
const
caffe
::
LayerParameter
&
binLayer
=
netBinary
.
layer
(
li
);
// Break if the layer name is the same and the blobs are not cleared
if
(
binLayer
.
name
()
==
name
&&
binLayer
.
blobs_size
()
!=
0
)
break
;
}
if
(
li
==
netBinary
.
layer_size
()
||
netBinary
.
layer
(
li
).
blobs_size
()
==
0
)
if
(
li
==
netBinary
.
layer_size
())
return
;
caffe
::
LayerParameter
*
binLayer
=
netBinary
.
mutable_layer
(
li
);
...
...
modules/dnn/test/test_caffe_importer.cpp
浏览文件 @
f8a27d26
...
...
@@ -454,6 +454,28 @@ TEST(Test_Caffe, multiple_inputs)
normAssert
(
out
,
first_image
+
second_image
);
}
TEST
(
Test_Caffe
,
shared_weights
)
{
const
string
proto
=
findDataFile
(
"dnn/layers/shared_weights.prototxt"
,
false
);
const
string
model
=
findDataFile
(
"dnn/layers/shared_weights.caffemodel"
,
false
);
Net
net
=
readNetFromCaffe
(
proto
,
model
);
Mat
input_1
=
(
Mat_
<
float
>
(
2
,
2
)
<<
0.
,
2.
,
4.
,
6.
);
Mat
input_2
=
(
Mat_
<
float
>
(
2
,
2
)
<<
1.
,
3.
,
5.
,
7.
);
Mat
blob_1
=
blobFromImage
(
input_1
);
Mat
blob_2
=
blobFromImage
(
input_2
);
net
.
setInput
(
blob_1
,
"input_1"
);
net
.
setInput
(
blob_2
,
"input_2"
);
Mat
sum
=
net
.
forward
();
EXPECT_EQ
(
sum
.
at
<
float
>
(
0
,
0
),
12.
);
EXPECT_EQ
(
sum
.
at
<
float
>
(
0
,
1
),
16.
);
}
typedef
testing
::
TestWithParam
<
tuple
<
std
::
string
,
Target
>
>
opencv_face_detector
;
TEST_P
(
opencv_face_detector
,
Accuracy
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录