Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Opencv
提交
c1745539
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,发现更多精彩内容 >>
提交
c1745539
编写于
10月 05, 2016
作者:
K
k-shinotsuka
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add simd code when dcn equals 4 at HLS2RGB_b().
上级
e0435d3b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
28 addition
and
0 deletion
+28
-0
modules/imgproc/src/color.cpp
modules/imgproc/src/color.cpp
+28
-0
未找到文件。
modules/imgproc/src/color.cpp
浏览文件 @
c1745539
...
...
@@ -4974,6 +4974,7 @@ struct HLS2RGB_b
v_alpha
=
vdup_n_u8
(
ColorChannel
<
uchar
>::
max
());
#elif CV_SSE2
v_scale
=
_mm_set1_ps
(
255.
f
);
v_alpha
=
_mm_set1_ps
(
ColorChannel
<
uchar
>::
max
());
v_zero
=
_mm_setzero_si128
();
haveSIMD
=
checkHardwareSupport
(
CV_CPU_SSE2
);
#endif
...
...
@@ -5125,6 +5126,32 @@ struct HLS2RGB_b
if
(
jr
)
dst
-=
jr
,
j
-=
jr
;
}
else
if
(
dcn
==
4
&&
haveSIMD
)
{
for
(
;
j
<=
(
dn
*
3
-
12
);
j
+=
12
,
dst
+=
16
)
{
__m128
v_buf0
=
_mm_mul_ps
(
_mm_load_ps
(
buf
+
j
),
v_scale
);
__m128
v_buf1
=
_mm_mul_ps
(
_mm_load_ps
(
buf
+
j
+
4
),
v_scale
);
__m128
v_buf2
=
_mm_mul_ps
(
_mm_load_ps
(
buf
+
j
+
8
),
v_scale
);
__m128
v_ba0
=
_mm_unpackhi_ps
(
v_buf0
,
v_alpha
);
__m128
v_ba1
=
_mm_unpacklo_ps
(
v_buf2
,
v_alpha
);
__m128i
v_src0
=
_mm_cvtps_epi32
(
_mm_shuffle_ps
(
v_buf0
,
v_ba0
,
0x44
));
__m128i
v_src1
=
_mm_shuffle_epi32
(
_mm_cvtps_epi32
(
_mm_shuffle_ps
(
v_ba0
,
v_buf1
,
0x4e
)),
0x78
);
__m128i
v_src2
=
_mm_cvtps_epi32
(
_mm_shuffle_ps
(
v_buf1
,
v_ba1
,
0x4e
));
__m128i
v_src3
=
_mm_shuffle_epi32
(
_mm_cvtps_epi32
(
_mm_shuffle_ps
(
v_ba1
,
v_buf2
,
0xee
)),
0x78
);
__m128i
v_dst0
=
_mm_packs_epi32
(
v_src0
,
v_src1
);
__m128i
v_dst1
=
_mm_packs_epi32
(
v_src2
,
v_src3
);
_mm_storeu_si128
((
__m128i
*
)
dst
,
_mm_packus_epi16
(
v_dst0
,
v_dst1
));
}
int
jr
=
j
%
3
;
if
(
jr
)
dst
-=
jr
,
j
-=
jr
;
}
#endif
for
(
;
j
<
dn
*
3
;
j
+=
3
,
dst
+=
dcn
)
...
...
@@ -5145,6 +5172,7 @@ struct HLS2RGB_b
uint8x8_t
v_alpha
;
#elif CV_SSE2
__m128
v_scale
;
__m128
v_alpha
;
__m128i
v_zero
;
bool
haveSIMD
;
#endif
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录