MPI和OpenMP实现矩阵相乘

MPI和OpenMP实现矩阵相乘

一、MPI实现矩阵相乘

  1. 首先要配置要MPI多节点集群环境,没有配置好的可以参考我的上一篇文章

  2. 原理:

    1. A×B=CA\times B=CA×B=C ,这里矩阵 A,B,CA,B,CABC 大小都为 N×NN \times NN×N ,代码中默认为128

    2. main节点将矩阵 AAA 按行分成多段后,发给salve节点

    3. main节点将矩阵 BBB 整体发给slave节点

    4. salve节点接受main节点传过来的 A,BA,BA,B 然后利用下面公式计算 CijC_{ij}Cij 然后传回给main节点

Cij=∑k=1NAik×Bkj C_{ij} = \sum_{k=1}^{N}A_{ik}\times B_{kj} Cij=k=1NAik×Bkj
3. 运行:

  1. 编写一个profile文件,里面是关于节点的配置,仅main节点需要,内容如下
   node01:2
   node02:2
  1. 编写源代码文件gemm.cpp,两个虚拟机都需要

  2. 编译gemm.cpp文件,两个虚拟机都需要编译

   mpic++ gemm.cpp -o gemm
  1. mpi
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值