Mar*_*cus 4 parallel-processing compiler-errors r
有人可以帮我理解为什么我的程序会产生这个错误吗?
从这里可以看出,"pay.freq"显然是环境的一部分,为什么它找不到呢?语法与"ts"相同,它可以毫无问题地找到它
大圆圈部分包含单词功能,小圆圈部分覆盖单词情节.

cf.pro <- function(t=0,Tb=T,r=Y, k=1, PRFlag="P", freq="w",plot=0){ #Beregner exposure for alle tidspunkter med udgangspunkt
ts <- seq(0,30,1/52)
pay.freq <- if(toupper(freq)=="W"){1}else #bestemmer hvor ofte der sker betalinger
if(toupper(freq)=="Q"){13}else
if(toupper(freq)=="H"){26}else
if(toupper(freq)=="Y"){52}else print("Fejl i frequency input")
library('parallel')
cl <- makeCluster(7)
clusterEvalQ(cl,source("C:/Users/Marcus/Documents/CBS/Speciale/Data/Global data.R"))
clusterEvalQ(cl,source("C:/Users/Marcus/Documents/CBS/Speciale/Data/Swappriser.R"))
clusterEvalQ(cl,source("C:/Users/Marcus/Documents/CBS/Speciale/Data/Interest simulation.R"))
clusterEvalQ(cl,source("C:/Users/Marcus/Documents/CBS/Speciale/Data/Survival sim.R"))
clusterEvalQ(cl,source("C:/Users/Marcus/Documents/CBS/Speciale/Data/Exposures.R"))
clusterExport(cl,"ts")
clusterExport(cl,"pay.freq")
cf.pro <- parSapplyLB(cl,1:n, function(j){ #Beregner exposure serie n gange
if (k==1) k=Swap(t=0,Ta=0,Tb=Tb,r=r[,j])
sapply(ts,function(i){Exposure.cf(t=i,Tb=Tb,r=r[,j], k=k, PRFlag=PRFlag, pay.freq=pay.freq)}) #beregner exposure for alle tidspunkter
})
stopCluster(cl)
if (plot==1) {
tss <- seq(t, Tb, dt)
matplot(tss, cf.pro[,1:n], type="l", lty=1, main="Exposure Profiles", ylab="Exposure")
lines(tss,rowMeans(cf.pro), lty=1, lwd=3)
}
return(cf.pro)
}
CF.pro.w=cf.pro(t=0,Tb=T,r=r, PRFlag="P", freq="w", plot=1)
Run Code Online (Sandbox Code Playgroud)
如果您查看clusterExport文档,则调用如下
clusterExport(cl, varlist, envir = .GlobalEnv)
Run Code Online (Sandbox Code Playgroud)
如您所见,查找要导出的变量的默认环境是.GlobalEnv.
您正在函数中进行导出,而pay.freq的范围不是GlobalEnv,而是函数的本地环境.但是您没有为clusterExport指定函数的环境,因此clusterExport查找GlobalEnv并且找不到pay.freq.
我愿意打赌这是你的问题,而pay.freq现在出现在你的环境中,因为你可能会逐行检查你的代码.我将清除您的环境并尝试通过为clusterExport指定函数环境来再次运行代码.
让我知道这是怎么回事,如果问题有点麻烦,我们也许可以解决这个问题.这只是我第一次想到这个问题.
| 归档时间: |
|
| 查看次数: |
3713 次 |
| 最近记录: |