IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 并行化MPI安装、构成与示例代码(Macbook与Linux示例) -> 正文阅读

[C++知识库]并行化MPI安装、构成与示例代码(Macbook与Linux示例)

Macbook M1 MPI环境安装与测试案例

一、安装MPI

brew install open-mpi

经过一段时间等待后,输入如下命令。若输出相关版本信息,则安装成功。

二、MPI代码构成

MPI代码基本结构如下所示:

#include<mpi.h>
#include<stdio.h>
int main(int argc, char* argv[])
{
	int rank, size;
    MPI_Init(&argc, &argv);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);
    MPI_Comm_size(MPI_COMM_WORLD, &size);
    “”“
    并行化代码
    ”“”
    MPI_Finalize();
    return 0;
}

接下来我们逐一进行解析。

2.1 argc与argv

int main(int argc, char* argv)

在MPI程序中,需要向主函数传入int型变量argc与char*变量argv。这两个参数用于获取在使用命令行运行MPI程序时获取到进程数量参数n。

2.2 rank与size

可以看到在上述的程序结构中,我们定义了两个整型变量rank和size。

int rank, size;

其中rank用作记录当前进程的进程号;size则为整个程序的进程数。

MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Comm_size(MPI_COMM_WORLD, &size);

这里我们使用MPI_Comm_rank和MPI_Comm_size分别获取当前进程号和总进程数量。
注意到我们传入的第一个标识(?)MPI_COMM_WORLD在mpi.h中代表当前程序的进程池,包含了当前程序的所有进程。

2.3 MPI_Init与MPI_Finalize

MPI_Init(&argc, &argv);

在程序开头部分,使用init函数来建立并行环境。这里传入命令行的数量参数以便获取准确唯一的并行环境。

MPI_Finalize();

在 并行化程序部分结束之后和主函数return前使用MPI_Finalize函数来终止并行化环境。

三、HelloMPI

以下为程序示例:

// hello_mpi.cpp

#include<mpi.h>
#include<stdio.h>
int main(int argc, char* argv[])
{
	int rank, size;
    MPI_Init(&argc, &argv);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);
    MPI_Comm_size(MPI_COMM_WORLD, &size);
    printf("Process%d: hello!\n", rank);
    MPI_Finalize();
    return 0;
}

然后我们在shell窗口内使用命令行编译:

mpicxx hello_mpi.cpp -o hello_mpi

在编译完成后我们得到名为hello_mpi的可执行文件.
使用mpirun命令来并行化运行可执行文件:

mpirun -n 8 hello_mpi

注意这里使用 -n 参数来确定程序的并行化进程数(经过实验,Macbook M1只能设定n=8)。
运行结果如下:

在这里插入图片描述

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-25 17:54:42  更:2022-06-25 17:55:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 15:30:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码