vs2010 mpi并行环境配置编译
2015-09-06 19:50
417 查看
转自:http://blog.csdn.net/liurong_cn/article/details/8764351
一 下载mpi for windows
在这一块我浪费了很多时间。首先windows下(自己电脑的多核)和一般的工作站是不一样的。windos为了兼容mpi,自己做了一个基于一般电脑的MPI实现,如果要安装真正意义的mpi,在intel上有。我这里是为了在自己笔记本上学习mpi,用的市微软的HPC Pack 2008 R2 MS-MPI Redistributable Package with Service Pack 4 - 中文(简体),下载地址:http://www.microsoft.com/zh-cn/download/details.aspx?id=14737。
不过如果是想在自己笔记本上用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文件(具体看自己的命名)
五 运行
因为mpi是有命令行输入的,需要mpiexec.exe来运行,
补充一点:我们的VS工程目录最好不要放在中文目录下,否则在进行第五步时可能会提示“Error (2) 系统找不到指定的文件。”的错误
一 下载mpi for windows
在这一块我浪费了很多时间。首先windows下(自己电脑的多核)和一般的工作站是不一样的。windos为了兼容mpi,自己做了一个基于一般电脑的MPI实现,如果要安装真正意义的mpi,在intel上有。我这里是为了在自己笔记本上学习mpi,用的市微软的HPC Pack 2008 R2 MS-MPI Redistributable Package with Service Pack 4 - 中文(简体),下载地址:http://www.microsoft.com/zh-cn/download/details.aspx?id=14737。
不过如果是想在自己笔记本上用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文件(具体看自己的命名)
/* 功能:mpi点对点通信 时间:2012.12.13 */ #include<stdio.h> #include<string.h> #include"mpi.h" #define BUFLEN 512 int main(int argc, char *argv[]) { int myid,numprocs,next,namelen; char buffer[BUFLEN],processor_name[MPI_MAX_PROCESSOR_NAME]; MPI_Status status; // MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &numprocs); MPI_Comm_rank(MPI_COMM_WORLD, &myid); MPI_Get_processor_name(processor_name, &namelen); printf("Process %d on %s \n", myid, processor_name); printf("Process %d of %d \n", myid, numprocs); memset(buffer, 0, BUFLEN*sizeof(char)); if(myid == numprocs-1) { next = 0; } else { next = myid+1; } if(myid == 0) { strcpy(buffer,"hello there"); printf("%d sending '%s' \n",myid, buffer);fflush(stdout); MPI_Send(buffer,strlen(buffer)+1, MPI_CHAR, next, 99, MPI_COMM_WORLD); printf("%d receving \n", myid);fflush(stdout); MPI_Recv(buffer, BUFLEN, MPI_CHAR, MPI_ANY_SOURCE, 99, MPI_COMM_WORLD, &status); printf("%d received '%s' \n", myid, buffer);fflush(stdout); } else { printf("%d receiving \n",myid);fflush(stdout); MPI_Recv(buffer, BUFLEN, MPI_CHAR, MPI_ANY_SOURCE, 99, MPI_COMM_WORLD, &status); printf("%d received '%s' \n", myid, buffer);fflush(stdout); MPI_Send(buffer,strlen(buffer)+1, MPI_CHAR, next, 99, MPI_COMM_WORLD); printf("%d sending '%s' \n",myid, buffer);fflush(stdout); } MPI_Finalize(); return 0; }
五 运行
因为mpi是有命令行输入的,需要mpiexec.exe来运行,
补充一点:我们的VS工程目录最好不要放在中文目录下,否则在进行第五步时可能会提示“Error (2) 系统找不到指定的文件。”的错误
相关文章推荐
- 软件测试基础_对应Mantis整理的测试计划流程步骤
- hdu5168 Legal path DP,最短路
- Asp.Net 之 WebService部署到服务器后出现" The test form is only available for requests from the local machine "
- bzoj3669
- CSS从图标集里截取某一图标
- 0906学习记录
- 尝试实现 atoi和atof函数
- 原生JS实现瀑布流
- bzoj3669
- 写html文件一定要养成好习惯
- UI课程04 事件处理
- Android常用控件之碎片Fragment
- LeetCode -- 4Sum
- HTML5八大特性助力移动WebApp开发
- 求两个字符串相互交叉出现
- Android开发中的问题及相应解决(持续更新)
- CCS3的transform--rotate的使用顺序
- 使用Maven搭建Struts2+Spring3+Hibernate4的整合开发环境
- 四种方案解决ScrollView嵌套ListView问题
- 基于OpenWrt添加ubus支持