PowerPoint 演示文稿

Similar documents
Parallel Programming with MPI

投影片 1

消息传递并行编程环境MPI.doc

模板

Microsoft PowerPoint - Tongji_MPI编程初步

mpi

第7章-并行计算.ppt

Linux Linux Linux

Microsoft PowerPoint - KN002.ppt

Parallel Programming with MPI

PowerPoint 演示文稿

Department of Science and Engineering Computing School of Mathematics School Peking University October 9, 2007

大綱介紹 MPI 標準介紹 MPI 的主要目標 Compiler & Run 平行程式 MPICH 程式基本架構 點對點通訊 函數介紹 集體通訊 函數介紹


Department of Science and Engineering Computing School of Mathematics School Peking University October 9, 2007

PowerPoint Presentation

PowerPoint 演示文稿

目 录 参 考 材 料 1 第 一 章 预 备 知 识 高 性 能 并 行 计 算 机 系 统 简 介 微 处 理 器 的 存 储 结 构

PowerPoint 演示文稿

Microsoft Word - 把时间当作朋友(2011第3版)3.0.b.06.doc

目录 第一章 MPI 简介 消息传递编程的相关概念 分布式内存 消息传输 进程 消息传递库 发送 / 接收 同步 / 异步 阻塞

MPI实验.doc

C/C++语言 - C/C++数据

Microsoft PowerPoint - 07 派生数据类型

CC213

07-1.indd

Slide 1

C 1

to AztecOO Department of Science and Engineering Computing School of Mathematics School Peking University October 9, 2007

科学计算的语言-FORTRAN95

c_cpp

1 学习目标了解并掌握 MPI 的各种非阻塞通信形式及其作用, 并能运用 MPI 的非阻塞通信语句编写高级的并行程序 2 重点和难点非阻塞通信的语义特点, 如何运用非阻塞通信的特点来实现特定的功能和性能 3 学习方法所有的阻塞调用形式都有其相应的非阻塞调用形式, 此外非阻塞调用还有其特殊的接口形式

C++ 程式設計

PowerPoint 演示文稿

mpic_2002

mannal

1 Project New Project 1 2 Windows 1 3 N C test Windows uv2 KEIL uvision2 1 2 New Project Ateml AT89C AT89C51 3 KEIL Demo C C File

OOP with Java 通知 Project 4: 4 月 18 日晚 9 点 关于抄袭 没有分数

Microsoft PowerPoint - 4. 数组和字符串Arrays and Strings.ppt [兼容模式]

FY.DOC

chap07.key

untitled

, 即 使 是 在 昏 暗 的 灯 光 下, 她 仍 然 可 以 那 么 耀 眼 我 没 有 地 方 去, 你 会 带 着 我 么 杜 晗 像 是 在 嘲 笑 一 般, 嘴 角 的 一 抹 冷 笑 有 着 不 适 合 这 个 年 龄 的 冷 酷 和 无 情, 看 着 江 华 的 眼 神 毫 无 温

SDK 概要 使用 Maven 的用户可以从 Maven 库中搜索 "odps-sdk" 获取不同版本的 Java SDK: 包名 odps-sdk-core odps-sdk-commons odps-sdk-udf odps-sdk-mapred odps-sdk-graph 描述 ODPS 基

Trilinos 简介 Trilinos 简介 卢朓 Trilinos 简介 卢朓 Trilinos 简介 Trilinos 简介 Trilinos 的安装和使用 Trilinos 简介 Trilinos 简介 Trilinos 的安装和使用 Trilinos 简介 Trilinos Epetra

Microsoft Word - FPKLSC_21.docx

Microsoft PowerPoint - 03.Fortran程序设计基础1

OOP with Java 通知 Project 2 提交时间 : 3 月 14 日晚 9 点 另一名助教 : 王桢 学习使用文本编辑器 学习使用 cmd: Power shell 阅读参考资料

C/C++ 语言 - 循环

Guava学习之Resources

新・明解C言語入門編『索引』

目录 1 IPv6 快速转发 IPv6 快速转发配置命令 display ipv6 fast-forwarding aging-time display ipv6 fast-forwarding cache ipv6 fas

Microsoft PowerPoint - 5. 指针Pointers.ppt [兼容模式]

1.3

56,,,,, :,, 1953,, 1953,1953,,1953,,,,,,,,, () ,30118, 34, ;,4912 %,5614 %, 1,1953, 1119, ,, , , 1111 (

OOP with Java 通知 Project 4: 5 月 2 日晚 9 点

(Microsoft Word - \251I\250D\245D\246W

Generated by Unregistered Batch DOC TO PDF Converter , please register! 浙江大学 C 程序设计及实验 试题卷 学年春季学期考试时间 : 2003 年 6 月 20 日上午 8:3

Microsoft PowerPoint - CEM-07-Parallel.pptx

提纲 1 2 OS Examples for 3

OOP with Java 通知 Project 4: 4 月 19 日晚 9 点

Microsoft PowerPoint - PC14.pptx

untitled

3.1 num = 3 ch = 'C' 2

Department of Science and Engineering Computing School of Mathematics School Peking University August 14, 2007

untitled

untitled

NOWOER.OM m/n m/=n m/n m%=n m%n m%=n m%n m/=n 4. enum string x1, x2, x3=10, x4, x5, x; 函数外部问 x 等于什么? 随机值 5. unsigned char *p1; unsigned long *p

AM101-1(中文)11.cdr


51 C 51 isp 10 C PCB C C C C KEIL

2013 C 1 # include <stdio.h> 2 int main ( void ) 3 { 4 int cases, a, b, i; 5 scanf ("%d", & cases ); 6 for (i = 0;i < cases ;i ++) 7 { 8 scanf ("%d %d

新版 明解C++入門編

地 理 志 鏡 止 煞, 來 達 到 安 宅 的 效 果 4. 門 神 符 紙 : 於 門 板 繪 製 門 神, 作 為 宅 第 的 守 護, 民 宅 所 使 用 的 門 神 題 材, 多 為 天 官 賜 福 或 文 武 官 員 符 紙 是 以 畫 了 符 咒 的 紙 懸 掛 室 內, 或 加 框

帝国CMS下在PHP文件中调用数据库类执行SQL语句实例

C

mvc

Microsoft PowerPoint - C语言课件-9-结构体.pptx

目 录(目录名)

C 1 # include <stdio.h> 2 int main ( void ) { 4 int cases, i; 5 long long a, b; 6 scanf ("%d", & cases ); 7 for (i = 0;i < cases ;i ++) 8 { 9

epub 33-8

第11章 可调内核参数

目录 1 IPv6 快速转发 IPv6 快速转发配置命令 display ipv6 fast-forwarding aging-time display ipv6 fast-forwarding cache ipv6 fas

untitled

BOOL EnumWindows(WNDENUMPROC lparam); lpenumfunc, LPARAM (Native Interface) PowerBuilder PowerBuilder PBNI 2

nooog

Microsoft Word - 物件導向編程精要.doc


OOP with Java 通知 Project 4: 推迟至 4 月 25 日晚 9 点

Microsoft PowerPoint - multicore curriculum of sspku.ppt

untitled

JLX

<4D F736F F D20482E323634B5F8B054BD73BD58A4A7A5ADA6E6A4C6ACE3A8732E646F63>

概述

《C语言程序设计》第2版教材习题参考答案

C PICC C++ C++ C C #include<pic.h> C static volatile unsigned char 0x01; static volatile unsigned char 0x02; static volatile unsigned cha

《计算概论》课程 第十九讲 C 程序设计语言应用

<4D F736F F F696E74202D BDE1B9B9BBAFB3CCD0F2C9E8BCC D20D1ADBBB7>

目 录(目录名)

Microsoft Word - 魔术师

Transcription:

第四讲 消息传递编程接口 MPI 一 MPI 编程基础

主要内容 MPI 安装 程序编译与运行 MPI 编程基础 MPI 程序基本结构 MPI 数据类型 消息发送和接收 MPI 一些常用函数

MPI 介绍 Message Passing Interface 消息传递编程标准, 目前最为通用的并行编程方式 提供一个高效 可扩展 统一的并行编程环境 MPI 是一个库, 不是一门语言,MPI 提供库函数 / 过程供 C/FORTRAN 调用 MPI 是一种标准或规范的代表而不特指某一个对它的具体实现 迄今为止所有的并行计算机制造商都提供对 MPI 的支持 MPI 是一种消息传递编程模型, 最终目的是服务于进程间通信这一目标

MPI 介绍 MPI 的目标 较高的通信性能 ; 较好的程序可移植性 ; 强大的功能 MPI 的实现 免费版本 1994 年公布 MPI 1.0 标准,1998 年公布 2.0 标准 MPI 1.0:MPICH 1.2.7 MPI 2.0:MPICH2 1.0.7 MPI 商业版本 一些厂商也提供商业版的 MPI 系统, 许多是在 MPICH 的基础上优化产生的

MPI 下载与安装 MPICH 下载 http://www.mpich.org/ MPICH 的安装 参考 MPICH Install Guide MPICH 的使用 参考 MPICH User Guide

MPI 编程基本概念 MPI 进程 MPI 程序中一个独立参与通信的个体 MPI 进程组 MPI 程序中由部分或全部进程构成的有序集合 每个进程都被赋予一个所在进程组中唯一的序号 (rank), 用于在该组中标识该进程, 称为进程号, 取值从 0 开始

MPI 进程与通信器 MPI 通信器 / 通信子 (Communicator) MPI 程序中进程间的通信必须通过通信器进行 通信器分为域内通信器 ( 同一进程组内的通信 ) 和域间通信器 ( 不同进程组的进程间的通信 ) MPI 程序启动时自动建立两个通信器 : MPI_COMM_WORLD : 包含程序中所有 MPI 进程 MPI_COMM_SELF : 有单个进程独自构成, 仅包含自己 MPI 程序中, 一个 MPI 进程由一个进程组和在该组中的进程号唯一确定 ; 或由一个通信器和在该通信器中的进程号唯一确定 进程号是相对进程组或通信器而言的, 同一进程在不同的进程组或通信器中可以有不同的进程号

MPI 消息 进程号是在进程组或通信器被创建时赋予的 空进程 :MPI_PROC_NULL 与空进程通信时不做任何操作 消息 (message) 一个消息指进程间进行的一次数据交换 一个消息由通信器 源地址 目的地址 消息标签 和数据构成

第一个 MPI Fortran 程序 program main include 'mpif.h' character * (MPI_MAX_PROCESSOR_NAME) proc_name integer myid, numprocs, namelen, rc, ierr call MPI_INIT( ierr ) call MPI_COMM_RANK( MPI_COMM_WORLD, myid, ierr ) call MPI_COMM_SIZE( MPI_COMM_WORLD, numprocs, ierr ) call MPI_GET_PROCESSOR_NAME(proc_name, namelen, ierr) write(*,10) myid, numprocs, proc_name 10 FORMAT('Hello, I am Proc. ',I2,' of ',I1,' on ', 20A) call MPI_FINALIZE(ierr) end mpif.h 是 MPI 相对于 FORTRAN 的头文件

MPI 程序分析 所有包含 MPI 调用的程序必须包含 MPI 头文件 MPI_MAX_PROCESSOR_NAME 是 MPI 预定义的宏, 即 MPI 所允许的机器名字的最大长度 MPI 程序的开始和结束必须是 MPI_INIT 和 MPI_FINALIZE, 分别完成 MPI 的初始化和结束工作 MPI_COMM_RANK 得到本进程的进程号 MPI_COMM_SIZE 得到所有参加运算的进程的个数 MPI_GET_PROCESSOR_NAME 得到运行本进程所在的结点的主机名 进程号取值范围为 0,, np-1

MPI 程序分析 在单个结点 (c1) 上, 开 4 个进程的运行结果 Hello, I am Proc. 1 of 4 on c1 Hello, I am Proc. 0 of 4 on c1 Hello, I am Proc. 2 of 4 on c1 Hello, I am Proc. 3 of 4 on c1 在四个结点上, 开 4 个进程的运行结果 Hello, I am Proc. 1 of 4 on c1 Hello, I am Proc. 0 of 4 on c2 Hello, I am Proc. 2 of 4 on c4 Hello, I am Proc. 3 of 4 on c3

MPI 程序执行过程 启动编译生成的可执行文件 hello 进程 0 进程 1 进程 2 进程 3 MPI_INIT MPI_COMM_RANK myid=0 MPI_GET_PROCESSOR_NAME proc_name=c1 namelen=2 Write hello, I am proc. 0 of 4 on c1............ MPI_INIT MPI_COMM_RANK myid=4 MPI_GET_PROCESSOR_NAME proc_name=c1 namelen=2 Write hello, I am proc. 3 of 4 on c1 MPI_FINALIZE MPI_FINALIZE 程序运行结束

第一个 MPI C 程序 #include "mpi.h" #include <stdio.h> #include <math.h> mpi.h 是 MPI 相对于 C 语言的头文件 int main(argc,argv) int argc; char *argv[]; { int myid, np; int namelen; char proc_name[mpi_max_processor_name]; MPI_Init(&argc,&argv); MPI_Comm_rank(MPI_COMM_WORLD,&myid); MPI_Comm_size(MPI_COMM_WORLD,&numprocs); MPI_Get_processor_name(proc_name,&namelen); fprintf(stderr,"hello, I am proc. %d of %d on %s\n", myid, np, proc_name); MPI_Finalize(); }

MPI 编程的一些惯例 MPI 的所有常量 变量与函数 / 过程均以 MPI_ 开头 MPI 的 C 语言接口为函数,FORTRAN 接口为 SUBROUTINE, 且对应接口的名称相同 在 C 程序中, 所有常数的定义除下划线外一律由大写字母组成, 在函数和数据类型定义中, 接 MPI_ 之后的第一个字母大写, 其余全部为小写字母, 即 MPI_Xxxx_xxx 形式 对于 FORTRAN 程序,MPI 函数全部以过程方式调用, 一般全用大写字母表示, 即 MPI_XXXX_XXX 形式 (FORTRAN 不区分大小写 ) 除 MPI_WTIME 和 MPI_WTICK 外, 所有 C 函数调用之后都将返回一个错误信息码, 而 MPI 的所有 FORTRAN 子程序中都有一个哑元参数 (IERR) 代表错误码

MPI 编程的一些惯例 由于 C 语言的函数调用机制是值传递, 所以 MPI 的所有 C 函数中的输出参数用的都是指针 MPI 是按进程组 (Process Group) 方式工作 : 所有 MPI 程序在开始时均被认为是在通信器 MPI_COMM_WORLD 所拥有的进程组中工作, 之后用户可以根据自己的需要, 建立其它的进程组 所有 MPI 的通信一定要在通信器中进行 FORTRAN 的数组下标缺省以 1 开始, 而 C 语言的数组是以 0 开始

MPI 数据类型 MPI 除了提供 C 语言函数和 FORTRAN 子程序之外, 还定义了一组常量和 C 变量数据类型 MPI 常量命名规则 : 全部大写 MPI 变量数据类型命名规则 : 以 MPI_ 开头, 后面跟 C 语言或 FORTRAN 原始数据类型名称 MPI 数据类型 : 原始数据类型和自定义数据类型

MPI 原始数据类型 FORTRAN 77 数据类型 MPI datatype MPI_INTEGER MPI_REAL MPI_DOUBLE_PRECISION MPI_COMPLEX MPI_DOUBLE_COMPLEX MPI_LOGICAL MPI_CHARACTER MPI_BYTE MPI_PACKED Fortran datatype INTEGER REAL DOUBLE PRECISION COMPLEX DOUBLE COMPLEX LOGICAL CHARACTER(1)

MPI 原始数据类型 C MPI datatype MPI_CHAR MPI_SHORT MPI_INT MPI_LONG MPI_UNSIGNED_CHAR MPI_UNSIGNED_SHORT MPI_UNSIGNED_INT MPI_UNSIGNED_LONG MPI_FLOAT MPI_DOUBLE MPI_LONG_DOUBLE MPI_BYTE MPI_PACKED C datatype signed char signed short int signed int signed long int unsigned char unsigned short int unsigned int unsigned long int float double long double

MPI 原始数据类型 某些 MPI 系统还支持一些附加数据类型 附加的 MPI 数据类型 MPI_LONG_LONG_INT long 相应的 C 数据类型 long int 附加的 MPI 数据类型 MPI_REAL2 MPI_REAL4 MPI_REAL8 MPI_INTEGER1 MPI_INTEGER2 MPI_INTEGER4 相应的 FORTRAN77 数据类型 REAL*2 REAL*4 REAL*8 INTEGER*1 INTEGER*2 INTEGER*4

MPI 最常用的六个接口 MPI_INIT MPI_FINALIZE MPI_COMM_RANK MPI_COMM_SIZE MPI_SEND MPI_RECV

MPI_INIT MPI_INIT:MPI 初始化 参数 C F77 无 int MPI_Init(int *argc, char ***argv) MPI_INIT(IERR) INTEGER IERR 该函数初始化 MPI 并行程序的执行环境, 它必须在调用所有其它 MPI 函数 ( 除 MPI_INITIALIZED) 之前被调用, 并且在一个 MPI 程序中, 只能被调用一次

MPI_FINALIZE MPI_FINALIZE: 结束 MPI 系统 参数 C F77 无 int MPI_Finalize(void) MPI_FINALIZE(IERR) INTEGER IERR 该函数清除 MPI 环境的所有状态 即一但它被调用, 所有 MPI 函数都不能再调用, 其中包括 MPI_INIT

MPI_COMM_RANK MPI_COMM_RANK(comm, rank) 参数 C F77 IN comm 通信器 OUT rank 本进程在通信器 comm 中的进程号 int MPI_Comm_rank(MPI_Comm comm, int *rank) MPI_COMM_RANK(COMM, RANK, IERR) INTEGER COMM, RANK, IERR 该函数返回本进程在指定通信器中的进程号

MPI_COMM_SIZE MPI_COMM_SIZE(comm, size) 参数 C F77 IN comm 通信器 OUT size 该通信器 comm 中的进程数 int MPI_Comm_size(MPI_Comm comm, int *size) MPI_COMM_SIZE(COMM, SIZE, IERR) INTEGER COMM, SIZE, IERR 该函数返回指定通信器所包含的进程数

MPI_SEND 点对点通信 MPI_SEND(buf,count,datatype,dest,tag,comm) 参数 C F77 IN buf 所发送消息的首地址 IN count 将发送的数据的个数 IN datatype 发送数据的数据类型 IN dest 接收消息的进程的标识号 IN tag 消息标签 IN comm 通信器 int MPI_Send(void *buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm) MPI_SEND(BUF,COUNT,DATATYPE,DEST,TAG, COMM, IERR) <type> BUF(*) INTEGER COUNT,DATATYPE,DEST,TAG,COMM,IERR

MPI_SEND 点对点通信 MPI_SEND(buf,count,datatype,dest,tag,comm) 阻塞型消息发送接口 MPI_SEND 将缓冲区中 count 个 datatype 类型的数据发给进程号为 dest 的目的进程 这里 count 是元素个数, 即指定数据类型的个数, 不是字节数, 数据的起始地址为 buf 本次发送的消息标签是 tag, 使用标签的目的是把本次发送的消息和本进程向同一目的进程发送的其它消息区别开来 其中 dest 的取值范围为 0~np-1 ( np 表示通信器 comm 中的进程数 ) 或 MPI_PROC_NULL,tag 的取值为 0~ MPI_TAG_UB 该函数可以发送各种类型的数据, 如整型 实型 字符等 点对点通信是 MPI 通信机制的基础

MPI_RECV 点对点通信 MPI_RECV(buf,count,datatype,source,tag,comm,status) 参数 C F77 OUT buf 接收消息数据的首地址 IN count 接收数据的最大个数 IN datatype 接收数据的数据类型 IN source 发送消息的进程的标识号 IN tag 消息标签 IN comm 通信器 OUT status 返回状态 int MPI_Recv(void *buf, int count, MPI_Datatype datatype, int source, int tag,mpi_comm comm,mpi_status *status) MPI_RECV(BUF, COUNT, DATATYPE, SOURCE, TAG, COMM, STATUS, IERR) <type> BUF(*) INTEGER COUNT, DATATYPE, SOURCE, TAG, COMM, IERR, STATUS(MPI_STATUS_SIZE)

MPI_RECV 点对点通信 MPI_RECV(buf,count,datatype,source,tag,comm,status) 阻塞型消息接收接口 从指定的进程 source 接收不超过 count 个 datatype 类型的数据, 并把它放到缓冲区中, 起始位置为 buf, 本次消息的标识为 tag 这里 source 的取值范围为 0 ~np-1, 或 MPI_ANY_SOURCE, 或 MPI_PROC_NULL,tag 的取值为 0~MPI_TAG_UB 或 MPI_ANY_TAG 接收消息时返回的状态 STATUS, 在 C 语言中是用结构定义的, 在 FORTRAN 中是用数组定义的, 其中包括 MPI_SOURCE,MPI_TAG 和 MPI_ERROR 此外 STATUS 还包含接收消息元素的个数, 但它不是显式给出的, 需要用到后面给出的函数 MPI_GET_COUNT

MPI 程序示例 例 : 将每个进程中某个数据发送给下一个进程, 并从前一个进程接收一个数据, 即 0 号进程给 1 号进程发送一个数据, 并从 np-1 号进程接收一个数据,1 号进程从 0 号进程接收一个数据, 并向 2 号进程发送一个数据, 以此类推 实现方式一 : 0 号进程先发送后接收, 其它进程先接收后发送 例 :ex4sendrecv01.f, ex4sendrecv02.f 实现方式二 : 奇数号进程先发送后接收, 偶数号进程先接收后发送 上机作业 在使用阻塞型函数传递消息时要避免死锁!

MPI 发送接收 MPI_SEND(buf,count,datatype,dest,tag,comm) 消息数据 消息信封 MPI_RECV(buf,count,datatype,source,tag,comm,status) 消息数据 消息信封 发送数据类型 通信函数中的数据类型 接收的数据类型要一致! C: 结构 status.mpi_source status.mpi_tag status.mpi_error FORTRAN: 数组 status(mpi_source) status(mpi_tag) status(mpi_error)

发送与接收组合进行 MPI_SENDRECV(sendbuf, sendcount, sendtype, dest, sendtag, recvbuf, recvcount, recvtype, source, recvtag, comm, status) 参数略 C F77 int MPI_Sendrecv(void *sendbuf, int sendcount, MPI_Datatype sendtype, int dest, int sendtag, void *recvbuf, int recvcount, MPI_Datatype recvtype, int source, int recvtag, MPI_Comm comm, MPI_Status *status) MPI_SENDRECV(SENDBUF, SENDCOUNT, SENDTYPE, DEST, SENDTAG, RECVBUF, RECVCOUNT, RECVTYPE, SOURCE, RECVTAG, COMM, STATUS,IERR) <type> INTEGER SENDBUF(*), RECVBUF(*) SENDCOUNT, SENDTYPE, DEST, SENDTAG, RECVCOUNT, RECVTYPE, SOURCE, RECVTAG, COMM, IERR, STATUS(MPI_STATUS_SIZE)

MPI_SENDRECV MPI_SENDRECV(sendbuf, sendcount, sendtype, dest, sendtag, recvbuf, recvcount, recvtype, source, recvtag, comm, status) 这是发送消息和接收消息组合在一起的一个函数, 好处是不用考虑先发送还是先接收消息, 从而可以避免消息传递过程中的死锁 sendbuf 和 recvbuf 必须指向不同的缓冲区 例 :ex4sendrecv03.f

MPI_SENDRECV_REPLACE MPI_SENDRECV_REPLACE(buf, datatype, dest, sendtag, source, recvtag, comm, status) 功能与 MPI_SENDRECV 类似, 但收发消息使用的是同一个缓冲区 例 :ex4sendrecv04.f

MPI 程序示例 例 : 计算 π 的值 1 n 4 π = d x h f( x ) 0 2 i x + 1 采用等步长中矩形公式, 其中 n 为积分区间数,h = 1/n 为步长,x i = (i + 0.5) h 为积分区间的中点 假设采用 p 的进程同时计算, 各自计算其中的一部分, 然后再将结果加起来 i= 1 例 :ex4pi.f mpif77 -Wno-globals o ex4pi ex4pi.f

MPI_GET_COUNT MPI_GET_COUNT(status, datatype, count) 参数 C F77 IN status IN datatype 接收操作的返回状态接收操作使用的数据类型 OUT count 接收到的数据个数 int MPI_Get_count(MPI_Status *status, MPI_Datatype datatype, int *count) MPI_GET_COUNT(STATUS,DATATYPE,COUNT,IERR) INTEGER DATATYPE,COUNT,IERR, STATUS(MPI_STATUS_SIZE) 查询实际接收到的数据信息

MPI 异常终止 MPI_ABORT(comm, errorcode) 参数 IN comm OUT errorcode 通信器 错误码 C F77 int MPI_Abort(MPI_Comm comm,int errorcode) MPI_ABORT(COMM, ERRORCODE, IERR) INTEGER COMM, ERRORCODE, IERR 异常终止 MPI 程序的执行,MPI 系统会尽量设法终止通信器中的所有进程

MPI 计时函数 MPI_WTIME() 参数 C F77 无 double MPI_Wtime(void) DOUBLE PRECISION MPI_WTIME() 该函数返回当前的墙钟时间

MPI 计时函数 MPI_WTICK() 参数 C F77 无 double MPI_Wtick(void) DOUBLE PRECISION MPI_WTICK() 该函数返回 MPI_WTIME 的时钟精度, 单位为秒 MPI_WTIME 和 MPI_WTICK 是 C 中仅有的两个返回双精度值而非整型错误码的 MPI 函数 ; 它们也是 FORTRAN 中仅有的两个 FUNCTION 形式的接口!

获取结点主机名 MPI_GET_PROCESSOR_NAME(name, namelen) 参数 C F77 OUT name 结点主机名 OUT namelen 主机名的长度 int MPI_Get_processor_name(char *name, int *namelen) MPI_GET_PROCESSOR_NAME(NAME, NAMELEN, IERR) CHARACTER(*) NAME INTEGER NAMELEN, IERR 该函数返回进程所在结点的主机名

获取 MPI 版本号 MPI_MPI_GET_VERSION(version, subver) 参数 C F77 OUT version 主版本号 OUT subver 次版本号 int MPI_Get_version(int *version, int *subver ) MPI_GET_VERSION(VERSION, SUBVER, IERR) INTEGER VERSION, SUBVER, IERR 该函数返回 MPI 的版本号