首先在官网下载,https://www.microsoft.com/en-us/download/details.aspx?id=57467
点开Download
全部下载,找到下载目录
分别安装两者,安装目录可自行更改,除此之外一直next和accept即可
安装完后得到如图六个文件夹
以管理员身份打开vs2019
新建空项目并在源文件添加新建项或新建控制台应用皆可
在解决方案资源管理器右键单击项目,打开属性
将平台设置为x64
在VC++目录里,包含目录添加上include文件的路径,库目录里添加Lib\x64的路径
在预处理器的预处理定义中添加MPICH_SKIP_MPICXX;
在代码生成运行库中选择多线程调试(/Mtd)
在链接器输入中添加msmpi.lib;
关掉属性框,在程序上方选择x64
尝试输入样例程序进行调试即可
#include <mpi.h>
#include <stdio.h>
#include <math.h>
int main(int argc, char* argv[]) {
int done = 0, n, myid, numprocs, i;
double mypi, pi, sum;
double startwtime, endwtime;
int namelen;
char processor_name[MPI_MAX_PROCESSOR_NAME];
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);
fprintf(stderr, "Process %d on %s\n", myid, processor_name);
fflush(stderr);
n = 0;
while (!done) {
if (myid == 0) {
printf("输入一个数字不超过100000000: (0 退出) "); fflush(stdout);
scanf_s("%d", &n);
startwtime = MPI_Wtime();
}
MPI_Bcast(&n, 1, MPI_INT, 0, MPI_COMM_WORLD);/*将n值广播出去*/
if (n == 0)
done = 1;
else {
sum = 0.0;
for (i = myid + 1; i <= n; i += numprocs) {
sum += i;
}
mypi = sum;/*各个进程并行计算得到的部分和*/
MPI_Reduce(&mypi, &pi, 1, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD);
if (myid == 0) {
/*执行累加的0号进程将近似值打印出来*/
printf("结果 %.16f\n", pi);
endwtime = MPI_Wtime();
printf("时间 = %f\n", endwtime - startwtime);
}
}
}
MPI_Finalize();
}
有些程序在vs运行不了,可以打开PowerShell或者命令行,进入对应路径,输入mpiexec -n 10 程序名.exe运行