ARM NEON - RGB转灰度的实现 (DSP Factory学习总结)

本文介绍了通过DSPFactory工程学习NEON指令集,特别是针对memcpy和RGB转灰度的NEON实现。作者强调了NEON处理向量数据的效率提升,但指出其对内存对齐的严格要求。提供了两个RGB转灰度的函数对比,以及ARMv8架构下启用NEON的编译选项,并提醒读者需通过测试验证性能提升。附带了相关资源链接和《NEON Programmer’s Guide》等参考资料。
摘要由CSDN通过智能技术生成

DSP Factory是B站up主的一个开源工程,不是我,我只是从这个工程中学到了NEON的知识,这里做一下总结。对我有用的地方有2个,一个是memcpy,另一个是RGB转Gray的NEON实现。

配套有2个视频,第一个14分钟讲了数据格式和介DSP Factory工程本身。

https://www.bilibili.com/video/BV1dq4y157NA

第二个45分钟的视频讲解了DSP Factory里面函数的使用方法。

https://www.bilibili.com/video/BV1V64y1X7Eo

这里给出了DSP Factory的地址,翻墙可以获取

dsp_factory: https://github.com/leonard73/dsp_factory

我这里将里面的重点列一下。

所谓的D register,也就是double精度的register,使用64bit,同样的,Q的意思是quadruple,4倍精度,占用128bit。
在这里插入图片描述
在这里插入图片描述
这些数据结构,可以将我们平时使用的标数据转为向量数据。如右图,如果512个uint16的数组,如果每次处理16bit,需要处理512次;而将64bit做为一个向量来处理,只需处理128次。

但是使用NEON是有限制的:NEON对内存的对齐是强制依赖的。因为使用的是D或者Q register,必须填充完毕,这样才能发挥SIMD的优势。
在这里插入图片描述
在这里插入图片描述
下面是RGB888单独提出各通道数据的实现
在这里插入图片描述
下面是RGB转灰度的公式
在这里插入图片描述
普通的实现和NEON的实现,可以在DSP Factory的NeonRgb2Gray.c 里面查看到
在这里插入图片描述

void do_RGB2GRAY_I16_Neon(unsigned char *src, unsigned char * dst, unsigned int width, unsigned int height)

void do_RGB2GRAY_I16(unsigned char *src, unsigned char * dst, unsigned int width, unsigned int height)

可以将这2个函数对比着看,收获会更大。

有用的tips:

1.ARMv8之后的架构才支持NEON

2.在编译选项启用 NEON 的配置是 -mfpu=neon

3.NEON是强制对齐的

4.数组能否被64或者128bit对齐,是能否使用NEON API的关键

5.未加速和使用NEON的函数,需要测试才能够确定是否达到预期

备注:

《NEON Programmer’s Guide》

ARM 官方指令查询

gcc 在线API 查询

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

魔尊moon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值