博客
关于我
【端智能】MNN CPU性能优化年度小结
阅读量:160 次
发布时间:2019-02-27

本文共 1188 字,大约阅读时间需要 3 分钟。

MNN推理引擎优化一年:性能提升与架构适配

自2020年5月MNN1.0.0版本发布以来,我们持续发力于推理引擎的性能优化与硬件适配,致力于打造通用性强、性能领先的推理解决方案。

架构改造:为多架构制定基础

为了支持更多指令集与精度选择,我们对引擎架构进行了全面改造。这一改造不仅降低了后续优化成本,更为后续对各类硬件和精度模式的支持奠定了基础。

几何计算:简化算子,提升性能

几何计算机制通过分离坐标映射部分,将复杂算子如Slice-TF、Pack、Unpack等简化,显著提升了CPU上的性能。这种机制在ARM架构和其他移动端硬件上表现尤为突出。

算子统一:降低实现复杂度

卷积、反卷积等核心算子在不同精度和硬件上有多种实现方案。MNN通过统一实现这些算子,确保在不同硬件和精度下都能达到最优性能。这种统一机制不仅简化了开发流程,更为后续优化奠定了坚实基础。

矩阵乘与卷积优化:提升SIMD效率

在矩阵乘和卷积算子的实现中,我们通过优化SIMD指令,显著提升了计算效率。特别是在ARMv8架构上,我们实现了更高效的内存访问策略,进一步降低了计算延迟。

ARM架构优化:挖掘硬件潜能

针对ARM架构,我们对存储指令和SIMD指令进行了深度优化,提升了矩阵乘和卷积的执行效率。这种优化使得MNN在ARM硬件上的运行性能得到了显著提升。

x64架构:兼顾性能与兼容性

在x64架构中,我们重点优化了AVX2和AVX512指令集。通过深度调优,MNN在AVX2上的性能提升达70%-100%,而在AVX512架构上,浮点矩阵乘的速度提升了60%,量化计算加速了200%。

低精度计算:精度与效率的平衡

我们支持了多种低精度计算模式,包括半精度浮点(FP16)和BF16。这些模式不仅减少了内存占用,还显著提升了计算效率。在ARMv8.2架构上,FP16计算实现了双倍性能提升。

量化计算:深化性能提升

通过Overflow-Aware、Winograd-Aware等量化算法,我们进一步优化了矩阵乘和卷积的执行效率。特别是在ARM架构上,这些算法使得量化模型的推理速度提升了30%以上。

横向对比:MNN的性能优势

经过一年的持续优化,MNN在ARM/ARMv8.2架构上的性能提升达10%-20%,而在x64架构上表现尤为突出。与其他开源框架如Bolt、TNN、Mindspore-lite和TFlite的对比,MNN在CPU性能上展现了显著优势。

未来展望:持续创新与优化

随着新硬件架构和压缩算法的不断涌现,MNN将继续秉持通用性为基础、适配新硬件特性的理念,持续优化推理性能,为算法部署提供更强的支持。

通过全面的架构优化、算子统一和硬件适配,MNN在推理引擎领域展现了强大的技术实力和市场潜力。我们将继续在性能优化与生态建设中深耕,让更多开发者能够轻松体验MNN的优势。

转载地址:http://lihf.baihongyu.com/

你可能感兴趣的文章
oracle script
查看>>
Oracle select表要带双引号的原因
查看>>
Oracle SOA Suit Adapter
查看>>
Oracle Spatial GeoRaster 金字塔栅格存储
查看>>
Oracle spatial 周边查询SQL
查看>>
Oracle Spatial空间数据库建立
查看>>
UML— 活动图
查看>>
oracle sqlplus已停止工作,安装完成客户端后sqlplus报“段错误”
查看>>
oracle SQLserver 函数
查看>>
oracle sql分组(group,根据多个内容分组)在select之后from之前 再进行select查询,复杂子查询的使用
查看>>
Oracle Statspack分析报告详解(一)
查看>>
oracle tirger_在Oracle中,临时表和全局临时表有什么区别?
查看>>
Oracle Validated Configurations 安装使用 说明
查看>>
oracle where 条件的执行顺序分析1
查看>>
oracle 中的 CONCAT,substring ,MINUS 用法
查看>>
Oracle 中的 decode
查看>>
oracle 中表一对多取多方的最新的一条数据
查看>>
oracle 使用 PL/SQL Developer创建表并插入单条、多条数据
查看>>
oracle 使用leading, use_nl, rownum调优
查看>>
oracle 修改字段类型方法
查看>>