天天看点

win10系统vs2019 mpich配置

首先在官网下载,https://www.microsoft.com/en-us/download/details.aspx?id=57467

win10系统vs2019 mpich配置

点开Download

win10系统vs2019 mpich配置

全部下载,找到下载目录

win10系统vs2019 mpich配置

分别安装两者,安装目录可自行更改,除此之外一直next和accept即可

安装完后得到如图六个文件夹

win10系统vs2019 mpich配置

以管理员身份打开vs2019

新建空项目并在源文件添加新建项或新建控制台应用皆可

在解决方案资源管理器右键单击项目,打开属性

win10系统vs2019 mpich配置

将平台设置为x64

在VC++目录里,包含目录添加上include文件的路径,库目录里添加Lib\x64的路径

win10系统vs2019 mpich配置

在预处理器的预处理定义中添加MPICH_SKIP_MPICXX;

win10系统vs2019 mpich配置

在代码生成运行库中选择多线程调试(/Mtd)

win10系统vs2019 mpich配置

在链接器输入中添加msmpi.lib;

win10系统vs2019 mpich配置

关掉属性框,在程序上方选择x64

win10系统vs2019 mpich配置

尝试输入样例程序进行调试即可

#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运行