Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
629461c8
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,发现更多精彩内容 >>
提交
629461c8
编写于
5月 07, 2014
作者:
V
Vladislav Vinogradov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix output matrix allocation in cv::subtract
上级
e2c7adc7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
43 addition
and
19 deletion
+43
-19
modules/core/src/arithm.cpp
modules/core/src/arithm.cpp
+29
-14
modules/core/test/test_arithm.cpp
modules/core/test/test_arithm.cpp
+14
-5
未找到文件。
modules/core/src/arithm.cpp
浏览文件 @
629461c8
...
...
@@ -1553,43 +1553,58 @@ void cv::add( InputArray src1, InputArray src2, OutputArray dst,
arithm_op
(
src1
,
src2
,
dst
,
mask
,
dtype
,
getAddTab
()
);
}
void
cv
::
subtract
(
InputArray
src1
,
InputArray
src2
,
OutputArray
dst
,
void
cv
::
subtract
(
InputArray
_src1
,
InputArray
_src2
,
OutputArray
_
dst
,
InputArray
mask
,
int
dtype
)
{
#ifdef HAVE_TEGRA_OPTIMIZATION
if
(
mask
.
empty
()
&&
src1
.
depth
()
==
CV_8U
&&
src2
.
depth
()
==
CV_8U
)
int
kind1
=
_src1
.
kind
(),
kind2
=
_src2
.
kind
();
Mat
src1
=
_src1
.
getMat
(),
src2
=
_src2
.
getMat
();
bool
src1Scalar
=
checkScalar
(
src1
,
_src2
.
type
(),
kind1
,
kind2
);
bool
src2Scalar
=
checkScalar
(
src2
,
_src1
.
type
(),
kind2
,
kind1
);
if
(
!
src1Scalar
&&
!
src2Scalar
&&
mask
.
empty
()
&&
src1
.
depth
()
==
CV_8U
&&
src2
.
depth
()
==
CV_8U
)
{
if
(
dtype
==
-
1
&&
dst
.
fixedType
())
dtype
=
dst
.
depth
();
if
(
dtype
==
-
1
)
{
if
(
_dst
.
fixedType
())
{
dtype
=
_dst
.
depth
();
}
else
{
dtype
=
src1
.
depth
();
}
}
dtype
=
CV_MAKE_TYPE
(
CV_MAT_DEPTH
(
dtype
),
src1
.
channels
());
dtype
=
CV_MAKE_TYPE
(
CV_MAT_DEPTH
(
dtype
),
_
src1
.
channels
());
if
(
!
dst
.
fixedType
()
||
dtype
==
dst
.
type
())
if
(
dtype
==
_
dst
.
type
())
{
dst
.
create
(
src1
.
size
(),
dtype
);
_dst
.
create
(
_
src1
.
size
(),
dtype
);
if
(
dtype
==
CV_16S
)
{
Mat
_dst
=
dst
.
getMat
();
if
(
tegra
::
subtract_8u8u16s
(
src1
.
getMat
(),
src2
.
getMat
(),
_
dst
))
Mat
dst
=
_
dst
.
getMat
();
if
(
tegra
::
subtract_8u8u16s
(
src1
,
src2
,
dst
))
return
;
}
else
if
(
dtype
==
CV_32F
)
{
Mat
_dst
=
dst
.
getMat
();
if
(
tegra
::
subtract_8u8u32f
(
src1
.
getMat
(),
src2
.
getMat
(),
_
dst
))
Mat
dst
=
_
dst
.
getMat
();
if
(
tegra
::
subtract_8u8u32f
(
src1
,
src2
,
dst
))
return
;
}
else
if
(
dtype
==
CV_8S
)
{
Mat
_dst
=
dst
.
getMat
();
if
(
tegra
::
subtract_8u8u8s
(
src1
.
getMat
(),
src2
.
getMat
(),
_
dst
))
Mat
dst
=
_
dst
.
getMat
();
if
(
tegra
::
subtract_8u8u8s
(
src1
,
src2
,
dst
))
return
;
}
}
}
#endif
arithm_op
(
src1
,
src2
,
dst
,
mask
,
dtype
,
getSubTab
()
);
arithm_op
(
_src1
,
_src2
,
_
dst
,
mask
,
dtype
,
getSubTab
()
);
}
void
cv
::
absdiff
(
InputArray
src1
,
InputArray
src2
,
OutputArray
dst
)
...
...
modules/core/test/test_arithm.cpp
浏览文件 @
629461c8
...
...
@@ -1580,12 +1580,21 @@ TEST_P(Mul1, One)
INSTANTIATE_TEST_CASE_P
(
Arithm
,
Mul1
,
testing
::
Values
(
Size
(
2
,
2
),
Size
(
1
,
1
)));
TEST
(
Subtract
8u8u16s
,
EmptyOutputMat
)
TEST
(
Subtract
,
EmptyOutputMat
)
{
cv
::
Mat
src1
=
cv
::
Mat
::
zeros
(
16
,
16
,
CV_8UC1
);
cv
::
Mat
src2
=
cv
::
Mat
::
zeros
(
16
,
16
,
CV_8UC1
);
cv
::
Mat
dst
;
cv
::
subtract
(
src1
,
src2
,
dst
,
cv
::
noArray
(),
CV_16S
);
ASSERT_FALSE
(
dst
.
empty
());
ASSERT_EQ
(
0
,
cv
::
countNonZero
(
dst
));
cv
::
Mat
dst1
,
dst2
,
dst3
;
cv
::
subtract
(
src1
,
src2
,
dst1
,
cv
::
noArray
(),
CV_16S
);
cv
::
subtract
(
src1
,
src2
,
dst2
);
cv
::
subtract
(
src1
,
cv
::
Scalar
::
all
(
0
),
dst3
,
cv
::
noArray
(),
CV_16S
);
ASSERT_FALSE
(
dst1
.
empty
());
ASSERT_FALSE
(
dst2
.
empty
());
ASSERT_FALSE
(
dst3
.
empty
());
ASSERT_EQ
(
0
,
cv
::
countNonZero
(
dst1
));
ASSERT_EQ
(
0
,
cv
::
countNonZero
(
dst2
));
ASSERT_EQ
(
0
,
cv
::
countNonZero
(
dst3
));
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录