下载MPI
之前安装了MPICH2,调试好环境之后,写了一个小的并行程序,发现在vs2010里编译能通过,解决方案也能生成成功。但是在Dos里面运行的时候,没有反应,试过网上各种各样的方法,都不行。后来才知道,可能是兼容的问题。Windows为了兼容MPI,自己做了msmpi版本,我安装Macrosoft MPI v8.1之后,并行程序成功运行,如图
最好不要下载v10,不然某些新功能与旧版本的vs可能会不兼容,编译通不过,这里选用了v8.1版本
https://www.microsoft.com/en-us/download/confirmation.aspx?id=55494
两者都勾选下载,然后分别点击安装即可。可以修改安装路径,我安装在了D盘。
vs2010配置项目环境
新建项目
- 打开vs2010
- 新建项目–>Visual C++ -->Win32控制台应用–>改名称–>位置(一定要记得)–>点击确定
- 选择空项目–>完成
- 右击源文件–>添加新建项–>C++文件
配置项目属性
VC++目录
包含目录加入MPI的include文件,我装在D盘的路径是D:\Program Files (x86)\Microsoft SDKs\MPI\Include
引用目录加入MPI的lib\x86文件,我的D:\Program Files (x86)\Microsoft SDKs\MPI\Lib\x86
我的电脑是64位的,之前选择x64会报错,后来查了一下,64位的电脑可以运行32位的程序,我改选x86之后就能成功生成解决方案了,具体什么原因我也不知道,可能还是版本的兼容问题吧。
C/C++
C/C+±->预处理器–>预处理器定义–>加入MPICH_SKIP_MPICXX
链接器
链接器–>输入–>附加依赖项 加入msmpi.lib
全部配置完之后,点击应用,再点击确定,配置就完成啦!
测试
#include "mpi.h"
#include <stdio.h>
int main(int argc, char* argv[])
{
int rank, numproces;
int namelen;
char processor_name[MPI_MAX_PROCESSOR_NAME];
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);//获得进程号
MPI_Comm_size(MPI_COMM_WORLD, &numproces);//返回通信子的进程数
MPI_Get_processor_name(processor_name, &namelen);
fprintf(stderr, "hello world! process %d of %d on %s\n", rank, numproces, processor_name);
MPI_Finalize();
return 0;
}
点击生成–>编译
编译成功
点击生成–>生成解决方案
生成解决方案成功
然后找到项目所在的文件夹,进入Debug,会出现以下三个文件
运行程序
在键盘上同时按Win+R,再输入cmd,回车,进入Dos命令窗口。
然后进入生成的Debug文件夹(cd 路径为Debug文件的地址,可以直接复制过去,然后回车)
然后输入命令
mpiexec -n 3 program1.exe
回车,运行成功