diff --git a/R/check_model.R b/R/check_model.R index d075fe5cb..d9d54682a 100644 --- a/R/check_model.R +++ b/R/check_model.R @@ -9,7 +9,7 @@ #' #' @param x A model object. #' @param dot_size,line_size Size of line and dot-geoms. -#' @param base_size Base font size for plots. +#' @param base_size,title_size,axis_title_size Base font size for axis and plot titles. #' @param panel Logical, if `TRUE`, plots are arranged as panels; else, #' single plots for each diagnostic are returned. #' @param check Character vector, indicating which checks for should be performed @@ -184,20 +184,22 @@ check_model <- function(x, ...) { #' @rdname check_model #' @export check_model.default <- function(x, - dot_size = 2, - line_size = 0.8, panel = TRUE, check = "all", - alpha = 0.2, - dot_alpha = 0.8, - colors = c("#3aaf85", "#1b6ca8", "#cd201f"), - theme = "see::theme_lucid", - base_size = 10, detrend = TRUE, - show_dots = NULL, bandwidth = "nrd", type = "density", residual_type = NULL, + show_dots = NULL, + dot_size = 2, + line_size = 0.8, + title_size = 12, + axis_title_size = base_size, + base_size = 10, + alpha = 0.2, + dot_alpha = 0.8, + colors = c("#3aaf85", "#1b6ca8", "#cd201f"), + theme = "see::theme_lucid", verbose = FALSE, ...) { # check model formula @@ -264,6 +266,8 @@ check_model.default <- function(x, attr(assumptions_data, "dot_size") <- dot_size attr(assumptions_data, "line_size") <- line_size attr(assumptions_data, "base_size") <- base_size + attr(assumptions_data, "axis_title_size") <- axis_title_size + attr(assumptions_data, "title_size") <- title_size attr(assumptions_data, "check") <- check attr(assumptions_data, "alpha") <- alpha attr(assumptions_data, "dot_alpha") <- dot_alpha @@ -303,21 +307,23 @@ plot.check_model <- function(x, ...) { #' @export check_model.stanreg <- function(x, - dot_size = 2, - line_size = 0.8, panel = TRUE, check = "all", - alpha = 0.2, - dot_alpha = 0.8, - colors = c("#3aaf85", "#1b6ca8", "#cd201f"), - theme = "see::theme_lucid", - base_size = 10, detrend = TRUE, - show_dots = NULL, bandwidth = "nrd", type = "density", residual_type = NULL, - verbose = TRUE, + show_dots = NULL, + dot_size = 2, + line_size = 0.8, + title_size = 12, + axis_title_size = base_size, + base_size = 10, + alpha = 0.2, + dot_alpha = 0.8, + colors = c("#3aaf85", "#1b6ca8", "#cd201f"), + theme = "see::theme_lucid", + verbose = FALSE, ...) { check_model(bayestestR::bayesian_as_frequentist(x), dot_size = dot_size, @@ -329,6 +335,7 @@ check_model.stanreg <- function(x, colors = colors, theme = theme, base_size = base_size, + axis_title_size = axis_title_size, detrend = detrend, show_dots = show_dots, bandwidth = bandwidth, @@ -346,21 +353,23 @@ check_model.brmsfit <- check_model.stanreg #' @export check_model.model_fit <- function(x, - dot_size = 2, - line_size = 0.8, panel = TRUE, check = "all", - alpha = 0.2, - dot_alpha = 0.8, - colors = c("#3aaf85", "#1b6ca8", "#cd201f"), - theme = "see::theme_lucid", - base_size = 10, detrend = TRUE, - show_dots = NULL, bandwidth = "nrd", type = "density", residual_type = NULL, - verbose = TRUE, + show_dots = NULL, + dot_size = 2, + line_size = 0.8, + title_size = 12, + axis_title_size = base_size, + base_size = 10, + alpha = 0.2, + dot_alpha = 0.8, + colors = c("#3aaf85", "#1b6ca8", "#cd201f"), + theme = "see::theme_lucid", + verbose = FALSE, ...) { check_model( x$fit, @@ -369,6 +378,7 @@ check_model.model_fit <- function(x, panel = panel, check = check, alpha = alpha, + axis_title_size = axis_title_size, dot_alpha = dot_alpha, colors = colors, theme = theme, @@ -386,21 +396,23 @@ check_model.model_fit <- function(x, #' @export check_model.performance_simres <- function(x, - dot_size = 2, - line_size = 0.8, panel = TRUE, check = "all", - alpha = 0.2, - dot_alpha = 0.8, - colors = c("#3aaf85", "#1b6ca8", "#cd201f"), - theme = "see::theme_lucid", - base_size = 10, detrend = TRUE, - show_dots = NULL, bandwidth = "nrd", type = "density", residual_type = NULL, - verbose = TRUE, + show_dots = NULL, + dot_size = 2, + line_size = 0.8, + title_size = 12, + axis_title_size = base_size, + base_size = 10, + alpha = 0.2, + dot_alpha = 0.8, + colors = c("#3aaf85", "#1b6ca8", "#cd201f"), + theme = "see::theme_lucid", + verbose = FALSE, ...) { check_model( x$fittedModel, @@ -410,6 +422,7 @@ check_model.performance_simres <- function(x, check = check, alpha = alpha, dot_alpha = dot_alpha, + axis_title_size = axis_title_size, colors = colors, theme = theme, base_size = base_size, diff --git a/man/check_model.Rd b/man/check_model.Rd index 3c90b67b9..bb4898df8 100644 --- a/man/check_model.Rd +++ b/man/check_model.Rd @@ -9,20 +9,22 @@ check_model(x, ...) \method{check_model}{default}( x, - dot_size = 2, - line_size = 0.8, panel = TRUE, check = "all", - alpha = 0.2, - dot_alpha = 0.8, - colors = c("#3aaf85", "#1b6ca8", "#cd201f"), - theme = "see::theme_lucid", - base_size = 10, detrend = TRUE, - show_dots = NULL, bandwidth = "nrd", type = "density", residual_type = NULL, + show_dots = NULL, + dot_size = 2, + line_size = 0.8, + title_size = 12, + axis_title_size = base_size, + base_size = 10, + alpha = 0.2, + dot_alpha = 0.8, + colors = c("#3aaf85", "#1b6ca8", "#cd201f"), + theme = "see::theme_lucid", verbose = FALSE, ... ) @@ -33,8 +35,6 @@ check_model(x, ...) \item{...}{Arguments passed down to the individual check functions, especially to \code{check_predictions()} and \code{binned_residuals()}.} -\item{dot_size, line_size}{Size of line and dot-geoms.} - \item{panel}{Logical, if \code{TRUE}, plots are arranged as panels; else, single plots for each diagnostic are returned.} @@ -48,29 +48,11 @@ effects and only available for mixed models. \code{"ncv"} is an alias for heteroscedasticity, as well as the linear relationship. By default, all possible checks are performed and plotted.} -\item{alpha, dot_alpha}{The alpha level of the confidence bands and dot-geoms. -Scalar from 0 to 1.} - -\item{colors}{Character vector with color codes (hex-format). Must be of -length 3. First color is usually used for reference lines, second color -for dots, and third color for outliers or extreme values.} - -\item{theme}{String, indicating the name of the plot-theme. Must be in the -format \code{"package::theme_name"} (e.g. \code{"ggplot2::theme_minimal"}).} - -\item{base_size}{Base font size for plots.} - \item{detrend}{Logical. Should Q-Q/P-P plots be detrended? Defaults to \code{TRUE} for linear models or when \code{residual_type = "normal"}. Defaults to \code{FALSE} for QQ plots based on simulated residuals (i.e. when \code{residual_type = "simulated"}).} -\item{show_dots}{Logical, if \code{TRUE}, will show data points in the plot. Set -to \code{FALSE} for models with many observations, if generating the plot is too -time-consuming. By default, \code{show_dots = NULL}. In this case \code{check_model()} -tries to guess whether performance will be poor due to a very large model -and thus automatically shows or hides dots.} - \item{bandwidth}{A character string indicating the smoothing bandwidth to be used. Unlike \code{stats::density()}, which used \code{"nrd0"} as default, the default used here is \code{"nrd"} (which seems to give more plausible results @@ -91,6 +73,26 @@ the model. Setting \code{residual_type = "normal"} for non-Gaussian models will use a half-normal Q-Q plot of the absolute value of the standardized deviance residuals.} +\item{show_dots}{Logical, if \code{TRUE}, will show data points in the plot. Set +to \code{FALSE} for models with many observations, if generating the plot is too +time-consuming. By default, \code{show_dots = NULL}. In this case \code{check_model()} +tries to guess whether performance will be poor due to a very large model +and thus automatically shows or hides dots.} + +\item{dot_size, line_size}{Size of line and dot-geoms.} + +\item{base_size, title_size, axis_title_size}{Base font size for axis and plot titles.} + +\item{alpha, dot_alpha}{The alpha level of the confidence bands and dot-geoms. +Scalar from 0 to 1.} + +\item{colors}{Character vector with color codes (hex-format). Must be of +length 3. First color is usually used for reference lines, second color +for dots, and third color for outliers or extreme values.} + +\item{theme}{String, indicating the name of the plot-theme. Must be in the +format \code{"package::theme_name"} (e.g. \code{"ggplot2::theme_minimal"}).} + \item{verbose}{If \code{FALSE} (default), suppress most warning messages.} } \value{