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

tentative solution for multiple calls of analyze_vars_in_cols #938

Merged
merged 27 commits into from
Jun 6, 2023
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
fd10361
small fix + test
Melkiades May 25, 2023
c3b13fa
very ugly draft
Melkiades May 25, 2023
f994c8b
complete fix
Melkiades May 26, 2023
64df796
Merge branch 'main' into 931_reinstate_summarize_vars_in_cols@main
Melkiades May 26, 2023
779963c
styling
Melkiades May 26, 2023
dd56802
fixes label with switcher
Melkiades May 31, 2023
41ea9a9
complete sort of the fix
Melkiades May 31, 2023
cc19fc8
changing indentation does not work
Melkiades May 31, 2023
16eb0e0
Merge cc19fc8400dc497817774a0e979f19cd564cc486 into f5986fa2785e78b6e…
Melkiades May 31, 2023
b8d140d
[skip actions] Restyle files
github-actions[bot] May 31, 2023
6d04dd0
remove commented code
Melkiades May 31, 2023
38ddb85
final fix of labels
Melkiades May 31, 2023
2a993a0
Merge 38ddb85124fd4ea2eaf9d57e19fe6e0473dc7a9f into f5986fa2785e78b6e…
Melkiades May 31, 2023
c99878a
[skip actions] Restyle files
github-actions[bot] May 31, 2023
10f90b6
empty
Melkiades May 31, 2023
5d6b027
Merge branch 'main' into 931_reinstate_summarize_vars_in_cols@main
Melkiades May 31, 2023
b6c3818
reverting indent
Melkiades Jun 1, 2023
627a7bd
Merge b6c3818455da50fab05888b9f36d9668cc30eda3 into 05643b25ac19fa352…
Melkiades Jun 1, 2023
03569b7
[skip actions] Restyle files
github-actions[bot] Jun 1, 2023
4de8161
tiny fix
Melkiades Jun 1, 2023
008c9a4
Merge branch '931_reinstate_summarize_vars_in_cols@main' of github.co…
Melkiades Jun 1, 2023
bd3b937
update docs
Melkiades Jun 1, 2023
c6af27e
completing docs
Melkiades Jun 2, 2023
b6d9cc1
fix involuntary example
Melkiades Jun 2, 2023
4b62637
LARGE fix
Melkiades Jun 2, 2023
df741d0
Merge branch 'main' into 931_reinstate_summarize_vars_in_cols@main
Melkiades Jun 5, 2023
f636231
Merge branch 'main' into 931_reinstate_summarize_vars_in_cols@main
Melkiades Jun 6, 2023
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
119 changes: 99 additions & 20 deletions R/analyze_vars_in_cols.R
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,29 @@
#'
#' @inheritParams argument_convention
#' @inheritParams rtables::analyze_colvars
#' @param summarize_row_groups (`flag`)\cr defaults to `FALSE` and applies the analysis to the current
#' label rows. This is a wrapper of [rtables::summarize_row_groups()] and it can accept `labelstr`
#' to define row labels. This behavior is not supported as we never need to overload row labels.
#' @param split_col_vars (`flag`)\cr defaults to `TRUE` and puts the analysis results onto the columns.
#' This option allows you to add multiple instances of this functions, also in a nested fashion,
#' without adding more splits. This split must happen only one time on a single layout.
#'
#' @return
#' A layout object suitable for passing to further layouting functions, or to [rtables::build_table()].
#' Adding this function to an `rtable` layout will summarize the given variables, arrange the output
#' in columns, and add it to the table layout.
#'
#' @note This is an experimental implementation of [rtables::summarize_row_groups()] and
#' [rtables::analyze_colvars()] that may be subjected to changes as `rtables` extends its
#' support to more complex analysis pipelines on the column space. For the same reasons,
#' we encourage to read the examples carefully and file issues for cases that differ from
#' them.
#'
#' Here `labelstr` behaves differently than usual. If it is not defined (default as `NULL`),
#' row labels are assigned automatically to the split values in case of `rtables::analyze_colvars`
#' (`summarize_row_groups = FALSE`, the default), and to the group label for
#' `summarize_row_groups = TRUE`.
#'
#' @seealso [summarize_vars()], [rtables::analyze_colvars()].
#'
#' @examples
Expand Down Expand Up @@ -54,7 +71,6 @@
#' result <- build_table(lyt, df = adpp)
#' result
#'
#' # PKPT03
#' lyt <- basic_table() %>%
#' split_rows_by(var = "TLG_DISPLAY", split_label = "PK Parameter", label_pos = "topleft") %>%
#' analyze_vars_in_cols(
Expand All @@ -75,6 +91,8 @@
#' result <- build_table(lyt, df = adpp)
#' result
#'
#' # Multiple calls
#'
#' @export
analyze_vars_in_cols <- function(lyt,
vars,
Expand All @@ -95,13 +113,19 @@ analyze_vars_in_cols <- function(lyt,
cv = "CV (%)",
geom_cv = "CV % Geometric Mean"
),
labelstr = " ",
labelstr = NULL,
summarize_row_groups = FALSE,
split_col_vars = TRUE,
.indent_mods = NULL,
nested = TRUE,
na_level = NULL,
.formats = NULL) {
checkmate::assert_string(na_level, null.ok = TRUE)
checkmate::assert_string(labelstr)
checkmate::assert_string(labelstr, null.ok = TRUE)
checkmate::assert_int(.indent_mods, null.ok = TRUE)
checkmate::assert_flag(nested)
checkmate::assert_flag(split_col_vars)
checkmate::assert_flag(summarize_row_groups)

# Automatic assignment of formats
if (is.null(.formats)) {
Expand All @@ -113,15 +137,32 @@ analyze_vars_in_cols <- function(lyt,
formats_v <- .formats
}

# if (length(labelstr) == 1L) {
# labelstr <- rep(labelstr, length(.stats))
# }
# Avoiding recursive argument, but keep the param name consistent
lbl_str <- labelstr

afun_list <- Map(
function(stat) {
make_afun(
s_summary,
.labels = labelstr,
.stats = stat,
.format_na_strs = na_level,
.formats = formats_v[names(formats_v) == stat]
)
function(u, .spl_context, labelstr = lbl_str, ...) {

res <- s_summary(u, ...)[[stat]]
if (summarize_row_groups) {
lbl <- ifelse(is.null(labelstr), " ", labelstr)
} else {
lbl <- ifelse(is.null(labelstr),
.spl_context$value[nrow(.spl_context)],
labelstr)
}

rcell(res,
label = lbl,
format = formats_v[names(formats_v) == stat][[1]],
format_na_str = na_level,
indent_mod = ifelse(is.null(.indent_mods), 0L, .indent_mods)
)
}
},
stat = .stats
)
Expand All @@ -136,15 +177,53 @@ analyze_vars_in_cols <- function(lyt,
)
}

lyt <- split_cols_by_multivar(
lyt = lyt,
vars = vars,
varlabels = .labels[.stats]
)
if (split_col_vars) {

analyze_colvars(lyt,
afun = afun_list,
nested = nested,
extra_args = list(...)
)
# Checking there is not a previous identical column split
clyt <- tail(clayout(lyt), 1)[[1]]

dummy_lyt <- split_cols_by_multivar(
lyt = basic_table(),
vars = vars,
varlabels = .labels[.stats]
)

if (any(sapply(clyt, identical, y = get_last_col_split(dummy_lyt)))) {
stop("Column split called again with the same values. ",
"This can create many unwanted columns. Please consider adding ",
"split_col_vars = FALSE to the last call of ",
deparse(sys.calls()[[sys.nframe()-1]]), ".")
}

lyt <- split_cols_by_multivar(
lyt = lyt,
vars = vars,
varlabels = .labels[.stats]
)
}

if (summarize_row_groups) {
if (length(unique(vars)) > 1) {
stop("When using summarize_row_groups only one label level var should be inserted.")
}
summarize_row_groups(
lyt = lyt,
var = unique(vars),
cfun = afun_list,
extra_args = list(...)
)
} else {
analyze_colvars(lyt,
afun = afun_list,
nested = nested,
extra_args = list(...)
)
}
}

# TODO: multiple analyze calls WITHOUT the row split

Melkiades marked this conversation as resolved.
Show resolved Hide resolved
# Help function
get_last_col_split <- function(lyt) {
Melkiades marked this conversation as resolved.
Show resolved Hide resolved
tail(tail(clayout(lyt), 1)[[1]], 1)[[1]]
}
3 changes: 2 additions & 1 deletion R/argument_convention.R
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,8 @@
#' all of that structure's children. Defaults to 0, which corresponds to the
#' unmodified default behavior.
#' @param labelstr (`character`)\cr label of the level of the parent split currently being summarized
#' (must be present as second argument in Content Row Functions).
#' (must be present as second argument in Content Row Functions). See [rtables::summarize_row_groups()]
#' for more information.
#' @param lyt (`layout`)\cr input layout where analyses will be added to.
#' @param na.rm (`flag`)\cr whether `NA` values should be removed from `x` prior to analysis.
#' @param na_level (`string`)\cr used to replace all `NA` or empty values in factors with custom `string`.
Expand Down
1 change: 1 addition & 0 deletions R/survival_timepoint.R
Original file line number Diff line number Diff line change
Expand Up @@ -339,6 +339,7 @@ surv_timepoint <- function(lyt,
var_labels = paste(tpt, var_labels),
table_names = paste0("surv_diff_", tpt, table_names_suffix),
show_labels = ifelse(method == "both", "hidden", show_labels),
indent_mod = ifelse(method == "both", 1L, 0L),
Melkiades marked this conversation as resolved.
Show resolved Hide resolved
afun = afun_surv_diff,
extra_args = list(
is_event = list(...)$is_event,
Expand Down
33 changes: 30 additions & 3 deletions man/analyze_vars_in_cols.Rd

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

3 changes: 2 additions & 1 deletion man/argument_convention.Rd

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

3 changes: 2 additions & 1 deletion man/c_label_n.Rd

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

3 changes: 2 additions & 1 deletion man/count_occurrences_by_grade.Rd

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

3 changes: 2 additions & 1 deletion man/count_patients_events_in_cols.Rd

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

3 changes: 2 additions & 1 deletion man/cox_regression.Rd

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

3 changes: 2 additions & 1 deletion man/summarize_num_patients.Rd

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

3 changes: 2 additions & 1 deletion man/summarize_patients_exposure_in_cols.Rd

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

56 changes: 40 additions & 16 deletions tests/testthat/_snaps/analyze_vars_in_cols.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,28 +7,52 @@
SEX n Mean SE
—————————————————————————————————
A: Drug X
F
0 NA NA
M
0 NA NA
F 0 NA NA
M 0 NA NA
B: Placebo
F
0 NA NA
M
0 NA NA
F 0 NA NA
M 0 NA NA
C: Combination
F
288 36.0 0.4
M
234 36.3 0.6
F 288 36.0 0.4
M 234 36.3 0.6

# custom labels can be set with labelstr

Code
res
Output
n Mean SD SE CV (%) CV % Geometric Mean
—————————————————————————————————————————————————————————————————————————
some custom label 288 36.0 6.3 0.4 17.6 18.0
some custom label 234 36.3 8.5 0.6 23.4 23.5
n Mean SD SE CV (%) CV % Geometric Mean
———————————————————————————————————————————————————————————————————————————
F
some custom label 288 36.0 6.3 0.4 17.6 18.0
M
some custom label 234 36.3 8.5 0.6 23.4 23.5

# custom labels can be set with labelstr and summarize

Code
res
Output
n Mean SD SE CV (%) CV % Geometric Mean
—————————————————————————————————————————————————————————
F 288 36.0 6.3 0.4 17.6 18.0
M 234 36.3 8.5 0.6 23.4 23.5

# summarize works with nested analyze

Code
sort_at_path(tbl, c("SEX", "*", "RACE"), scorefun(1))
Output
n Mean SD SE CV (%) CV % Geometric Mean
——————————————————————————————————————————————————————————————————————————————————————————
F 288 36.0 6.3 0.4 17.6 18.0
ASIAN 135 35.4 4.4 0.4 12.5 13.0
BLACK OR AFRICAN AMERICAN 81 35.3 6.9 0.8 19.6 21.0
WHITE 36 38.3 7.7 1.3 20.2 20.2
AMERICAN INDIAN OR ALASKA NATIVE 36 37.8 8.5 1.4 22.5 23.0
M 234 36.3 8.5 0.6 23.4 23.5
ASIAN 126 34.8 6.7 0.6 19.3 19.2
WHITE 63 36.5 9.5 1.2 26.1 28.6
BLACK OR AFRICAN AMERICAN 27 45.2 9.6 1.8 21.1 20.3
AMERICAN INDIAN OR ALASKA NATIVE 18 32.8 4.9 1.2 15.1 15.3

Loading