Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
ef4eadd5
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,发现更多精彩内容 >>
提交
ef4eadd5
编写于
11月 12, 2013
作者:
R
Roman Donchenko
提交者:
OpenCV Buildbot
11月 12, 2013
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #1766 from ilya-lavrenov:ocl_remap_linear
上级
46e423d2
760b7189
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
74 addition
and
16 deletion
+74
-16
modules/ocl/src/imgproc.cpp
modules/ocl/src/imgproc.cpp
+4
-6
modules/ocl/src/opencl/imgproc_remap.cl
modules/ocl/src/opencl/imgproc_remap.cl
+63
-9
modules/ocl/test/test_warp.cpp
modules/ocl/test/test_warp.cpp
+7
-1
未找到文件。
modules/ocl/src/imgproc.cpp
浏览文件 @
ef4eadd5
...
...
@@ -198,10 +198,8 @@ namespace cv
if
(
map1
.
empty
())
map1
.
swap
(
map2
);
CV_Assert
(
interpolation
==
INTER_LINEAR
||
interpolation
==
INTER_NEAREST
/*|| interpolation == INTER_CUBIC || interpolation == INTER_LANCZOS4*/
);
CV_Assert
((
map1
.
type
()
==
CV_16SC2
&&
(
map2
.
empty
()
||
(
interpolation
==
INTER_NEAREST
&&
(
map2
.
type
()
==
CV_16UC1
||
map2
.
type
()
==
CV_16SC1
))
))
||
CV_Assert
(
interpolation
==
INTER_LINEAR
||
interpolation
==
INTER_NEAREST
);
CV_Assert
((
map1
.
type
()
==
CV_16SC2
&&
(
map2
.
empty
()
||
(
map2
.
type
()
==
CV_16UC1
||
map2
.
type
()
==
CV_16SC1
))
)
||
(
map1
.
type
()
==
CV_32FC2
&&
!
map2
.
data
)
||
(
map1
.
type
()
==
CV_32FC1
&&
map2
.
type
()
==
CV_32FC1
));
CV_Assert
(
!
map2
.
data
||
map2
.
size
()
==
map1
.
size
());
...
...
@@ -231,8 +229,8 @@ namespace cv
CV_Error
(
CV_StsBadArg
,
"Unsupported map types"
);
int
ocn
=
dst
.
oclchannels
();
size_t
localThreads
[
3
]
=
{
16
,
16
,
1
};
size_t
globalThreads
[
3
]
=
{
dst
.
cols
,
dst
.
rows
,
1
};
size_t
localThreads
[
3
]
=
{
256
,
1
,
1
};
size_t
globalThreads
[
3
]
=
{
dst
.
cols
,
dst
.
rows
,
1
};
Mat
scalar
(
1
,
1
,
CV_MAKE_TYPE
(
dst
.
depth
(),
ocn
),
borderValue
);
std
::
string
buildOptions
=
format
(
"-D %s -D %s -D T=%s%s"
,
interMap
[
interpolation
],
...
...
modules/ocl/src/opencl/imgproc_remap.cl
浏览文件 @
ef4eadd5
...
...
@@ -243,6 +243,60 @@ __kernel void remap_16SC2_16UC1(__global const T * restrict src, __global T * ds
#
elif
INTER_LINEAR
__kernel
void
remap_16SC2_16UC1
(
__global
T
const
*
restrict
src,
__global
T
*
dst,
__global
short2
*
restrict
map1,
__global
ushort
*
restrict
map2,
int
src_offset,
int
dst_offset,
int
map1_offset,
int
map2_offset,
int
src_step,
int
dst_step,
int
map1_step,
int
map2_step,
int
src_cols,
int
src_rows,
int
dst_cols,
int
dst_rows,
T
nVal
)
{
int
x
=
get_global_id
(
0
)
;
int
y
=
get_global_id
(
1
)
;
if
(
x
<
dst_cols
&&
y
<
dst_rows
)
{
int
dstIdx
=
mad24
(
y,
dst_step,
x
+
dst_offset
)
;
int
map1Idx
=
mad24
(
y,
map1_step,
x
+
map1_offset
)
;
int
map2Idx
=
mad24
(
y,
map2_step,
x
+
map2_offset
)
;
int2
map_dataA
=
convert_int2
(
map1[map1Idx]
)
;
int2
map_dataB
=
(
int2
)(
map_dataA.x
+
1
,
map_dataA.y
)
;
int2
map_dataC
=
(
int2
)(
map_dataA.x,
map_dataA.y
+
1
)
;
int2
map_dataD
=
(
int2
)(
map_dataA.x
+
1
,
map_dataA.y
+
1
)
;
ushort
map2Value
=
(
ushort
)(
map2[map2Idx]
&
(
INTER_TAB_SIZE2
-
1
))
;
WT2
u
=
(
WT2
)(
map2Value
&
(
INTER_TAB_SIZE
-
1
)
,
map2Value
>>
INTER_BITS
)
/
(
WT2
)(
INTER_TAB_SIZE
)
;
WT
scalar
=
convertToWT
(
nVal
)
;
WT
a
=
scalar,
b
=
scalar,
c
=
scalar,
d
=
scalar
;
if
(
!NEED_EXTRAPOLATION
(
map_dataA.x,
map_dataA.y
))
a
=
convertToWT
(
src[mad24
(
map_dataA.y,
src_step,
map_dataA.x
+
src_offset
)
]
)
;
else
EXTRAPOLATE
(
map_dataA,
a
)
;
if
(
!NEED_EXTRAPOLATION
(
map_dataB.x,
map_dataB.y
))
b
=
convertToWT
(
src[mad24
(
map_dataB.y,
src_step,
map_dataB.x
+
src_offset
)
]
)
;
else
EXTRAPOLATE
(
map_dataB,
b
)
;
if
(
!NEED_EXTRAPOLATION
(
map_dataC.x,
map_dataC.y
))
c
=
convertToWT
(
src[mad24
(
map_dataC.y,
src_step,
map_dataC.x
+
src_offset
)
]
)
;
else
EXTRAPOLATE
(
map_dataC,
c
)
;
if
(
!NEED_EXTRAPOLATION
(
map_dataD.x,
map_dataD.y
))
d
=
convertToWT
(
src[mad24
(
map_dataD.y,
src_step,
map_dataD.x
+
src_offset
)
]
)
;
else
EXTRAPOLATE
(
map_dataD,
d
)
;
WT
dst_data
=
a
*
(
1
-
u.x
)
*
(
1
-
u.y
)
+
b
*
(
u.x
)
*
(
1
-
u.y
)
+
c
*
(
1
-
u.x
)
*
(
u.y
)
+
d
*
(
u.x
)
*
(
u.y
)
;
dst[dstIdx]
=
convertToT
(
dst_data
)
;
}
}
__kernel
void
remap_2_32FC1
(
__global
T
const
*
restrict
src,
__global
T
*
dst,
__global
float
*
map1,
__global
float
*
map2,
int
src_offset,
int
dst_offset,
int
map1_offset,
int
map2_offset,
...
...
@@ -263,7 +317,7 @@ __kernel void remap_2_32FC1(__global T const * restrict src, __global T * dst,
int2
map_dataA
=
convert_int2_sat_rtn
(
map_data
)
;
int2
map_dataB
=
(
int2
)(
map_dataA.x
+
1
,
map_dataA.y
)
;
int2
map_dataC
=
(
int2
)(
map_dataA.x,
map_dataA.y
+
1
)
;
int2
map_dataD
=
(
int2
)(
map_dataA.x
+
1
,
map_dataA.y
+1
)
;
int2
map_dataD
=
(
int2
)(
map_dataA.x
+
1
,
map_dataA.y
+
1
)
;
float2
_u
=
map_data
-
convert_float2
(
map_dataA
)
;
WT2
u
=
convertToWT2
(
convert_int2_rte
(
convertToWT2
(
_u
)
*
(
WT2
)
INTER_TAB_SIZE
))
/
(
WT2
)
INTER_TAB_SIZE
;
...
...
@@ -290,10 +344,10 @@ __kernel void remap_2_32FC1(__global T const * restrict src, __global T * dst,
else
EXTRAPOLATE
(
map_dataD,
d
)
;
WT
dst_data
=
a
*
(
WT
)(
1
-
u.x
)
*
(
WT
)
(
1
-
u.y
)
+
b
*
(
WT
)(
u.x
)
*
(
WT
)
(
1
-
u.y
)
+
c
*
(
WT
)(
1
-
u.x
)
*
(
WT
)
(
u.y
)
+
d
*
(
WT
)(
u.x
)
*
(
WT
)
(
u.y
)
;
WT
dst_data
=
a
*
(
1
-
u.x
)
*
(
1
-
u.y
)
+
b
*
(
u.x
)
*
(
1
-
u.y
)
+
c
*
(
1
-
u.x
)
*
(
u.y
)
+
d
*
(
u.x
)
*
(
u.y
)
;
dst[dstIdx]
=
convertToT
(
dst_data
)
;
}
}
...
...
@@ -343,10 +397,10 @@ __kernel void remap_32FC2(__global T const * restrict src, __global T * dst,
else
EXTRAPOLATE
(
map_dataD,
d
)
;
WT
dst_data
=
a
*
(
WT
)(
1
-
u.x
)
*
(
WT
)
(
1
-
u.y
)
+
b
*
(
WT
)(
u.x
)
*
(
WT
)
(
1
-
u.y
)
+
c
*
(
WT
)(
1
-
u.x
)
*
(
WT
)
(
u.y
)
+
d
*
(
WT
)(
u.x
)
*
(
WT
)
(
u.y
)
;
WT
dst_data
=
a
*
(
1
-
u.x
)
*
(
1
-
u.y
)
+
b
*
(
u.x
)
*
(
1
-
u.y
)
+
c
*
(
1
-
u.x
)
*
(
u.y
)
+
d
*
(
u.x
)
*
(
u.y
)
;
dst[dstIdx]
=
convertToT
(
dst_data
)
;
}
}
...
...
modules/ocl/test/test_warp.cpp
浏览文件 @
ef4eadd5
...
...
@@ -313,7 +313,12 @@ PARAM_TEST_CASE(Remap, MatDepth, Channels, pair<MatType, MatType>, Border, bool)
Border
map2Border
=
randomBorder
(
0
,
useRoi
?
MAX_VALUE
:
0
);
if
(
map2Type
!=
noType
)
randomSubMat
(
map2
,
map2_roi
,
dstROISize
,
map2Border
,
map2Type
,
-
mapMaxValue
,
mapMaxValue
);
{
int
mapMinValue
=
-
mapMaxValue
;
if
(
map2Type
==
CV_16UC1
||
map2Type
==
CV_16SC1
)
mapMinValue
=
0
,
mapMaxValue
=
INTER_TAB_SIZE2
;
randomSubMat
(
map2
,
map2_roi
,
dstROISize
,
map2Border
,
map2Type
,
mapMinValue
,
mapMaxValue
);
}
generateOclMat
(
gsrc
,
gsrc_roi
,
src
,
srcROISize
,
srcBorder
);
generateOclMat
(
gdst
,
gdst_roi
,
dst
,
dstROISize
,
dstBorder
);
...
...
@@ -452,6 +457,7 @@ INSTANTIATE_TEST_CASE_P(ImgprocWarp, Remap_INTER_LINEAR, Combine(
Values
(
CV_8U
,
CV_16U
,
CV_16S
,
CV_32F
,
CV_64F
),
Values
(
1
,
2
,
3
,
4
),
Values
(
pair
<
MatType
,
MatType
>
((
MatType
)
CV_32FC1
,
(
MatType
)
CV_32FC1
),
pair
<
MatType
,
MatType
>
((
MatType
)
CV_16SC2
,
(
MatType
)
CV_16UC1
),
pair
<
MatType
,
MatType
>
((
MatType
)
CV_32FC2
,
noType
)),
Values
((
Border
)
BORDER_CONSTANT
,
(
Border
)
BORDER_REPLICATE
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录