Skip to content

Commit

Permalink
1.3.4 cran
Browse files Browse the repository at this point in the history
  • Loading branch information
jinseob2kim committed Sep 24, 2024
1 parent 88d0193 commit 07813a5
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 19 deletions.
2 changes: 1 addition & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Package: jstable
Title: Create Tables from Different Types of Regression
Version: 1.3.4
Date: 2024-09-05
Date: 2024-09-24
Authors@R: c(person("Jinseob", "Kim", email = "jinseob2kim@gmail.com", role = c("aut", "cre"), comment = c(ORCID = "0000-0002-9403-605X")),
person("Zarathu", role = c("cph", "fnd")),
person("Yoonkyoung","Jeon", role = c("aut")),
Expand Down
1 change: 1 addition & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
# jstable 1.3.4
* Fix: error in `forestcox` when categorical binary outcome
* Fix: error in `forestglm` when categorical covariates

# jstable 1.3.3
* Update: Add cox2.display available in fine-and-gray(competing risk), Multi-State Model (MSM)
Expand Down
46 changes: 28 additions & 18 deletions R/forestglm.R
Original file line number Diff line number Diff line change
Expand Up @@ -91,22 +91,25 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
model <- stats::glm(formula, data = data, x = T, family = family)
# if (!is.null(model$xlevels) & length(model$xlevels[[1]]) != 2) stop("Categorical independent variable must have 2 levels.")
}

xlev <- ifelse(length(model$xlevels) == 0, NA, model$xlevels)

xlev <- NA
if (length(model$xlevels[[xlabel]]) > 0){
xlev <- model$xlevels[[xlabel]]
}

# cc, PE, CI, PV 구하기
cc <- summary(model)$coefficients
Point.Estimate <- round(stats::coef(model), decimal.estimate)[2:(1 + ncoef)]
CI <- round(matrix(c(cc[2:(1 + ncoef), 1] - qnorm(0.975) * cc[2:(1 + ncoef), 2], cc[2:(1 + ncoef), 1] + qnorm(0.975) * cc[2:(1 + ncoef), 2]),
ncol = 2,
dimnames = list(paste0(xlabel, xlev[[1]][-1]), c("2.5 %", "97.5 %"))
dimnames = list(paste0(xlabel, xlev[-1]), c("2.5 %", "97.5 %"))
), decimal.estimate)

if (family %in% c("binomial", "poisson", "quasipoisson")) {
Point.Estimate <- round(exp(stats::coef(model)), decimal.estimate)[2:(1 + ncoef)]
CI <- round(exp(matrix(c(cc[2:(1 + ncoef), 1] - qnorm(0.975) * cc[2:(1 + ncoef), 2], cc[2:(1 + ncoef), 1] + qnorm(0.975) * cc[2:(1 + ncoef), 2]),
ncol = 2,
dimnames = list(paste0(xlabel, xlev[[1]][-1]), c("2.5 %", "97.5 %"))
dimnames = list(paste0(xlabel, xlev[-1]), c("2.5 %", "97.5 %"))
)), decimal.estimate)
}

Expand All @@ -132,7 +135,7 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
} else {
data.frame(
Variable = c("Overall", rep("", length(Point.Estimate))), Count = c(length(model$y), rep("", length(Point.Estimate))), Percent = c(100, rep("", length(Point.Estimate))),
Levels = paste0(xlabel, "=", xlev[[1]]), `Point Estimate` = c("Reference", Point.Estimate), Lower = c("", CI[, 1]), Upper = c("", CI[, 2])
Levels = paste0(xlabel, "=", xlev), `Point Estimate` = c("Reference", Point.Estimate), Lower = c("", CI[, 1]), Upper = c("", CI[, 2])
) %>%
dplyr::mutate(`P value` = c("", ifelse(pv >= 0.001, pv, "<0.001")), `P for interaction` = NA) -> out

Expand Down Expand Up @@ -164,8 +167,11 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
table() %>%
names() -> label_val
label_val %>% purrr::map(~ possible_svyglm(formula, design = subset(data, get(var_subgroup) == .), x = TRUE, family = family.svyglm)) -> model
xlev <- ifelse(length(survey::svyglm(formula, design = data)$xlevels) == 0, NA, survey::svyglm(formula, design = data)$xlevels)

xlev <- NA
if (length(survey::svyglm(formula, design = data)$xlevels[[xlabel]]) > 0){
xlev <- survey::svyglm(formula, design = data)$xlevels[[xlabel]]
}

# pv_int 구하기
pv_int <- tryCatch(
{
Expand Down Expand Up @@ -211,7 +217,11 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
select(dplyr::all_of(var_subgroup)) %>%
table() %>%
names() -> label_val
xlev <- ifelse(length(stats::glm(formula, data = data, family = family)$xlevels) == 0, NA, stats::glm(formula, data = data, family = family)$xlevels)

xlev <- NA
if (length(stats::glm(formula, data = data, family = family)$xlevels[[xlabel]]) > 0){
xlev <- stats::glm(formula, data = data, family = family)$xlevels[[xlabel]]
}
model.int <- possible_glm(as.formula(gsub(xlabel, paste(xlabel, "*", var_subgroup, sep = ""), deparse(formula))), data = data, family = family)

# pv_int 구하기
Expand All @@ -236,8 +246,8 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
Point.Estimate <- model %>%
purrr::map("coefficients", default = NA) %>%
lapply(function(x) {
est <- rep(NA, max(length(xlev[[1]]) - 1, 1))
names(est) <- paste0(xlabel, xlev[[1]][-1])
est <- rep(NA, max(length(xlev) - 1, 1))
names(est) <- paste0(xlabel, xlev[-1])

for (i in names(est)) {
tryCatch(est[i] <- x[i],
Expand All @@ -254,7 +264,7 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
return(NA)
})

ci0 <- matrix(NA, ncol = 2, nrow = max(length(xlev[[1]]) - 1, 1), dimnames = list(paste0(xlabel, xlev[[1]][-1]), c("2.5 %", "97.5 %")))
ci0 <- matrix(NA, ncol = 2, nrow = max(length(xlev) - 1, 1), dimnames = list(paste0(xlabel, xlev[-1]), c("2.5 %", "97.5 %")))
for (i in rownames(ci0)) {
ci0[i, 1] <- tryCatch(cc0[i, 1] - stats::qnorm(0.975) * cc0[i, 2], error = function(e) {
return(NA)
Expand All @@ -270,8 +280,8 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
Point.Estimate <- model %>%
purrr::map("coefficients", default = NA) %>%
lapply(function(x) {
est <- rep(NA, max(length(xlev[[1]]) - 1, 1))
names(est) <- paste0(xlabel, xlev[[1]][-1])
est <- rep(NA, max(length(xlev) - 1, 1))
names(est) <- paste0(xlabel, xlev[-1])

for (i in names(est)) {
tryCatch(est[i] <- x[i],
Expand All @@ -288,7 +298,7 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
return(NA)
})

ci0 <- matrix(NA, ncol = 2, nrow = max(length(xlev[[1]]) - 1, 1), dimnames = list(paste0(xlabel, xlev[[1]][-1]), c("2.5 %", "97.5 %")))
ci0 <- matrix(NA, ncol = 2, nrow = max(length(xlev) - 1, 1), dimnames = list(paste0(xlabel, xlev[-1]), c("2.5 %", "97.5 %")))
for (i in rownames(ci0)) {
ci0[i, 1] <- tryCatch(cc0[i, 1] - stats::qnorm(0.975) * cc0[i, 2], error = function(e) {
return(NA)
Expand All @@ -308,8 +318,8 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
return(NA)
})

pvl <- rep(NA, max(length(xlev[[1]]) - 1, 1))
names(pvl) <- paste0(xlabel, xlev[[1]][-1])
pvl <- rep(NA, max(length(xlev) - 1, 1))
names(pvl) <- paste0(xlabel, xlev[-1])
for (i in names(pvl)) {
pvl[i] <- tryCatch(cc0[i, 4], error = function(e) {
return(NA)
Expand All @@ -332,8 +342,8 @@ TableSubgroupGLM <- function(formula, var_subgroup = NULL, var_cov = NULL, data,
}
} else {
data.frame(
Variable = unlist(lapply(label_val, function(x) c(x, rep("", length(xlev[[1]]) - 1)))), Count = unlist(lapply(Count, function(x) c(x, rep("", length(xlev[[1]]) - 1)))), Percent = unlist(lapply(round(Count / sum(Count) * 100, decimal.percent), function(x) c(x, rep("", length(xlev[[1]]) - 1)))),
Levels = rep(paste0(xlabel, "=", xlev[[1]]), length(label_val)), `Point Estimate` = unlist(lapply(Point.Estimate, function(x) c("Reference", x))), Lower = unlist(lapply(CI, function(x) c("", x[, 1]))), Upper = unlist(lapply(CI, function(x) c("", x[, 2])))
Variable = unlist(lapply(label_val, function(x) c(x, rep("", length(xlev) - 1)))), Count = unlist(lapply(Count, function(x) c(x, rep("", length(xlev) - 1)))), Percent = unlist(lapply(round(Count / sum(Count) * 100, decimal.percent), function(x) c(x, rep("", length(xlev) - 1)))),
Levels = rep(paste0(xlabel, "=", xlev), length(label_val)), `Point Estimate` = unlist(lapply(Point.Estimate, function(x) c("Reference", x))), Lower = unlist(lapply(CI, function(x) c("", x[, 1]))), Upper = unlist(lapply(CI, function(x) c("", x[, 2])))
) %>%
dplyr::mutate(`P value` = unlist(lapply(pv, function(x) c("", ifelse(x >= 0.001, x, "<0.001")))), `P for interaction` = NA) -> out

Expand Down

0 comments on commit 07813a5

Please sign in to comment.