Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
32f48a8d
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,发现更多精彩内容 >>
提交
32f48a8d
编写于
12月 01, 2016
作者:
V
Vadim Pisarevsky
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #7631 from savuor:openvx_accumulate
上级
924ac101
7c2734ff
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
97 addition
and
0 deletion
+97
-0
modules/imgproc/src/accum.cpp
modules/imgproc/src/accum.cpp
+97
-0
未找到文件。
modules/imgproc/src/accum.cpp
浏览文件 @
32f48a8d
...
...
@@ -45,6 +45,12 @@
#include "opencl_kernels_imgproc.hpp"
#include "opencv2/core/hal/intrin.hpp"
#ifdef HAVE_OPENVX
#define IVX_USE_OPENCV
#define IVX_HIDE_INFO_WARNINGS
#include "ivx.hpp"
#endif
namespace
cv
{
...
...
@@ -1930,6 +1936,77 @@ static bool ipp_accumulate(InputArray _src, InputOutputArray _dst, InputArray _m
}
#endif
#ifdef HAVE_OPENVX
namespace
cv
{
enum
{
VX_ACCUMULATE_OP
=
0
,
VX_ACCUMULATE_SQUARE_OP
=
1
,
VX_ACCUMULATE_WEIGHTED_OP
=
2
};
static
bool
openvx_accumulate
(
InputArray
_src
,
InputOutputArray
_dst
,
InputArray
_mask
,
double
_weight
,
int
opType
)
{
Mat
srcMat
=
_src
.
getMat
(),
dstMat
=
_dst
.
getMat
();
if
(
!
_mask
.
empty
()
||
(
opType
==
VX_ACCUMULATE_WEIGHTED_OP
&&
dstMat
.
type
()
!=
CV_8UC1
)
||
(
opType
!=
VX_ACCUMULATE_WEIGHTED_OP
&&
dstMat
.
type
()
!=
CV_16SC1
)
||
srcMat
.
type
()
!=
CV_8UC1
)
{
return
false
;
}
//TODO: handle different number of channels (channel extract && channel combine)
//TODO: handle mask (threshold mask to 0xff && bitwise AND with src)
//(both things can be done by creating a graph)
try
{
ivx
::
Context
context
=
ivx
::
Context
::
create
();
ivx
::
Image
srcImage
=
ivx
::
Image
::
createFromHandle
(
context
,
ivx
::
Image
::
matTypeToFormat
(
srcMat
.
type
()),
ivx
::
Image
::
createAddressing
(
srcMat
),
srcMat
.
data
);
ivx
::
Image
dstImage
=
ivx
::
Image
::
createFromHandle
(
context
,
ivx
::
Image
::
matTypeToFormat
(
dstMat
.
type
()),
ivx
::
Image
::
createAddressing
(
dstMat
),
dstMat
.
data
);
ivx
::
Scalar
shift
=
ivx
::
Scalar
::
create
<
VX_TYPE_UINT32
>
(
context
,
0
);
ivx
::
Scalar
alpha
=
ivx
::
Scalar
::
create
<
VX_TYPE_FLOAT32
>
(
context
,
_weight
);
switch
(
opType
)
{
case
VX_ACCUMULATE_OP
:
ivx
::
IVX_CHECK_STATUS
(
vxuAccumulateImage
(
context
,
srcImage
,
dstImage
));
break
;
case
VX_ACCUMULATE_SQUARE_OP
:
ivx
::
IVX_CHECK_STATUS
(
vxuAccumulateSquareImage
(
context
,
srcImage
,
shift
,
dstImage
));
break
;
case
VX_ACCUMULATE_WEIGHTED_OP
:
ivx
::
IVX_CHECK_STATUS
(
vxuAccumulateWeightedImage
(
context
,
srcImage
,
alpha
,
dstImage
));
break
;
default:
break
;
}
#ifdef VX_VERSION_1_1
//we should take user memory back before release
//(it's not done automatically according to standard)
srcImage
.
swapHandle
();
dstImage
.
swapHandle
();
#endif
}
catch
(
ivx
::
RuntimeError
&
e
)
{
CV_Error
(
CV_StsInternal
,
e
.
what
());
return
false
;
}
catch
(
ivx
::
WrapperError
&
e
)
{
CV_Error
(
CV_StsInternal
,
e
.
what
());
return
false
;
}
return
true
;
}
}
#endif
void
cv
::
accumulate
(
InputArray
_src
,
InputOutputArray
_dst
,
InputArray
_mask
)
{
CV_INSTRUMENT_REGION
()
...
...
@@ -1946,6 +2023,13 @@ void cv::accumulate( InputArray _src, InputOutputArray _dst, InputArray _mask )
CV_IPP_RUN
((
_src
.
dims
()
<=
2
||
(
_src
.
isContinuous
()
&&
_dst
.
isContinuous
()
&&
(
_mask
.
empty
()
||
_mask
.
isContinuous
()))),
ipp_accumulate
(
_src
,
_dst
,
_mask
));
#ifdef HAVE_OPENVX
if
(
openvx_accumulate
(
_src
,
_dst
,
_mask
,
0.0
,
VX_ACCUMULATE_OP
))
{
return
;
}
#endif
Mat
src
=
_src
.
getMat
(),
dst
=
_dst
.
getMat
(),
mask
=
_mask
.
getMat
();
...
...
@@ -2042,6 +2126,13 @@ void cv::accumulateSquare( InputArray _src, InputOutputArray _dst, InputArray _m
CV_IPP_RUN
((
_src
.
dims
()
<=
2
||
(
_src
.
isContinuous
()
&&
_dst
.
isContinuous
()
&&
(
_mask
.
empty
()
||
_mask
.
isContinuous
()))),
ipp_accumulate_square
(
_src
,
_dst
,
_mask
));
#ifdef HAVE_OPENVX
if
(
openvx_accumulate
(
_src
,
_dst
,
_mask
,
0.0
,
VX_ACCUMULATE_SQUARE_OP
))
{
return
;
}
#endif
Mat
src
=
_src
.
getMat
(),
dst
=
_dst
.
getMat
(),
mask
=
_mask
.
getMat
();
int
fidx
=
getAccTabIdx
(
sdepth
,
ddepth
);
...
...
@@ -2243,6 +2334,12 @@ void cv::accumulateWeighted( InputArray _src, InputOutputArray _dst,
CV_IPP_RUN
((
_src
.
dims
()
<=
2
||
(
_src
.
isContinuous
()
&&
_dst
.
isContinuous
()
&&
_mask
.
isContinuous
())),
ipp_accumulate_weighted
(
_src
,
_dst
,
alpha
,
_mask
));
#ifdef HAVE_OPENVX
if
(
openvx_accumulate
(
_src
,
_dst
,
_mask
,
alpha
,
VX_ACCUMULATE_WEIGHTED_OP
))
{
return
;
}
#endif
Mat
src
=
_src
.
getMat
(),
dst
=
_dst
.
getMat
(),
mask
=
_mask
.
getMat
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录