Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
98b72ff3
O
Opencv
项目概览
Greenplum
/
Opencv
11 个月 前同步成功
通知
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,发现更多精彩内容 >>
提交
98b72ff3
编写于
2月 03, 2014
作者:
I
Ilya Lavrenov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
optimized cv::pow for integer power
上级
b5d8f4d5
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
49 addition
and
28 deletion
+49
-28
modules/core/src/mathfuncs.cpp
modules/core/src/mathfuncs.cpp
+34
-20
modules/core/src/opencl/arithm.cl
modules/core/src/opencl/arithm.cl
+6
-1
modules/core/test/ocl/test_arithm.cpp
modules/core/test/ocl/test_arithm.cpp
+9
-7
未找到文件。
modules/core/src/mathfuncs.cpp
浏览文件 @
98b72ff3
...
...
@@ -2033,17 +2033,17 @@ static IPowFunc ipowTab[] =
#ifdef HAVE_OPENCL
static
bool
ocl_pow
(
InputArray
_src
,
double
power
,
OutputArray
_dst
)
static
bool
ocl_pow
(
InputArray
_src
,
double
power
,
OutputArray
_dst
,
bool
is_ipower
,
int
ipower
)
{
int
type
=
_src
.
type
(),
depth
=
CV_MAT_DEPTH
(
type
),
cn
=
CV_MAT_CN
(
type
);
bool
doubleSupport
=
ocl
::
Device
::
getDefault
().
doubleFPConfig
()
>
0
;
if
(
!
(
_src
.
dims
()
<=
2
&&
(
depth
==
CV_32F
||
depth
==
CV_64F
))
||
(
depth
==
CV_64F
&&
!
doubleSupport
)
)
if
(
depth
==
CV_64F
&&
!
doubleSupport
)
return
false
;
bool
issqrt
=
std
::
abs
(
power
-
0.5
)
<
DBL_EPSILON
;
const
char
*
const
op
=
issqrt
?
"OP_SQRT"
:
"OP_POW"
;
const
char
*
const
op
=
issqrt
?
"OP_SQRT"
:
is_ipower
?
"OP_POWN"
:
"OP_POW"
;
ocl
::
Kernel
k
(
"KF"
,
ocl
::
core
::
arithm_oclsrc
,
format
(
"-D dstT=%s -D %s -D UNARY_OP%s"
,
ocl
::
typeToStr
(
CV_MAKE_TYPE
(
depth
,
1
)),
...
...
@@ -2060,6 +2060,8 @@ static bool ocl_pow(InputArray _src, double power, OutputArray _dst)
if
(
issqrt
)
k
.
args
(
srcarg
,
dstarg
);
else
if
(
is_ipower
)
k
.
args
(
srcarg
,
dstarg
,
ipower
);
else
{
if
(
depth
==
CV_32F
)
...
...
@@ -2076,39 +2078,35 @@ static bool ocl_pow(InputArray _src, double power, OutputArray _dst)
void
pow
(
InputArray
_src
,
double
power
,
OutputArray
_dst
)
{
CV_OCL_RUN
(
_dst
.
isUMat
(),
ocl_pow
(
_src
,
power
,
_dst
))
Mat
src
=
_src
.
getMat
();
int
type
=
src
.
type
(),
depth
=
src
.
depth
(),
cn
=
src
.
channels
();
_dst
.
create
(
src
.
dims
,
src
.
size
,
type
);
Mat
dst
=
_dst
.
getMat
();
int
ipower
=
cvRound
(
power
);
bool
is_ipower
=
false
;
bool
is_ipower
=
false
,
same
=
false
;
int
type
=
_src
.
type
(),
depth
=
CV_MAT_DEPTH
(
type
),
cn
=
CV_MAT_CN
(
type
),
ipower
=
cvRound
(
power
);
if
(
fabs
(
ipower
-
power
)
<
DBL_EPSILON
)
{
if
(
ipower
<
0
)
{
divide
(
1.
,
src
,
dst
);
divide
(
1.
,
_src
,
_
dst
);
if
(
ipower
==
-
1
)
return
;
ipower
=
-
ipower
;
s
rc
=
dst
;
s
ame
=
true
;
}
switch
(
ipower
)
{
case
0
:
dst
=
Scalar
::
all
(
1
);
_dst
.
createSameSize
(
_src
,
type
);
_dst
.
setTo
(
Scalar
::
all
(
1
));
return
;
case
1
:
src
.
copyTo
(
dst
);
_src
.
copyTo
(
_
dst
);
return
;
case
2
:
multiply
(
src
,
src
,
dst
);
if
(
same
)
multiply
(
_dst
,
_dst
,
_dst
);
else
multiply
(
_src
,
_src
,
_dst
);
return
;
default:
is_ipower
=
true
;
...
...
@@ -2117,6 +2115,22 @@ void pow( InputArray _src, double power, OutputArray _dst )
else
CV_Assert
(
depth
==
CV_32F
||
depth
==
CV_64F
);
CV_OCL_RUN
(
_dst
.
isUMat
()
&&
_src
.
dims
()
<=
2
,
ocl_pow
(
same
?
_dst
:
_src
,
power
,
_dst
,
is_ipower
,
ipower
))
Mat
src
,
dst
;
if
(
same
)
{
dst
=
_dst
.
getMat
();
src
=
dst
;
}
else
{
src
=
_src
.
getMat
();
_dst
.
create
(
src
.
dims
,
src
.
size
,
type
);
dst
=
_dst
.
getMat
();
}
const
Mat
*
arrays
[]
=
{
&
src
,
&
dst
,
0
};
uchar
*
ptrs
[
2
];
NAryMatIterator
it
(
arrays
,
ptrs
);
...
...
modules/core/src/opencl/arithm.cl
浏览文件 @
98b72ff3
...
...
@@ -211,6 +211,11 @@
#elif defined OP_POW
#define PROCESS_ELEM dstelem = pow(srcelem1, srcelem2)
#elif defined OP_POWN
#undef workT
#define workT int
#define PROCESS_ELEM dstelem = pown(srcelem1, srcelem2)
#elif defined OP_SQRT
#define PROCESS_ELEM dstelem = sqrt(srcelem1)
...
...
@@ -293,7 +298,7 @@ dstelem = v > (dstT)(0) ? log(v) : log(-v)
#if defined OP_AND || defined OP_OR || defined OP_XOR || defined OP_ADD || defined OP_SAT_ADD || \
defined OP_SUB || defined OP_SAT_SUB || defined OP_RSUB || defined OP_SAT_RSUB || \
defined OP_ABSDIFF || defined OP_CMP || defined OP_MIN || defined OP_MAX || defined OP_POW || \
defined OP_MUL || defined OP_DIV
defined OP_MUL || defined OP_DIV
|| defined OP_POWN
#undef EXTRA_PARAMS
#define EXTRA_PARAMS , workT srcelem2
#endif
...
...
modules/core/test/ocl/test_arithm.cpp
浏览文件 @
98b72ff3
...
...
@@ -773,16 +773,18 @@ typedef ArithmTestBase Pow;
OCL_TEST_P
(
Pow
,
Mat
)
{
static
const
double
pows
[]
=
{
-
4
,
-
1
,
-
2.5
,
0
,
1
,
2
,
3.7
,
4
};
for
(
int
j
=
0
;
j
<
test_loop_times
;
j
++
)
{
generateTestData
();
double
p
=
4.5
;
for
(
int
k
=
0
,
size
=
sizeof
(
pows
)
/
sizeof
(
double
);
k
<
size
;
++
k
)
{
generateTestData
()
;
OCL_OFF
(
cv
::
pow
(
src1_roi
,
p
,
dst1_roi
));
OCL_ON
(
cv
::
pow
(
usrc1_roi
,
p
,
udst1_roi
));
OCL_OFF
(
cv
::
pow
(
src1_roi
,
pows
[
k
]
,
dst1_roi
));
OCL_ON
(
cv
::
pow
(
usrc1_roi
,
pows
[
k
]
,
udst1_roi
));
Near
(
1
);
}
Near
(
1
);
}
}
//////////////////////////////// AddWeighted /////////////////////////////////////////////////
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录