The function summaryByVisit()
produces a table with
descriptive statistics for continues variables at different time points
(visits). It is largely based on the function
gtsummary::tbl_summary()
and
gtsummary::tbl_strata_nested_stack
. The changes as compared
to these functions are:
To demonstrate the various functionalities of the function, we will create a small dataset. We have three hypotetical lab-values: LDH, ANC and Lymphocytes. Each lab-value has been measured at 10 time points (visits), which can further be divided into three visit groups (baseline, treatment and follow-up). In addition, we have a grouping variable called ‘arm’.
data<-NULL
visit <- c(paste0(rep("Visit ", 10), rbind(c(1:10))),
paste0(rep("Visit ", 10), rbind(c(1:10))),
paste0(rep("Visit ", 10), rbind(c(1:10))))
data <- as.data.frame(cbind( visit, rnorm(30)))
data<-as.data.frame(rbind(data, data, data, data, data))
data$visitgroup<- ifelse(data$visit %in% c("Visit 1", "Visit 2"), "Baseline", ifelse(data$visit %in% c("Visit 3", "Visit 4"), "Treatment", "Follow-up"))
data$visitgroup<-factor(data$visitgroup, levels = c("Baseline", "Treatment", "Follow-up"))
data$LDH<-rnorm(150)
data$Lymphocytes<-rnorm(150)
data$ANC<-rnorm(150)
data$LDH[3]<-NA
data$arm<- c(rep("Arm A", 70), rep("Arm B", 80))
Now, we use summarySCI::summaryLevels
to create a
summary table for median and range of each lab-value by visit.
Visit | N | N = 151 |
---|---|---|
LDH | ||
Visit 1 | 15 | 0.3 (-1.4, 1.3) |
Visit 2 | 15 | 0.5 (-1.5, 1.9) |
Visit 3 | 14 | 0.0 (-2.2, 1.4) |
Visit 4 | 15 | 0.0 (-2.2, 1.1) |
Visit 5 | 15 | -0.1 (-2.0, 1.1) |
Visit 6 | 15 | -0.1 (-1.4, 2.4) |
Visit 7 | 15 | -0.2 (-1.7, 1.3) |
Visit 8 | 15 | 0.4 (-1.7, 1.7) |
Visit 9 | 15 | 0.0 (-1.8, 1.6) |
Visit 10 | 15 | -0.1 (-1.3, 1.1) |
Lymphocytes | ||
Visit 1 | 15 | 0.1 (-1.3, 1.5) |
Visit 2 | 15 | -0.1 (-1.5, 2.0) |
Visit 3 | 15 | 0.0 (-1.7, 2.3) |
Visit 4 | 15 | 0.3 (-1.4, 1.2) |
Visit 5 | 15 | 0.5 (-1.5, 2.1) |
Visit 6 | 15 | -0.2 (-2.9, 1.7) |
Visit 7 | 15 | 0.0 (-1.6, 1.9) |
Visit 8 | 15 | 0.2 (-1.2, 1.3) |
Visit 9 | 15 | 0.8 (-1.5, 1.7) |
Visit 10 | 15 | 0.8 (-1.5, 2.5) |
ANC | ||
Visit 1 | 15 | -0.8 (-1.5, 2.4) |
Visit 2 | 15 | -0.1 (-2.0, 1.5) |
Visit 3 | 15 | -0.2 (-2.0, 1.5) |
Visit 4 | 15 | 0.2 (-1.6, 0.9) |
Visit 5 | 15 | -0.1 (-1.7, 2.0) |
Visit 6 | 15 | 0.3 (-1.4, 1.2) |
Visit 7 | 15 | -0.2 (-1.9, 1.4) |
Visit 8 | 15 | 0.4 (-2.2, 1.3) |
Visit 9 | 15 | 0.0 (-3.4, 1.5) |
Visit 10 | 15 | 0.2 (-1.6, 1.7) |
1Median (Min, Max) |
We can the visit group to group visits accordingly. Visitgroup needs to be an ordered factor.
summaryByVisit(data,
vars = c("LDH", "Lymphocytes", "ANC"),
visitgroup = "visitgroup",
visit = "visit")
Visit | N = 151 |
---|---|
LDH | |
Baseline | |
Visit 1 | 0.3 (-1.4, 1.3) |
Visit 2 | 0.5 (-1.5, 1.9) |
Treatment | |
Visit 3 | 0.0 (-2.2, 1.4) |
Visit 4 | 0.0 (-2.2, 1.1) |
Follow-up | |
Visit 5 | -0.1 (-2.0, 1.1) |
Visit 6 | -0.1 (-1.4, 2.4) |
Visit 7 | -0.2 (-1.7, 1.3) |
Visit 8 | 0.4 (-1.7, 1.7) |
Visit 9 | 0.0 (-1.8, 1.6) |
Visit 10 | -0.1 (-1.3, 1.1) |
Lymphocytes | |
Baseline | |
Visit 1 | 0.1 (-1.3, 1.5) |
Visit 2 | -0.1 (-1.5, 2.0) |
Treatment | |
Visit 3 | 0.0 (-1.7, 2.3) |
Visit 4 | 0.3 (-1.4, 1.2) |
Follow-up | |
Visit 5 | 0.5 (-1.5, 2.1) |
Visit 6 | -0.2 (-2.9, 1.7) |
Visit 7 | 0.0 (-1.6, 1.9) |
Visit 8 | 0.2 (-1.2, 1.3) |
Visit 9 | 0.8 (-1.5, 1.7) |
Visit 10 | 0.8 (-1.5, 2.5) |
ANC | |
Baseline | |
Visit 1 | -0.8 (-1.5, 2.4) |
Visit 2 | -0.1 (-2.0, 1.5) |
Treatment | |
Visit 3 | -0.2 (-2.0, 1.5) |
Visit 4 | 0.2 (-1.6, 0.9) |
Follow-up | |
Visit 5 | -0.1 (-1.7, 2.0) |
Visit 6 | 0.3 (-1.4, 1.2) |
Visit 7 | -0.2 (-1.9, 1.4) |
Visit 8 | 0.4 (-2.2, 1.3) |
Visit 9 | 0.0 (-3.4, 1.5) |
Visit 10 | 0.2 (-1.6, 1.7) |
1Median (Min, Max) |
We can stratify the table by groups via the group
argument. The overall column can still be shown if desired, using the
overall = TRUE
argument. A maximum of 3 groups are
supported.
summaryByVisit(data,
vars = c("LDH", "Lymphocytes", "ANC"),
group = "arm",
visitgroup = "visitgroup",
visit = "visit")
Visit | Arm A | Arm B |
---|---|---|
LDH | ||
Baseline | ||
Visit 1 | 0.3 (-1.3, 1.3) | 0.1 (-1.4, 1.2) |
Visit 2 | 0.5 (-0.2, 1.8) | 0.6 (-1.5, 1.9) |
Treatment | ||
Visit 3 | 0.3 (-2.2, 1.4) | 0.0 (-1.0, 0.3) |
Visit 4 | -0.2 (-2.2, 0.5) | 0.1 (-1.1, 1.1) |
Follow-up | ||
Visit 5 | -0.5 (-2.0, 1.1) | 0.0 (-1.4, 0.7) |
Visit 6 | -0.1 (-0.3, 1.1) | -0.9 (-1.4, 2.4) |
Visit 7 | 0.0 (-1.0, 1.3) | -0.3 (-1.7, 0.8) |
Visit 8 | 0.4 (-1.7, 1.7) | -0.2 (-1.7, 1.4) |
Visit 9 | 0.0 (-1.2, 0.8) | 0.1 (-1.8, 1.6) |
Visit 10 | 0.1 (-1.3, 1.1) | -0.2 (-0.8, 1.0) |
Lymphocytes | ||
Baseline | ||
Visit 1 | -0.2 (-1.3, 1.5) | 0.2 (-1.2, 0.7) |
Visit 2 | -0.1 (-1.4, 2.0) | 0.3 (-1.5, 2.0) |
Treatment | ||
Visit 3 | -0.2 (-1.7, 1.7) | 0.4 (-0.4, 2.3) |
Visit 4 | 0.3 (-0.8, 0.9) | 0.1 (-1.4, 1.2) |
Follow-up | ||
Visit 5 | -0.4 (-1.5, 0.8) | 0.6 (-0.2, 2.1) |
Visit 6 | -1.1 (-2.9, 0.6) | 0.2 (-2.2, 1.7) |
Visit 7 | 0.5 (-1.4, 1.1) | -0.6 (-1.6, 1.9) |
Visit 8 | 0.4 (-0.5, 0.8) | 0.0 (-1.2, 1.3) |
Visit 9 | 0.8 (-1.5, 1.0) | 0.5 (-0.9, 1.7) |
Visit 10 | 0.3 (-0.6, 2.5) | 0.8 (-1.5, 1.3) |
ANC | ||
Baseline | ||
Visit 1 | -0.1 (-1.4, 2.0) | -0.8 (-1.5, 2.4) |
Visit 2 | -0.3 (-2.0, 1.5) | 0.0 (-1.8, 1.2) |
Treatment | ||
Visit 3 | -0.6 (-2.0, 0.2) | 0.0 (-1.4, 1.5) |
Visit 4 | 0.2 (-1.0, 0.7) | 0.3 (-1.6, 0.9) |
Follow-up | ||
Visit 5 | -0.4 (-1.7, 0.1) | 0.1 (-0.8, 2.0) |
Visit 6 | 0.3 (-1.4, 1.2) | 0.2 (-1.4, 1.2) |
Visit 7 | -0.1 (-1.9, 0.6) | -0.2 (-1.5, 1.4) |
Visit 8 | 0.7 (-0.5, 1.3) | 0.1 (-2.2, 1.3) |
Visit 9 | -0.1 (-3.4, 1.5) | 0.1 (-1.1, 1.1) |
Visit 10 | 0.4 (-1.6, 1.3) | 0.0 (-1.2, 1.7) |
1Median (Min, Max) |
summaryByVisit(data,
vars = c("LDH", "Lymphocytes", "ANC"),
group = "arm",
overall = TRUE,
visitgroup = "visitgroup",
visit = "visit")
Visit | Overall | Arm A | Arm B |
---|---|---|---|
LDH | |||
Baseline | |||
Visit 1 | 0.3 (-1.4, 1.3) | 0.3 (-1.3, 1.3) | 0.1 (-1.4, 1.2) |
Visit 2 | 0.5 (-1.5, 1.9) | 0.5 (-0.2, 1.8) | 0.6 (-1.5, 1.9) |
Treatment | |||
Visit 3 | 0.0 (-2.2, 1.4) | 0.3 (-2.2, 1.4) | 0.0 (-1.0, 0.3) |
Visit 4 | 0.0 (-2.2, 1.1) | -0.2 (-2.2, 0.5) | 0.1 (-1.1, 1.1) |
Follow-up | |||
Visit 5 | -0.1 (-2.0, 1.1) | -0.5 (-2.0, 1.1) | 0.0 (-1.4, 0.7) |
Visit 6 | -0.1 (-1.4, 2.4) | -0.1 (-0.3, 1.1) | -0.9 (-1.4, 2.4) |
Visit 7 | -0.2 (-1.7, 1.3) | 0.0 (-1.0, 1.3) | -0.3 (-1.7, 0.8) |
Visit 8 | 0.4 (-1.7, 1.7) | 0.4 (-1.7, 1.7) | -0.2 (-1.7, 1.4) |
Visit 9 | 0.0 (-1.8, 1.6) | 0.0 (-1.2, 0.8) | 0.1 (-1.8, 1.6) |
Visit 10 | -0.1 (-1.3, 1.1) | 0.1 (-1.3, 1.1) | -0.2 (-0.8, 1.0) |
Lymphocytes | |||
Baseline | |||
Visit 1 | 0.1 (-1.3, 1.5) | -0.2 (-1.3, 1.5) | 0.2 (-1.2, 0.7) |
Visit 2 | -0.1 (-1.5, 2.0) | -0.1 (-1.4, 2.0) | 0.3 (-1.5, 2.0) |
Treatment | |||
Visit 3 | 0.0 (-1.7, 2.3) | -0.2 (-1.7, 1.7) | 0.4 (-0.4, 2.3) |
Visit 4 | 0.3 (-1.4, 1.2) | 0.3 (-0.8, 0.9) | 0.1 (-1.4, 1.2) |
Follow-up | |||
Visit 5 | 0.5 (-1.5, 2.1) | -0.4 (-1.5, 0.8) | 0.6 (-0.2, 2.1) |
Visit 6 | -0.2 (-2.9, 1.7) | -1.1 (-2.9, 0.6) | 0.2 (-2.2, 1.7) |
Visit 7 | 0.0 (-1.6, 1.9) | 0.5 (-1.4, 1.1) | -0.6 (-1.6, 1.9) |
Visit 8 | 0.2 (-1.2, 1.3) | 0.4 (-0.5, 0.8) | 0.0 (-1.2, 1.3) |
Visit 9 | 0.8 (-1.5, 1.7) | 0.8 (-1.5, 1.0) | 0.5 (-0.9, 1.7) |
Visit 10 | 0.8 (-1.5, 2.5) | 0.3 (-0.6, 2.5) | 0.8 (-1.5, 1.3) |
ANC | |||
Baseline | |||
Visit 1 | -0.8 (-1.5, 2.4) | -0.1 (-1.4, 2.0) | -0.8 (-1.5, 2.4) |
Visit 2 | -0.1 (-2.0, 1.5) | -0.3 (-2.0, 1.5) | 0.0 (-1.8, 1.2) |
Treatment | |||
Visit 3 | -0.2 (-2.0, 1.5) | -0.6 (-2.0, 0.2) | 0.0 (-1.4, 1.5) |
Visit 4 | 0.2 (-1.6, 0.9) | 0.2 (-1.0, 0.7) | 0.3 (-1.6, 0.9) |
Follow-up | |||
Visit 5 | -0.1 (-1.7, 2.0) | -0.4 (-1.7, 0.1) | 0.1 (-0.8, 2.0) |
Visit 6 | 0.3 (-1.4, 1.2) | 0.3 (-1.4, 1.2) | 0.2 (-1.4, 1.2) |
Visit 7 | -0.2 (-1.9, 1.4) | -0.1 (-1.9, 0.6) | -0.2 (-1.5, 1.4) |
Visit 8 | 0.4 (-2.2, 1.3) | 0.7 (-0.5, 1.3) | 0.1 (-2.2, 1.3) |
Visit 9 | 0.0 (-3.4, 1.5) | -0.1 (-3.4, 1.5) | 0.1 (-1.1, 1.1) |
Visit 10 | 0.2 (-1.6, 1.7) | 0.4 (-1.6, 1.3) | 0.0 (-1.2, 1.7) |
1Median (Min, Max) |
Sample size can be shown for each column, if the option
add_n
is set to TRUE
.
summaryByVisit(data,
vars = c("LDH", "Lymphocytes", "ANC"),
group = "arm",
overall = TRUE,
visitgroup = "visitgroup",
visit = "visit",
add_n = TRUE)
Visit | N | Overall | N | Arm A | N | Arm B |
---|---|---|---|---|---|---|
LDH | ||||||
Baseline | ||||||
Visit 1 | 15 | 0.3 (-1.4, 1.3) | 7 | 0.3 (-1.3, 1.3) | 8 | 0.1 (-1.4, 1.2) |
Visit 2 | 15 | 0.5 (-1.5, 1.9) | 7 | 0.5 (-0.2, 1.8) | 8 | 0.6 (-1.5, 1.9) |
Treatment | ||||||
Visit 3 | 14 | 0.0 (-2.2, 1.4) | 6 | 0.3 (-2.2, 1.4) | 8 | 0.0 (-1.0, 0.3) |
Visit 4 | 15 | 0.0 (-2.2, 1.1) | 7 | -0.2 (-2.2, 0.5) | 8 | 0.1 (-1.1, 1.1) |
Follow-up | ||||||
Visit 5 | 15 | -0.1 (-2.0, 1.1) | 7 | -0.5 (-2.0, 1.1) | 8 | 0.0 (-1.4, 0.7) |
Visit 6 | 15 | -0.1 (-1.4, 2.4) | 7 | -0.1 (-0.3, 1.1) | 8 | -0.9 (-1.4, 2.4) |
Visit 7 | 15 | -0.2 (-1.7, 1.3) | 7 | 0.0 (-1.0, 1.3) | 8 | -0.3 (-1.7, 0.8) |
Visit 8 | 15 | 0.4 (-1.7, 1.7) | 7 | 0.4 (-1.7, 1.7) | 8 | -0.2 (-1.7, 1.4) |
Visit 9 | 15 | 0.0 (-1.8, 1.6) | 7 | 0.0 (-1.2, 0.8) | 8 | 0.1 (-1.8, 1.6) |
Visit 10 | 15 | -0.1 (-1.3, 1.1) | 7 | 0.1 (-1.3, 1.1) | 8 | -0.2 (-0.8, 1.0) |
Lymphocytes | ||||||
Baseline | ||||||
Visit 1 | 15 | 0.1 (-1.3, 1.5) | 7 | -0.2 (-1.3, 1.5) | 8 | 0.2 (-1.2, 0.7) |
Visit 2 | 15 | -0.1 (-1.5, 2.0) | 7 | -0.1 (-1.4, 2.0) | 8 | 0.3 (-1.5, 2.0) |
Treatment | ||||||
Visit 3 | 15 | 0.0 (-1.7, 2.3) | 7 | -0.2 (-1.7, 1.7) | 8 | 0.4 (-0.4, 2.3) |
Visit 4 | 15 | 0.3 (-1.4, 1.2) | 7 | 0.3 (-0.8, 0.9) | 8 | 0.1 (-1.4, 1.2) |
Follow-up | ||||||
Visit 5 | 15 | 0.5 (-1.5, 2.1) | 7 | -0.4 (-1.5, 0.8) | 8 | 0.6 (-0.2, 2.1) |
Visit 6 | 15 | -0.2 (-2.9, 1.7) | 7 | -1.1 (-2.9, 0.6) | 8 | 0.2 (-2.2, 1.7) |
Visit 7 | 15 | 0.0 (-1.6, 1.9) | 7 | 0.5 (-1.4, 1.1) | 8 | -0.6 (-1.6, 1.9) |
Visit 8 | 15 | 0.2 (-1.2, 1.3) | 7 | 0.4 (-0.5, 0.8) | 8 | 0.0 (-1.2, 1.3) |
Visit 9 | 15 | 0.8 (-1.5, 1.7) | 7 | 0.8 (-1.5, 1.0) | 8 | 0.5 (-0.9, 1.7) |
Visit 10 | 15 | 0.8 (-1.5, 2.5) | 7 | 0.3 (-0.6, 2.5) | 8 | 0.8 (-1.5, 1.3) |
ANC | ||||||
Baseline | ||||||
Visit 1 | 15 | -0.8 (-1.5, 2.4) | 7 | -0.1 (-1.4, 2.0) | 8 | -0.8 (-1.5, 2.4) |
Visit 2 | 15 | -0.1 (-2.0, 1.5) | 7 | -0.3 (-2.0, 1.5) | 8 | 0.0 (-1.8, 1.2) |
Treatment | ||||||
Visit 3 | 15 | -0.2 (-2.0, 1.5) | 7 | -0.6 (-2.0, 0.2) | 8 | 0.0 (-1.4, 1.5) |
Visit 4 | 15 | 0.2 (-1.6, 0.9) | 7 | 0.2 (-1.0, 0.7) | 8 | 0.3 (-1.6, 0.9) |
Follow-up | ||||||
Visit 5 | 15 | -0.1 (-1.7, 2.0) | 7 | -0.4 (-1.7, 0.1) | 8 | 0.1 (-0.8, 2.0) |
Visit 6 | 15 | 0.3 (-1.4, 1.2) | 7 | 0.3 (-1.4, 1.2) | 8 | 0.2 (-1.4, 1.2) |
Visit 7 | 15 | -0.2 (-1.9, 1.4) | 7 | -0.1 (-1.9, 0.6) | 8 | -0.2 (-1.5, 1.4) |
Visit 8 | 15 | 0.4 (-2.2, 1.3) | 7 | 0.7 (-0.5, 1.3) | 8 | 0.1 (-2.2, 1.3) |
Visit 9 | 15 | 0.0 (-3.4, 1.5) | 7 | -0.1 (-3.4, 1.5) | 8 | 0.1 (-1.1, 1.1) |
Visit 10 | 15 | 0.2 (-1.6, 1.7) | 7 | 0.4 (-1.6, 1.3) | 8 | 0.0 (-1.2, 1.7) |
1Median (Min, Max) |