Usage
g_lineplot(
df,
alt_counts_df = NULL,
variables = control_lineplot_vars(),
mid = "mean",
interval = "mean_ci",
whiskers = c("mean_ci_lwr", "mean_ci_upr"),
table = NULL,
sfun = s_summary,
...,
mid_type = "pl",
mid_point_size = 2,
position = ggplot2::position_dodge(width = 0.4),
legend_title = NULL,
legend_position = "bottom",
ggtheme = nestcolor::theme_nest(),
x_lab = obj_label(df[[variables[["x"]]]]),
y_lab = NULL,
y_lab_add_paramcd = TRUE,
y_lab_add_unit = TRUE,
title = "Plot of Mean and 95% Confidence Limits by Visit",
subtitle = "",
subtitle_add_paramcd = TRUE,
subtitle_add_unit = TRUE,
caption = NULL,
table_format = get_formats_from_stats(table),
table_labels = get_labels_from_stats(table),
table_font_size = 3,
newpage = lifecycle::deprecated(),
col = NULL
)
Arguments
- df
(
data.frame
)
data set containing all analysis variables.- alt_counts_df
(
data.frame
orNULL
)
data set that will be used (only) to counts objects in groups for stratification.- variables
-
(named
character
) vector of variable names indf
which should include:x
(string
)
name of x-axis variable.y
(string
)
name of y-axis variable.group_var
(string
orNULL
)
name of grouping variable (or strata), i.e. treatment arm. Can beNA
to indicate lack of groups.subject_var
(string
orNULL
)
name of subject variable. Only applies ifgroup_var
is not NULL.paramcd
(string
orNA
)
name of the variable for parameter's code. Used for y-axis label and plot's subtitle. Can beNA
ifparamcd
is not to be added to the y-axis label or subtitle.y_unit
(string
orNA
)
name of variable with units ofy
. Used for y-axis label and plot's subtitle. Can beNA
if y unit is not to be added to the y-axis label or subtitle.facet_var
(string
orNA
)
name of the secondary grouping variable used for plot faceting, i.e. treatment arm. Can beNA
to indicate lack of groups.
- mid
(
character
orNULL
)
names of the statistics that will be plotted as midpoints. All the statistics indicated inmid
variable must be present in the object returned bysfun
, and be of adouble
ornumeric
type vector of length one.- interval
(
character
orNULL
)
names of the statistics that will be plotted as intervals. All the statistics indicated ininterval
variable must be present in the object returned bysfun
, and be of adouble
ornumeric
type vector of length two. Setinterval = NULL
if intervals should not be added to the plot.- whiskers
(
character
)
names of the interval whiskers that will be plotted. Names must match names of the list elementinterval
that will be returned bysfun
(e.g.mean_ci_lwr
element ofsfun(x)[["mean_ci"]]
). It is possible to specify one whisker only, or to suppress all whiskers by settinginterval = NULL
.- table
(
character
orNULL
)
names of the statistics that will be displayed in the table below the plot. All the statistics indicated intable
variable must be present in the object returned bysfun
.- sfun
(
function
)
the function to compute the values of required statistics. It must return a namedlist
with atomic vectors. The names of thelist
elements refer to the names of the statistics and are used bymid
,interval
,table
. It must be able to accept as input a vector with data for which statistics are computed.- ...
optional arguments to
sfun
.- mid_type
(
string
)
controls the type of themid
plot, it can be point ("p"
), line ("l"
), or point and line ("pl"
).- mid_point_size
(
numeric(1)
)
font size of themid
plot points.- position
(
character
orcall
)
geom element position adjustment, either as a string, or the result of a call to a position adjustment function.- legend_title
(
string
)
legend title.- legend_position
(
string
)
the position of the plot legend ("none"
,"left"
,"right"
,"bottom"
,"top"
, or a two-element numeric vector).- ggtheme
(
theme
)
a graphical theme as provided byggplot2
to control styling of the plot.- x_lab
(
string
orNULL
)
x-axis label. IfNULL
then no label will be added.- y_lab
(
string
orNULL
)
y-axis label. IfNULL
then no label will be added.- y_lab_add_paramcd
(
flag
)
whetherparamcd
, i.e.unique(df[[variables["paramcd"]]])
should be added to the y-axis label (y_lab
).- y_lab_add_unit
(
flag
)
whether y-axis unit, i.e.unique(df[[variables["y_unit"]]])
should be added to the y-axis label (y_lab
).- title
(
string
)
plot title.- subtitle
(
string
)
plot subtitle.- subtitle_add_paramcd
(
flag
)
whetherparamcd
, i.e.unique(df[[variables["paramcd"]]])
should be added to the plot's subtitle (subtitle
).- subtitle_add_unit
(
flag
)
whether the y-axis unit, i.e.unique(df[[variables["y_unit"]]])
should be added to the plot's subtitle (subtitle
).- caption
(
string
)
optional caption below the plot.- table_format
(named
character
orNULL
)
format patterns for descriptive statistics used in the (optional) table appended to the plot. It is passed directly to theh_format_row
function through theformat
parameter. Names oftable_format
must match the names of statistics returned bysfun
function.- table_labels
(named
character
orNULL
)
labels for descriptive statistics used in the (optional) table appended to the plot. Names oftable_labels
must match the names of statistics returned bysfun
function.- table_font_size
(
numeric(1)
)
font size of the text in the table.- newpage
- col
(
character
)
color(s).
Examples
library(nestcolor)
adsl <- tern_ex_adsl
adlb <- tern_ex_adlb %>% dplyr::filter(ANL01FL == "Y", PARAMCD == "ALT", AVISIT != "SCREENING")
adlb$AVISIT <- droplevels(adlb$AVISIT)
adlb <- dplyr::mutate(adlb, AVISIT = forcats::fct_reorder(AVISIT, AVISITN, min))
# Mean with CI
g_lineplot(adlb, adsl, subtitle = "Laboratory Test:")
# Mean with CI, no stratification with group_var
g_lineplot(adlb, variables = control_lineplot_vars(group_var = NA))
# Mean, upper whisker of CI, no group_var(strata) counts N
g_lineplot(
adlb,
whiskers = "mean_ci_upr",
title = "Plot of Mean and Upper 95% Confidence Limit by Visit"
)
# Median with CI
g_lineplot(
adlb,
adsl,
mid = "median",
interval = "median_ci",
whiskers = c("median_ci_lwr", "median_ci_upr"),
title = "Plot of Median and 95% Confidence Limits by Visit"
)
# Mean, +/- SD
g_lineplot(adlb, adsl,
interval = "mean_sdi",
whiskers = c("mean_sdi_lwr", "mean_sdi_upr"),
title = "Plot of Median +/- SD by Visit"
)
# Mean with CI plot with stats table
g_lineplot(adlb, adsl, table = c("n", "mean", "mean_ci"))
# Mean with CI, table and customized confidence level
g_lineplot(
adlb,
adsl,
table = c("n", "mean", "mean_ci"),
control = control_analyze_vars(conf_level = 0.80),
title = "Plot of Mean and 80% Confidence Limits by Visit"
)
# Mean with CI, table, filtered data
adlb_f <- dplyr::filter(adlb, ARMCD != "ARM A" | AVISIT == "BASELINE")
g_lineplot(adlb_f, table = c("n", "mean"))