首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >rJAGS版本的write.model()?

rJAGS版本的write.model()?
EN

Stack Overflow用户
提问于 2013-07-23 16:08:12
回答 2查看 725关注 0票数 3

R2WinBUGS包有一个名为write.model()的函数。R包rjags没有这样的功能,我知道。write.model创建一个临时文本文件,该文本文件可以被WinBUGS作为模型读取。

我知道我可以在控制台中输入write.model来查看函数,但是这个函数似乎调用了我以前从未见过的函数,并且无法在help()中搜索(例如,replaceScientificNotationR显然是一个函数)。

我看到这篇文章描述了一些这样做的方法,但如果可能的话,我希望不必使用引号(只是为了维护语法突出显示),还有一条评论建议“复制write.model函数”应该是可行的。

有人做过这个吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-02-08 05:53:36

想必,您可以只加载R2WinBUGS来访问该函数。

但是,在通常情况下,如果有一个函数无法看到代码,请尝试getAnywhere

例如,getAnywhere(replaceScientificNotationR)生产:

代码语言:javascript
复制
A single object matching ‘replaceScientificNotationR’ was found
It was found in the following places
  namespace:R2WinBUGS
with value

function (bmodel, digits = 5) 
{
    env <- new.env()
    assign("rSNRidCounter", 0, envir = env)
    replaceID <- function(bmodel, env, digits = 5) {
        for (i in seq_along(bmodel)) {
            if (length(bmodel[[i]]) == 1) {
                if (as.character(bmodel[[i]]) %in% c(":", "[", 
                  "[[")) 
                  return(bmodel)
                if ((typeof(bmodel[[i]]) %in% c("double", "integer")) && 
                  ((abs(bmodel[[i]]) < 0.001) || (abs(bmodel[[i]]) > 
                    10000))) {
                  counter <- get("rSNRidCounter", envir = env) + 
                    1
                  assign("rSNRidCounter", counter, envir = env)
                  id <- paste("rSNRid", counter, sep = "")
                  assign(id, formatC(bmodel[[i]], digits = digits, 
                    format = "E"), envir = env)
                  bmodel[[i]] <- id
                }
            }
            else {
                bmodel[[i]] <- replaceID(bmodel[[i]], env, digits = digits)
            }
        }
        bmodel
    }
    bmodel <- deparse(replaceID(bmodel, env, digits = digits), 
        control = NULL)
    for (i in ls(env)) {
        bmodel <- gsub(paste("\"", i, "\"", sep = ""), get(i, 
            envir = env), bmodel, fixed = TRUE)
    }
    bmodel
}
<environment: namespace:R2WinBUGS>

因此,它是R2WinBUGS包中的一个内部函数。或者,您可以下载来自CRAN的包源并进行探索。

票数 2
EN

Stack Overflow用户

发布于 2015-04-01 22:49:25

除非您愿意,否则不需要复制write.model函数。诀窍是将write.model与textConnection结合使用。例如:

代码语言:javascript
复制
require(nlme)
require(rjags)
require(R2WinBUGS)

jdat <- list(nobs=nrow(Rail), travel=Rail$travel, Rail=Rail$Rail)
jinit <- list(mu=50, tau=1, tau.theta=1)

jfun6 <- function() {
  for(i in 1:nobs){
    travel[i] ~ dnorm(mu + theta[Rail[i]], tau)
  }
  for(j in 1:6) {
    theta[j] ~ dnorm(0, tau.theta)
  }
  # mu ~ dnorm() works fine since the mean is far from 0
  # mu ~ dgamma(1, 0.0001) could be used to ensure positive numbers.
  # mu ~ dnorm(50, 0.0001) I(0,) also ensures positive numbers.
  # We use truncation to show a difference between rjags and R2WinBUGS.
  # R2WinBUGS needs a dummy operator %_% that will be removed.
  mu ~ dnorm(50, 0.0001) %_% I(0,)
  tau ~ dgamma(1, .001)
  tau.theta ~ dgamma(1, .001)
  sigma <- 1/sqrt(tau)
  sigma.theta <- 1/sqrt(tau.theta)
}

# Save the jfun6 function into a text object called jmod6
tc1 <- textConnection("jmod6", "w")
write.model(jfun6, tc1)
close(tc1)

# Read the text object
tc2 <- textConnection(jmod6)
j6 <- jags.model(tc2, data=jdat, inits=jinit)
close(tc2)
c6 <- coda.samples(j6, c("mu","theta", "sigma", "sigma.theta"), n.iter=100000, thin=5)
summary(c6)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17815418

复制
相关文章

相似问题

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