R/pairwise-internal.R

Defines functions pwgen pwgen_study

# Auxiliary functions to transform relative treatment effects to
# pairwise comparisons
#
# Author: Gert van Valkenhoef <gvanvalkenhoef@cochrane.org>
# License: GPL (>= 2)
#

# For use with dplyr::group_map
#
pwgen_study <- function(input, studlab) {
  # Get rid of warning 'Undefined global functions or variables'
  treat1 <- NULL
  #
  studlab <- studlab$studlab
  
  # Get rid of warning 'Undefined global functions or variables'
  n <- NULL
  
  # separate the reference arm from the other rows
  ref <- input[input$treat1 == input$treat2, ]
  stopifnot(nrow(ref) == 1)
  rel <- input %>% filter(treat1 != ref$treat2) %>%
    mutate(studlab = studlab, n1 = n, n2 = ref$n) %>%
    select(!n)
  stopifnot(nrow(rel) == nrow(input) - 1)
  stopifnot(nrow(rel) == length(unique(rel$treat1)))
  
  # calculate other treatment effects
  if (nrow(rel) > 1) {
    # generate the missing treatment pairs
    other <- combn(rel$treat1, 2)
    # for each pair, calculate TE and seTE
    other <- mapply(function(treat1, treat2) {
      r1 <- rel[rel$treat1 == treat1, ]
      r2 <- rel[rel$treat1 == treat2, ]
      data.frame(
        studlab,
        treat1,
        treat2,
        TE = r1$TE - r2$TE,
        seTE = sqrt(r1$seTE^2 + r2$seTE^2 - 2 * ref$seTE^2),
        n1 = r1$n1,
        n2 = r2$n1)
    },
    other[1, ], other[2, ], SIMPLIFY = FALSE) %>% bind_rows()
    #
    bind_rows(rel, other)
  }
  else {
    rel
  }
}

# Expects one row per arm of each study:
#  - treat1 is the current study arm 
#  - treat2 is the study reference arm (e.g. control/placebo)
#  - if treat1 != treat2, TE is the treatment effect estimate, otherwise NA
#  - if treat1 != treat2, seTE is the standard error of the treatment effect
#    estimate, otherwise it is the standard error of the reference arm
#    (or the square root of the covariance between treatment effects) - optional
#    for two-arm studies.
#
pwgen <- function(studlab, treat1, treat2, TE, seTE, n) {
  nulln <- is.null(n)
  if (nulln) {
    n <- rep(NA, length(TE))
  }
  
  # Get rid of warning 'Undefined global functions or variables'
  n1 <- n2 <- NULL
  
  result <- data.frame(studlab, treat1, treat2, TE, seTE, n) %>%
    group_by(studlab) %>%
    group_map(pwgen_study) %>%
    bind_rows() %>%
    relocate(studlab)
  
  if (nulln) {
    result %>% select(!c(n1, n2)) %>% as.data.frame
  }
  else {
    as.data.frame(result)
  }
}

Try the meta package in your browser

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

meta documentation built on April 2, 2026, 5:07 p.m.