全球最实用的IT互联网信息网站!

AI人工智能P2P分享&下载搜索网页发布信息网站地图

当前位置:诺佳网 > 电子/半导体 > 可编程逻辑 >

提高矢量化效率

时间:2018-10-15 03:14

人气:

作者:admin

标签: 内存  编程  C++ 

导读:Watch a demonstration on analyzing memory access patterns....

应用程序开发人员喜欢通过将应用程序的逻辑设计为不同对象实体之间的交互来坚持面向对象的编程风格。在这个过程中,每个实体都被建模为C++类或结构。结构数组(AOS)维护这些实体的集合,这使得代码更可读,更易于维护。但是,这种用户友好的代码可能会面临一个挑战时,涉及到矢量化效率。通常,由于在主存储器中以非单位步长的方式布置数据,所以收集用于填充向量寄存器所需的数据。为了使数据布局更加矢量友好,开发人员经常需要手动将数据结构从AoS更改为数组结构(SoA)。Intel的单指令多数据(SIMD)布局模板帮助开发人员在编程时保留AoS接口,但是在幕后,数据结构以SoA格式布局。这是一个双赢的解决方案,面向对象和矢量友好的编程。

本演示文稿演示了如何分析性能敏感循环中的内存访问模式,以及如何使布局模板能够尽可能地从常量和变量跨行内存访问更改为单元跨行内存访问。

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信