MPI_Bcast与MPI_Comm_split配合,实现行广播或列广播

article/2025/10/5 11:14:03

15个进程,3行5列,结合MPI_Comm_split函数,MPI_Bcast实现行广播和列广播。
Bcast广播时,如果通讯域是split之后的,则会按照color相同的进行广播,即color相同的为一组,每个组内编号为root的向组内其他进程广播。
下面的代码首先是按照列划分组并广播,然后是按照行划分组并广播。

#include "mpi.h"
#include "stdio.h"
int main(int argc, char** argv) {int dataCol = 0, dataRow = 11;MPI_Comm colComm, rowComm;int worldRank, worldSize;MPI_Status status;MPI_Init(&argc, &argv);MPI_Comm_rank(MPI_COMM_WORLD, &worldRank);MPI_Comm_size(MPI_COMM_WORLD, &worldSize);if (worldRank / 5 == 0) {dataCol = worldRank;}int colorCol = worldRank % 5;int keyRow = worldRank / 5;MPI_Comm_split(MPI_COMM_WORLD, colorCol, keyRow, &colComm);MPI_Bcast(&dataCol, 1, MPI_INT, 0, colComm);printf("worldRank = %d, data = %d ", worldRank, dataCol);fflush(stdout);MPI_Barrier(MPI_COMM_WORLD);if (worldRank == 0) {printf("\n");}if (worldRank % 5 == 0) {dataRow = worldRank;}int colorRow = worldRank / 5;int keyCol = worldRank % 5;MPI_Comm_split(MPI_COMM_WORLD, colorRow, keyCol, &rowComm);MPI_Bcast(&dataRow, 1, MPI_INT, 0, rowComm);printf("worldRank = %d, data = %d ", worldRank, dataRow);fflush(stdout);MPI_Finalize();return 0;
}

运行结果如下:
在这里插入图片描述


http://chatgpt.dhexx.cn/article/IcAhUKEk.shtml

相关文章

VMware 虚拟机 linux执行 ifconfig 命令 eth0没有IP地址(intet addr、Bcast、Mask) UP BROADCAST MULTICAST 问题

VMware 虚拟机 ifconfig没有net_addr地址、Bcast、Mask的解决方法: 在vmvare中,使用ifconfig命令查看linux系统的IP地址,发现没有分配IP地址。 eth0:网络接口 link encap : 网络类型 HWaddr : 网卡物理地址 Inet addr &…

CABAC

CABAC CABAC(上下文自适应的二进制算术编码)基于算术编码,在HEVC中,除了参数集、SEI和slice头部之外,其余的所有数据都使用CABAC来进行熵编码。1.4.1 原理 主要包括三个步骤: 二进制化; 上下…

【Redis】 - Redis 6.0 新特性之客户端缓存

Redis 6.0 新特性之客户端缓存 1. 为什么需要客户端缓存1.1 低延迟和大规模提供数据服务1.2 其他 cache 层 2. Redis 中的客户端缓存2.1 什么样的数据集应该被客户端缓存2.2 客户端缓存的两个主要优点 3. 缓存的数据一致性问题4. Redis 客户端缓存的实现原理4.1 普通模式4.1.1 …

MCAST是什么?(播协议通信程序)

看海康isapi.pdf文档看到的,不懂什么意思 播协议通信程序,用于测试在局域网或者在三层交换机架构下进行通信测试 Multicast Protocol communications procedures, for testing in the local area network or switches in the three-tier framework for …

一、Broadcast简介

Android广播(Broadcast) 一、Broadcast简介 Broadcast是android中的四大组件之一,是在组件之间传播数据(Intent)的一种机制。广播的发送者和接收者事先是不需要知道对方的存在的。这样带来的好处便是,系统的…

BCSP

BCSP 包的类型 有4种类型,Sync,Sync-Resp,Conf,Conf-Resp Sync: {0xda,0xdc,0xed,0xed} Sync-Resp: {0xac,0xaf,0xef,0xee} Conf: {0xad,0xef,0xac,0xed} Conf-Resp: {0xde,0xad,0xd0,0xd0} 上面2图式BCSP的行为和状…

MPI MPI_Bcast (广播)用法详解

函数范式 int MPI_Bcast(void * data_p;int count;MPI_Datatype datatype;int source_proc;MPI_Comm comm; );功能描述: 一个广播发生的时候,一个进程会把同样一份数据传递给一个 communicator 里的所有其他进程。根节点调用 MPI_Bcast 函数的时候&…

关于inet addr(网络地址)、bcast(广播地址)、mask(子网掩码)的学习

int addr:网络地址。IP地址和子网掩码进行相与运算,将运算结果中的网络地址不变,主机地址变为0,即主机号全0是网络地址。示例: 如果是192的C段地址,那么网络地址就是:192.168.1.0,地址掩码是:25…

错误码415

POST请求报错: “status”: 415, “error”: “Unsupported Media Type”, “message”: "Content type app charlse 错误码 415表示不支持内容类型。 错误原因 没有正确设置内容类型标头。 正确做法 检查 content-type

发送HTTP请求返回415状态码的解决办法

1.问题出现: 在用POST方式携带token访问一个API接口时,发现返回状态码为415,错误信息为“Unsupported Media Type” 2.分析原因: 415错误的解释是说,服务器无法处理请求附带的媒体格式,不明白什么意思&am…

http post 415错误

前面在spring boot项目中,进行前后端数据交互时突然遇到了415错误。一时间有点懵,在网上找了一些资料,总算是知道为什么了,不多说,直接上图。 这是正常的form提交的数据。 debug之后能够服务器能够正常的接收数据。 当…

http405错误解决

问题描述:在使用vue框架和spring boot进行前后端分离开发时,出现405错误。 解决思考: 分析:我们知道,一般4开头的错误基本都是前端的问题,或者是浏览器的问题。而且我之前使用了swagger对后端接口进行了测…

415错误如何解决

415错误可能是由于前端传输的格式不对引起的 我这里是因为传的json字符串 更正前 错误 只要加上一行: contentType: application/json;charsetutf-8,问题解决

【前后端异常】axios post请求 解决返回415状态码的错误

错误描述: 进行有文件的表单提交时出现415错误,以前没遇到过记录一下 415错误的解释是说,服务器无法处理请求附带的媒体格式。以下是HTTP的状态码关于415返回码的说明: 415Unsupported Media Type服务器无法处理请求附带的媒体格…

JMeter 请求报Response code:415错误

jmeter做压测时,调用某个接口时报415: 然后用postman调同样的接口,传相同的参数,请求接口返回的数据正常: 怎么回事讷???? 其实啊,仔细看一下结果树里面给我…

axios请求415错误Uncaught (in promise) Error: Request failed with status code 415

Uncaught (in promise) Error: Request failed with status code 415 错误如下图 前端代码(vue): var data {username: this.loginForm.username,password: this.loginForm.password}this.$axios.post(this.GLOBAL.host /login, this.$q…

http409 415报错原因

409 今天一个同事的接口突然报409,大概百度了一下,不是很清楚,谷歌也没找到特别好的解释 因为是直接调用的gitlab,就直接看了下gitlab的api The following table shows the possible return codes for API requests. Return valuesDescription200 OKThe GET, PUT or DELETE re…

ajax请求415错误

1.ajax请求服务器报415错误多半是ajax的请求格式不对,服务器不支持此媒体类型, 那么,此时你首先小检查自己的ajax的格式是否正确,在就是传递的参数类型是否是正确的(传递给服务器的参数也要根据后台的要求设置,有时传递一个对象,但有时要将对象转换为json字符串),下面举两个典…

Uncaught (in promise) Error: Request failed with status code 415

今天在做接口对接的时候,出现了415这个错误,这个坑改了好久,记录一下 我首先用swagger测试了一下数据,是可以成功的 这样可以猜测错误应该出现在前端axios请求过程中了 但是前端也确定发送的请求没问题,又检查了一下&a…

415错误解决方案

springboot框架 用mybatis-plus自动生成代码,做一个前端注册功能报415错误 后端发现去掉ResponseBody即可