称为调用,其包括功能的foreach%dopar%从的Optim构造导致错误:的R - 与内部功能的foreach%dopar%问题通过的Optim
> workers <- startWorkers(6) # 6 cores
>
> registerDoSMP(workers)
>
> t0 <- Sys.time()
>
> optim(w,maxProb2,control=list(fnscale=-1))
>
> Error in { : task 1 failed - "unused argument(s) (isPrebuilt = TRUE)"
>
> Sys.time()-t0
>
> Time difference of 2.032 secs
>
> stopWorkers(workers)
被调用的函数看起来像这样:
> maxProb2 <- function(wp) {
>
> r <- foreach (i=s0:s1, .combine=c) %dopar% { pf(i,x[i,5],wp,isPrebuilt=TRUE) }
>
> cat("w=",wp,"max=",sum(r),"\n")
>
> sum(r)
>
> }
pf是一些其他函数,x是一个预先计算的元素的静态表。
而且调用该函数进行优化,只有一次引起了同样的错误:
> workers <- startWorkers(6) # 6 cores
>
> Warning message:
> In startWorkers(6) : there is an existing doSMP session using doSMP1
>
> registerDoSMP(workers)
>
> maxProb2(w)
> Error in { : task 1 failed - "unused argument(s) (isPrebuilt = TRUE)"
>
> stopWorkers(workers)
有什么奇怪的,在相同的代码工作正常时直接调用一个时间(的Optim卡列斯同样的功能很多次):
> workers <- startWorkers(6) # 6 - ilosc rdzeni
>
> Warning message:
> In startWorkers(6) : there is an existing doSMP session using doSMP1
>
> registerDoSMP(workers)
>
> r <- foreach (i=s0:s1, .combine=c) %dopar% { pf(i,x[i,5],w,isPrebuilt=TRUE) }
>
> sum(r)
> [1] 187.1781
>
> stopWorkers(workers)
当使用%do%代替%dopar%时,被调用函数(maxProb2)可以正常工作。
如何正确调用包含foreach%dopar%构造的函数?
更新2011-07-17:
我已经改名为PF功能分为probf但问题仍然存在。
probf函数在脚本中定义,而不是在某些外部包中定义。
有两点需要注意:操作系统:Windows 7,IDE:革命分析企业4.3
> workers <- startWorkers(workerCount = 3)
>
> registerDoSMP(workers)
>
> maxProb2(w)
>
Error in { : task 1 failed - "could not find function "probf""
请始终在您的问题中包含确切的错误信息。 –