Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv
Commits
32f48a8d
Commit
32f48a8d
authored
8 years ago
by
Vadim Pisarevsky
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #7631 from savuor:openvx_accumulate
parents
924ac101
7c2734ff
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
97 additions
and
0 deletions
+97
-0
accum.cpp
modules/imgproc/src/accum.cpp
+97
-0
No files found.
modules/imgproc/src/accum.cpp
View file @
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
();
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment