我一直在尝试运行R代码来使用OpenBugs。它一直运作到昨天,我不知道我做了什么它开始显示一些错误。然后我决定看看一些简单的例子是否运作良好。所以我尝试了R2WinBUGS
vignettes中的学校示例。
文件schools.txt中的模型是
sink("schools.txt")
cat("
model {
for (j in 1:J)
{
y[j] ~ dnorm (theta[j], tau.y[j])
theta[j] ~ dnorm (mu.theta, tau.theta)
tau.y[j] <- pow(sigma.y[j], -2)
}
mu.theta ~ dnorm (0.0, 1.0E-6)
tau.theta <- pow(sigma.theta, -2)
sigma.theta ~ dunif (0, 1000)
}",fill=TRUE)
sink()
运行程序其余部分的代码如下:
data(schools)
J <- nrow(schools)
y <- schools$estimate
sigma.y <- schools$sd
data <- list ("J", "y", "sigma.y")
inits <- function()
{
list(theta = rnorm(J, 0, 100), mu.theta = rnorm(1, 0, 100),sigma.theta = runif(1, 0, 100))
}
schools.sim <- bugs(data, inits, model.file = "schools.txt",parameters = c("theta", "mu.theta", "sigma.theta"),n.chains = 3, n.iter = 1000)
不幸的是,我收到的错误与之前相同。
> schools.sim <- bugs(data, inits, model.file = "schools.txt",parameters = c("theta", "mu.theta", "sigma.theta"),n.chains = 3, n.iter = 1000)
Error in sd(as.vector(ai)) : unused argument(s) (as.vector(ai))
我也尝试过指定program=c('OpenBugs')
但是这给了我另一个奇怪的错误,因为OpenBugs在路径中
Error in bugs(data, inits, model.file = "schools.txt", parameters = c("theta", :
unused argument(s) (program = c("OpenBugs"))
修改
> sessionInfo()
R version 2.15.2 (2012-10-26)
Platform: i386-w64-mingw32/i386 (32-bit)
locale:
[1] LC_COLLATE=English_United States.1252 LC_CTYPE=English_United States.1252
[3] LC_MONETARY=English_United States.1252 LC_NUMERIC=C
[5] LC_TIME=English_United States.1252
attached base packages:
[1] parallel stats graphics grDevices utils datasets methods base
other attached packages:
[1] abind_1.4-0 rjags_3-9 R2WinBUGS_2.1-18 BRugs_0.8-0 R2OpenBUGS_3.2-2.1
[6] LearnBayes_2.12 coda_0.16-1 lattice_0.20-10
loaded via a namespace (and not attached):
[1] boot_1.3-7 grid_2.15.2 plyr_1.8 stringr_0.6.2 tools_2.15.2
traceback()
给出了......
> traceback()
No traceback available
修改-2
> getAnywhere("sd")
2 differing objects matching ‘sd’ were found
in the following places
.GlobalEnv
package:stats
namespace:stats
Use [] to view one of them`
如何删除我定义的sd
.GlobalEnv
?
修改-3
问题解决了。我从工作区中删除了对象sd
,一切正常。
答案 0 :(得分:0)
我认为你已经以某种方式获得了sd
定义的奇怪版本。 getAnywhere("sd")$where
的结果是什么?它应该是"package:stats" "namespace:stats"
。如果你做了attach(schools)
我可以看到它会在你的工作区中创建另一个名为sd
的对象,但这不应该导致问题,因为它不是一个函数。
解决方案:rm(sd)
或rm("sd")
(后者可能更好)