|
我用了两个测试的例子,一个是程序自带的hello_c,还有一个是下载的hello_c,但出现的结果都是一样的。
#include <stdio.h>
#include "mpi.h"
int main(int argc, char* argv[])
{
int rank, size, len;
char version[MPI_MAX_LIBRARY_VERSION_STRING];
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Comm_size(MPI_COMM_WORLD, &size);
MPI_Get_library_version(version, &len);
printf("Hello, world, I am %d of %d, (%s, %d)\n",
rank, size, version, len);
MPI_Finalize();
}
另一个是
#include<stdio.h>
#include"mpi.h"
int main(int argc, char *argv[]){
int totalTaskNum, rankID;
int rt = MPI_Init(&argc, &argv);
if(rt != MPI_SUCCESS){
printf("Error starting MPI.\n");
MPI_Abort(MPI_COMM_WORLD, rt);
}
MPI_Comm_size(MPI_COMM_WORLD, &totalTaskNum);
MPI_Comm_rank(MPI_COMM_WORLD, &rankID);
printf("Hellow, world! %dth of totalTaskNum = %d\n", rankID, totalTaskNum);
MPI_Finalize();
return 0;
}
程序应该没问题,因为在集群上运行是正常的。我对并行计算不太熟悉,只是看过一些mpi和openmp的资料,所以想问问是不是对单机安装有什么特殊的地方? |
|