inst/tinytest/coerce.R

# expect_equalcoersion of y
char_y <- matrix(LETTERS[1:2], 4, 3)
logi_y <- matrix(rep(c(TRUE, FALSE), each=6), 4, 3)
int_y <- matrix(1:12, 4, 3)
num_y <- matrix(1.0*1:12, 4, 3)
tools::assertError(grpreg:::newY(char_y, 'gaussian'))
tools::assertError(grpreg:::newY(num_y, 'binomial'))
tools::assertError(grpreg:::newY(int_y, 'binomial'))
grpreg:::newY(logi_y, 'binomial')
suppressMessages(grpreg:::newY(char_y, 'binomial'))
grpreg:::newY(num_y, 'gaussian')
grpreg:::newY(int_y, 'gaussian')
suppressMessages(grpreg:::newY(char_y[,1], 'binomial'))

# expect_equalcoersion of X, y
data(Birthwt, package='grpreg')
X <- data.frame(Birthwt$X)
y <- factor(Birthwt$low, labels=c("No", "Yes"))
suppressMessages(fit <- grpreg(X, y, family="binomial"))

# expect_equalcoersion of group
y <- Birthwt$low
g1 <- Birthwt$group
g2 <- as.numeric(factor(g1))
g3 <- as.numeric(factor(g1, levels=sort(levels(g1)))) ## Tests reordering
fit1 <- grpreg(X, y, group=g1, family="binomial")
fit2 <- grpreg(X, y, group=g2, family="binomial")
fit3 <- grpreg(X, y, group=g3, family="binomial")
expect_equal(coef(fit1, which=50), coef(fit2, which=50), tol=0.001)
expect_equal(coef(fit2, which=50), coef(fit3, which=50), tol=0.001)
expect_equal(coef(fit1, which=50), coef(fit3, which=50), tol=0.001)

Try the grpreg package in your browser

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

grpreg documentation built on July 27, 2021, 1:08 a.m.