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

update g_lineplot with cohort param. #1078

Merged
merged 13 commits into from
Oct 18, 2023
Merged
12 changes: 9 additions & 3 deletions R/g_lineplot.R
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@
#' * `x` (`character`)\cr name of x-axis variable.
#' * `y` (`character`)\cr name of y-axis variable.
#' * `strata` (`character`)\cr name of grouping variable, i.e. treatment arm. Can be `NA` to indicate lack of groups.
#' * `cohort_id` (`character`)\cr name of the variable that identifies group belonging. Only applies if `strata` is
#' not NULL.
#' * `paramcd` (`character`)\cr name of the variable for parameter's code. Used for y-axis label and plot's subtitle.
#' Can be `NA` if `paramcd` is not to be added to the y-axis label or subtitle.
#' * `y_unit` (`character`)\cr name of variable with units of `y`. Used for y-axis label and plot's subtitle.
Expand Down Expand Up @@ -173,6 +175,7 @@ g_lineplot <- function(df,
strata <- NULL # NULL if strata == NA or it is not in variables
} else {
strata <- variables[["strata"]]
cohort_id <- variables[["cohort_id"]]
}
checkmate::assert_flag(y_lab_add_paramcd, null.ok = TRUE)
checkmate::assert_flag(subtitle_add_paramcd, null.ok = TRUE)
Expand Down Expand Up @@ -216,7 +219,7 @@ g_lineplot <- function(df,
if (!is.null(strata) && !is.null(alt_counts_df)) {
strata_N <- paste0(strata, "_N") # nolint

df_N <- as.data.frame(table(alt_counts_df[[strata]], exclude = c(NA, NaN, Inf))) # nolint
df_N <- stats::aggregate(USUBJID ~ eval(parse(text = strata)), data = alt_counts_df, FUN = function(x) length(unique(x))) # nolint
colnames(df_N) <- c(strata, "N") # nolint
df_N[[strata_N]] <- paste0(df_N[[strata]], " (N = ", df_N$N, ")") # nolint

Expand Down Expand Up @@ -471,6 +474,7 @@ h_format_row <- function(x, format, labels = NULL) {
#' @param x (`character`)\cr x variable name.
#' @param y (`character`)\cr y variable name.
#' @param strata (`character` or `NA`)\cr strata variable name.
#' @param cohort_id (`character` or `NA`)\cr variable to identify subjects in cohorts.
#' @param paramcd (`character` or `NA`)\cr `paramcd` variable name.
#' @param y_unit (`character` or `NA`)\cr `y_unit` variable name.
#'
Expand All @@ -481,13 +485,15 @@ h_format_row <- function(x, format, labels = NULL) {
#' control_lineplot_vars(strata = NA)
#'
#' @export
control_lineplot_vars <- function(x = "AVISIT", y = "AVAL", strata = "ARM", paramcd = "PARAMCD", y_unit = "AVALU") {
control_lineplot_vars <- function(x = "AVISIT", y = "AVAL", strata = "ARM", paramcd = "PARAMCD", y_unit = "AVALU",
cohort_id = "USUBJID") {
checkmate::assert_string(x)
checkmate::assert_string(y)
checkmate::assert_string(strata, na.ok = TRUE)
checkmate::assert_string(cohort_id, na.ok = TRUE)
checkmate::assert_string(paramcd, na.ok = TRUE)
checkmate::assert_string(y_unit, na.ok = TRUE)

variables <- c(x = x, y = y, strata = strata, paramcd = paramcd, y_unit = y_unit)
variables <- c(x = x, y = y, strata = strata, paramcd = paramcd, y_unit = y_unit, cohort_id = cohort_id)
return(variables)
}
5 changes: 4 additions & 1 deletion man/control_lineplot_vars.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions man/g_lineplot.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

52 changes: 26 additions & 26 deletions tests/testthat/_snaps/summarize_coxreg.md
Original file line number Diff line number Diff line change
Expand Up @@ -147,15 +147,15 @@
2 vs control (1) 340 0.64 (0.43, 0.94) 0.0242
Covariate:
Age 340 0.1757
40 0.62 (0.42, 0.93)
40 0.62 (0.42, 0.93)
A Covariate Label 340 0.9883
1 0.63 (0.35, 1.14)
2 0.58 (0.27, 1.26)
3 0.55 (0.22, 1.35)
4 0.69 (0.23, 2.07)
1 0.63 (0.35, 1.14)
2 0.58 (0.27, 1.26)
3 0.55 (0.22, 1.35)
ayogasekaram marked this conversation as resolved.
Show resolved Hide resolved
4 0.69 (0.23, 2.07)
Sex (F/M) 340 0.7759
F 0.67 (0.36, 1.22)
M 0.60 (0.36, 0.99)
F 0.67 (0.36, 1.22)
M 0.60 (0.36, 0.99)

# summarize_coxreg 'at' argument works in univariate case

Expand All @@ -168,12 +168,12 @@
2 vs control (1) 340 0.64 (0.43, 0.94) 0.0242
Covariate:
Age 340 0.1757
15 0.35 (0.13, 0.92)
30 0.49 (0.29, 0.86)
60 0.98 (0.47, 2.04)
15 0.35 (0.13, 0.92)
30 0.49 (0.29, 0.86)
60 0.98 (0.47, 2.04)
Sex (F/M) 340 0.7759
F 0.67 (0.36, 1.22)
M 0.60 (0.36, 0.99)
F 0.67 (0.36, 1.22)
M 0.60 (0.36, 0.99)

# summarize_coxreg `na_str` argument works

Expand All @@ -186,13 +186,13 @@
2 vs control (1) 340 0.64 (0.43, 0.94) 0.0242 ---
Covariate:
A Covariate Label 340 0.9883
1 0.63 (0.35, 1.14) ---
2 0.58 (0.27, 1.26) ---
3 0.55 (0.22, 1.35) ---
4 0.69 (0.23, 2.07) ---
1 0.63 (0.35, 1.14) ---
2 0.58 (0.27, 1.26) ---
3 0.55 (0.22, 1.35) ---
4 0.69 (0.23, 2.07) ---
Sex (F/M) 340 0.7759
F 0.67 (0.36, 1.22) ---
M 0.60 (0.36, 0.99) ---
F 0.67 (0.36, 1.22) ---
M 0.60 (0.36, 0.99) ---

# summarize_coxreg works without treatment arm in univariate case

Expand Down Expand Up @@ -235,8 +235,8 @@
ARM: 2 vs control (ARM: 1) 340 0.64 (0.43, 0.94) 0.0242
Covariate:
COVAR2 340 0.7759
F 0.67 (0.36, 1.22)
M 0.60 (0.36, 0.99)
F 0.67 (0.36, 1.22)
M 0.60 (0.36, 0.99)

---

Expand All @@ -249,13 +249,13 @@
ARM: 2 vs control (ARM: 1) 340 0.64 (0.43, 0.94) 0.0242
Covariate:
A Covariate Label 340 0.9883
1 0.63 (0.35, 1.14)
2 0.58 (0.27, 1.26)
3 0.55 (0.22, 1.35)
4 0.69 (0.23, 2.07)
1 0.63 (0.35, 1.14)
2 0.58 (0.27, 1.26)
3 0.55 (0.22, 1.35)
4 0.69 (0.23, 2.07)
COVAR2 340 0.7759
F 0.67 (0.36, 1.22)
M 0.60 (0.36, 0.99)
F 0.67 (0.36, 1.22)
M 0.60 (0.36, 0.99)

# summarize_coxreg adds the multivariate Cox regression layer to rtables

Expand Down
15 changes: 15 additions & 0 deletions tests/testthat/test-g_lineplot.R
Original file line number Diff line number Diff line change
Expand Up @@ -21,3 +21,18 @@ testthat::test_that("g_lineplot works with custom settings and statistics table"
caption = "caption"
))
})

testthat::test_that("g_lineplot works with cohort_id specified", {
testthat::expect_silent(g_lineplot(
adlb,
adsl,
strata = control_lineplot_vars(strata = "ARM", cohort_id = "USUBJID"),
mid = "median",
table = c("n", "mean", "mean_ci"),
control = control_analyze_vars(conf_level = 0.80),
title = "Plot of Mean and 80% Confidence Limits by Visit",
y_lab = "Lab Test",
subtitle = "Laboratory Test:",
caption = "caption"
))
})