我正在尝试将一段代码在4个节点(类型为“SOCK”)上并行化。这是我的代码。
library(itertools)
library(foreach)
library(doParallel)
library(parallel)
workers <- ip address of 4 nodes
cl = makePSOCKcluster(workers, master="ip address of master")
registerDoParallel(cl)
z <- read.csv("ProcessedData.csv", header=TRUE, as.is=TRUE)
z <- as.matrix(z)
system.time({
chunks <- getDoParWorkers()
b <- foreach (these = isplitIndices(nrow(z),
chunks=chunks),
.combine = c) %dopar% {
a <- rep(0, length(these))
for (i in 1:length(these)) {
a[i] <- mean(z[these[i],])
}
a
}
})
我遇到了这个错误:
4个节点产生了错误,第一个错误:找不到对象'.doSnowGlobals'。
如果我使用doMC即使用同一台机器的内核,这段代码可以正常运行。但是当我尝试使用其他计算机进行并行计算时,就会出现上述错误。当我将其更改为registerDoSNOW时,错误仍然存在。
snow和DoSNOW在集群中能否工作?我可以使用snow在本地主机上创建节点,但无法在集群上创建。有人在使用snow吗?