微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用 MPI 在 Cluster 中的 slaves 和 master 之间划分特定进程?

如何解决如何使用 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 举报,一经查实,本站将立刻删除。