Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
7453a693
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,发现更多精彩内容 >>
提交
7453a693
编写于
8月 07, 2018
作者:
A
Alexander Alekhin
提交者:
Vadim Pisarevsky
8月 07, 2018
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
core(test): extra tests/fixes for merge/split (#12171)
* core(test): merge hang test * core(merge/split): fix intrin optimization
上级
39f5e573
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
61 addition
and
3 deletion
+61
-3
modules/core/src/merge.cpp
modules/core/src/merge.cpp
+1
-1
modules/core/src/split.cpp
modules/core/src/split.cpp
+2
-2
modules/core/test/test_mat.cpp
modules/core/test/test_mat.cpp
+58
-0
未找到文件。
modules/core/src/merge.cpp
浏览文件 @
7453a693
...
...
@@ -42,7 +42,7 @@ vecmerge_( const T** src, T* dst, int len, int cn )
if
(
r
!=
0
)
{
mode
=
hal
::
STORE_UNALIGNED
;
if
(
r
%
dstElemSize
==
0
&&
len
>
VECSZ
)
if
(
r
%
dstElemSize
==
0
&&
len
>
VECSZ
*
2
)
i0
=
VECSZ
-
(
r
/
dstElemSize
);
}
...
...
modules/core/src/split.cpp
浏览文件 @
7453a693
...
...
@@ -27,8 +27,8 @@ vecsplit_( const T* src, T** dst, int len, int cn )
if
(
(
r0
|
r1
|
r2
|
r3
)
!=
0
)
{
mode
=
hal
::
STORE_UNALIGNED
;
if
(
r0
==
r1
&&
r0
==
r2
&&
r0
==
r3
&&
r0
%
cn
==
0
&&
len
>
VECSZ
)
i0
=
VECSZ
-
(
r0
/
cn
);
if
(
r0
==
r1
&&
r0
==
r2
&&
r0
==
r3
&&
r0
%
sizeof
(
T
)
==
0
&&
len
>
VECSZ
*
2
)
i0
=
VECSZ
-
(
r0
/
sizeof
(
T
)
);
}
if
(
cn
==
2
)
...
...
modules/core/test/test_mat.cpp
浏览文件 @
7453a693
...
...
@@ -1824,4 +1824,62 @@ BIGDATA_TEST(Mat, push_back_regression_4158) // memory usage: ~10.6 Gb
}
}
TEST
(
Core_Merge
,
hang_12171
)
{
Mat
src1
(
4
,
24
,
CV_8UC1
,
Scalar
::
all
(
1
));
Mat
src2
(
4
,
24
,
CV_8UC1
,
Scalar
::
all
(
2
));
Rect
src_roi
(
0
,
0
,
23
,
4
);
Mat
src_channels
[
2
]
=
{
src1
(
src_roi
),
src2
(
src_roi
)
};
Mat
dst
(
4
,
24
,
CV_8UC2
,
Scalar
::
all
(
5
));
Rect
dst_roi
(
1
,
0
,
23
,
4
);
cv
::
merge
(
src_channels
,
2
,
dst
(
dst_roi
));
EXPECT_EQ
(
5
,
dst
.
ptr
<
uchar
>
()[
0
]);
EXPECT_EQ
(
5
,
dst
.
ptr
<
uchar
>
()[
1
]);
EXPECT_EQ
(
1
,
dst
.
ptr
<
uchar
>
()[
2
]);
EXPECT_EQ
(
2
,
dst
.
ptr
<
uchar
>
()[
3
]);
EXPECT_EQ
(
5
,
dst
.
ptr
<
uchar
>
(
1
)[
0
]);
EXPECT_EQ
(
5
,
dst
.
ptr
<
uchar
>
(
1
)[
1
]);
EXPECT_EQ
(
1
,
dst
.
ptr
<
uchar
>
(
1
)[
2
]);
EXPECT_EQ
(
2
,
dst
.
ptr
<
uchar
>
(
1
)[
3
]);
}
TEST
(
Core_Split
,
hang_12171
)
{
Mat
src
(
4
,
24
,
CV_8UC2
,
Scalar
(
1
,
2
,
3
,
4
));
Rect
src_roi
(
0
,
0
,
23
,
4
);
Mat
dst1
(
4
,
24
,
CV_8UC1
,
Scalar
::
all
(
5
));
Mat
dst2
(
4
,
24
,
CV_8UC1
,
Scalar
::
all
(
10
));
Rect
dst_roi
(
0
,
0
,
23
,
4
);
Mat
dst
[
2
]
=
{
dst1
(
dst_roi
),
dst2
(
dst_roi
)
};
cv
::
split
(
src
(
src_roi
),
dst
);
EXPECT_EQ
(
1
,
dst1
.
ptr
<
uchar
>
()[
0
]);
EXPECT_EQ
(
1
,
dst1
.
ptr
<
uchar
>
()[
1
]);
EXPECT_EQ
(
2
,
dst2
.
ptr
<
uchar
>
()[
0
]);
EXPECT_EQ
(
2
,
dst2
.
ptr
<
uchar
>
()[
1
]);
EXPECT_EQ
(
1
,
dst1
.
ptr
<
uchar
>
(
1
)[
0
]);
EXPECT_EQ
(
1
,
dst1
.
ptr
<
uchar
>
(
1
)[
1
]);
EXPECT_EQ
(
2
,
dst2
.
ptr
<
uchar
>
(
1
)[
0
]);
EXPECT_EQ
(
2
,
dst2
.
ptr
<
uchar
>
(
1
)[
1
]);
}
TEST
(
Core_Split
,
crash_12171
)
{
Mat
src
(
4
,
40
,
CV_8UC2
,
Scalar
(
1
,
2
,
3
,
4
));
Rect
src_roi
(
0
,
0
,
39
,
4
);
Mat
dst1
(
4
,
40
,
CV_8UC1
,
Scalar
::
all
(
5
));
Mat
dst2
(
4
,
40
,
CV_8UC1
,
Scalar
::
all
(
10
));
Rect
dst_roi
(
0
,
0
,
39
,
4
);
Mat
dst
[
2
]
=
{
dst1
(
dst_roi
),
dst2
(
dst_roi
)
};
cv
::
split
(
src
(
src_roi
),
dst
);
EXPECT_EQ
(
1
,
dst1
.
ptr
<
uchar
>
()[
0
]);
EXPECT_EQ
(
1
,
dst1
.
ptr
<
uchar
>
()[
1
]);
EXPECT_EQ
(
2
,
dst2
.
ptr
<
uchar
>
()[
0
]);
EXPECT_EQ
(
2
,
dst2
.
ptr
<
uchar
>
()[
1
]);
EXPECT_EQ
(
1
,
dst1
.
ptr
<
uchar
>
(
1
)[
0
]);
EXPECT_EQ
(
1
,
dst1
.
ptr
<
uchar
>
(
1
)[
1
]);
EXPECT_EQ
(
2
,
dst2
.
ptr
<
uchar
>
(
1
)[
0
]);
EXPECT_EQ
(
2
,
dst2
.
ptr
<
uchar
>
(
1
)[
1
]);
}
}}
// namespace
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录