R/df_to_gapclosing_list.R

Defines functions df_to_gapclosing_list

Documented in df_to_gapclosing_list

#' Convert Back to Canonical List Output
#' @description If the user has used \code{as.data.frame(x)} to convert a \code{gapclosing} object to a data frame of estimates, this function will invert back to the original list format. This function does not fully reinstate the original gapclosing object because some elements are lost when \code{as.data.frame()} is called. This function is most useful as a check on \code{as.data.frame()} and as a helper in settings like bootstrapping where a data frame is easier to work with but we want to return to the original format before returning an object to the user.
#' @param x A data frame produced by \code{as.data.frame(x)} applied to an object \code{x} of class \code{gapclosing}.
#' @return A list containing a subset of the elements in a \code{gapclosing} object.
#' @references Lundberg I (2021). "The gap-closing estimand: A causal approach to study interventions that close disparities across social categories." Sociological Methods and Research. Available at {https://osf.io/gx4y3/}.
#' @importFrom magrittr %>%
#' @export
#'
#' @examples
#' # Simulate example data
#' simulated_data <- generate_simulated_data(n = 100)
#'
#' # Fit by outcome modeling
#' estimate <- gapclosing(
#'   data = simulated_data,
#'   outcome_formula = formula(outcome ~ treatment * category + confounder),
#'   treatment_name = "treatment",
#'   category_name = "category",
#'   counterfactual_assignments = 1
#' )
#' summary(estimate)
#'
#' # Convert to a data frame
#' estimate.df <- as.data.frame(estimate)
#' # Convert back to a list
#' estimate.df <- df_to_gapclosing_list(estimate.df)

df_to_gapclosing_list <- function(x) {

  # Initialize some objects for non-standard evaluation
  estimator <- estimand <- primary <- NULL

  # The gapclosing object uses tibbles, so use a tibble
  x <- tidyr::as_tibble(x)

  factual <- list(factual_means = x %>%
                    dplyr::filter(estimand == "factual_means") %>%
                    dplyr::select(-estimand,-estimator,-primary),
                  factual_disparities = x %>%
                    dplyr::filter(estimand == "factual_disparities") %>%
                    dplyr::select(-estimand,-estimator,-primary))
  estimator_names <- unique(x$estimator)
  estimator_names <- estimator_names[estimator_names != "mean"]
  all_estimators <- lapply(estimator_names, function(estimator_case) {
    list(counterfactual_means = x %>%
           dplyr::filter(estimand == "counterfactual_means" & estimator == estimator_case) %>%
           dplyr::select(-estimand,-estimator,-primary),
         counterfactual_disparities = x %>%
           dplyr::filter(estimand == "counterfactual_disparities" & estimator == estimator_case) %>%
           dplyr::select(-estimand,-estimator,-primary),
         change_means = x %>%
           dplyr::filter(grepl("change_means",estimand) & estimator == estimator_case) %>%
           tidyr::separate(estimand, into = c("estimand", "change_type", "change_formula"), sep = "__") %>%
           dplyr::select(-estimand,-estimator,-primary),
         change_disparities = x %>%
           dplyr::filter(grepl("change_disparities",estimand) & estimator == estimator_case) %>%
           tidyr::separate(estimand, into = c("estimand", "change_type", "change_formula"), sep = "__") %>%
           dplyr::select(-estimand,-estimator,-primary))
  })

  names(all_estimators) <- estimator_names
  primary_estimator_name <- unique(x$estimator[x$primary & x$estimator != "mean"])
  return(c(factual,
           all_estimators[[primary_estimator_name]],
           all_estimators = list(all_estimators)))
}

Try the gapclosing package in your browser

Any scripts or data that you put into this service are public.

gapclosing documentation built on Oct. 11, 2021, 9:07 a.m.