Cannon矩阵乘法的MPI实现及性能分析

上传人:飞*** 文档编号:44926188 上传时间:2018-06-14 格式:DOC 页数:8 大小:45KB
返回 下载 相关 举报
Cannon矩阵乘法的MPI实现及性能分析_第1页
第1页 / 共8页
Cannon矩阵乘法的MPI实现及性能分析_第2页
第2页 / 共8页
Cannon矩阵乘法的MPI实现及性能分析_第3页
第3页 / 共8页
Cannon矩阵乘法的MPI实现及性能分析_第4页
第4页 / 共8页
Cannon矩阵乘法的MPI实现及性能分析_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《Cannon矩阵乘法的MPI实现及性能分析》由会员分享,可在线阅读,更多相关《Cannon矩阵乘法的MPI实现及性能分析(8页珍藏版)》请在金锄头文库上搜索。

1、#include #include #include #include #include #include MPI_Status status;double *A, *B, *C; /C=A*Bdouble *a,*b,*c; /各个进程的缓冲区int n; /矩阵的行列数int np; /每个进程控制的小矩阵的行列数int p,rank; /进程个个数、当前进程的编号,笛卡尔进程编号double *tempa, *tempb;void ProduceABC(); /在根处理器中生成矩阵 AB,初始化矩阵 Cvoid PrintABC();/输出结果void ScatterAB();/ 分发矩

2、阵 AB 中的元素到各个进程中void MainProcess(); /cannon 算法的主过程void collectC(); /收集结果矩阵 Cvoid Mutiply(); /矩阵相乘void Printab();void Printc();int main(int argc, char *argv) int i;double starttime,endtime;MPI_Init(MPI_Comm_size(MPI_COMM_WORLD, MPI_Comm_rank(MPI_COMM_WORLD, if(rank = 0)printf(“请输入矩阵的行列数 n= “); fflush(

3、stdout);scanf_s(“%d“, printf(“n“);MPI_Bcast(/ n = atoi(argv1);np = n/(int)sqrt(p);a = (double*)malloc(np*np*sizeof(double);b = (double*)malloc(np*np*sizeof(double);c = (double*)malloc(np*np*sizeof(double);memset(c, 0, np*np*sizeof(double);tempa = (double*)malloc(np*np*sizeof(double);tempb = (double*

4、)malloc(np*np*sizeof(double); if(rank = 0) /在根处理器中为矩阵 ABC 分配空间A = (double*)malloc(n*sizeof(double*);B = (double*)malloc(n*sizeof(double*);C = (double*)malloc(n*sizeof(double*);for(i = 0; i n; i+)Ai = (double*)malloc(n*sizeof(double);Bi = (double*)malloc(n*sizeof(double);Ci = (double*)malloc(n*sizeof

5、(double);ProduceABC(); /在根处理器中随机生成矩阵 AB,初始化矩阵 CScatterAB();/ 分发矩阵 AB 中的元素到各个进程中 elseMPI_Recv(a, np*np, MPI_DOUBLE, 0, 1, MPI_COMM_WORLD, MPI_Recv(b, np*np, MPI_DOUBLE, 0, 2, MPI_COMM_WORLD, starttime=MPI_Wtime(); /开始时间MainProcess(); /cannon 算法的主过程if(rank = 0)collectC(); /收集结果矩阵 CPrintABC(); /输出结果end

6、time=MPI_Wtime();printf(“time used: %lfn“,endtime - starttime);for(i = 0; i n; i+)free(Ai);free(Bi);free(Ci);free(A);free(B);free(C);elseMPI_Send(c, np*np, MPI_DOUBLE, 0, 1, MPI_COMM_WORLD);free(a);free(b);free(c);free(tempa);free(tempb);MPI_Finalize();return 0;void ProduceABC()/在根处理器中生成矩阵 AB int i,

7、j;for(i=0; in; i+)for(j=0; jn; j+)Aij=1.0;Bij=1.0;Cij=0.0;void PrintABC()/输出结果printf(“A00=%fnB00=%fnC00=%fn“,A00,B00,C00); void ScatterAB()/ 分发矩阵 AB 中的元素到各个进程中int imin,imax,jmin,jmax;int sp;int i,j,k,m;for(k=0; kp; k+)/*计算相应处理器所分得的矩阵块在总矩阵中的坐标范围*/sp = (int)sqrt(p);imin = (k / sp) * np;imax = imin + n

8、p - 1; jmin = (k % sp) * np;jmax = jmin + np -1;/*rank=0 的处理器将 A,B 中的相应块拷至 tempa,tempb,准备向其他处理器发送*/m = 0; for(i=imin; i=imax; i+)for(j=jmin; j=jmax; j+)tempam = Aij;tempbm = Bji; /矩阵 B 按列优先存储m+;/*根处理器将自己对应的矩阵块从 tempa,tempb 拷至 a,b*/if(k=0)memcpy(a, tempa, np*np*sizeof(double);memcpy(b, tempb, np*np*s

9、izeof(double); else /*根处理器向其他处理器发送 tempa,tempb 中相关的矩阵块*/MPI_Send(tempa, np*np, MPI_DOUBLE, k, 1, MPI_COMM_WORLD);MPI_Send(tempb, np*np, MPI_DOUBLE, k, 2, MPI_COMM_WORLD);void MainProcess() /cannon 算法的主过程MPI_Comm comm; /笛卡尔结构通讯器int crank;int dims2,periods2, coords2;int source, dest, up, down, right,

10、left;int i;dims0 = dims1 = (int)sqrt(p);periods0 = periods1 = 1;MPI_Cart_create(MPI_COMM_WORLD, 2, dims, periods, 1, MPI_Comm_rank(comm, MPI_Cart_coords(comm, crank, 2, coords);MPI_Cart_shift(comm, 1, -1, MPI_Cart_shift(comm, 0, -1, MPI_Cart_shift(comm, 1, -coords0, MPI_Sendrecv_replace(a, np*np, MP

11、I_DOUBLE, dest, 1, source, 1, comm, MPI_Cart_shift(comm, 0, -coords1, MPI_Sendrecv_replace(b, np*np, MPI_DOUBLE, dest, 1, source, 1, comm, Mutiply(); /矩阵相乘for(i = 1; i dims0; i+)MPI_Sendrecv_replace(a, np*np, MPI_DOUBLE, left, 1, right, 1, comm, MPI_Sendrecv_replace(b, np*np, MPI_DOUBLE, up, 1, down

12、, 1, comm, Mutiply(); /矩阵相乘MPI_Comm_free(void collectC() /收集结果矩阵 Cint i,j,k,s,m;int imin,imax,jmin,jmax;int sp= (int)sqrt(p);/* 根处理器中的 c 赋给总矩阵 C */for (i=0;inp;i+)for(j=0;jnp;j+)Cij=ci*np+j;for (k=1;kp;k+)/*根处理器从其他处理器接收相应的分块 c*/MPI_Recv(c, np*np, MPI_DOUBLE, k, 1, MPI_COMM_WORLD, /printf(“rank = %dn

13、“, k);Printc();imin = (k / sp) * np;imax = imin + np - 1; jmin = (k % sp) * np;jmax = jmin + np -1;/*将接收到的 c 拷至 C 中的相应位置,从而构造出 C*/for(i=imin,m=0; i=imax; i+,m+)for(j=jmin,s=0; j=jmax; j+,s+)Cij=cm*np+s; void Mutiply() /矩阵相乘int i,j,k;for(i=0; inp; i+)for(j=0; jnp; j+)for(k=0; knp; k+)ci*np+j += ai*np+k*bj*np+k; /b 按列优先来搞注意:1.以.c 来编译2.realease 需单独配环境,并以 realease 跑比较快3.64 位的 mpich2 要以 x64 平台编译,否则通不过4.mpiexec 中一定要勾选以单独窗口运行,否则跑不动5.矩阵乘法,第二个矩阵按列优先存储性能提升数倍。若以二维存储,先转置再乘,同样的效果。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号