Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
c97c0be4
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,发现更多精彩内容 >>
提交
c97c0be4
编写于
8月 12, 2014
作者:
V
Vadim Pisarevsky
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #3082 from ElenaGvozdeva:ocl_morphSmall
上级
5505aa28
8124d105
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
20 addition
and
20 deletion
+20
-20
modules/imgproc/src/morph.cpp
modules/imgproc/src/morph.cpp
+16
-16
modules/imgproc/test/ocl/test_filters.cpp
modules/imgproc/test/ocl/test_filters.cpp
+4
-4
未找到文件。
modules/imgproc/src/morph.cpp
浏览文件 @
c97c0be4
...
...
@@ -1511,22 +1511,6 @@ static bool ocl_morphOp(InputArray _src, OutputArray _dst, InputArray _kernel,
bool
haveExtraMat
=
!
_extraMat
.
empty
();
CV_Assert
(
actual_op
<=
3
||
haveExtraMat
);
// try to use OpenCL kernel adopted for small morph kernel
if
(
dev
.
isIntel
()
&&
!
(
dev
.
type
()
&
ocl
::
Device
::
TYPE_CPU
)
&&
((
ksize
.
width
<
5
&&
ksize
.
height
<
5
&&
esz
<=
4
)
||
(
ksize
.
width
==
5
&&
ksize
.
height
==
5
&&
cn
==
1
))
&&
(
iterations
==
1
))
{
if
(
ocl_morphSmall
(
_src
,
_dst
,
_kernel
,
anchor
,
borderType
,
op
,
actual_op
,
_extraMat
))
return
true
;
}
if
(
iterations
==
0
||
kernel
.
rows
*
kernel
.
cols
==
1
)
{
_src
.
copyTo
(
_dst
);
return
true
;
}
if
(
!
kernel
.
data
)
{
kernel
=
getStructuringElement
(
MORPH_RECT
,
Size
(
1
+
iterations
*
2
,
1
+
iterations
*
2
));
...
...
@@ -1543,6 +1527,22 @@ static bool ocl_morphOp(InputArray _src, OutputArray _dst, InputArray _kernel,
iterations
=
1
;
}
// try to use OpenCL kernel adopted for small morph kernel
if
(
dev
.
isIntel
()
&&
!
(
dev
.
type
()
&
ocl
::
Device
::
TYPE_CPU
)
&&
((
ksize
.
width
<
5
&&
ksize
.
height
<
5
&&
esz
<=
4
)
||
(
ksize
.
width
==
5
&&
ksize
.
height
==
5
&&
cn
==
1
))
&&
(
iterations
==
1
))
{
if
(
ocl_morphSmall
(
_src
,
_dst
,
kernel
,
anchor
,
borderType
,
op
,
actual_op
,
_extraMat
))
return
true
;
}
if
(
iterations
==
0
||
kernel
.
rows
*
kernel
.
cols
==
1
)
{
_src
.
copyTo
(
_dst
);
return
true
;
}
#ifdef ANDROID
size_t
localThreads
[
2
]
=
{
16
,
8
};
#else
...
...
modules/imgproc/test/ocl/test_filters.cpp
浏览文件 @
c97c0be4
...
...
@@ -242,7 +242,7 @@ OCL_TEST_P(Erode, Mat)
for
(
int
j
=
0
;
j
<
test_loop_times
;
j
++
)
{
random_roi
();
Mat
kernel
=
randomMat
(
kernelSize
,
CV_8UC1
,
0
,
3
);
Mat
kernel
=
ksize
==
0
?
Mat
()
:
randomMat
(
kernelSize
,
CV_8UC1
,
0
,
3
);
OCL_OFF
(
cv
::
erode
(
src_roi
,
dst_roi
,
kernel
,
Point
(
-
1
,
-
1
),
iterations
)
);
OCL_ON
(
cv
::
erode
(
usrc_roi
,
udst_roi
,
kernel
,
Point
(
-
1
,
-
1
),
iterations
)
);
...
...
@@ -264,7 +264,7 @@ OCL_TEST_P(Dilate, Mat)
for
(
int
j
=
0
;
j
<
test_loop_times
;
j
++
)
{
random_roi
();
Mat
kernel
=
randomMat
(
kernelSize
,
CV_8UC1
,
0
,
3
);
Mat
kernel
=
ksize
==
0
?
Mat
()
:
randomMat
(
kernelSize
,
CV_8UC1
,
0
,
3
);
OCL_OFF
(
cv
::
dilate
(
src_roi
,
dst_roi
,
kernel
,
Point
(
-
1
,
-
1
),
iterations
)
);
OCL_ON
(
cv
::
dilate
(
usrc_roi
,
udst_roi
,
kernel
,
Point
(
-
1
,
-
1
),
iterations
)
);
...
...
@@ -413,7 +413,7 @@ OCL_INSTANTIATE_TEST_CASE_P(Filter, GaussianBlurTest, Combine(
OCL_INSTANTIATE_TEST_CASE_P
(
Filter
,
Erode
,
Combine
(
Values
(
CV_8UC1
,
CV_8UC3
,
CV_8UC4
,
CV_32FC1
,
CV_32FC3
,
CV_32FC4
,
CV_64FC1
,
CV_64FC4
),
Values
(
3
,
5
,
7
),
Values
(
0
,
3
,
5
,
7
),
// kernel size, 0 means kernel = Mat()
Values
(
Size
(
0
,
0
)),
//not used
Values
((
BorderType
)
BORDER_CONSTANT
),
Values
(
1.0
,
2.0
,
3.0
),
...
...
@@ -422,7 +422,7 @@ OCL_INSTANTIATE_TEST_CASE_P(Filter, Erode, Combine(
OCL_INSTANTIATE_TEST_CASE_P
(
Filter
,
Dilate
,
Combine
(
Values
(
CV_8UC1
,
CV_8UC3
,
CV_8UC4
,
CV_32FC1
,
CV_32FC3
,
CV_32FC4
,
CV_64FC1
,
CV_64FC4
),
Values
(
3
,
5
,
7
),
Values
(
0
,
3
,
5
,
7
),
// kernel size, 0 means kernel = Mat()
Values
(
Size
(
0
,
0
)),
// not used
Values
((
BorderType
)
BORDER_CONSTANT
),
Values
(
1.0
,
2.0
,
3.0
),
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录