MPI parallelization using SNOW is slow

后端 未结 1 1705
死守一世寂寞
死守一世寂寞 2021-01-19 06:18

My foray into parallelization continues. I initially had difficulty installing Rmpi, but I got that going (I needed to sudo apt-get it). I should s

1条回答
  •  失恋的感觉
    2021-01-19 06:59

    It's a bit the same as with your other question : the communication between the nodes in the cluster is taking up more time than the actual function.

    This can be illustrated by changing your functions :

    library(snow)
    cl <- makeCluster(2)
    
    SnowSim <- function(cluster, nSims=10,n){
      parSapply(cluster, 1:nSims, function(x){
        Sys.sleep(n)
        x
      })
    }
    
    
    
    library(foreach)
    library(doSNOW)
    registerDoSNOW(cl)
    
    ForSim <- function(nSims=10,n) {
      foreach(i=1:nSims, .combine=c) %dopar% {
          Sys.sleep(n)
          i
      }
    }
    

    This way we can simulate a long-calculating and a short-calculating function in different numbers of simulations. Let's take two cases, one where you have 1 sec calculation and 10 loops, and one with 1ms calculation and 10000 loops. Both should last 10sec :

    > system.time(SnowSim(cl,10,1))
       user  system elapsed 
          0       0       5 
    
    > system.time(ForSim(10,1))
       user  system elapsed 
       0.03    0.00    5.03 
    
    > system.time(SnowSim(cl,10000,0.001))
       user  system elapsed 
       0.02    0.00    9.78 
    
    > system.time(ForSim(10000,0.001))
       user  system elapsed 
      10.04    0.00   19.81 
    

    Basically what you see, is that for long-calculating functions and low simulations, the parallelized versions cleanly cut the calculation time in half as expected.

    Now the simulations you do are of the second case. There you see that the snow solution doesn't really make a difference any more, and that the foreach solution even needs twice as much. This is simply due to the overhead of communication to and between nodes, and handling of the data that gets returned. The overhead of foreach is a lot bigger than with snow, as shown in my answer to your previous question.

    I didn't fire up my Ubuntu to try with an MPI cluster, but it's basically the same story. There are subtle differences between the different types of clusters according to time needed for communication, partly due to differences between the underlying packages.

    0 讨论(0)
提交回复
热议问题