我正在尝试微软的 MPI 实现。我从这里安装了 CCP sdk:
http://www.microsoft.com/en-us/download/details.aspx?id=239
然后在我的项目设置中,我添加了包含文件夹、lib 文件夹并提到了 msmpi.lib。
使用其余设置,我构建程序,然后在命令提示符中继续运行程序,但启动后没有任何反应。
这是代码(它应该显示每个线程的 id 号):
#include "stdafx.h"
#include "mpi.h"
#include <stdio.h>
//Commands in cmd prompt
//cd "C:\Program Files\Microsoft Compute Cluster Pack\Bin"
//mpiexec.exe -n 2 "C:\Users\MyNameHere\Documents\Visual Studio 2012\Projects\tspMpi\Debug\tspMpi.exe"
int main(int argc, char* argv[])
{
int nTasks = 0, rank = 0;
MPI_Init(&argc,&argv);
MPI_Comm_size(MPI_COMM_WORLD,&nTasks);
MPI_Comm_rank(MPI_COMM_WORLD,&rank);
printf ("Number of threads = %d, My rank = %d\n", nTasks, rank);
return 0;
MPI_Finalize();
}
一旦我运行 mpiexec.exe(命令在注释中),程序什么也不做,直到我按下 Ctrl-C。有谁知道我做错了什么?构建程序时没有错误,如果我从 Visual Studio 运行它,就好像只启动了一个进程。