ここで関連する質問をしたところ、応答はうまくいきました: 並列の parLapply を使用: 並列コード内の変数にアクセスできません
問題は、関数内で答えを使用しようとすると、のデフォルト環境にあると思われるため、機能しないことですclusterExport
。私はビネットを読んでヘルプファイルを見ましたが、非常に限られた知識ベースでこれに取り組んでいます. 私が使用した方法は、次のようparLapply
に動作することを期待していましlapply
たが、そうではないようです。
これが私の試みです:
par.test <- function(text.var, gc.rate=10){
ntv <- length(text.var)
require(parallel)
pos <- function(i) {
paste(sapply(strsplit(tolower(i), " "), nchar), collapse=" | ")
}
cl <- makeCluster(mc <- getOption("cl.cores", 4))
clusterExport(cl=cl, varlist=c("text.var", "ntv", "gc.rate", "pos"))
parLapply(cl, seq_len(ntv), function(i) {
x <- pos(text.var[i])
if (i%%gc.rate==0) gc()
return(x)
}
)
}
par.test(rep("I like cake and ice cream so much!", 20))
#gives this error message
> par.test(rep("I like cake and ice cream so much!", 20))
Error in get(name, envir = envir) : object 'text.var' not found