Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
51281f8d
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,发现更多精彩内容 >>
提交
51281f8d
编写于
4月 11, 2023
作者:
Z
zihaomu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
support the split node of onnx opset >= 13
上级
d2dbaa4c
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
20 addition
and
1 deletion
+20
-1
modules/dnn/src/onnx/onnx_importer.cpp
modules/dnn/src/onnx/onnx_importer.cpp
+18
-1
modules/dnn/test/test_onnx_importer.cpp
modules/dnn/test/test_onnx_importer.cpp
+2
-0
未找到文件。
modules/dnn/src/onnx/onnx_importer.cpp
浏览文件 @
51281f8d
...
...
@@ -1467,6 +1467,10 @@ void ONNXImporter::parseSlice(LayerParams& layerParams, const opencv_onnx::NodeP
void
ONNXImporter
::
parseSplit
(
LayerParams
&
layerParams
,
const
opencv_onnx
::
NodeProto
&
node_proto
)
{
int
axis
=
layerParams
.
get
<
int
>
(
"axis"
,
0
);
MatShape
inpShape
=
outShapes
[
node_proto
.
input
(
0
)];
axis
=
normalize_axis
(
axis
,
inpShape
.
size
());
if
(
layerParams
.
has
(
"split"
))
{
DictValue
splits
=
layerParams
.
get
(
"split"
);
...
...
@@ -1480,13 +1484,26 @@ void ONNXImporter::parseSplit(LayerParams& layerParams, const opencv_onnx::NodeP
}
layerParams
.
set
(
"slice_point"
,
DictValue
::
arrayInt
(
&
slicePoints
[
0
],
slicePoints
.
size
()));
}
else
if
(
node_proto
.
input_size
()
==
2
)
// opset >= 13, the split will be stored at the second input, instead of the attribute.
{
CV_Assert
(
constBlobs
.
find
(
node_proto
.
input
(
1
))
!=
constBlobs
.
end
());
Mat
splitsBlob
=
getBlob
(
node_proto
,
1
);
int
splitSize
=
splitsBlob
.
total
();
std
::
vector
<
int
>
slicePoints
(
splitSize
-
1
,
splitsBlob
.
at
<
int
>
(
0
));
for
(
int
i
=
1
;
i
<
splitSize
-
1
;
++
i
)
{
slicePoints
[
i
]
=
slicePoints
[
i
-
1
]
+
splitsBlob
.
at
<
int
>
(
i
);
}
layerParams
.
set
(
"slice_point"
,
DictValue
::
arrayInt
(
&
slicePoints
[
0
],
slicePoints
.
size
()));
}
else
{
layerParams
.
set
(
"num_split"
,
node_proto
.
output_size
());
}
int
depth
=
layerParams
.
get
<
int
>
(
"depth"
,
CV_32F
);
layerParams
.
type
=
(
depth
==
CV_8S
)
?
"SliceInt8"
:
"Slice"
;
layerParams
.
set
(
"axis"
,
layerParams
.
get
<
float
>
(
"axis"
,
0
)
);
layerParams
.
set
(
"axis"
,
axis
);
addLayer
(
layerParams
,
node_proto
);
}
...
...
modules/dnn/test/test_onnx_importer.cpp
浏览文件 @
51281f8d
...
...
@@ -1149,6 +1149,8 @@ TEST_P(Test_ONNX_layers, Split)
testONNXModels
(
"split_2"
);
testONNXModels
(
"split_3"
);
testONNXModels
(
"split_4"
);
testONNXModels
(
"split_5"
);
testONNXModels
(
"split_6"
);
testONNXModels
(
"split_neg_axis"
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录