如何使用 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 (将#修改为@)