Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
ad3186ed
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,发现更多精彩内容 >>
提交
ad3186ed
编写于
4月 26, 2018
作者:
A
Alexander Alekhin
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #11400 from alalek:ipp_norm_L1_16UC3_mask
上级
331af82e
57dad685
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
23 addition
and
0 deletion
+23
-0
modules/core/src/norm.cpp
modules/core/src/norm.cpp
+5
-0
modules/core/test/test_arithm.cpp
modules/core/test/test_arithm.cpp
+18
-0
未找到文件。
modules/core/src/norm.cpp
浏览文件 @
ad3186ed
...
...
@@ -1005,6 +1005,11 @@ static bool ipp_norm(InputArray _src1, InputArray _src2, int normType, InputArra
type
==
CV_16UC3
?
(
ippiMaskNormDiffFuncC3
)
ippiNormDiff_L2_16u_C3CMR
:
type
==
CV_32FC3
?
(
ippiMaskNormDiffFuncC3
)
ippiNormDiff_L2_32f_C3CMR
:
0
)
:
0
;
if
(
cv
::
ipp
::
getIppTopFeatures
()
&
ippCPUID_AVX2
)
// IPP_DISABLE_NORM_16UC3_mask_small (#11399)
{
if
(
normType
==
NORM_L1
&&
type
==
CV_16UC3
&&
sz
.
width
<
16
)
return
false
;
}
if
(
ippiNormDiff_C3CMR
)
{
Ipp64f
norm1
,
norm2
,
norm3
;
...
...
modules/core/test/test_arithm.cpp
浏览文件 @
ad3186ed
...
...
@@ -2084,4 +2084,22 @@ TEST(Core_Set, regression_11044)
EXPECT_EQ
(
std
::
numeric_limits
<
double
>::
infinity
(),
testDouble
.
at
<
double
>
(
0
,
0
));
}
TEST
(
Core_Norm
,
IPP_regression_NORM_L1_16UC3_small
)
{
int
cn
=
3
;
Size
sz
(
9
,
4
);
// width < 16
Mat
a
(
sz
,
CV_MAKE_TYPE
(
CV_16U
,
cn
),
Scalar
::
all
(
1
));
Mat
b
(
sz
,
CV_MAKE_TYPE
(
CV_16U
,
cn
),
Scalar
::
all
(
2
));
uchar
mask_
[
9
*
4
]
=
{
255
,
255
,
255
,
0
,
255
,
255
,
0
,
255
,
0
,
0
,
255
,
0
,
0
,
255
,
255
,
255
,
255
,
0
,
0
,
0
,
0
,
255
,
0
,
255
,
0
,
255
,
255
,
0
,
0
,
255
,
0
,
255
,
255
,
255
,
0
,
255
};
Mat
mask
(
sz
,
CV_8UC1
,
mask_
);
EXPECT_EQ
((
double
)
9
*
4
*
cn
,
cv
::
norm
(
a
,
b
,
NORM_L1
));
// without mask, IPP works well
EXPECT_EQ
((
double
)
20
*
cn
,
cv
::
norm
(
a
,
b
,
NORM_L1
,
mask
));
}
}}
// namespace
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录