inst/tests/blrm-pred.r

require(rmsb)
stanSet()
set.seed(1)
n <- 100
x1 <- rnorm(n)
x2 <- rnorm(n)
y  <- round(x1 + x2 + rnorm(n), .1)
table(y)
dd <- datadist(x1, x2); options(datadist='dd')
f <- orm(y ~ x1 + x2)
n <- data.frame(x1=c(-.5, .3), x2=.75)

g <- blrm(y ~ x1 + x2, ~ x1, cppo=function(y) y)
# Just keep the first 8 posterior draws to make later output smaller
# g$draws <- g$draws[1:8,]
predict(f, n)
stat <- 'mean'
p <- predict(g, n, posterior.summary=stat)
p
pf <- predict(f, n, type='fitted')
# xless(t(pf))
p <- predict(g, n, type='fitted', posterior.summary=stat)
p
pf <- predict(f, n, type='fitted.ind')
# xless(t(pf))
predict(g, n, type='fitted.ind', posterior.summary=stat)
alldraws <- predict(g, n, type='fitted.ind', posterior.summary='all')
M <- Mean(g)
predict(f, n, type='mean')
p <- predict(g, n, fun=M, posterior.summary=stat)
p
alldraws <- predict(g, n, posterior.summary='all')

pf <- predict(f, n)
pg <- predict(g, n, posterior.summary=stat)
ybar <- Mean(f)
ybar(pf)
ybar <- Mean(g)
ybar(pg$linear.predictors)

yq <- Quantile(f)
yq(lp=pf)   # defaults to median
yq <- Quantile(g)
yq(lp=pg$linear.predictors)

ep <- ExProb(f)
ep(pf, y=.5)
ep <- ExProb(g)
ep(pg$linear.predictors, y=.5)

f <- update(f, x=TRUE, y=TRUE)

a <- seq(-2, 2, by=1)
Predict(f, x1=a)
Predict(g, x1=a)

Predict(f, x1=a, fun='mean', conf.int=0)
Predict(g, x1=a, fun=M)

ggplot(Predict(f, x1, fun='mean', conf.int=0))
ggplot(Predict(g, x1, fun=M))

Try the rmsb package in your browser

Any scripts or data that you put into this service are public.

rmsb documentation built on Sept. 26, 2023, 5:11 p.m.