我的mpi学习实践

来源:互联网 发布:python ma优化 编辑:程序博客网 时间:2024/05/19 23:26

基本学习篇

参考<并行计算导论>一书,进行学习:


安装

mpich下载地址
按照INSTALL的步骤进行安装.

编译链接执行

编译:mpicc -c cpi.c
链接:mpicc -o cpi cpi.o
执行:mpiexec -n 3 cpi //-n代表单机上使用几个节点跑

\examples\有很多例子,可以跑一些结果试试.

计算积分的例子(第一个mpi程序)

/* 程序来源: MPICH examples/cpi.c */#include "mpi.h"#include <stdio.h>double f( double a ) { return (4.0 / (1.0 + a*a)); }int main( int argc, char *argv[]){int n, myid, numprocs, i, namelen;double PI25DT = 3.141592653589793238462643;double mypi, pi, h, sum, x;double startwtime, endwtime;char processor_name[MPI_MAX_PROCESSOR_NAME];14MPI_Init(&argc,&argv);MPI_Comm_size(MPI_COMM_WORLD,&numprocs);MPI_Comm_rank(MPI_COMM_WORLD,&myid);MPI_Get_processor_name(processor_name,&namelen);fprintf(stderr,"Process %d on %s\n", myid, processor_name);if (myid == 0) {n=10000;startwtime = MPI_Wtime();}MPI_Bcast(&n, 1, MPI_INT, 0, MPI_COMM_WORLD);h = 1.0 / (double) n;sum = 0.0;for (i = myid; i < n; i += numprocs) {x = h * ((double)i + 0.5);sum += f(x);}mypi = h * sum;MPI_Reduce(&mypi, &pi, 1, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD);if (myid == 0) {endwtime = MPI_Wtime();printf("pi is approximately %.16f, error is %.16f\n", pi, pi - PI25DT);printf("wall clock time = %f\n", endwtime-startwtime);}MPI_Finalize();return 0;}
0 0
原创粉丝点击