在R中调用OpenBUGS无法正常工作

时间:2012-12-29 08:22:27

标签: r winbugs

我一直在尝试运行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,一切正常。

1 个答案:

答案 0 :(得分:0)

我认为你已经以某种方式获得了sd定义的奇怪版本。 getAnywhere("sd")$where的结果是什么?它应该是"package:stats" "namespace:stats"。如果你做了attach(schools)我可以看到它会在你的工作区中创建另一个名为sd的对象,但这不应该导致问题,因为它不是一个函数。

解决方案:rm(sd)rm("sd")(后者可能更好)