From 2cb539d823c9093d1989ee539461af8ace40a4bf Mon Sep 17 00:00:00 2001 From: Konrad Pagacz Date: Mon, 16 Sep 2024 16:55:54 +0200 Subject: [PATCH 1/3] feat: added "fraction" statistic to the "analyze_var_count" method group --- R/analyze_variables.R | 4 ++++ R/utils_default_stats_formats_labels.R | 2 +- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/R/analyze_variables.R b/R/analyze_variables.R index 6f6a212131..69e0041607 100644 --- a/R/analyze_variables.R +++ b/R/analyze_variables.R @@ -310,6 +310,10 @@ s_summary.factor <- function(x, c(x, ifelse(dn > 0, x / dn, 0)) } ) + y$fraction <- lapply( + y$count, + function(count) c("num" = count, "denom" = dn) + ) y$n_blq <- sum(grepl("BLQ|LTR|<[1-9]| Date: Tue, 17 Sep 2024 09:49:30 +0200 Subject: [PATCH 2/3] fixed tests; added to NEWS.md --- NEWS.md | 2 + tests/testthat/_snaps/analyze_variables.md | 152 ++++++++++++++++-- tests/testthat/_snaps/compare_variables.md | 18 ++- .../utils_default_stats_formats_labels.md | 8 +- 4 files changed, 163 insertions(+), 17 deletions(-) diff --git a/NEWS.md b/NEWS.md index ec0cb22d30..f1e6627300 100644 --- a/NEWS.md +++ b/NEWS.md @@ -6,6 +6,8 @@ * Added the `riskdiff` argument to `tabulate_rsp_subgroups` and `tabulate_survival_subgroups` to allow users to add a risk difference table column, and function `control_riskdiff` to specify settings for the risk difference column. * Added warning to `tabulate_rsp_subgroups` when `pval` statistic is selected but `df` has not been correctly generated to add p-values to the output table. * Added `n_rate` statistic as a non-default option to `estimate_incidence_rate` which returns both number of events observed and estimated incidence rate. +* Added `fraction` statistic to the `analyze_var_count` method group. + ### Bug Fixes * Fixed a bug in `a_surv_time` that threw an error when split only has `"is_event"`. diff --git a/tests/testthat/_snaps/analyze_variables.md b/tests/testthat/_snaps/analyze_variables.md index b2a9dbb9a5..65f42acee6 100644 --- a/tests/testthat/_snaps/analyze_variables.md +++ b/tests/testthat/_snaps/analyze_variables.md @@ -628,6 +628,20 @@ [1] 4.0000000 0.4444444 + $fraction + $fraction$Female + num denom + 2 9 + + $fraction$Male + num denom + 3 9 + + $fraction$Unknown + num denom + 4 9 + + $n_blq [1] 0 @@ -668,6 +682,24 @@ [1] 1.0000000 0.1428571 + $fraction + $fraction$Female + num denom + 2 7 + + $fraction$Male + num denom + 2 7 + + $fraction$Unknown + num denom + 2 7 + + $fraction$`NA` + num denom + 1 7 + + $n_blq [1] 0 @@ -702,6 +734,20 @@ [1] 4.0000000 0.4444444 + $fraction + $fraction$Female + num denom + 2 9 + + $fraction$Male + num denom + 3 9 + + $fraction$Unknown + num denom + 4 9 + + $n_blq [1] 0 @@ -736,6 +782,20 @@ [1] 0 0 + $fraction + $fraction$a + num denom + 0 0 + + $fraction$b + num denom + 0 0 + + $fraction$c + num denom + 0 0 + + $n_blq [1] 0 @@ -770,6 +830,20 @@ [1] 4.0 0.2 + $fraction + $fraction$Female + num denom + 2 20 + + $fraction$Male + num denom + 3 20 + + $fraction$Unknown + num denom + 4 20 + + $n_blq [1] 0 @@ -804,6 +878,20 @@ [1] 4.0000000 0.1333333 + $fraction + $fraction$Female + num denom + 2 30 + + $fraction$Male + num denom + 3 30 + + $fraction$Unknown + num denom + 4 30 + + $n_blq [1] 0 @@ -844,6 +932,24 @@ [1] 1.0 0.1 + $fraction + $fraction$Female + num denom + 2 10 + + $fraction$Male + num denom + 3 10 + + $fraction$Unknown + num denom + 4 10 + + $fraction$`NA` + num denom + 1 10 + + $n_blq [1] 0 @@ -971,7 +1077,10 @@ 8 a 3 (60.0%) 0 a 9 b 1 (20.0%) 0 b 10 c 1 (20.0%) 0 c - 11 n_blq 0 0 n_blq + 11 a 3/5 (60.0%) 0 a + 12 b 1/5 (20.0%) 0 b + 13 c 1/5 (20.0%) 0 c + 14 n_blq 0 0 n_blq --- @@ -991,7 +1100,10 @@ 8 A 2 (50.0%) 0 A 9 B 1 (25.0%) 0 B 10 C 1 (25.0%) 0 C - 11 n_blq 0 0 n_blq + 11 A 2/4 (50.0%) 0 A + 12 B 1/4 (25.0%) 0 B + 13 C 1/4 (25.0%) 0 C + 14 n_blq 0 0 n_blq --- @@ -1005,7 +1117,8 @@ 2 count 3 0 count 3 count_fraction 3 (60%) 0 count_fraction 4 count_fraction 3 (60.0%) 0 count_fraction - 5 n_blq 0 0 n_blq + 5 fraction 0 fraction + 6 n_blq 0 0 n_blq # a_summary works with custom input. @@ -1039,7 +1152,11 @@ 11 b 1 (20.0%) 0 b 12 c 1 (20.0%) 0 c 13 NA 1 (20.0%) 0 NA - 14 n_blq 0 0 n_blq + 14 a 2/5 (40.0%) 0 a + 15 b 1/5 (20.0%) 0 b + 16 c 1/5 (20.0%) 0 c + 17 NA 1/5 (20.0%) 0 NA + 18 n_blq 0 0 n_blq # a_summary works with healthy input when compare = TRUE. @@ -1093,8 +1210,11 @@ 8 a 3 (60.0%) 0 a 9 b 1 (20.0%) 0 b 10 c 1 (20.0%) 0 c - 11 n_blq 0 0 n_blq - 12 p-value (chi-squared test) 0.9560 0 p-value (chi-squared test) + 11 a 3/5 (60.0%) 0 a + 12 b 1/5 (20.0%) 0 b + 13 c 1/5 (20.0%) 0 c + 14 n_blq 0 0 n_blq + 15 p-value (chi-squared test) 0.9560 0 p-value (chi-squared test) --- @@ -1114,8 +1234,11 @@ 8 A 2 (50.0%) 0 A 9 B 1 (25.0%) 0 B 10 C 1 (25.0%) 0 C - 11 n_blq 0 0 n_blq - 12 p-value (chi-squared test) 0.9074 0 p-value (chi-squared test) + 11 A 2/4 (50.0%) 0 A + 12 B 1/4 (25.0%) 0 B + 13 C 1/4 (25.0%) 0 C + 14 n_blq 0 0 n_blq + 15 p-value (chi-squared test) 0.9074 0 p-value (chi-squared test) --- @@ -1129,8 +1252,9 @@ 2 count 3 0 count 3 count_fraction 3 (60%) 0 count_fraction 4 count_fraction 3 (60.0%) 0 count_fraction - 5 n_blq 0 0 n_blq - 6 p-value (chi-squared test) 0.8091 0 p-value (chi-squared test) + 5 fraction 0 fraction + 6 n_blq 0 0 n_blq + 7 p-value (chi-squared test) 0.8091 0 p-value (chi-squared test) # a_summary works with custom input when compare = TRUE. @@ -1164,8 +1288,12 @@ 11 b 1 (20.0%) 0 b 12 c 1 (20.0%) 0 c 13 NA 1 (20.0%) 0 NA - 14 n_blq 0 0 n_blq - 15 p-value (chi-squared test) 0.8254 0 p-value (chi-squared test) + 14 a 2/5 (40.0%) 0 a + 15 b 1/5 (20.0%) 0 b + 16 c 1/5 (20.0%) 0 c + 17 NA 1/5 (20.0%) 0 NA + 18 n_blq 0 0 n_blq + 19 p-value (chi-squared test) 0.8254 0 p-value (chi-squared test) # `analyze_vars` works with healthy input, default `na.rm = TRUE`. diff --git a/tests/testthat/_snaps/compare_variables.md b/tests/testthat/_snaps/compare_variables.md index eaf443e564..493db5697c 100644 --- a/tests/testthat/_snaps/compare_variables.md +++ b/tests/testthat/_snaps/compare_variables.md @@ -21,8 +21,8 @@ Code res Output - [1] "n" "count" "count_fraction" "n_blq" - [5] "pval_counts" + [1] "n" "count" "count_fraction" "fraction" + [5] "n_blq" "pval_counts" --- @@ -75,6 +75,20 @@ [1] 1.0 0.2 + $fraction + $fraction$a + num denom + 3 5 + + $fraction$b + num denom + 1 5 + + $fraction$c + num denom + 1 5 + + $n_blq [1] 0 diff --git a/tests/testthat/_snaps/utils_default_stats_formats_labels.md b/tests/testthat/_snaps/utils_default_stats_formats_labels.md index fb13d7d35c..774a14a31d 100644 --- a/tests/testthat/_snaps/utils_default_stats_formats_labels.md +++ b/tests/testthat/_snaps/utils_default_stats_formats_labels.md @@ -20,7 +20,7 @@ Output [1] "n" "count" [3] "count_fraction" "count_fraction_fixed_dp" - [5] "n_blq" + [5] "fraction" "n_blq" --- @@ -138,6 +138,8 @@ "n" "count" count_fraction count_fraction_fixed_dp "count_fraction" "count_fraction" - n_blq pval_counts - "n_blq" "p-value (chi-squared test)" + fraction n_blq + "fraction" "n_blq" + pval_counts + "p-value (chi-squared test)" From 51bb9b5381c8f1748498b8a83223aa677fbad4d0 Mon Sep 17 00:00:00 2001 From: Konrad Pagacz Date: Tue, 17 Sep 2024 09:50:06 +0200 Subject: [PATCH 3/3] Update NEWS.md Signed-off-by: Konrad Pagacz --- NEWS.md | 1 - 1 file changed, 1 deletion(-) diff --git a/NEWS.md b/NEWS.md index f1e6627300..b8d2a61466 100644 --- a/NEWS.md +++ b/NEWS.md @@ -8,7 +8,6 @@ * Added `n_rate` statistic as a non-default option to `estimate_incidence_rate` which returns both number of events observed and estimated incidence rate. * Added `fraction` statistic to the `analyze_var_count` method group. - ### Bug Fixes * Fixed a bug in `a_surv_time` that threw an error when split only has `"is_event"`. * Added defaults for `d_count_cumulative` parameters as described in the documentation.