BLAS 在矩阵乘法方面的卓越性能
您已经见证了您自己的矩阵乘法函数与布拉斯。这就提出了两个问题:
1。 BLAS 如何实现极致性能?
BLAS 根据复杂度和优化技术分为三个级别:
2.为什么您的实现速度较慢?
您的实现缺乏 BLAS 使用的缓存优化。矩阵-矩阵乘法中的 O(N^3) 运算会导致内存和缓存之间发生大量数据移动。通过实现最大限度地减少缓存冲突的专用算法,BLAS 显着加速了这一过程。
虽然现代编译器有助于优化代码,但它们无法完全弥补 BLAS 实现中使用的专业技术(如 ATLAS、GotoBLAS 和 OpenBLAS)。
BLAS 使用的算法
BLAS 不使用像 Coppersmith–Winograd 或 Strassen 这样的复杂算法,因为:
以上是为什么 BLAS 比我的矩阵乘法实现快得多?的详细内容。更多信息请关注PHP中文网其他相关文章!