首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >R doParallel与独立工人的错误处理

R doParallel与独立工人的错误处理
EN

Stack Overflow用户
提问于 2015-12-29 05:18:19
回答 1查看 1.9K关注 0票数 5

我必须运行很多随机森林模型,所以我想在我的服务器上使用doParallel来加快进程。

然而,有些模型需要比其他模型更长的时间,甚至可能会导致错误。我想并行运行8个模型,如果模型抛出错误和/或跳过,那么工作人员应该继续运行。每个模型的结果都保存在硬盘上,这样我就可以在以后访问并组合它们。

代码语言:javascript
运行
复制
TryCatch

代码语言:javascript
运行
复制
.errorhandling="remove" 

没有解决问题。我得到了

代码语言:javascript
运行
复制
 Error in unserialize(socklist[[n]]) : error reading from connection

代码示例:我尝试了%do%并成功地运行了模型2-7。但在%dopar%中,我得到了显示的错误

代码语言:javascript
运行
复制
 foreach(model=1:8, .errorhandling="remove") %dopar% {


      tryCatch({
          outl <- rf_perform(...)
          saveRDS(outl,file=getwd() %+% "/temp/result_" %+% model %+% ".rds")

     }, error = function(e) {print(e)}, finally = {})
  }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-29 16:36:06

我想我发现了一个问题:如果您导出到集群的对象太大,要么R不能再处理它,要么就会有超时

我的数据对象导出器是500万行300个变量,输出到16个集群。

代码语言:javascript
运行
复制
cl <- makeCluster(16)
registerDoParallel(cl)
clusterExport(cl, "data")

#data must not be too large

我把物体缩小成较小的部分,现在它起作用了。作者可能希望在doParallel文档中提到这一点,或者在对象太大时抛出警告。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34504853

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档