博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[转]MPI--MPI+VS2010 配置及编译
阅读量:6258 次
发布时间:2019-06-22

本文共 2275 字,大约阅读时间需要 7 分钟。

一  下载mpi for windows

     在这一块我浪费了很多时间。首先windows下(自己电脑的多核)和一般的工作站是不一样的。windos为了兼容mpi,自己做了一个基于一般电脑的MPI实现,如果要安装真正意义的mpi,在intel上有。我这里是为了在自己笔记本上学习mpi,用的是微软的HPC Pack 2008 R2 MS-MPI Redistributable Package with Service Pack 4。

   不过如果是想在自己笔记本上用fortran版的mpi,即用fortran编译mpi,那么和这里的不一样。这里是c的。fortran的以后添加。

二 安装mpi

   我的电脑是64位的,所以安装的是mpi_x64.msi,安在C:\Program Files\Microsoft HPC Pack 2008 R2,

三 配置vs2010

   3.1配置目录,即加载Include和Lib库

 3.2配置运行库

 

3.3预处理处理,这里至于为什么,我没搞懂,

 

3.4加载依赖项

 

四 编译

这是一个测试例子,在vs2010下编译生成xx.exe文件(具体看自己的命名)

  1. 1 /* 2   功能:mpi点对点通信 3   时间:2012.12.13 4 */ 5 #include
    6 #include
    7 #include"mpi.h" 8 9 #define BUFLEN 51210 int main(int argc, char *argv[])11 {12 int myid,numprocs,next,namelen;13 char buffer[BUFLEN],processor_name[MPI_MAX_PROCESSOR_NAME];14 MPI_Status status;15 16 //17 MPI_Init(&argc, &argv);18 MPI_Comm_size(MPI_COMM_WORLD, &numprocs);19 MPI_Comm_rank(MPI_COMM_WORLD, &myid);20 MPI_Get_processor_name(processor_name, &namelen);21 22 printf("Process %d on %s \n", myid, processor_name);23 printf("Process %d of %d \n", myid, numprocs);24 memset(buffer, 0, BUFLEN*sizeof(char));25 if(myid == numprocs-1)26 {27 next = 0;28 }29 else30 {31 next = myid+1;32 }33 if(myid == 0)34 {35 strcpy(buffer,"hello there");36 printf("%d sending '%s' \n",myid, buffer);fflush(stdout);37 MPI_Send(buffer,strlen(buffer)+1, MPI_CHAR, next, 99, MPI_COMM_WORLD);38 printf("%d receving \n", myid);fflush(stdout);39 MPI_Recv(buffer, BUFLEN, MPI_CHAR, MPI_ANY_SOURCE, 99, MPI_COMM_WORLD, &status);40 printf("%d received '%s' \n", myid, buffer);fflush(stdout);41 }42 else43 {44 printf("%d receiving \n",myid);fflush(stdout);45 MPI_Recv(buffer, BUFLEN, MPI_CHAR, MPI_ANY_SOURCE, 99, MPI_COMM_WORLD, &status);46 printf("%d received '%s' \n", myid, buffer);fflush(stdout);47 MPI_Send(buffer,strlen(buffer)+1, MPI_CHAR, next, 99, MPI_COMM_WORLD);48 printf("%d sending '%s' \n",myid, buffer);fflush(stdout);49 }50 MPI_Finalize();51 return 0;52 }

     

五 运行

因为mpi是有命令行输入的,需要mpiexec.exe来运行:

具体的命令可以help 一下,自己摸索吧

转载于:https://www.cnblogs.com/mrbin/p/3469303.html

你可能感兴趣的文章
安装Jenkins getting started卡住
查看>>
金软PDF转换(x-PDFConper)
查看>>
喵哈哈村的魔法考试 Round #15 (Div.2) 题解
查看>>
使用架构(XSD)验证XML文件
查看>>
Android开发之httpclient文件上传实现
查看>>
极客头条使用心得
查看>>
CSS解决无空格太长的字母,数字不会自己主动换行的问题
查看>>
日志打印longging模块(控制台和文件同时输出)
查看>>
这些年我们一起搞过的持续集成~Jenkins+Perl and Shell script
查看>>
php新版本号废弃 preg_replace /e 修饰符
查看>>
Android:Unable to resolve target ‘android-8’问题解决
查看>>
cocos2D(七)---- CCScene
查看>>
【DeepLearning】汉字手写体识别
查看>>
2017年中国大学生程序设计竞赛-中南地区赛暨第八届湘潭市大学生计算机程序设计大赛题解&源码(A.高斯消元,D,模拟,E,前缀和,F,LCS,H,Prim算法,I,胡搞,J,树状数组)...
查看>>
PostgreSQL 10首个测试版本发布
查看>>
ORACLE拼日期
查看>>
使用eclipse创建android项目的时候为什么会生成两个项目
查看>>
常见内存错误的几点总结
查看>>
Extjs的各版本下载
查看>>
使用LVS实现负载均衡原理及安装配置详解
查看>>