This vignette focuses on the visualization functionalities available within the inTextSummaryTable package.
If you need to see figures bigger, just click on a graphic, and it will pop up more readable.
Summary statistics can be visualized by:
computeSummaryStatisticsTable function (used for getSummaryStatistics function)subjectProfileSummaryPlot functionBy default the subjectProfileSummaryPlot plots the mean values with error bars based on standard errors.
Moreover, the subjectProfileSummaryPlot allows the possibility to add a table of counts of the number of subject for a specific combination of variables.
This vignette will guide the user to
However, in order to get a full overview of the functionalities the documentation is available in the console with ? subjectProfileSummaryPlot.
We will first create example data sets to show how the exporting functionalities work. The data sets used here are available in the clinUtils package.
library(inTextSummaryTable)
library(clinUtils)
library(pander)# load example data
data(dataADaMCDISCP01)
dataAll <- dataADaMCDISCP01
labelVars <- attr(dataAll, "labelVars")Below we compute summary statistics for the laboratory data set.
dataLB <- subset(dataAll$ADLBC, grepl("Baseline|Week", AVISIT))
dataLB$AVISIT <- with(dataLB, reorder(trimws(AVISIT), AVISITN))
dataLB$TRTA <- with(dataLB, reorder(TRTA, TRTAN))
summaryTableDf <- computeSummaryStatisticsTable(
    data = dataLB,
    var = "AVAL",
    rowVar = c("PARCAT1", "PARAM"),
    colVar = c("TRTA", "AVISIT")
)The code below shows the default visualization, which plots the mean with standard errors suitable for an A4 document, e.g. Word/pdf.
Note that the table below the plot is based on the counts for treatment and visit variables, as specificed in the colVar argument of the code chuck above for computeSummaryStatisticsTable.
# create the plot
dataPlot <- subset(
    summaryTableDf, 
    !isTotal &
     PARAM == "Alanine Aminotransferase (U/L)"
)
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN"
)The code below shows the default visualization suitable for a presentation, either in Powerpoint or ioslides.
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)Please note that the default font for presentation is Tahoma.
If you don’t have this default font available, the R package extrafont might be useful to register fonts with your R graphics device.
The inTextSummaryTable uses default palettes available in the clinUtils package.
However, palettes are fully customizable. Currently, there are two alternative approaches to change the defaults:
subjectProfileSummaryPlot via the dedicated parameters colorPalette, shapePalette, linetypePalettePassing input arguments to the function might be convenient when creating one plot.
Instead, passing the global options is very handy when creating multiple graphics, so that the palettes have to be set only once at the beginning of the R script, without the need to copy-paste input arguments in the different visualizations.
If you want to know more about aesthetics options of the inTextSummaryTable, there is a dedicated vignette available here) or with
vignette("inTextSummaryTable-aesthetics", "inTextSummaryTable")If you want to know more about default options from the clinUtils, you may check out the vignette of the package:
vignette("clinUtils-vignette", "clinUtils")Sections below show below both alternative approaches for setting the palettes.
In this section we guide on how to set custom palettes via the subjectProfileSummaryPlot function.
This section focuses on the possibility to set the colorPalette argument.
# custom color palette by setting a named vector of colors
customColorPalette <- c(
    `Xanomeline Low Dose` = "green",
    `Xanomeline High Dose` = "red",
    `Placebo` = "blue"
)
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    colorPalette = customColorPalette,
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)This section focuses on the possibility to set the shapePalette and linetypePalette arguments.
# custom shape palette
customShapePalette <- c(15, 17, 19)
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    shapePalette = customShapePalette,
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)# custom linetype palette
customLinetypePalette <- c("twodash", "dotted", "longdash")
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    linetypePalette = customLinetypePalette,
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)The inTextSummaryTable package allows the user to define global options in the R session.
As mentioned above, setting the global options is convenient because the palettes have to be set only once in the R script or Rmd document.
Please note that the global options have to be set after loading the package. This because when loading the package, the default global options for palettes will overwrite the custom palettes.
Here in practice:
# this is OK
library(inTextSummaryTable)
options(inTextSummaryTable.colors.plot = customColorPalette)
# this does NOT set your custom palette
options(inTextSummaryTable.colors.plot = customColorPalette)
library(inTextSummaryTable)Color palettes can be set up with the inTextSummaryTable.colors.plot option.
# custom color palette by setting a simple vector of colors
customColorPalette <- c("blue", "green", "orange")
options(inTextSummaryTable.colors.plot = customColorPalette)
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)# custom color palette by setting a named vector of colors
customColorPalette <- c(
    `Xanomeline Low Dose` = "green",
    `Xanomeline High Dose` = "red",
    `Placebo` = "purple"
)
options(inTextSummaryTable.colors.plot = customColorPalette)
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)What shown for the color palette is consistent for shape and linetypes palettes. In this case, the global options are called inTextSummaryTable.shapes.plot and inTextSummaryTable.linetypes.plot.
# custom shape palette
customShapePalette <- c(17, 19, 22)
options(inTextSummaryTable.shapes.plot = customShapePalette)
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)# custom linetype palette
customLinetypePalette <- c("dotted", "longdash", "solid")
options(inTextSummaryTable.linetypes.plot = customLinetypePalette)
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)There is always to possibility to switch back to the default palettes of the package:
options(inTextSummaryTable.colors.plot = clinColors)
options(inTextSummaryTable.shapes.plot = clinShapes)
options(inTextSummaryTable.linetypes.plot = clinLinetypes)The user can decide to remove the table of counts by setting the parameter tableText to NULL, as the code below shows.
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = NULL,
    style = "presentation"
)It is possible to directly plot multiple parameters with the facetVar argument.
Please note that setting the facetVar is not compatible with adding a table of counts underneath the plot.
# create the plot
dataPlotFacets <- subset(
    summaryTableDf, 
    !isTotal &
        PARAM %in% c(
            "Alanine Aminotransferase (U/L)",
            "Albumin (g/L)",
            "Bilirubin (umol/L)",
            "Calcium (mmol/L)"
        )
)
subjectProfileSummaryPlot(
    data = dataPlotFacets,
    xVar = "AVISIT",
    colorVar = "TRTA",
    labelVars = labelVars,
    facetVar = c("PARCAT1", "PARAM"),
    useLinetype = TRUE
)The subjectProfileSummaryPlot has many options! A non-exaustive demonstration is presented below.
# plot the median instead of mean
# no error bars
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    meanVar = "statMedian",
    seVar = NULL,
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)# plot the mean with standard deviation
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    seVar = "statSD",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)# change labels
subjectProfileSummaryPlot(
    data = dataPlot,
    xVar = "AVISIT",
    xLab = "Time points",
    yLab = "Mean and Standard Errors",
    title = "Title of the plot",
    colorVar = "TRTA",
    labelVars = labelVars,
    useLinetype = TRUE,
    tableText = "statN",
    style = "presentation"
)R version 4.2.2 (2022-10-31)
Platform: x86_64-pc-linux-gnu (64-bit)
locale: LC_CTYPE=en_US.UTF-8, LC_NUMERIC=C, LC_TIME=en_US.UTF-8, LC_COLLATE=C, LC_MONETARY=en_US.UTF-8, LC_MESSAGES=en_US.UTF-8, LC_PAPER=en_US.UTF-8, LC_NAME=C, LC_ADDRESS=C, LC_TELEPHONE=C, LC_MEASUREMENT=en_US.UTF-8 and LC_IDENTIFICATION=C
attached base packages: tools, stats, graphics, grDevices, utils, datasets, methods and base
other attached packages: plyr(v.1.8.8), pander(v.0.6.5), clinUtils(v.0.1.4), inTextSummaryTable(v.3.3.0) and knitr(v.1.42)
loaded via a namespace (and not attached): sass(v.0.4.5), jsonlite(v.1.8.4), viridisLite(v.0.4.1), bslib(v.0.4.2), shiny(v.1.7.4), askpass(v.1.1), highr(v.0.10), fontLiberation(v.0.1.0), yaml(v.2.3.7), ggrepel(v.0.9.3), gdtools(v.0.3.1), pillar(v.1.8.1), glue(v.1.6.2), uuid(v.1.1-0), digest(v.0.6.31), promises(v.1.2.0.1), colorspace(v.2.1-0), cowplot(v.1.1.1), htmltools(v.0.5.4), httpuv(v.1.6.9), gfonts(v.0.2.0), fontBitstreamVera(v.0.1.1), pkgconfig(v.2.0.3), httpcode(v.0.3.0), haven(v.2.5.1), xtable(v.1.8-4), scales(v.1.2.1), later(v.1.3.0), officer(v.0.6.0), fontquiver(v.0.2.1), tibble(v.3.1.8), openssl(v.2.0.5), generics(v.0.1.3), farver(v.2.1.1), ggplot2(v.3.4.1), ellipsis(v.0.3.2), DT(v.0.27), cachem(v.1.0.7), withr(v.2.5.0), cli(v.3.6.0), magrittr(v.2.0.3), crayon(v.1.5.2), mime(v.0.12), memoise(v.2.0.1), evaluate(v.0.20), fansi(v.1.0.4), forcats(v.1.0.0), xml2(v.1.3.3), textshaping(v.0.3.6), data.table(v.1.14.8), hms(v.1.1.2), lifecycle(v.1.0.3), stringr(v.1.5.0), flextable(v.0.8.6), munsell(v.0.5.0), zip(v.2.2.2), compiler(v.4.2.2), jquerylib(v.0.1.4), systemfonts(v.1.0.4), rlang(v.1.0.6), grid(v.4.2.2), htmlwidgets(v.1.6.1), crosstalk(v.1.2.0), labeling(v.0.4.2), rmarkdown(v.2.20), gtable(v.0.3.1), curl(v.5.0.0), reshape2(v.1.4.4), R6(v.2.5.1), dplyr(v.1.1.0), fastmap(v.1.1.1), utf8(v.1.2.3), ragg(v.1.2.5), stringi(v.1.7.12), crul(v.1.3), Rcpp(v.1.0.10), vctrs(v.0.5.2), tidyselect(v.1.2.0) and xfun(v.0.37)