tests/visual_tests/transitionClass_vtest.R

set.seed(1)
library(magrittr)
library(Gmisc)
grid.newpage()
names <-
  strsplit(
    "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation",
    " "
  )[[1]] %>%
  gsub("[,.]", " ", .)

n <- 100
my_data <-
  data.frame(
    Binary = sample(c("Alt 1", "Alt 2"),
      size = n,
      replace = TRUE,
      prob = c(.4, .6)
    ),
    Var_a = sample(names[1:3],
      size = n,
      replace = TRUE
    ),
    Var_b = sample(names[4:7],
      size = n,
      replace = TRUE
    ),
    Var_c = sapply(8:13, function(x) {
      paste(names[x * 2 + 1:2],
        collapse = " - "
      )
    }) %>%
      sample(
        size = n,
        replace = TRUE
      ),
    Var_d = sample(names[15:16],
      size = n,
      replace = TRUE
    )
  )

transitions <- with(
  my_data,
  table(Var_a, Var_b)
) %>%
  getRefClass("Transition")$new(label = c("Var a", "Var b"))

with(
  my_data,
  table(Var_b, Var_c)
) %>%
  transitions$addTransitions()
transitions$render()

#######################
# Side by side render #
#######################
data.1 <- data.frame(
  source = c("A", "A", "A", "B", "B", "C", "C"),
  target = c("A", "B", "C", "B", "C", "C", "C")
)
data.2 <- data.frame(
  source = c("D", "D", "E", "E", "E", "E", "F"),
  target = c("D", "E", "D", "E", "F", "F", "F")
)

transitions.1 <- getRefClass("Transition")$new(table(data.1$source, data.1$target), label = c("Before", "After"))
transitions.2 <- getRefClass("Transition")$new(table(data.2$source, data.2$target), label = c("Before", "After"))

transitions.1$title <- "one"
transitions.2$title <- "two"

# wish to render transition 1 and transition 2 next to each other
library(grid)
grid.newpage()
pushViewport(viewport(name = "basevp", layout = grid.layout(nrow = 1, ncol = 2)))
pushViewport(viewport(layout.pos.row = 1, layout.pos.col = 1))
transitions.1$render(new_page = FALSE)
popViewport()
pushViewport(viewport(layout.pos.row = 1, layout.pos.col = 2))
transitions.2$render(new_page = FALSE)

##################
# From issue #43 #
##################

transMatrix <- as.table(matrix(c(16, 4, 16, 64), ncol = 2, byrow = T))
transitions <- transMatrix %>%
  getRefClass("Transition")$new(label = c("Step 1", "Step 2"))
transitions$lwd_prop_type <- "box"
transitions$render()
gforge/Gmisc documentation built on Aug. 30, 2023, 7:38 a.m.