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

Rename group/group_by arguments into by #433

Merged
merged 15 commits into from
May 24, 2024
3 changes: 2 additions & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Package: report
Type: Package
Title: Automated Reporting of Results and Statistical Models
Version: 0.5.8.2
Version: 0.5.8.3
Authors@R:
c(person(given = "Dominique",
family = "Makowski",
Expand Down Expand Up @@ -150,3 +150,4 @@ Collate:
'utils_grouped_df.R'
'zzz.R'
Roxygen: list(markdown = TRUE)
Remotes: easystats/insight, easystats/datawizard, easystats/parameters, easystats/performance, easystats/modelbased
9 changes: 9 additions & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,14 @@
# report 0.5.9

Breaking

* Arguments named `group`, `at` and `group_by` will be deprecated in future
releases. of _easystats_ packages. Please use `by` instead. This affects
following functions in *report*:

* `report_participants()`
* `report_sample()`

Minor changes

* `report` now supports reporting of Bayesian model comparison with variables of class `brms::loo_compare`.
Expand Down
16 changes: 8 additions & 8 deletions R/report.lm.R
Original file line number Diff line number Diff line change
Expand Up @@ -53,11 +53,11 @@
#' @export

report.lm <- function(x, include_effectsize = TRUE, effectsize_method = "refit", ...) {
table <- report_table(x,

Check warning on line 56 in R/report.lm.R

View workflow job for this annotation

GitHub Actions / lint-changed-files / lint-changed-files

file=R/report.lm.R,line=56,col=3,[object_overwrite_linter] 'table' is an exported object from package 'base'. Avoid re-using such symbols.
include_effectsize = include_effectsize,
effectsize_method = effectsize_method, ...
)
text <- report_text(x,

Check warning on line 60 in R/report.lm.R

View workflow job for this annotation

GitHub Actions / lint-changed-files / lint-changed-files

file=R/report.lm.R,line=60,col=3,[object_overwrite_linter] 'text' is an exported object from package 'graphics'. Avoid re-using such symbols.
table = table, ...
)

Expand All @@ -72,7 +72,7 @@
#' @export

report_effectsize.lm <- function(x, effectsize_method = "refit", ...) {
table <- suppressWarnings(effectsize::effectsize(x, method = effectsize_method, ...))

Check warning on line 75 in R/report.lm.R

View workflow job for this annotation

GitHub Actions / lint-changed-files / lint-changed-files

file=R/report.lm.R,line=75,col=3,[object_overwrite_linter] 'table' is an exported object from package 'base'. Avoid re-using such symbols.
method <- .text_standardize(table)
estimate <- names(table)[effectsize::is_effectsize_name(names(table))]

Expand Down Expand Up @@ -105,7 +105,7 @@
start_col <- 3L
}

table <- as.data.frame(table)[c(merge_by, estimate, "CI_low", "CI_high")]

Check warning on line 108 in R/report.lm.R

View workflow job for this annotation

GitHub Actions / lint-changed-files / lint-changed-files

file=R/report.lm.R,line=108,col=3,[object_overwrite_linter] 'table' is an exported object from package 'base'. Avoid re-using such symbols.
names(table)[start_col:ncol(table)] <- c(paste0(estimate, "_CI_low"), paste0(estimate, "_CI_high"))

rules <- .text_effectsize(attr(attr(interpret, "rules"), "rule_name"))
Expand Down Expand Up @@ -162,7 +162,7 @@
params <- datawizard::data_remove(params, "df_error")
}
table_full <- datawizard::data_remove(params, "SE")
table <- datawizard::data_remove(

Check warning on line 165 in R/report.lm.R

View workflow job for this annotation

GitHub Actions / lint-changed-files / lint-changed-files

file=R/report.lm.R,line=165,col=3,[object_overwrite_linter] 'table' is an exported object from package 'base'. Avoid re-using such symbols.
table_full,
select = "(_CI_low|_CI_high)$",
regex = TRUE,
Expand Down Expand Up @@ -483,7 +483,7 @@
effectsize <- report_effectsize(x, ...)
}

text <- .info_effectsize(x, effectsize = effectsize, include_effectsize = include_effectsize)
info_text <- .info_effectsize(x, effectsize = effectsize, include_effectsize = include_effectsize)

if (is.null(parameters)) {
parameters <- report_parameters(x, ...)
Expand All @@ -495,7 +495,7 @@
}

if ("ci_method" %in% names(att)) {
text <- paste0(text, " ", .info_df(
info_text <- paste0(info_text, " ", .info_df(
ci = att$ci,
ci_method = att$ci_method,
test_statistic = att$test_statistic,
Expand All @@ -508,7 +508,7 @@
# }


as.report_info(text)
as.report_info(info_text)
}


Expand Down Expand Up @@ -538,25 +538,25 @@
model,
". ",
perf,
ifelse(nchar(perf) > 0, ". ", ""),
ifelse(nzchar(perf, keepNA = TRUE), ". ", ""),
intercept,
params_text_full,
"\n\n",
info
)

text <- paste0(
summary_text <- paste0(
"We fitted a ",
summary(model),
". ",
summary(perf),
ifelse(nchar(perf) > 0, ". ", ""),
ifelse(nzchar(perf, keepNA = TRUE), ". ", ""),
summary(intercept),
params_text
)


as.report_text(text_full, summary = text)
as.report_text(text_full, summary = summary_text)
}


Expand All @@ -569,7 +569,7 @@
if (!is.null(coefname) && coefname %in% names(table)) {
estimate <- attributes(table)$coefficient_name
} else {
estimate <- datawizard::data_find(table, candidates, regex = TRUE, verbose = FALSE)[1]
estimate <- datawizard::extract_column_names(table, candidates, regex = TRUE, verbose = FALSE)[1]
}
estimate
}
18 changes: 9 additions & 9 deletions R/report_htest_ttest.R
Original file line number Diff line number Diff line change
Expand Up @@ -33,25 +33,25 @@

.report_table_ttest <- function(table_full, effsize) {
table_full <- cbind(table_full, attributes(effsize)$table)
table <- datawizard::data_remove(
table_small <- datawizard::data_remove(
table_full,
c("Parameter", "Group", "Mean_Group1", "Mean_Group2", "Method", "d_CI_low", "d_CI_high")
)
list(table = table, table_full = table_full)
list(table = table_small, table_full = table_full)
}


# report_effectsize ---------------------

.report_effectsize_ttest <- function(x, table, dot_args, type, rules = "cohen1988") {
args <- c(list(x), dot_args)
table <- do.call(effectsize::effectsize, args)
my_args <- c(list(x), dot_args)
table <- do.call(effectsize::effectsize, my_args)
ci <- attributes(table)$ci
estimate <- names(table)[1]
rules <- ifelse(is.null(dot_args$rules), rules, dot_args$rules)

args <- list(table, rules = rules, dot_args)
interpretation <- do.call(effectsize::interpret, args)$Interpretation
my_args <- list(table, rules = rules, dot_args)
interpretation <- do.call(effectsize::interpret, my_args)$Interpretation
rules <- .text_effectsize(attr(attr(interpretation, "rules"), "rule_name"))

if (estimate %in% c("d", "Cohens_d")) {
Expand Down Expand Up @@ -88,7 +88,7 @@
.report_model_ttest <- function(x, table) {
# If against mu
if (names(x$null.value) == "mean") {
# TODO: @DominiqueMakowski why do we need "table" here?
# TODO: @DominiqueMakowski why do we need "table" here??

Copy link
Member Author

@strengejacke strengejacke May 16, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@DominiqueMakowski ?
The object table is never used...

table$Difference <- x$estimate - x$null.value
means <- paste0(" (mean = ", insight::format_value(x$estimate), ")")
Expand All @@ -106,12 +106,12 @@
vars <- paste0(x$data.name)
}

text <- paste0(
final_text <- paste0(
trimws(x$method),
" testing the difference ",
ifelse(grepl(" by ", x$data.name, fixed = TRUE), "of ", "between "),
vars_full
)

text
final_text
}
86 changes: 46 additions & 40 deletions R/report_participants.R
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,12 @@
#' so countries that represent less than 10% will be combined in the "other" category).
#' @param participants The name of the participants' identifier column (for
#' instance in the case of repeated measures).
#' @param group A character vector indicating the name(s) of the column(s) used
#' @param by A character vector indicating the name(s) of the column(s) used
#' for stratified description.
#' @param spell_n Logical, fully spell the sample size (`"Three participants"`
#' instead of `"3 participants"`).
#' @inheritParams report.numeric
#' @param group Deprecated. Use `by` instead.
#'
#' @return A character vector with description of the "participants", based on
#' the information provided in `data`.
Expand Down Expand Up @@ -106,7 +107,7 @@
#' sex = "Sex",
#' gender = "Gender",
#' participants = "Participant",
#' group = "Condition"
#' by = "Condition"
#' )
#'
#' # Spell sample size
Expand All @@ -123,14 +124,21 @@ report_participants <- function(data,
country = NULL,
race = NULL,
participants = NULL,
group = NULL,
by = NULL,
spell_n = FALSE,
digits = 1,
threshold = 10,
group = NULL,
...) {
## TODO: deprecate later
if (!is.null(group)) {
insight::format_warning("Argument `group` is deprecated and will be removed in a future release. Please use `by` instead.") # nolint
by <- group
}

# Convert empty strings to NA
data_list <- lapply(data, function(x) {
x[which(x == "")] <- NA
x[which(x == "")] <- NA # nolint
x
})
data <- as.data.frame(data_list, stringsAsFactors = FALSE)
Expand Down Expand Up @@ -165,8 +173,8 @@ report_participants <- function(data,
race <- .find_race_in_data(data)
}

if (is.null(group)) {
text <- .report_participants(
if (is.null(by)) {
final_text <- .report_participants(
data,
age = age,
sex = sex,
Expand All @@ -181,9 +189,9 @@ report_participants <- function(data,
...
)
} else {
text <- NULL
data[[group]] <- as.character(data[[group]])
for (i in split(data, data[group])) {
final_text <- NULL
data[[by]] <- as.character(data[[by]])
for (i in split(data, data[by])) {
current_text <- .report_participants(
i,
age = age,
Expand All @@ -200,15 +208,15 @@ report_participants <- function(data,

pre_text <- paste0(
"the '",
paste0(names(i[group]), " - ", vapply(i[group], unique, "character"), collapse = " and "),
paste0(names(i[by]), " - ", vapply(i[by], unique, "character"), collapse = " and "),
"' group: "
)

text <- c(text, paste0(pre_text, current_text))
final_text <- c(final_text, paste0(pre_text, current_text))
}
text <- paste("For", datawizard::text_concatenate(text, sep = ", for ", last = " and for "))
final_text <- paste("For", datawizard::text_concatenate(final_text, sep = ", for ", last = " and for "))
}
text
final_text
}

#' @keywords internal
Expand Down Expand Up @@ -338,9 +346,7 @@ report_participants <- function(data,
) %in% c("male", "m", "female", "f", NA, "na")]) /
nrow(data) * 100, digits = digits),
"% other",
if (!insight::format_value(length(data[[sex]][tolower(
data[[sex]]
) %in% c(NA, "na")]) / nrow(data) * 100) == "0.00") {
if (insight::format_value(length(data[[sex]][tolower(data[[sex]]) %in% c(NA, "na")]) / nrow(data) * 100) != "0.00") { # nolint
paste0(", ", insight::format_value(length(data[[sex]][tolower(
data[[sex]]
) %in% c(NA, "na")]) / nrow(data) * 100), "% missing")
Expand Down Expand Up @@ -375,9 +381,9 @@ report_participants <- function(data,
data[[gender]]
) %in% both_genders]) /
nrow(data) * 100), "% non-binary",
if (!insight::format_value(length(data[[gender]][tolower(
if (insight::format_value(length(data[[gender]][tolower(
data[[gender]]
) %in% c(NA, "na")]) / nrow(data) * 100) == "0.00") {
) %in% c(NA, "na")]) / nrow(data) * 100) != "0.00") {
paste0(", ", insight::format_value(length(data[[gender]][tolower(
data[[gender]]
) %in% c(NA, "na")]) / nrow(data) * 100), "% missing")
Expand All @@ -387,31 +393,29 @@ report_participants <- function(data,

if (all(is.na(data[[education]]))) {
text_education <- ""
} else {
if (is.numeric(data[[education]])) {
text_education <- summary(
report_statistics(
data[[education]],
n = FALSE,
centrality = "mean",
missing_percentage = NULL,
digits = digits,
...
)
)

text_education <- sub("Mean =", "Mean education =", text_education, fixed = TRUE)
} else {
data[which(data[[education]] %in% c(NA, "NA")), education] <- "missing"
txt <- summary(report_statistics(
as.factor(data[[education]]),
levels_percentage = TRUE,
} else if (is.numeric(data[[education]])) {
text_education <- summary(
report_statistics(
data[[education]],
n = FALSE,
centrality = "mean",
missing_percentage = NULL,
digits = digits,
...
))
)
)

text_education <- paste0("Education: ", txt)
}
text_education <- sub("Mean =", "Mean education =", text_education, fixed = TRUE)
} else {
data[which(data[[education]] %in% c(NA, "NA")), education] <- "missing"
txt <- summary(report_statistics(
as.factor(data[[education]]),
levels_percentage = TRUE,
digits = digits,
...
))

text_education <- paste0("Education: ", txt)
}

text_country <- if (all(is.na(data[[country]]))) {
Expand Down Expand Up @@ -468,6 +472,7 @@ report_participants <- function(data,
text_race <- paste("Race:", value_string)
}

# nolint start
paste0(
size,
" participants (",
Expand All @@ -491,6 +496,7 @@ report_participants <- function(data,
), text_race)),
")"
)
# nolint end
}

#' @keywords internal
Expand Down
Loading
Loading