Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

posterior_linpred() for ordinal families: argument for taking the intercept into account #1137

Merged
merged 34 commits into from
May 5, 2021
Merged
Changes from 1 commit
Commits
Show all changes
34 commits
Select commit Hold shift + click to select a range
a609e11
Introduce an argument to posterior_linpred() for taking the intercept…
fweber144 Apr 12, 2021
fcd2c21
Add a NEWS entry.
fweber144 Apr 12, 2021
0a68dae
Insert GitHub PR number.
fweber144 Apr 12, 2021
40e43ac
Merge branch 'master' into projpred_augdat
fweber144 Apr 13, 2021
ec4126c
Merge branch 'master' into projpred_augdat
fweber144 Apr 14, 2021
448e813
Merge branch 'master' into projpred_augdat
fweber144 Apr 14, 2021
7b696c2
Merge branch 'master' into projpred_augdat
fweber144 Apr 29, 2021
de47fdd
add 'slice' function
paul-buerkner Apr 29, 2021
837a8e5
refactor 'dcumulative'
paul-buerkner Apr 29, 2021
3a431d8
update implementation of 'incl_thres'
paul-buerkner Apr 29, 2021
63ba13e
fix typo
paul-buerkner Apr 29, 2021
827591f
Re-indent tests/local/tests.models_new.R
fweber144 Apr 30, 2021
8e7f4fe
Add (preliminary) tests for argument `incl_thres` of posterior_linpre…
fweber144 Apr 30, 2021
4adac19
Fix a test for argument `incl_thres` of posterior_linpred() (the one …
fweber144 Apr 30, 2021
089e506
Remove an unnecessary check.
fweber144 Apr 30, 2021
d689fd7
Fix a typo.
fweber144 Apr 30, 2021
b690b75
posterior_epred_ordinal() in case of grouped thresholds: Fill missing…
fweber144 Apr 30, 2021
71eb8eb
Merge branch 'master' into projpred_augdat
fweber144 May 1, 2021
8eb1157
posterior_epred_ordinal() in case of grouped thresholds: For the "ide…
fweber144 May 1, 2021
650b732
Replace remaining extract_col() occurrences by slice_col().
fweber144 May 1, 2021
e089a4d
minor cleaning
paul-buerkner May 2, 2021
5c1c2e3
Internally document dcumulative() and inv_link_cumulative().
fweber144 May 3, 2021
00148e1
In inv_link_cumulative(): Overwrite `x`.
fweber144 May 3, 2021
64080d3
Create and use inv_link_sratio().
fweber144 May 3, 2021
1da7f7e
Create and use inv_link_cratio().
fweber144 May 3, 2021
b0bde2f
Create and use inv_link_acat().
fweber144 May 3, 2021
5b4b3f9
Test that d<ordinal_family>() works correctly.
fweber144 May 4, 2021
5fa503e
Add argument `drop` to slice().
fweber144 May 4, 2021
aadc683
inv_link_sratio(), inv_link_cratio(), and inv_link_acat(): Allow for …
fweber144 May 4, 2021
d7e50bf
Test that inv_link_<ordinal_family>() works correctly for arrays.
fweber144 May 4, 2021
5c2cdb4
minor cleaning
paul-buerkner May 5, 2021
2438629
add frank as contributor
paul-buerkner May 5, 2021
68b4fe7
some more minor cleaning
paul-buerkner May 5, 2021
c841e36
more cleaning
paul-buerkner May 5, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Test that d<ordinal_family>() works correctly.
  • Loading branch information
fweber144 committed May 5, 2021
commit 5b4b3f9a637f90f15b6d4924f77b49217b5d92be
77 changes: 77 additions & 0 deletions tests/testthat/tests.distributions.R
Original file line number Diff line number Diff line change
Expand Up @@ -198,3 +198,80 @@ test_that("wiener distribution functions run without errors", {
expect_equal(names(r1), names(r2))
expect_equal(dim(r1), dim(r2))
})

test_that("d<ordinal_family>() works correctly", {
# This test corresponds to a single observation.
set.seed(1234)
ndraws <- 5
ncat <- 3
thres_test <- matrix(rnorm(ndraws * (ncat - 1)), nrow = ndraws)
# Emulate no category-specific effects (i.e., only a single vector of linear
# predictors) as well as category-specific effects (i.e., a matrix of linear
# predictors):
eta_test_list <- list(rnorm(ndraws),
matrix(rnorm(ndraws * (ncat - 1)), nrow = ndraws))
for (eta_test in eta_test_list) {
for (link in c("logit", "probit", "cauchit", "cloglog")) {
invlinkfun <- switch(link,
"logit" = plogis,
"probit" = pnorm,
"cauchit" = pcauchy,
"cloglog" = inv_cloglog)
F_thres_eta <- invlinkfun(if (is.matrix(eta_test)) {
stopifnot(identical(dim(eta_test), dim(thres_test)))
thres_test - eta_test
} else {
# Just to try something different:
sweep(thres_test, 1, as.array(eta_test))
})
F_eta_thres <- invlinkfun(if (is.matrix(eta_test)) {
stopifnot(identical(dim(eta_test), dim(thres_test)))
eta_test - thres_test
} else {
# Just to try something different:
sweep(-thres_test, 1, as.array(eta_test),
FUN = "+")
})
S_thres_eta_cumprod <- t(apply(1 - F_thres_eta, 1, cumprod))
F_eta_thres_cumprod <- t(apply(F_eta_thres, 1, cumprod))
S_eta_thres_cumprod_rev <- t(apply(
1 - F_eta_thres[, rev(seq_len(ncat - 1)), drop = FALSE],
1, cumprod
))
S_eta_thres_cumprod_rev <- S_eta_thres_cumprod_rev[,
rev(seq_len(ncat - 1)),
drop = FALSE]

# cumulative():
d_cumul <- dcumulative(seq_len(ncat),
eta_test, thres_test, link = link)
d_cumul_ch <- cbind(F_thres_eta, 1) - cbind(0, F_thres_eta)
dimnames(d_cumul_ch) <- list(NULL, NULL)
expect_equal(d_cumul, d_cumul_ch)

# sratio():
d_sratio <- dsratio(seq_len(ncat),
eta_test, thres_test, link = link)
d_sratio_ch <- cbind(F_thres_eta, 1) *
cbind(1, S_thres_eta_cumprod)
dimnames(d_sratio_ch) <- list(NULL, NULL)
expect_equal(d_sratio, d_sratio_ch)

# cratio():
d_cratio <- dcratio(seq_len(ncat),
eta_test, thres_test, link = link)
d_cratio_ch <- cbind(1 - F_eta_thres, 1) *
cbind(1, F_eta_thres_cumprod)
dimnames(d_cratio_ch) <- list(NULL, NULL)
expect_equal(d_cratio, d_cratio_ch)

# acat():
d_acat <- dacat(seq_len(ncat),
eta_test, thres_test, link = link)
d_acat_ch <- cbind(1, F_eta_thres_cumprod) *
cbind(S_eta_thres_cumprod_rev, 1)
d_acat_ch <- d_acat_ch / rowSums(d_acat_ch)
expect_equal(d_acat, d_acat_ch)
}
}
})