问题描述
我有一个集群(一主一从),我想发送数据=[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 (将#修改为@)