R/plotmod_helpers_2.R

Defines functions add_lv_implied add_fillin_lv scale_by_implied x_for_w_categorical x_for_w_numeric x_for_w check_w_type x_for_wlevels

x_for_wlevels <- function(wlevels_i, mf, x, band = .16, nvalues = 2) {
    k <- ncol(wlevels_i)
    ws <- colnames(wlevels_i)
    wtypes <- sapply(ws, check_w_type, mf = mf, nvalues = nvalues)
    x_ids <- mapply(x_for_w,
                   w_i = wlevels_i,
                   w = ws,
                   w_numeric = (wtypes == "numeric"),
                   MoreArgs = list(mf = mf,
                                   x = x,
                                   row_id = TRUE,
                                   band = band)
                   )
    x_id <- apply(x_ids, 1, all)
    mf[x_id, x]
  }

check_w_type <- function(w, mf, nvalues = 2) {
    if (!is.numeric(mf[, w])) {
        return("categorical")
      }
    tmp <- length(unique(mf[, w]))
    if (tmp > nvalues) {
        return("numeric")
      } else {
        return("categorical")
      }
  }

x_for_w <- function(w_i, mf, x, w, w_numeric, ...) {
    if (w_numeric) {
        return(x_for_w_numeric(w_i = w_i,
                               mf = mf,
                               x = x,
                               w = w,
                               ...))
      } else {
        return(x_for_w_categorical(w_i = w_i,
                               mf = mf,
                               x = x,
                               w = w,
                               ...))
      }
  }

x_for_w_numeric <- function(w_i, mf, x, w, band = .16, row_id = FALSE) {
    w0 <- mf[, w]
    w_ecdf <- stats::ecdf(w0)
    w_i_p <- w_ecdf(w_i)
    w_i_r <- c(w_i_p - band, w_i_p + band)
    w_i_r[1] <- max(w_i_r[1], 0)
    w_i_r[2] <- min(w_i_r[2], 1)
    w_i_b <- stats::quantile(w0, w_i_r, na.rm = TRUE, names = FALSE)
    x_id <- (w0 >= w_i_b[1]) & (w0 <= w_i_b[2])
    if (row_id) {
        return(x_id)
      } else {
        x1 <- mf[, x]
        return(x1)
      }
  }

x_for_w_categorical <- function(w_i, mf, x, w, row_id = FALSE, ...) {
    w0 <- mf[, w]
    if (row_id) {
        return(w0 == w_i)
      } else {
        x1 <- mf[w0 == w_i, x]
        return(x1)
      }
  }

#' @noRd
# Rescale data such that the means and SDs are those required

scale_by_implied <- function(data_original, implied) {
    data_new <- data_original
    for (x in colnames(data_original)) {
        raw_v <- data_original[, x]
        mean_v <- mean(raw_v)
        sd_v <- stats::sd(raw_v)
        sd_v_implied <- sqrt(implied$cov[x, x])
        if (!(all(is.na(implied$mean)) || is.null(implied$mean))) {
            mean_v_implied <- implied$mean[x]
          } else {
            mean_v_implied <- mean_v
          }
        z_v <- scale(data_original[, x])[, 1]
        new_v <- z_v * sd_v_implied + mean_v_implied
        data_new[, x] <- new_v
      }
    data_new
  }

#' @noRd
# Add fill-in latent variable data

add_fillin_lv <- function(data_original, cov_lv, mean_lv = NULL) {
    lv <- colnames(cov_lv)
    if (is.null(mean_lv)) {
        mean_lv <- rep(0, length(lv))
        names(mean_lv) <- lv
      }
    n <- nrow(data_original)
    dat_lv <- MASS::mvrnorm(n, mu = mean_lv, Sigma = cov_lv, empirical = TRUE)
    data_new <- cbind(data_original, dat_lv)
  }

#' @noRd
# Add implied stats of lv

add_lv_implied <- function(implied_stats, cov_lv, mean_lv = NULL) {
    lv <- colnames(cov_lv)
    if (is.null(mean_lv)) {
        mean_lv <- rep(0, length(lv))
        names(mean_lv) <- lv
      }
    p1 <- nrow(implied_stats$cov)
    p2 <- length(lv)
    zero <- matrix(0, nrow = p1, ncol = p2)
    colnames(zero) <- lv
    rownames(zero) <- rownames(implied_stats$cov)
    new_cov <- rbind(cbind(implied_stats$cov, zero),
                     cbind(t(zero), cov_lv))
    class(new_cov) <- class(implied_stats$cov)
    if (!is.null(implied_stats$mean)) {
        mean_ov <- implied_stats$mean
      } else {
        mean_ov <- rep(0, p1)
        names(mean_ov) <- colnames(implied_stats$cov)
      }
    new_mean <- c(mean_ov,
                  mean_lv)
    class(new_mean) <- class(mean_lv)
    out <- list(cov = new_cov,
                mean = new_mean)
  }

Try the manymome package in your browser

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

manymome documentation built on June 22, 2024, 9:34 a.m.