如何解决如何使用 MPI 在 Cluster 中的 slaves 和 master 之间划分特定进程?
我有一个集群(一主一从),我想发送数据=[1,2,3,4,5]给从。
我愿意:方法(a)
if( myrank == 0) { // master
for(i=1; i<=5; i++)
send(slave,i,data[i-1]);
}
else { // slaves
recv_from_master( master,data);
printf(data);
}
好的,这段代码即使在一台机器上也能运行:mpi exec -5 ./code
但我有一个集群(一台主机和一台从机),我可以这样做:APPROACH(b)
if( processor_name == "master")
// do this
else if(processor_name == "slave")
// do this
但我的老师说我们通常使用进程而不是处理器来编写代码。现在我的困惑来了。
我们通过以下方式运行集群:mpi exec -5 machine file ./code
机器文件包含:
大师:4
从:4
那么,我怎么知道这个进程从属机器会运行而进程 0 主机会运行。 寻求帮助。谢谢!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。