- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
利用MPI计算矩阵相乘简单算法
利用MPICH2计算矩阵相乘的简单算法
烤鱼片
cleverysm@
MPICH2是用来进行并行运算的平台,而对矩阵算法的分解应该是并行运算应用中很常见的。今天在这里就用MPICH2写一个矩阵乘法的并行计算程序来学习一下MPICH2的使用。
首先要复习一下矩阵乘法的算法,我们在线性代数里都学过。
假设矩阵A为m行,k列。m=4,k=3。B是k行,n列,k=3,n=2,计算一个矩阵与列数据,或者叫做一个向量vector的乘积,结果矩阵C应当是m行,n列。
A:
1,2,3
4,5,6
7,8,9
8,7,6
B:
5,4
3,2
1,0
A,B,C都按照行主序表示。即A(0,0)=1,A(0,1)=2, A(0,3)=3。
则
如C(1,0)=A(1,0)×B(0,0)+A(1,1)×B(1,0)+A(1,2)×B(2,0)=4×5+5×3+6×1=41 。
C:
14,8
41,26
68,44
67,46
那如何将这个算法进行分解,分配到参与计算的各进程上去呢?简单的做法是可以将矩阵A进行划分,每个计算进程分配若干行,每次与B的一列数据计算的时候分别计算其进程所分配的行与B的这一列相乘的结果。
比如有两个进程计算,分别为进程1和进程2。1分配A的0,和2行,2
分配A的1和3行,与B的0列计算的时候,1进程将只计算得到C的一列的0和2位置两个数据,而2进程则算得1和3位置的数据。两个进程个子计算完成相应位置的数据后组合起来就是C的一列结果数据。
在此,我使用MPI构建一种主-从(master-slave)模式的程序,也就是有一个进程是主进程,负责分发A矩阵的数据,并收集从进程的计算结果,将这些结果合并为最终的结果数据。这样整个程序需要一个主进程和若干个从进程,也就是至少要两个进程。
主进程的代码如下:
//主进程
int master()
{
int myid; //
int numprocs; //
MPI_Status status;
//获取当前进程的进程编号,保存在myid中
MPI_Comm_rank(MPI_COMM_WORLD,myid);
//获取当前进程的进程总数,保存在numprocs中
MPI_Comm_size(MPI_COMM_WORLD,numprocs);
int const M(4),K(3),N(2);
//结果矩阵C
int C[M*N];
int V[M];
//将结果矩阵各元素初始化为0
for(int i=0;iM*N;i++)
{
C[i]=0;
}
//C矩阵共N列数据
for(int i=0;iN;i++)
{
//从各从进程接受数据
for(int j=1;jnumprocs;j++)
{
MPI_Recv(V, M, MPI_INT, j, i, MPI_COMM_WORLD, status);
//将各从进程的部分数据整合成完整的一个向量
for(int ij=0;ijM;ij++)
{
C[ij*N+i]=C[ij*N+i]+V[ij];
}
}
}
//打印结果
for(int i=0;iM;i++)
{
for(int j=0;jN;j++)
{
coutC[i*N+j]\t;
}
coutendl;
}
return 0;
}
从进程代码:
//从进程
int slave()
{
int myid; //
int numprocs; //
MPI_Status status;
//获取当前进程的进程编号,保存在myid中
MPI_Comm_rank(MPI_COMM_WORLD,myid);
//获取当前进程的进程总数,保存在numprocs中
MPI_Comm_size(MPI_COMM_WORLD,numprocs);
int const M(4),K(3),N(2);
vectorint indexes;
int V[M];
int A[M*K]={1,2,3,4,5,6,7,8,9,8,7,6};
int B[K*N]={5,4,3,2,1,0};
//计算本进程分配A矩阵中哪些行,保存在indexes中
//比如2个从进程,A是4行数据,id为1的从进程分配的是0和2行
for(int i=myid-1;iM;i+=numprocs-1)
{
indexes.push_back(i);
}
//依次计算B的N列数据
for(int i=0;iN;i++)
{
//将保存列数据的向量V各元素初始化为0
for(int j=0;jM;j+
您可能关注的文档
- 关于农村用水问题调研报告 .doc
- 关于利用数码照片资料加强输变电工程安全质量过程控制有关要求.doc
- 关于制定2007级教学计划指导性意见.doc
- 关于制订“动画”专业人才培养方案几点体会.doc
- 关于加强中小河流治理项目验收管理指导意见.doc
- 关于化妆品市场调研报告.doc
- 关于历史地区保护及其当代作用建议.doc
- 关于吊车出租管理办法.doc
- 关于周至猕猴桃产业销售问题调查与思考.doc
- 关于员工工资水平影响因素spss数据分析报告1.doc
- 2025中国冶金地质总局所属在京单位高校毕业生招聘23人笔试参考题库附带答案详解.doc
- 2025年01月中国人民大学文学院公开招聘1人笔试历年典型考题(历年真题考点)解题思路附带答案详解.doc
- 2024黑龙江省农业投资集团有限公司权属企业市场化选聘10人笔试参考题库附带答案详解.pdf
- 2025汇明光电秋招提前批开启笔试参考题库附带答案详解.pdf
- 2024中国能建葛洲坝集团审计部公开招聘1人笔试参考题库附带答案详解.pdf
- 2024吉林省水工局集团竞聘上岗7人笔试参考题库附带答案详解.pdf
- 2024首发(河北)物流有限公司公开招聘工作人员笔试参考题库附带答案详解.pdf
- 2023国家电投海南公司所属单位社会招聘笔试参考题库附带答案详解.pdf
- 2024湖南怀化会同县供水有限责任公司招聘9人笔试参考题库附带答案详解.pdf
- 2025上海烟草机械有限责任公司招聘22人笔试参考题库附带答案详解.pdf
最近下载
- 广东梅州市嘉城建设集团有限公司招聘笔试题库2025.pdf
- 危险化学品的分类和品种目录.docx VIP
- 2024辽宁农业科学院所属事业单位招聘30人历年公开引进高层次人才和急需紧缺人才笔试参考题库(共500题)答案详解版.docx
- 《电子CAD技术》教学课件:第4章 印制电路板设计基础.ppt VIP
- 老年患者临床营养管理服务规范--公布版2022.5.2.(1).pdf VIP
- 2019人教版小学六年级数学上册全册教案.docx VIP
- 高维之境:图模型与多变点检测的统计推断新探.docx
- 广东嘉城建设集团有限公司及其下属公司招聘笔试题库2025.pdf
- 河北省生产经营单位安全培训教育档案(最新版-冀应急人(2019)50号).docx VIP
- 加强医德医风建设的重要性.docx
文档评论(0)