1、先下载安装mpich,下载地址为:
http://www.mpich.org/downloads/
完成后的目录如下图所示:
2、打开VS,创建如下工程
3、选择项目属性,添加头文件和库文件
4、引入mpi头文件和库
(1)找到“VC++ Directions-》Include Directories”,加上MPICH2的include文件路径,例如:“D:\software\MPICH2\include”
(2)左边还是“VC++ Directions-》Library Directories”,在此项的最后添加MPICH2的lib文件的路径,如“D:\software\MPICH2\lib”
5、因为VC的IO库与MPI的宏定义有冲突,所以需要预定义一个MPICH_SKIP_MPICXX宏,使得编译时跳过MPICXX定义。在如下位置加上“MPICH_SKIP_MPICXX”即可。
6、设置运行库为多线程
在如下位置选择“Multi-threaded Debug (/MTd)”,可以通过下拉单选择。
7、添加连接库
在如下位置添加“mpi.lib”
8、注册MPI,使得系统知道它。
打开“开始”,找到“MPICH2”文件夹,如下:
选择“wmpiregister.exe”,如下:
输入用户名和密码(此处的用户名和密码就是你锁屏时的用户名和密码),点击“Register”,当下面出现“Password encrypted into the Register”后点击“OK”即可。
9、运行程序
(1)先在VS中编译源程序,得到.exe文件;
(2)打开“开始”,找到“MPICH2”文件夹下的“wmpiexec.exe”,如下
选择刚才编译得到的.exe文件,如“D:\program\vs_code\MPI_01\Release\MPI_01.exe”
设置线程数“Number of processes”,例如:4
点击执行“Execute”,在下面的编辑框中会出现运行的结果,如下:
测试源码:
#include "mpi.h" #include<stdio.h> int main(int argc, char* argv[]) { int myid, numprocs; int namelen; char processor_name[MPI_MAX_PROCESSOR_NAME]; MPI_Init(&argc, &argv); MPI_Comm_rank(MPI_COMM_WORLD, &myid); MPI_Comm_size(MPI_COMM_WORLD, &numprocs); MPI_Get_processor_name(processor_name, &namelen); printf("Hello World! Process %d of %d on %s\n", myid, numprocs, processor_name); MPI_Finalize(); return 0; }