inst/examples/test_rmpi/allreduce_spmd.r

### SHELL> mpiexec -np 2 Rscript --vanilla [...]_spmd.r

suppressMessages(library(pbdMPI, quietly = TRUE))

source("./01_setting")

x <- (1:N) + N * .comm.rank

time.proc <- list()

time.proc$array <- system.time({
  for(i in 1:iter.total){
    y <- allreduce(matrix(as.integer(x), nrow = sqrt(N)), op = "sum")
  }
  barrier()
})

time.proc$integer <- system.time({
  for(i in 1:iter.total){
    y <- allreduce(as.integer(x), integer(N), op = "sum")
  }
  barrier()
})

time.proc$double <- system.time({ 
  for(i in 1:iter.total){
    y <- allreduce(as.double(x), double(N), op = "sum")
  }
  barrier()
})

time.proc$integer.nobuffer <- system.time({
  for(i in 1:iter.total){
    y <- allreduce(as.integer(x), op = "sum")
  }
  barrier()
})

time.proc$double.nobuffer <- system.time({ 
  for(i in 1:iter.total){
    y <- allreduce(as.double(x), op = "sum")
  }
  barrier()
})

comm.print(time.proc, quiet = TRUE)

finalize()

Try the pbdMPI package in your browser

Any scripts or data that you put into this service are public.

pbdMPI documentation built on Aug. 30, 2025, 1:12 a.m.