OpenBLAS 中矩阵运算函数学习

简介: OpenBLAS 中矩阵运算函数学习

GEMM 是矩阵乘法最成熟的优化计算方式,也有很多现成的优化好的库可以调用。


OpenBLAS 矩阵计算


OpenBLAS 库实现成熟优化的矩阵与矩阵乘法的函数 cblas_sgemm 和矩阵与向量乘法函数 cblas_sgemv,二者使用方法基本相同,参数较多,所以对参数的使用做个记录。


矩阵与矩阵乘法


cblas_sgemm 计算的矩阵公式:C=alpha*A*B+beta*C,其中 ABC 都是矩阵,C 初始中存放的可以是偏置值。

cblas_sgemm 函数定义:

cblas_sgemm(layout, transA, transB, M, N, K, alpha, A, LDA, B, LDB, beta, C, LDC);

  • layout:存储格式,有行主序(CblasRowMajor)和列主序(CblasColMajor),C/C++ 一般是行主序。
  • transAA 矩阵是否需要转置。
  • transBB 矩阵是否需要转置。
  • MNKA 矩阵经过 transA 之后的维度是 M*KB 矩阵经过 transB 之后的维度是 K*NC 矩阵的维度是 M*N
  • LDALDBLDC矩阵在 trans (如果需要转置)之前,在主维度方向的维度(如果是行主序,那这个参数就是列数)。

示例代码:


#include <stdio.h>
#include <cblas.h>
int main() {
  int i, j;
  float a[6]={1,3,5,2,7,8};
  float b[6]={5,3,7,2,4,2};
  float c[6]={0,0,0,0,0,0};
  cblas_sgemm(CblasRowMajor, CblasTrans, CblasTrans, 3, 3, 2, 1.0, a, 3, b, 2, 0.0, c, 3);
  for(i = 0; i < 3; ++i){
    for(j = 0; j < 3; ++j){
      printf("%f ", c[i*3+j]);
    }
    printf("\n");
  }
  return 1;
}


代码解释:

在主函数中,定义了三个数组a、b和c,分别表示两个矩阵和它们的乘积。然后调用了BLAS库中的函数cblas_sgemm,该函数用于矩阵乘法的计算。该函数有很多参数,其中:

  • CblasRowMajor:表示矩阵是行主序(row-major)的,即按行存储;
  • CblasTrans:表示矩阵是转置的;
  • 3和2:表示矩阵的行数和列数;
  • 1.0和0.0:表示乘法中的加法和乘法的因子;
  • a和b:表示两个矩阵的数据;
  • c:表示乘积的结果;
  • 3和2:表示矩阵的列数和行数。

最后,通过两个for循环打印出乘积矩阵c的值。


矩阵与向量乘法


矩阵与向量乘法本质也是矩阵与矩阵,只不过 gemvgemm 要快一些,所以有时候也需要用 gemv。计算式:C=alpha*A*b+beta*C

cblas_sgemv 函数定义:

cblas_sgemv(layout, trans, M, N, alpha, A, LDA, b, 1, beta, C, 1)

参数的定义基本和 gemm 相同,MNA 的行数和列数,bC 的列数都是 1。

目录
相关文章
|
7月前
线性代数介绍和矩阵运算
线性代数介绍和矩阵运算
|
4月前
|
机器学习/深度学习 人工智能 PyTorch
掌握 PyTorch 张量乘法:八个关键函数与应用场景对比解析
PyTorch提供了几种张量乘法的方法,每种方法都是不同的,并且有不同的应用。我们来详细介绍每个方法,并且详细解释这些函数有什么区别:
86 4
掌握 PyTorch 张量乘法:八个关键函数与应用场景对比解析
|
4月前
|
机器学习/深度学习 Serverless 数据处理
《零基础实践深度学习》 Numpy 线性代数 应用举例 张量表示
这篇文章介绍了NumPy在线性代数中的应用,包括矩阵操作和文件读写功能,并提供了使用NumPy进行图片处理和激活函数计算的示例,同时探讨了飞桨框架中张量(Tensor)的使用和与NumPy数组的转换。
|
5月前
|
Java Apache Python
矩阵运算是
【7月更文挑战第4天】
49 2
|
7月前
|
机器学习/深度学习 搜索推荐 数据挖掘
矩阵运算与分解:NumPy的高级应用
【4月更文挑战第17天】NumPy是Python数值计算基础库,支持高效矩阵运算和分解。本文介绍了NumPy的矩阵加减、乘法以及特征值、奇异值和Cholesky分解,并展示了它们在机器学习(如线性回归、PCA)、图像处理和科学计算中的应用。通过掌握这些高级功能,用户能更有效地处理矩阵数据,解决各种计算和分析任务。
|
机器学习/深度学习 人工智能 PyTorch
【Pytorch神经网络理论篇】 02 Pytorch快速上手(二)GPU与CPU张量切换+具有随机值的张量+张量的数学运算
【Pytorch神经网络理论篇】 02 Pytorch快速上手(二)GPU与CPU张量切换+具有随机值的张量+张量的数学运算
190 0
|
TensorFlow 算法框架/工具 索引
《30天吃掉那只 TensorFlow2.0》 4-2 张量的数学运算
《30天吃掉那只 TensorFlow2.0》 4-2 张量的数学运算
《30天吃掉那只 TensorFlow2.0》 4-2 张量的数学运算
|
机器学习/深度学习 数据挖掘 PyTorch
PyTorch: 张量的变换、数学运算及线性回归
PyTorch: 张量的变换、数学运算及线性回归
121 0
PyTorch: 张量的变换、数学运算及线性回归
|
Python
矩阵运算
矩阵运算
160 0