Title: | Prepare American Psychological Association Journal Articles with R Markdown |
---|---|
Description: | Tools to create dynamic, submission-ready manuscripts, which conform to American Psychological Association manuscript guidelines. We provide R Markdown document formats for manuscripts (PDF and Word) and revision letters (PDF). Helper functions facilitate reporting statistical analyses or create publication-ready tables and plots. |
Authors: | Frederik Aust [aut, cre] , Marius Barth [aut] , Birk Diedenhofen [ctb], Christoph Stahl [ctb], Joseph V. Casillas [ctb], Rudolf Siegel [ctb] |
Maintainer: | Frederik Aust <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.1.3 |
Built: | 2025-01-21 05:43:11 UTC |
Source: | https://github.com/crsh/papaja |
These methods are only defined for backward compatibility with older
versions of papaja. In the past, the column names ofapa_results_table
s
were less standardized than they are today. In order to maintain backwards
compatibility, it is still possible to extract columns with the old columns names,
because we here provide aliased indexing. Note that aliased indexing will be
defunct in a future release of papaja.
## S3 method for class 'apa_results_table' x$name ## S3 method for class 'apa_results_table' x[[i, exact = TRUE]] ## S3 method for class 'apa_results_table' x[i, j, ..., drop = TRUE]
## S3 method for class 'apa_results_table' x$name ## S3 method for class 'apa_results_table' x[[i, exact = TRUE]] ## S3 method for class 'apa_results_table' x[i, j, ..., drop = TRUE]
x |
Object from which to extract element(s). |
name |
a literal character string or a name (possibly backtick
quoted). For extraction, this is normally (see under
‘Environments’) partially matched to the |
i , j , ...
|
Indices specifying elements to extract. See |
exact |
controls possible partial matching of |
drop |
relevant for matrices and arrays. If |
A (vector of) character values as extracted from an object of class
apa_results_table
.
This is an internal function that prepends every element of a character
vector with an 'equals' sign if the respective element does not contain one
of c("=", "<", ">")
.
add_equals(x)
add_equals(x)
x |
A character vector. |
Character vector
add_equals(c("42", "<= 42", "> 42", "= 42"))
add_equals(c("42", "<= 42", "> 42", "= 42"))
Create one or more bar plots from a data.frame
containing data from
a factorial design and set APA-friendly defaults.
apa_barplot(data, ...) ## Default S3 method: apa_barplot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", reference = 0, intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_rect = NULL, args_error_bars = NULL, args_legend = NULL, xlab = NULL, ylab = NULL, main = NULL, set_par = TRUE, ... ) ## S3 method for class 'afex_aov' apa_barplot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
apa_barplot(data, ...) ## Default S3 method: apa_barplot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", reference = 0, intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_rect = NULL, args_error_bars = NULL, args_legend = NULL, xlab = NULL, ylab = NULL, main = NULL, set_par = TRUE, ... ) ## S3 method for class 'afex_aov' apa_barplot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
data |
A |
... |
Further arguments passed on to |
id |
Character. Variable name that identifies subjects. |
factors |
Character. A vector of up to four variable names that is used to stratify the data. |
dv |
Character. The name of the dependent variable. |
tendency |
Closure. A function that will be used as measure of central tendency. |
dispersion |
Closure. A function that will be used to construct error bars (i.e., whiskers). Defaults to
|
level |
Numeric. Defines the width of the interval if confidence intervals are plotted. Defaults to |
fun_aggregate |
Closure. The function that will be used to aggregate observations within subjects and factors
before calculating descriptive statistics for each cell of the design. Defaults to |
na.rm |
Logical. Specifies if missing values are removed. Defaults to |
use |
Character. Specifies a method to exclude cases if there are missing values after aggregating.
Possible options are |
reference |
Numeric. A reference point that determines the y coordinate of the x axis. Useful if there exists a 'nil' value; defaults to |
intercept |
Numeric. Adds a horizontal line at height |
args_x_axis |
An optional |
args_y_axis |
An optional |
args_title |
An optional |
args_rect |
An optional |
args_error_bars |
An optional |
args_legend |
An optional |
xlab |
Character or expression. Label for x axis. |
ylab |
Character or expression. Label for y axis. |
main |
Character or expression. For up to two factors, simply specify the main title. If you stratify the data by more than two factors, either specify a single value that will be added to automatically generated main title, or specify an array of multiple titles, one for each plot area. |
set_par |
Logical. Determines whether |
The measure of dispersion can be either conf_int()
for between-subjects confidence intervals, se()
for standard errors,
or any other standard function. For within-subjects confidence intervals, specify wsci()
or within_subjects_conf_int()
.
If between- or within-subjects confidence intervals are requested, you can also specify the area of the cumulative
distribution function that will be covered. For instance, if you want a 98% confidence interval, specify
level = 0.98
. The default is level = 0.95
for 95% confidence intervals.
apa_factorial_plot()
and its descendants apa_barplot()
, apa_lineplot()
,
apa_beeplot()
, and apa_violinplot()
are wrapper functions that sequentially call:
axis()
(once for x axis, once for y axis),
title()
for axis labels and titles,
rect()
for bars in bar plots,
points()
for bee swarms,
lines()
for lines connecting central tendency points,
arrows()
for error bars,
points()
for tendency points,
legend()
for a legend, and
lines()
for intercepts.
These calls can be customized by setting the respective parameters args_*** = list(...)
.
A named (nested) list of plot options including raw and derived data. Note that the structure of the return value is about to change in a forthcoming release of papaja.
Other plots for factorial designs:
apa_beeplot()
,
apa_factorial_plot()
,
apa_lineplot()
,
apa_violinplot()
apa_barplot( data = npk , id = "block" , dv = "yield" , factors = c("N") ) apa_barplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") ) apa_barplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P", "K") , ylim = c(0, 80) , level = .34 , las = 1 )
apa_barplot( data = npk , id = "block" , dv = "yield" , factors = c("N") ) apa_barplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") ) apa_barplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P", "K") , ylim = c(0, 80) , level = .34 , las = 1 )
Create one or more beeswarm plots from a data.frame
containing data from
a factorial design and set APA-friendly defaults.
apa_beeplot(data, ...) ## Default S3 method: apa_beeplot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_points = NULL, args_swarm = NULL, args_error_bars = NULL, args_legend = NULL, jit = 0.3, xlab = NULL, ylab = NULL, main = NULL, set_par = TRUE, ... ) ## S3 method for class 'afex_aov' apa_beeplot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
apa_beeplot(data, ...) ## Default S3 method: apa_beeplot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_points = NULL, args_swarm = NULL, args_error_bars = NULL, args_legend = NULL, jit = 0.3, xlab = NULL, ylab = NULL, main = NULL, set_par = TRUE, ... ) ## S3 method for class 'afex_aov' apa_beeplot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
data |
A |
... |
Further arguments passed on to |
id |
Character. Variable name that identifies subjects. |
factors |
Character. A vector of up to four variable names that is used to stratify the data. |
dv |
Character. The name of the dependent variable. |
tendency |
Closure. A function that will be used as measure of central tendency. |
dispersion |
Closure. A function that will be used to construct error bars (i.e., whiskers). Defaults to
|
level |
Numeric. Defines the width of the interval if confidence intervals are plotted. Defaults to |
fun_aggregate |
Closure. The function that will be used to aggregate observations within subjects and factors
before calculating descriptive statistics for each cell of the design. Defaults to |
na.rm |
Logical. Specifies if missing values are removed. Defaults to |
use |
Character. Specifies a method to exclude cases if there are missing values after aggregating.
Possible options are |
intercept |
Numeric. Adds a horizontal line at height |
args_x_axis |
An optional |
args_y_axis |
An optional |
args_title |
An optional |
args_points |
An optional |
args_swarm |
An optional |
args_error_bars |
An optional |
args_legend |
An optional |
jit |
Numeric. Determines the amount of horizontal displacement. Defaults to |
xlab |
Character or expression. Label for x axis. |
ylab |
Character or expression. Label for y axis. |
main |
Character or expression. For up to two factors, simply specify the main title. If you stratify the data by more than two factors, either specify a single value that will be added to automatically generated main title, or specify an array of multiple titles, one for each plot area. |
set_par |
Logical. Determines whether |
The measure of dispersion can be either conf_int()
for between-subjects confidence intervals, se()
for standard errors,
or any other standard function. For within-subjects confidence intervals, specify wsci()
or within_subjects_conf_int()
.
If between- or within-subjects confidence intervals are requested, you can also specify the area of the cumulative
distribution function that will be covered. For instance, if you want a 98% confidence interval, specify
level = 0.98
. The default is level = 0.95
for 95% confidence intervals.
apa_factorial_plot()
and its descendants apa_barplot()
, apa_lineplot()
,
apa_beeplot()
, and apa_violinplot()
are wrapper functions that sequentially call:
axis()
(once for x axis, once for y axis),
title()
for axis labels and titles,
rect()
for bars in bar plots,
points()
for bee swarms,
lines()
for lines connecting central tendency points,
arrows()
for error bars,
points()
for tendency points,
legend()
for a legend, and
lines()
for intercepts.
These calls can be customized by setting the respective parameters args_*** = list(...)
.
A named (nested) list of plot options including raw and derived data. Note that the structure of the return value is about to change in a forthcoming release of papaja.
Other plots for factorial designs:
apa_barplot()
,
apa_factorial_plot()
,
apa_lineplot()
,
apa_violinplot()
apa_beeplot( data = npk , id = "block" , dv = "yield" , factors = c("N") ) apa_beeplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") , args.legend = list(x = "center") ) apa_beeplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P", "K") , ylim = c(0, 80) , level = .34 , las = 1 )
apa_beeplot( data = npk , id = "block" , dv = "yield" , factors = c("N") ) apa_beeplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") , args.legend = list(x = "center") ) apa_beeplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P", "K") , ylim = c(0, 80) , level = .34 , las = 1 )
This is a function for processing degrees of freedom. It takes care that trailing digits are only printed if non-integer values are given.
apa_df(x, digits = 2L, big.mark = "", elementwise = TRUE) print_df(x, digits = 2L, big.mark = "", elementwise = TRUE)
apa_df(x, digits = 2L, big.mark = "", elementwise = TRUE) print_df(x, digits = 2L, big.mark = "", elementwise = TRUE)
x |
Numeric. The degrees of freedom to report. |
digits |
Integer. The desired number of digits after the decimal point to
be used if |
big.mark |
character; if not empty used as mark between every
|
elementwise |
Logical. Determines whether the number of trailing digits
should be determined for each element of |
An object of the same class as x
with all numeric values converted
to character.
apa_df(c(1, 1.23151))
apa_df(c(1, 1.23151))
Create one or more plots by sequentially calling functions from the graphics package.
apa_factorial_plot()
is the workhorse function that is called by
apa_barplot()
, apa_beeplot()
, and apa_lineplot()
.
apa_factorial_plot(data, ...) ## Default S3 method: apa_factorial_plot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", reference = 0, intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_rect = NULL, args_points = NULL, args_lines = NULL, args_swarm = NULL, args_violins = NULL, args_density = NULL, args_error_bars = NULL, args_legend = NULL, plot = NULL, jit = 0.3, xlab = NULL, ylab = NULL, main = NULL, set_par = TRUE, ... ) ## S3 method for class 'afex_aov' apa_factorial_plot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
apa_factorial_plot(data, ...) ## Default S3 method: apa_factorial_plot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", reference = 0, intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_rect = NULL, args_points = NULL, args_lines = NULL, args_swarm = NULL, args_violins = NULL, args_density = NULL, args_error_bars = NULL, args_legend = NULL, plot = NULL, jit = 0.3, xlab = NULL, ylab = NULL, main = NULL, set_par = TRUE, ... ) ## S3 method for class 'afex_aov' apa_factorial_plot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
data |
A |
... |
Arguments passed on to
|
id |
Character. Variable name that identifies subjects. |
factors |
Character. A vector of up to four variable names that is used to stratify the data. |
dv |
Character. The name of the dependent variable. |
tendency |
Closure. A function that will be used as measure of central tendency. |
dispersion |
Closure. A function that will be used to construct error bars (i.e., whiskers). Defaults to
|
level |
Numeric. Defines the width of the interval if confidence intervals are plotted. Defaults to |
fun_aggregate |
Closure. The function that will be used to aggregate observations within subjects and factors
before calculating descriptive statistics for each cell of the design. Defaults to |
na.rm |
Logical. Specifies if missing values are removed. Defaults to |
use |
Character. Specifies a method to exclude cases if there are missing values after aggregating.
Possible options are |
reference |
Numeric. A reference point that determines the y coordinate of the x axis. Useful if there exists a 'nil' value; defaults to |
intercept |
Numeric. Adds a horizontal line at height |
args_x_axis |
An optional |
args_y_axis |
An optional |
args_title |
An optional |
args_rect |
An optional |
args_points |
An optional |
args_lines |
An optional |
args_swarm |
An optional |
args_violins |
An optional |
args_density |
An optional |
args_error_bars |
An optional |
args_legend |
An optional |
plot |
Character. A vector specifying which elements of the plot should be plotted. Available options are
|
jit |
Numeric. Determines the amount of horizontal displacement. Defaults to |
xlab |
Character or expression. Label for x axis. |
ylab |
Character or expression. Label for y axis. |
main |
Character or expression. For up to two factors, simply specify the main title. If you stratify the data by more than two factors, either specify a single value that will be added to automatically generated main title, or specify an array of multiple titles, one for each plot area. |
set_par |
Logical. Determines whether |
The measure of dispersion can be either conf_int()
for between-subjects confidence intervals, se()
for standard errors,
or any other standard function. For within-subjects confidence intervals, specify wsci()
or within_subjects_conf_int()
.
If between- or within-subjects confidence intervals are requested, you can also specify the area of the cumulative
distribution function that will be covered. For instance, if you want a 98% confidence interval, specify
level = 0.98
. The default is level = 0.95
for 95% confidence intervals.
apa_factorial_plot()
and its descendants apa_barplot()
, apa_lineplot()
,
apa_beeplot()
, and apa_violinplot()
are wrapper functions that sequentially call:
axis()
(once for x axis, once for y axis),
title()
for axis labels and titles,
rect()
for bars in bar plots,
points()
for bee swarms,
lines()
for lines connecting central tendency points,
arrows()
for error bars,
points()
for tendency points,
legend()
for a legend, and
lines()
for intercepts.
These calls can be customized by setting the respective parameters args_*** = list(...)
.
A named (nested) list of plot options including raw and derived data. Note that the structure of the return value is about to change in a forthcoming release of papaja.
Other plots for factorial designs:
apa_barplot()
,
apa_beeplot()
,
apa_lineplot()
,
apa_violinplot()
apa_factorial_plot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P", "K") , las = 1 , plot = c("error_bars", "points", "swarms") , ylim = c(0, 100) )
apa_factorial_plot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P", "K") , las = 1 , plot = c("error_bars", "points", "swarms") , ylim = c(0, 100) )
Creates a character string to report interval estimates, such as frequentist confidence or Bayesian credible intervals.
apa_interval(x, ...) print_interval(x, ...) ## S3 method for class 'numeric' apa_interval( x, y = NULL, ..., conf.int = NULL, interval_type = NULL, enclose_math = FALSE ) ## S3 method for class 'matrix' apa_interval( x, ..., conf.int = NULL, interval_type = NULL, enclose_math = FALSE ) ## S3 method for class 'data.frame' apa_interval( x, ..., conf.int = NULL, interval_type = NULL, enclose_math = FALSE ) ## S3 method for class 'list' apa_interval( x, ..., conf.int = NULL, interval_type = NULL, enclose_math = FALSE ) apa_confint( x, ..., conf.int = NULL, interval_type = "CI", enclose_math = FALSE ) print_confint( x, ..., conf.int = NULL, interval_type = "CI", enclose_math = FALSE ) apa_hdint(x, ..., conf.int = NULL, interval_type = "HDI", enclose_math = FALSE) print_hdint( x, ..., conf.int = NULL, interval_type = "HDI", enclose_math = FALSE )
apa_interval(x, ...) print_interval(x, ...) ## S3 method for class 'numeric' apa_interval( x, y = NULL, ..., conf.int = NULL, interval_type = NULL, enclose_math = FALSE ) ## S3 method for class 'matrix' apa_interval( x, ..., conf.int = NULL, interval_type = NULL, enclose_math = FALSE ) ## S3 method for class 'data.frame' apa_interval( x, ..., conf.int = NULL, interval_type = NULL, enclose_math = FALSE ) ## S3 method for class 'list' apa_interval( x, ..., conf.int = NULL, interval_type = NULL, enclose_math = FALSE ) apa_confint( x, ..., conf.int = NULL, interval_type = "CI", enclose_math = FALSE ) print_confint( x, ..., conf.int = NULL, interval_type = "CI", enclose_math = FALSE ) apa_hdint(x, ..., conf.int = NULL, interval_type = "HDI", enclose_math = FALSE) print_hdint( x, ..., conf.int = NULL, interval_type = "HDI", enclose_math = FALSE )
x |
Numeric. A vector (of length 2, unless |
... |
Further arguments passed on to |
y |
Numeric. An optional vector of the same length as |
conf.int |
Numeric. Confidence level of the interval. Ignored if
level can be inferred from attributes of |
interval_type |
Character. Abbreviation indicating the type of interval
estimate, e.g. |
enclose_math |
Logical. Indicates whether the interval should be
enclosed in |
If possible the confidence level of the interval is inferred from
attributes of x
. For a vector of length 2, the attribute conf.level
is
is consulted; for a matrix
or data.frame
the column names are used,
if they are of the format "2.5 \
If x
is a matrix
or data.frame
the row names are used as names for
the returned list
of intervals.
A single interval is returned as a character
vector of length 1;
multiple intervals are returned as a named list
of character
vectors
of length 1.
apa_confint(1, 2, conf.int = 0.95) apa_confint(c(1, 2), conf.int = 0.95) apa_confint(matrix(c(1, 2), ncol = 2), conf.int = 0.95) apa_confint(confint(lm(cars))) apa_confint(confint(lm(cars)), digits = 3)
apa_confint(1, 2, conf.int = 0.95) apa_confint(c(1, 2), conf.int = 0.95) apa_confint(matrix(c(1, 2), ncol = 2), conf.int = 0.95) apa_confint(confint(lm(cars))) apa_confint(confint(lm(cars)), digits = 3)
Creates one or more line plots from a data.frame
containing data from
a factorial design and set APA-friendly defaults.
apa_lineplot(data, ...) ## Default S3 method: apa_lineplot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_points = NULL, args_lines = NULL, args_error_bars = NULL, args_legend = NULL, jit = 0.3, xlab = NULL, ylab = NULL, main = NULL, set_par = TRUE, ... ) ## S3 method for class 'afex_aov' apa_lineplot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
apa_lineplot(data, ...) ## Default S3 method: apa_lineplot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_points = NULL, args_lines = NULL, args_error_bars = NULL, args_legend = NULL, jit = 0.3, xlab = NULL, ylab = NULL, main = NULL, set_par = TRUE, ... ) ## S3 method for class 'afex_aov' apa_lineplot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
data |
A |
... |
Further arguments passed on to |
id |
Character. Variable name that identifies subjects. |
factors |
Character. A vector of up to four variable names that is used to stratify the data. |
dv |
Character. The name of the dependent variable. |
tendency |
Closure. A function that will be used as measure of central tendency. |
dispersion |
Closure. A function that will be used to construct error bars (i.e., whiskers). Defaults to
|
level |
Numeric. Defines the width of the interval if confidence intervals are plotted. Defaults to |
fun_aggregate |
Closure. The function that will be used to aggregate observations within subjects and factors
before calculating descriptive statistics for each cell of the design. Defaults to |
na.rm |
Logical. Specifies if missing values are removed. Defaults to |
use |
Character. Specifies a method to exclude cases if there are missing values after aggregating.
Possible options are |
intercept |
Numeric. Adds a horizontal line at height |
args_x_axis |
An optional |
args_y_axis |
An optional |
args_title |
An optional |
args_points |
An optional |
args_lines |
An optional |
args_error_bars |
An optional |
args_legend |
An optional |
jit |
Numeric. Determines the amount of horizontal displacement. Defaults to |
xlab |
Character or expression. Label for x axis. |
ylab |
Character or expression. Label for y axis. |
main |
Character or expression. For up to two factors, simply specify the main title. If you stratify the data by more than two factors, either specify a single value that will be added to automatically generated main title, or specify an array of multiple titles, one for each plot area. |
set_par |
Logical. Determines whether |
The measure of dispersion can be either conf_int()
for between-subjects confidence intervals, se()
for standard errors,
or any other standard function. For within-subjects confidence intervals, specify wsci()
or within_subjects_conf_int()
.
If between- or within-subjects confidence intervals are requested, you can also specify the area of the cumulative
distribution function that will be covered. For instance, if you want a 98% confidence interval, specify
level = 0.98
. The default is level = 0.95
for 95% confidence intervals.
apa_factorial_plot()
and its descendants apa_barplot()
, apa_lineplot()
,
apa_beeplot()
, and apa_violinplot()
are wrapper functions that sequentially call:
axis()
(once for x axis, once for y axis),
title()
for axis labels and titles,
rect()
for bars in bar plots,
points()
for bee swarms,
lines()
for lines connecting central tendency points,
arrows()
for error bars,
points()
for tendency points,
legend()
for a legend, and
lines()
for intercepts.
These calls can be customized by setting the respective parameters args_*** = list(...)
.
A named (nested) list of plot options including raw and derived data. Note that the structure of the return value is about to change in a forthcoming release of papaja.
Other plots for factorial designs:
apa_barplot()
,
apa_beeplot()
,
apa_factorial_plot()
,
apa_violinplot()
apa_lineplot( data = npk , id = "block" , dv = "yield" , factors = c("N") ) apa_lineplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") , args_legend = list(x = "center") , jit = 0 ) apa_lineplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P", "K") , ylim = c(0, 80) , level = .34 , las = 1 )
apa_lineplot( data = npk , id = "block" , dv = "yield" , factors = c("N") ) apa_lineplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") , args_legend = list(x = "center") , jit = 0 ) apa_lineplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P", "K") , ylim = c(0, 80) , level = .34 , las = 1 )
Converts numerical values to character strings for printing and reporting.
apa_num(x, ...) printnum(x, ...) print_num(x, ...) ## Default S3 method: apa_num(x, na_string = getOption("papaja.na_string"), ...) ## S3 method for class 'list' apa_num(x, ...) ## S3 method for class 'integer' apa_num( x, numerals = TRUE, capitalize = FALSE, zero_string = "no", na_string = getOption("papaja.na_string"), ... ) ## S3 method for class 'numeric' apa_num( x, gt1 = TRUE, zero = TRUE, na_string = getOption("papaja.na_string"), use_math = TRUE, add_equals = FALSE, ... ) ## S3 method for class 'data.frame' apa_num(x, margin = 2, ...) ## S3 method for class 'matrix' apa_num(x, margin = 2, ...) ## S3 method for class 'tiny_labelled' apa_num(x, ...)
apa_num(x, ...) printnum(x, ...) print_num(x, ...) ## Default S3 method: apa_num(x, na_string = getOption("papaja.na_string"), ...) ## S3 method for class 'list' apa_num(x, ...) ## S3 method for class 'integer' apa_num( x, numerals = TRUE, capitalize = FALSE, zero_string = "no", na_string = getOption("papaja.na_string"), ... ) ## S3 method for class 'numeric' apa_num( x, gt1 = TRUE, zero = TRUE, na_string = getOption("papaja.na_string"), use_math = TRUE, add_equals = FALSE, ... ) ## S3 method for class 'data.frame' apa_num(x, margin = 2, ...) ## S3 method for class 'matrix' apa_num(x, margin = 2, ...) ## S3 method for class 'tiny_labelled' apa_num(x, ...)
x |
Can be either a single value, vector, |
... |
Arguments passed on to
|
na_string |
Character. String to print if any element of |
numerals |
Logical. Indicates if integers should be converted to words. |
capitalize |
Logical. Indicates if first letter should be capitalized.
Ignored if |
zero_string |
Character. Word to print if |
gt1 |
Logical. Indicates if the statistic can, in principle, have an
absolute value greater than 1. If |
zero |
Logical. Indicates if the statistic can, in principle, be 0. If
|
use_math |
Logical. Indicates whether to use |
add_equals |
Logical. Indicates if the output string should be
prepended with an |
margin |
Integer. If |
If x
is a vector, all arguments can be vectors according to which each
element of the vector is formatted. Parameters are recycled if length of
x
exceeds the length of the parameter vectors. If x
is a matrix
or
data.frame
, the vectors specify the formatting of either rows or columns
according to the value of margin
.
We recommend to use apa_num()
, rather than printnum()
or print_num()
,
which are aliases kept only for backward compatibility.
An object of the same class as x
with all numeric values converted
to character.
apa_num(1/3) apa_num(1/3, gt1 = FALSE) apa_num(1/3, digits = 5) apa_num(0) apa_num(0, zero = FALSE)
apa_num(1/3) apa_num(1/3, gt1 = FALSE) apa_num(1/3, digits = 5) apa_num(0) apa_num(0, zero = FALSE)
Convenience wrapper for apa_num
to print p values.
apa_p(x, digits = 3L, na_string = "", add_equals = FALSE) printp(x, digits = 3L, na_string = "", add_equals = FALSE) print_p(x, digits = 3L, na_string = "", add_equals = FALSE)
apa_p(x, digits = 3L, na_string = "", add_equals = FALSE) printp(x, digits = 3L, na_string = "", add_equals = FALSE) print_p(x, digits = 3L, na_string = "", add_equals = FALSE)
x |
Numeric. The p value(s) to report. |
digits |
Integer. The desired number of digits after the decimal point, passed on to |
na_string |
Character. String to print if any element of |
add_equals |
Logical. Indicates if the output string should be
prepended with an |
An object of the same class as x
with all numeric values converted
to character.
apa_p(0.05) apa_p(0.0005) apa_p(0.99999999) apa_p(c(.001, 0), add_equals = TRUE)
apa_p(0.05) apa_p(0.0005) apa_p(0.99999999) apa_p(c(.001, 0), add_equals = TRUE)
Prepares objects to be used in the rendering process and creates title page and abstract for MS Word documents. This function has been defunct. It is no longer needed.
apa_prepare_doc()
apa_prepare_doc()
The function creates and locks a non-exported object apa_lang
that is used by other papaja-functions. apa_lang
is a
list
containing localizations for document elements such as abstract
and title. The selected language is defined by the lang
-parameter
in the documents yaml-header. Currently, English (default) and German
("german"
) are supported.
If the output document is MS Word (output: \link{apa6_word}
) the
function additionally creates a title page and adds the abstract. You
should, therefore, always call apa_prepare_doc
at the very
beginning of the R Markdown document.
Returns NULL
invisibly.
A generic function that takes objects from various statistical methods to
create formatted character strings to report the results in accordance with
APA manuscript guidelines. The function invokes particular methods, which
depend on the class
of the first argument.
apa_print(x, ...)
apa_print(x, ...)
x |
A model object. |
... |
Additional arguments passed to methods. |
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Other apa_print:
apa_print.BFBayesFactor()
,
apa_print.aov()
,
apa_print.emmGrid()
,
apa_print.glht()
,
apa_print.htest()
,
apa_print.list()
,
apa_print.lm()
,
apa_print.lme()
,
apa_print.merMod()
# List methods for apa_print() methods("apa_print")
# List methods for apa_print() methods("apa_print")
These methods take objects from various R functions that calculate analysis
of variance (i.e., ANOVA) or analysis of deviance. They create formatted
character strings to report the results in accordance with APA manuscript
guidelines. For anova
-objects from model comparisons see
apa_print.list()
.
## S3 method for class 'aov' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'summary.aov' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'aovlist' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'summary.aovlist' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'Anova.mlm' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, correction = getOption("papaja.sphericity_correction"), intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'summary.Anova.mlm' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, correction = getOption("papaja.sphericity_correction"), intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'afex_aov' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, correction = getOption("papaja.sphericity_correction"), intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'anova' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'manova' apa_print(x, test = "Pillai", in_paren = FALSE, ...) ## S3 method for class 'summary.manova' apa_print(x, in_paren = FALSE, ...)
## S3 method for class 'aov' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'summary.aov' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'aovlist' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'summary.aovlist' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'Anova.mlm' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, correction = getOption("papaja.sphericity_correction"), intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'summary.Anova.mlm' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, correction = getOption("papaja.sphericity_correction"), intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'afex_aov' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, correction = getOption("papaja.sphericity_correction"), intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'anova' apa_print( x, estimate = getOption("papaja.estimate_anova", "ges"), observed = NULL, intercept = FALSE, mse = getOption("papaja.mse", TRUE), in_paren = FALSE, ... ) ## S3 method for class 'manova' apa_print(x, test = "Pillai", in_paren = FALSE, ...) ## S3 method for class 'summary.manova' apa_print(x, in_paren = FALSE, ...)
x |
An object containing the results from an analysis of variance ANOVA |
estimate |
Character, function, or data frame. Determines which estimate of effect size is to be used. See details. |
observed |
Character. The names of the factors that are observed,
i.e., not manipulated. Necessary only for calculating generalized eta
squared; otherwise ignored. If |
intercept |
Logical. Indicates if the intercept term should be included in output. |
mse |
Logical. Indicates if mean squared errors should be included in
output. The default is taken from the global option |
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
... |
Further arguments that may be passed to |
correction |
Character. For repeated-measures ANOVA, the type of
sphericity correction to be used. Possible values are |
test |
Character. For MANOVA, the multivariate test statistic to be
reported, see |
The factor names are sanitized to facilitate their use as list names (see
Value section). Parentheses are omitted and other non-word characters are
replaced by _
.
Argument estimate
determines which measure of effect size is to be used:
It is currently possible to provide one of three characters to specify the
to-be-calculated effect size: "ges"
for generalized ,
"pes"
for partial , and
"es"
for .
Note that
is calculated correctly if and only if the design is
balanced.
It is also possible to provide a data.frame
with columns estimate
,
conf.low
, and conf.high
, which allows for including custom effect-
size measures.
A third option is to provide a function from the effectsize package
that will be used to calculate effect-size measures from x
. If
effectsize is installed (and papaja is loaded), this is the
new default. This default can be changed via
options(papaja.estimate_anova = ...)
.
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Bakeman, R. (2005). Recommended effect size statistics for repeated measures designs. Behavior Research Methods , 37 (3), 379–384. doi: doi:10.3758/BF03192707
aov()
, car::Anova()
, apa_print.list()
Other apa_print:
apa_print()
,
apa_print.BFBayesFactor()
,
apa_print.emmGrid()
,
apa_print.glht()
,
apa_print.htest()
,
apa_print.list()
,
apa_print.lm()
,
apa_print.lme()
,
apa_print.merMod()
## From Venables and Ripley (2002) p. 165. npk_aov <- aov(yield ~ block + N * P * K, npk) apa_print(npk_aov) # Use the effectsize package to calculate partial eta-squared with # confidence intervals apa_print(npk_aov, estimate = effectsize::omega_squared)
## From Venables and Ripley (2002) p. 165. npk_aov <- aov(yield ~ block + N * P * K, npk) apa_print(npk_aov) # Use the effectsize package to calculate partial eta-squared with # confidence intervals apa_print(npk_aov, estimate = effectsize::omega_squared)
These methods take result objects from the BayesFactor package to create formatted character strings to report the results in accordance with APA manuscript guidelines.
## S3 method for class 'BFBayesFactor' apa_print( x, stat_name = NULL, est_name = NULL, subscript = NULL, escape_subscript = FALSE, scientific_threshold = NULL, reciprocal = FALSE, log = FALSE, mcmc_error = any(x@bayesFactor$error > 0.05), iterations = 10000, standardized = FALSE, central_tendency = median, interval = hd_int, interval_type = "HDI", bf_r1 = NULL, bf_1r = NULL, ... ) ## S3 method for class 'BFBayesFactorTop' apa_print(x, reciprocal = FALSE, ...)
## S3 method for class 'BFBayesFactor' apa_print( x, stat_name = NULL, est_name = NULL, subscript = NULL, escape_subscript = FALSE, scientific_threshold = NULL, reciprocal = FALSE, log = FALSE, mcmc_error = any(x@bayesFactor$error > 0.05), iterations = 10000, standardized = FALSE, central_tendency = median, interval = hd_int, interval_type = "HDI", bf_r1 = NULL, bf_1r = NULL, ... ) ## S3 method for class 'BFBayesFactorTop' apa_print(x, reciprocal = FALSE, ...)
x |
Output object. See details. |
stat_name |
Character. If |
est_name |
Character. If |
subscript |
Character. Index used to specify the model comparison for
the Bayes factors, e.g., |
escape_subscript |
Logical. If |
scientific_threshold |
Numeric. Named vector of length 2 taking the form
|
reciprocal |
Logical. If |
log |
Logical. If |
mcmc_error |
Logical. If |
iterations |
Numeric. Number of iterations of the MCMC sampler to estimate HDIs from the posterior. |
standardized |
Logical. Whether to return standardized or unstandardized effect size estimates. |
central_tendency |
Function to calculate central tendency of MCMC samples to obtain a point estimate from the posterior. |
interval |
Function to calculate an interval estimate of MCMC
samples from the posterior. The returned object must be either a named
vector or matrix with (column) names giving the interval bounds
(e.g., |
interval_type |
Character. Used to specify the type of interval in the formatted text. |
bf_r1 |
Numeric. Vector of the same length as |
bf_1r |
Numeric. Same as |
... |
Arguments passed on to
|
stat_name
and est_name
are placed in the output string and are
thus passed to pandoc or LaTeX through knitr. To the extent it is
supported by the final document type, you can pass LaTeX-markup to format
the final text (e.g., M_\Delta
yields ).
For models with order constraint, the evidence for the order constraint
relative to the null model can be obtained by multiplying the
Bayes factor for the order constraint relative to the
unconstrained model (
bf_r1
) with the Bayes factor for the
unconstrained model relative to the null model,
.
can be calculated from the prior and posterior odds of the
order constraint (e.g., Morey & Wagenmakers, 2014). If
bf_r1
(or
bf_1r
) is specified they are multiplied with the corresponding Bayes
factor supplied in x
before the reciprocal is taken and the results are
formatted. Note, that it is not possible to determine whether x
gives
or
and, hence,
bf_r1
and bf_1r
are treated
identically; the different argument names only serve to ensure the
expressiveness of the code. It is the user's responsibility to ensure that
the supplied Bayes factor is correct!
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Morey, R. D., & Wagenmakers, E.-J. (2014). Simple relation between Bayesian order-restricted and point-null hypothesis tests. Statistics & Probability Letters, 92, 121–124. doi: doi:10.1016/j.spl.2014.05.010
Other apa_print:
apa_print()
,
apa_print.aov()
,
apa_print.emmGrid()
,
apa_print.glht()
,
apa_print.htest()
,
apa_print.list()
,
apa_print.lm()
,
apa_print.lme()
,
apa_print.merMod()
# ANOVA data(sleep, package = "BayesFactor") bayesian_anova <- BayesFactor::anovaBF( extra ~ group + ID , data = sleep , whichRandom = "ID" , progress = FALSE ) # Paired t-test ttest_paired <- BayesFactor::ttestBF( x = sleep$extra[sleep$group == 1] , y = sleep$extra[sleep$group == 2] , paired = TRUE ) # Results for paired t-tests are indistinguishable # from one-sample t-tests. We therefore specify the # appropriate `est_name` manually. apa_print( ttest_paired , est_name = "M_D" , iterations = 1000 ) apa_print( ttest_paired , iterations = 1000 , interval = function(x) quantile(x, probs = c(0.025, 0.975)) , interval_type = "CrI" )
# ANOVA data(sleep, package = "BayesFactor") bayesian_anova <- BayesFactor::anovaBF( extra ~ group + ID , data = sleep , whichRandom = "ID" , progress = FALSE ) # Paired t-test ttest_paired <- BayesFactor::ttestBF( x = sleep$extra[sleep$group == 1] , y = sleep$extra[sleep$group == 2] , paired = TRUE ) # Results for paired t-tests are indistinguishable # from one-sample t-tests. We therefore specify the # appropriate `est_name` manually. apa_print( ttest_paired , est_name = "M_D" , iterations = 1000 ) apa_print( ttest_paired , iterations = 1000 , interval = function(x) quantile(x, probs = c(0.025, 0.975)) , interval_type = "CrI" )
Takes various emmeans objects to create formatted character strings to report the results in accordance with APA manuscript guidelines. emmeans supports a wide range of analyses, not all of which are currently (fully) supported. Proceed with caution.
## S3 method for class 'emmGrid' apa_print(x, infer = TRUE, conf.int = 0.95, ...) ## S3 method for class 'summary_emm' apa_print( x, contrast_names = NULL, est_name = "\\hat{\\theta}", in_paren = FALSE, ... ) ## S3 method for class 'lsmobj' apa_print(x, ...) ## S3 method for class 'summary.ref.grid' apa_print(x, ...)
## S3 method for class 'emmGrid' apa_print(x, infer = TRUE, conf.int = 0.95, ...) ## S3 method for class 'summary_emm' apa_print( x, contrast_names = NULL, est_name = "\\hat{\\theta}", in_paren = FALSE, ... ) ## S3 method for class 'lsmobj' apa_print(x, ...) ## S3 method for class 'summary.ref.grid' apa_print(x, ...)
x |
Object |
infer |
A vector of one or two logical values. The first determines whether confidence intervals are displayed, and the second determines whether t tests and P values are displayed. If only one value is provided, it is used for both. |
conf.int |
Numeric. Confidence level for confidence intervals. |
... |
Arguments passed on to
|
contrast_names |
Character. An optional vector of names to label the calculated contrasts. |
est_name |
Character. If |
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
When p-values and confidence intervals are adjusted for multiple testing,
the correction method is added as an index to the output (e.g.
p_{Tukey(3)}
). Values in parenthesis indicate the size of the family of
tests or the rank of the set of linear functions (for the Scheffé method).
If possible, each family of tests is additionally marked in the returned table by alphabetic superscripts.
Generally, the summary_emm
objects returned by emmeans::summary_emm
omit
information that may be needed to add some of the information on the
adjustments made to p-values and confidence intervals. It is therefore
preferable to pass emmGrid
-objects if possible. For example, by using
emmeans(object, 1 ~ x1, adjust = "scheffe")
.
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Other apa_print:
apa_print()
,
apa_print.BFBayesFactor()
,
apa_print.aov()
,
apa_print.glht()
,
apa_print.htest()
,
apa_print.list()
,
apa_print.lm()
,
apa_print.lme()
,
apa_print.merMod()
# From the emmeans manual: library(emmeans) warp.lm <- lm(breaks ~ wool*tension, data = warpbreaks) warp.emm <- emmeans(warp.lm, ~ tension | wool) warp.contr <- contrast(warp.emm, "poly") apa_print(warp.contr) # In this example, because degrees of freedom are equal across all rows # of the output, it is possible to move that information to the variable # labels. This is useful if a compact results table is required: df_into_label(apa_print(warp.contr))
# From the emmeans manual: library(emmeans) warp.lm <- lm(breaks ~ wool*tension, data = warpbreaks) warp.emm <- emmeans(warp.lm, ~ tension | wool) warp.contr <- contrast(warp.emm, "poly") apa_print(warp.contr) # In this example, because degrees of freedom are equal across all rows # of the output, it is possible to move that information to the variable # labels. This is useful if a compact results table is required: df_into_label(apa_print(warp.contr))
These methods are not properly tested and should be considered experimental.
## S3 method for class 'glht' apa_print(x, test = multcomp::adjusted(), ...) ## S3 method for class 'summary.glht' apa_print(x, conf.int = 0.95, in_paren = FALSE, ...)
## S3 method for class 'glht' apa_print(x, test = multcomp::adjusted(), ...) ## S3 method for class 'summary.glht' apa_print(x, conf.int = 0.95, in_paren = FALSE, ...)
x |
Object |
test |
Function. Computes p-values (adjusted for multiple comparisons). |
... |
Further arguments to pass to |
conf.int |
Numeric. If |
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Other apa_print:
apa_print()
,
apa_print.BFBayesFactor()
,
apa_print.aov()
,
apa_print.emmGrid()
,
apa_print.htest()
,
apa_print.list()
,
apa_print.lm()
,
apa_print.lme()
,
apa_print.merMod()
# From the multcomp::glht() examples: library(multcomp) amod <- aov(breaks ~ tension, data = warpbreaks) glht_out <- glht(amod, linfct = mcp(tension = "Tukey")) apa_print(glht_out) # In this example, because degrees of freedom are equal across all rows # of the output, it is possible to move that information to the variable # labels. This is useful if a compact results table is required: df_into_label(apa_print(glht_out))
# From the multcomp::glht() examples: library(multcomp) amod <- aov(breaks ~ tension, data = warpbreaks) glht_out <- glht(amod, linfct = mcp(tension = "Tukey")) apa_print(glht_out) # In this example, because degrees of freedom are equal across all rows # of the output, it is possible to move that information to the variable # labels. This is useful if a compact results table is required: df_into_label(apa_print(glht_out))
Takes htest
objects from various statistical methods (e.g., t.test()
,
wilcox.test()
, cor.test()
) to create formatted character strings to
report the results in accordance with APA manuscript guidelines.
## S3 method for class 'htest' apa_print( x, stat_name = NULL, est_name = NULL, n = NULL, conf.int = NULL, in_paren = FALSE, ... )
## S3 method for class 'htest' apa_print( x, stat_name = NULL, est_name = NULL, n = NULL, conf.int = NULL, in_paren = FALSE, ... )
x |
An |
stat_name |
Character. If |
est_name |
Character. If |
n |
Numeric. Sample size; required when reporting |
conf.int |
Numeric. If |
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
... |
Arguments passed on to
|
The function should work on a wide range of htest
objects. Due to the
large number of functions that produce these objects and their
idiosyncrasies, the returned strings should be compared to the original
object. If you experience inaccuracies you may report these
here (please include
a reproducible example in your report).
stat_name
and est_name
are placed in the output string and are thus
passed to pandoc or LaTeX through knitr. Thus, to the extent it is
supported by the final document type, you can pass LaTeX-markup to format
the final text (e.g., \\tau
yields ).
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Other apa_print:
apa_print()
,
apa_print.BFBayesFactor()
,
apa_print.aov()
,
apa_print.emmGrid()
,
apa_print.glht()
,
apa_print.list()
,
apa_print.lm()
,
apa_print.lme()
,
apa_print.merMod()
# Comparisons of central tendencies t_stat <- t.test(extra ~ group, data = sleep) apa_print(t_stat) apa_print(t_stat, stat_name = "tee") wilcox_stat <- wilcox.test(extra ~ group, data = sleep, exact = FALSE) apa_print(wilcox_stat) # Correlations ## Data from Hollander & Wolfe (1973), p. 187f. x <- c(44.4, 45.9, 41.9, 53.3, 44.7, 44.1, 50.7, 45.2, 60.1) y <- c( 2.6, 3.1, 2.5, 5.0, 3.6, 4.0, 5.2, 2.8, 3.8) cor_stat <- cor.test(x, y, method = "spearman") apa_print(cor_stat) # Contingency tables ## Data from Fleiss (1981), p. 139. smokers <- c(83, 90, 129, 70) patients <- c(86, 93, 136, 82) prop_stat <- prop.test(smokers, patients) apa_print(prop_stat, n = sum(patients))
# Comparisons of central tendencies t_stat <- t.test(extra ~ group, data = sleep) apa_print(t_stat) apa_print(t_stat, stat_name = "tee") wilcox_stat <- wilcox.test(extra ~ group, data = sleep, exact = FALSE) apa_print(wilcox_stat) # Correlations ## Data from Hollander & Wolfe (1973), p. 187f. x <- c(44.4, 45.9, 41.9, 53.3, 44.7, 44.1, 50.7, 45.2, 60.1) y <- c( 2.6, 3.1, 2.5, 5.0, 3.6, 4.0, 5.2, 2.8, 3.8) cor_stat <- cor.test(x, y, method = "spearman") apa_print(cor_stat) # Contingency tables ## Data from Fleiss (1981), p. 139. smokers <- c(83, 90, 129, 70) patients <- c(86, 93, 136, 82) prop_stat <- prop.test(smokers, patients) apa_print(prop_stat, n = sum(patients))
This method performs comparisons of lm-objects and creates formatted character strings and a model comparison table to report the results in accordance with APA manuscript guidelines.
## S3 method for class 'list' apa_print( x, anova_fun = stats::anova, conf.int = 0.9, boot_samples = 10000, progress_bar = interactive(), observed = TRUE, in_paren = FALSE, ... )
## S3 method for class 'list' apa_print( x, anova_fun = stats::anova, conf.int = 0.9, boot_samples = 10000, progress_bar = interactive(), observed = TRUE, in_paren = FALSE, ... )
x |
List. A |
anova_fun |
Function. Function to compare model-objects contained in
|
conf.int |
Numeric. Confidence level for the bootstrap confidence interval
for |
boot_samples |
Numeric. Number of bootstrap samples to estimate
confidence intervals for |
progress_bar |
Logical. Determines whether a progress bar is printed while bootstrapping. |
observed |
Logical. Indicates whether predictor variables were observed. See details. |
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
... |
Additional arguments passed to the function specified as
|
As demonstrated by Algina, Keselman & Penfield (2007), asymptotic
confidence intervals for are often unreliable. Confidence
intervals for model comparisons of
lm
objects are, therefore,
estimated using their modified percentile bootstrap method. Note that the
accuracy of the confidence intervals depends on the number of predictors
, their distribution, and the sample size
:
"When the predictor distribution is multivariate normal, one can obtain
accurate CIs for with
when
. For
and for
,
is advisable. When the
predictor distribution is nonnormal in form, sample size requirements vary
with type of nonnormality." (p. 939, Algina, Keselman & Penfield, 2010)
If MBESS is available, confidence intervals for are
computed using
MBESS::ci.R2()
to obtain a confidence region that
corresponds to the confidence level conf.int
, the default being a 90% CI (see
Steiger, 2004). If observed = FALSE
, it is assumed that predictors are
fixed variables, i.e., "the values of the [predictors] were selected a
priori as part of the research design" (p. 15, Kelly, 2007); put
differently, it is assumed that predictors are not random. The confidence
intervals for the regression coefficients in the model comparison table
correspond to the -level chosen for
and
(e.g., 90% CI or
for
and
yields a 95% CI for regression coefficients,
Steiger, 2004).
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Algina, J., Keselman, H. J., & Penfield, R. D. (2007). Confidence intervals for an effect size measure in multiple linear regression. Educational and Psychological Measurement, 67(2), 207–218. doi: doi:10.1177/0013164406292030
Algina, J., Keselman, H. J., & Penfield, R. D. (2010). Confidence intervals for squared semipartial correlation coefficients: The effect of nonnormality. Educational and Psychological Measurement, 70(6), 926–940. doi: doi:10.1177/0013164410379335
Steiger (2004). Beyond the F test: Effect size confidence intervals and tests of close fit in the analysis of variance and contrast analysis. Psychological Methods, 9(2), 164–182. doi: doi:10.1037/1082-989X.9.2.164
Kelley, K. (2007). Confidence intervals for standardized effect sizes: Theory, application, and implementation. Journal of Statistical Software, 20(8), 1–24. doi: doi:10.18637/jss.v020.i08
Other apa_print:
apa_print()
,
apa_print.BFBayesFactor()
,
apa_print.aov()
,
apa_print.emmGrid()
,
apa_print.glht()
,
apa_print.htest()
,
apa_print.lm()
,
apa_print.lme()
,
apa_print.merMod()
mod1 <- lm(Sepal.Length ~ Sepal.Width, data = iris) mod2 <- update(mod1, formula = . ~ . + Petal.Length) mod3 <- update(mod2, formula = . ~ . + Petal.Width) # No bootstrapped Delta R^2 CI apa_print(list(Baseline = mod1, Length = mod2, Both = mod3), boot_samples = 0)
mod1 <- lm(Sepal.Length ~ Sepal.Width, data = iris) mod2 <- update(mod1, formula = . ~ . + Petal.Length) mod3 <- update(mod2, formula = . ~ . + Petal.Width) # No bootstrapped Delta R^2 CI apa_print(list(Baseline = mod1, Length = mod2, Both = mod3), boot_samples = 0)
These methods take (generalized) linear model objects to create formatted character strings to report the results in accordance with APA manuscript guidelines.
## S3 method for class 'lm' apa_print( x, est_name = NULL, standardized = FALSE, conf.int = 0.95, observed = TRUE, in_paren = FALSE, ... ) ## S3 method for class 'glm' apa_print( x, est_name = NULL, standardized = FALSE, conf.int = 0.95, observed = TRUE, in_paren = FALSE, ... ) ## S3 method for class 'summary.glm' apa_print(x, ...) ## S3 method for class 'summary.lm' apa_print(x, ...)
## S3 method for class 'lm' apa_print( x, est_name = NULL, standardized = FALSE, conf.int = 0.95, observed = TRUE, in_paren = FALSE, ... ) ## S3 method for class 'glm' apa_print( x, est_name = NULL, standardized = FALSE, conf.int = 0.95, observed = TRUE, in_paren = FALSE, ... ) ## S3 method for class 'summary.glm' apa_print(x, ...) ## S3 method for class 'summary.lm' apa_print(x, ...)
x |
|
est_name |
Character. If |
standardized |
Logical. Indicates if coefficients were standardized
(e.g., using |
conf.int |
Numeric. Either a single value (range [0, 1]) giving the
confidence level or a two-column |
observed |
Logical. Indicates whether predictor variables were observed. See details. |
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
... |
Arguments passed on to
|
The coefficient names are sanitized to facilitate their use as list names.
Parentheses are omitted and other non-word characters are replaced by _
(see sanitize_terms()
).
est_name
is placed in the output string and is then passed to pandoc or
LaTeX through knitr. Thus, to the extent it is supported by the
final document type, you can pass LaTeX-markup to format the final text
(e.g., "\\\\beta"
yields ).
If standardized = TRUE
, scale()
is removed from coefficient names
(see examples). This option is currently ignored for glm
-objects.
If conf.int
is a single value, confidence intervals are calculated using
stats::confint()
.
If x
is an lm
object and the MBESS package is available,
confidence intervals for are computed using
MBESS::ci.R2()
to
obtain a confidence region that corresponds to the -level
chosen for the confidence intervals of regression coefficients (e.g.,
95% CI or
for regression coefficients yields a 90% CI
for
, see Steiger, 2004). If
observed = FALSE
, it is assumed
that predictors are fixed variables, i.e., "the values of the
[predictors] were selected a priori as part of the research design"
(p. 15, Kelly, 2007); put differently, it is assumed that predictors are
not random.
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Steiger (2004). Beyond the F Test: Effect Size Confidence Intervals and Tests of Close Fit in the Analysis of Variance and Contrast Analysis. Psychological Methods, 9(2), 164-182. doi: doi:10.1037/1082-989X.9.2.164
Kelley, K. (2007). Confidence intervals for standardized effect sizes: Theory, application, and implementation. Journal of Statistical Software, 20(8), 1-24. doi: doi:10.18637/jss.v020.i08
stats::confint()
, MBESS::ci.pvaf()
Other apa_print:
apa_print()
,
apa_print.BFBayesFactor()
,
apa_print.aov()
,
apa_print.emmGrid()
,
apa_print.glht()
,
apa_print.htest()
,
apa_print.list()
,
apa_print.lme()
,
apa_print.merMod()
# Data from Dobson (1990), p. 9. ctl <- c(4.17, 5.58, 5.18, 6.11, 4.50, 4.61, 5.17, 4.53, 5.33, 5.14) trt <- c(4.81, 4.17, 4.41, 3.59, 5.87, 3.83, 6.03, 4.89, 4.32, 4.69) group <- gl(2, 10, 20, labels = c("Ctl", "Trt")) weight <- c(ctl, trt) lm_fit <- lm(weight ~ group) apa_print(lm_fit) trt <- rep(trt, 2) # More data is always better ctl <- rep(ctl, 2) lm_fit2 <- lm(scale(trt) ~ scale(ctl)) apa_print(lm_fit2, standardized = TRUE) # It is possible to simplify the regression table with transmute_df_into_label(): transmute_df_into_label(apa_print(lm_fit2, standardized = TRUE)) # Dobson (1990) Page 93: Randomized Controlled Trial : counts <- c(18,17,15,20,10,20,25,13,12) outcome <- gl(3,1,9) treatment <- gl(3,3) d.AD <- data.frame(treatment, outcome, counts) glm.D93 <- glm(counts ~ outcome + treatment, family = poisson()) apa_print(glm.D93)
# Data from Dobson (1990), p. 9. ctl <- c(4.17, 5.58, 5.18, 6.11, 4.50, 4.61, 5.17, 4.53, 5.33, 5.14) trt <- c(4.81, 4.17, 4.41, 3.59, 5.87, 3.83, 6.03, 4.89, 4.32, 4.69) group <- gl(2, 10, 20, labels = c("Ctl", "Trt")) weight <- c(ctl, trt) lm_fit <- lm(weight ~ group) apa_print(lm_fit) trt <- rep(trt, 2) # More data is always better ctl <- rep(ctl, 2) lm_fit2 <- lm(scale(trt) ~ scale(ctl)) apa_print(lm_fit2, standardized = TRUE) # It is possible to simplify the regression table with transmute_df_into_label(): transmute_df_into_label(apa_print(lm_fit2, standardized = TRUE)) # Dobson (1990) Page 93: Randomized Controlled Trial : counts <- c(18,17,15,20,10,20,25,13,12) outcome <- gl(3,1,9) treatment <- gl(3,3) d.AD <- data.frame(treatment, outcome, counts) glm.D93 <- glm(counts ~ outcome + treatment, family = poisson()) apa_print(glm.D93)
These methods take mixed-effects models fitted with the nlme package and create formatted character strings report the results in accordance with APA manuscript guidelines.
## S3 method for class 'lme' apa_print(x, conf.int = 0.95, in_paren = FALSE, est_name = NULL, ...) ## S3 method for class 'anova.lme' apa_print(x, in_paren = FALSE, ...)
## S3 method for class 'lme' apa_print(x, conf.int = 0.95, in_paren = FALSE, est_name = NULL, ...) ## S3 method for class 'anova.lme' apa_print(x, in_paren = FALSE, ...)
x |
A (non-)linear mixed-effects model fitted with |
conf.int |
Numeric specifying the required confidence level or a named list
of additional arguments that are passed to |
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
est_name |
An optional character. The label to be used for fixed-effects coefficients. |
... |
Further arguments that may be passed to |
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Other apa_print:
apa_print()
,
apa_print.BFBayesFactor()
,
apa_print.aov()
,
apa_print.emmGrid()
,
apa_print.glht()
,
apa_print.htest()
,
apa_print.list()
,
apa_print.lm()
,
apa_print.merMod()
library(nlme) fm1 <- lme(distance ~ age, data = Orthodont, method = "ML") # random is ~ age apa_print(fm1, conf.int = .9) # ANOVA-like tables single_anova <- anova(fm1) apa_print(single_anova)
library(nlme) fm1 <- lme(distance ~ age, data = Orthodont, method = "ML") # random is ~ age apa_print(fm1, conf.int = .9) # ANOVA-like tables single_anova <- anova(fm1) apa_print(single_anova)
These methods take objects from various R functions that calculate hierarchical (generalized) linear models to create formatted character strings to report the results in accordance with APA manuscript guidelines.
## S3 method for class 'merMod' apa_print( x, effects = "fixed", conf.int = 0.95, in_paren = FALSE, est_name = NULL, ... ) ## S3 method for class 'mixed' apa_print(x, ...)
## S3 method for class 'merMod' apa_print( x, effects = "fixed", conf.int = 0.95, in_paren = FALSE, est_name = NULL, ... ) ## S3 method for class 'mixed' apa_print(x, ...)
x |
A fitted hierarchical (generalized) linear model, either from
|
effects |
Character. Determines which information is returned.
Currently, only fixed-effects terms ( |
conf.int |
Numeric specifying the required confidence level or a named
list specifying additional arguments that are passed to
|
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
est_name |
An optional character. The label to be used for fixed-effects coefficients. |
... |
Further arguments that may be passed to |
Confidence intervals are calculated by calling lme4::confint.merMod()
.
By default, Wald confidence intervals are calculated, but this may
change in the future.
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Other apa_print:
apa_print()
,
apa_print.BFBayesFactor()
,
apa_print.aov()
,
apa_print.emmGrid()
,
apa_print.glht()
,
apa_print.htest()
,
apa_print.list()
,
apa_print.lm()
,
apa_print.lme()
# Fit a linear mixed model using the lme4 package # or the lmerTest package (if dfs and p values are desired) library(lmerTest) fm1 <- lmer(Reaction ~ Days + (Days | Subject), sleepstudy) # Format statistics for fixed-effects terms (the default) apa_print(fm1)
# Fit a linear mixed model using the lme4 package # or the lmerTest package (if dfs and p values are desired) library(lmerTest) fm1 <- lmer(Reaction ~ Days + (Days | Subject), sleepstudy) # Format statistics for fixed-effects terms (the default) apa_print(fm1)
This method takes an output object from wsci
and creates a
table and character strings to report means and within-subjects confidence
intervals in a table or in text.
## S3 method for class 'papaja_wsci' apa_print(x, ...)
## S3 method for class 'papaja_wsci' apa_print(x, ...)
x |
An object of class |
... |
Arguments passed on to
|
apa_print()
-methods return a named list of class apa_results
containing the following elements:
estimate |
One or more character strings giving point estimates, confidence intervals, and confidence level. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
statistic |
One or more character strings giving the test statistic, parameters (e.g., degrees of freedom), and p-value. A single string is returned in a vector; multiple strings are returned as a named list. If no estimate is available the element is |
full_result |
One or more character strings comprised 'estimate' and 'statistic'. A single string is returned in a vector; multiple strings are returned as a named list. |
table |
A |
Column names in apa_results_table
are standardized following the broom glossary (e.g., term
, estimate
conf.int
, statistic
, df
, df.residual
, p.value
). Additionally, each column is labelled (e.g., $\hat{\eta}^2_G$
or $t$
) using the tinylabels package and these labels are used as column names when an apa_results_table
is passed to apa_table()
.
Formats matrices and data frames to report them as tables in R Markdown documents according to APA guidelines.
apa_table(x, ...) ## Default S3 method: apa_table(x, ...) ## S3 method for class 'apa_results_table' apa_table(x, escape = FALSE, ...) ## S3 method for class 'apa_results' apa_table(x, ...) ## S3 method for class 'matrix' apa_table( x, caption = NULL, note = NULL, stub_indents = NULL, added_stub_head = NULL, col_spanners = NULL, midrules = NULL, placement = "tbp", landscape = FALSE, font_size = NULL, escape = TRUE, span_text_columns = TRUE, ..., format.args = NULL ) ## S3 method for class 'list' apa_table( x, caption = NULL, note = NULL, stub_indents = NULL, added_stub_head = NULL, col_spanners = NULL, midrules = NULL, placement = "tbp", landscape = FALSE, font_size = NULL, escape = TRUE, merge_method = "indent", span_text_columns = TRUE, ..., format.args = NULL ) ## S3 method for class 'data.frame' apa_table( x, caption = NULL, note = NULL, stub_indents = NULL, added_stub_head = NULL, col_spanners = NULL, midrules = NULL, placement = "tbp", landscape = FALSE, font_size = NULL, escape = TRUE, span_text_columns = TRUE, ..., format.args = NULL )
apa_table(x, ...) ## Default S3 method: apa_table(x, ...) ## S3 method for class 'apa_results_table' apa_table(x, escape = FALSE, ...) ## S3 method for class 'apa_results' apa_table(x, ...) ## S3 method for class 'matrix' apa_table( x, caption = NULL, note = NULL, stub_indents = NULL, added_stub_head = NULL, col_spanners = NULL, midrules = NULL, placement = "tbp", landscape = FALSE, font_size = NULL, escape = TRUE, span_text_columns = TRUE, ..., format.args = NULL ) ## S3 method for class 'list' apa_table( x, caption = NULL, note = NULL, stub_indents = NULL, added_stub_head = NULL, col_spanners = NULL, midrules = NULL, placement = "tbp", landscape = FALSE, font_size = NULL, escape = TRUE, merge_method = "indent", span_text_columns = TRUE, ..., format.args = NULL ) ## S3 method for class 'data.frame' apa_table( x, caption = NULL, note = NULL, stub_indents = NULL, added_stub_head = NULL, col_spanners = NULL, midrules = NULL, placement = "tbp", landscape = FALSE, font_size = NULL, escape = TRUE, span_text_columns = TRUE, ..., format.args = NULL )
x |
Object to print, either a |
... |
Arguments passed on to
|
escape |
Logical. If |
caption |
Character. Caption to be printed above the table. |
note |
Character. Note to be printed below the table. |
stub_indents |
List. A named list of vectors that contain indices of rows to indent. The name of each list element containing the vector is used as title for indented sections. |
added_stub_head |
Character. Used as stub head (name of first column)
if |
col_spanners |
List. A named list of vectors of length 2 that contain the indices of the first and last column to span. The name of each list element is used as grouping column name. Currently ignored in Word documents. |
midrules |
Numeric. Vector of line numbers in table (not counting column headings) that should be followed by a horizontal rule; currently ignored in Word documents. |
placement |
Character. Indicates whether table should be placed, for
example, at the current location ( |
landscape |
Logical. If |
font_size |
Character. Font size to use for table contents (can be
|
span_text_columns |
Logical. If |
format.args |
List. A named list of arguments to be passed to
|
merge_method |
Character. Determines how to merge tables if |
When using apa_table
, the type of the output (LaTeX or Word) is
determined automatically by the rendered document type. In interactive R
session the output defaults to LaTeX.
If x
is a list
, all list elements are merged by columns into a single
table and the names of list elements are added according to the setting of
merge_method
.
By default, the width of the table is set to accommodate its contents. In
some cases, this may cause the table to exceed the page width. To address
this, tables can be rotated 90 degrees by setting langscape = TRUE
or,
by explicitly using "paragraph columns" with fixed column widths, such
that the contents is automatically broken into multiple lines. For
example, set align = "lm{5cm}l"
to limit the second column to a width of
5 cm. Similarly, to space columns equally use
align = paste0("m{", 1/(ncol(x) + 1), "\\linewidth}")
Note that placement options are not supported in appendices of apa6
documents and will be printed to the document. To omit the printed options
set placement = NULL
.
A character vector of the table source code of class knit_asis
, see
knitr::asis_output()
.
my_table <- t(apply(cars, 2, function(x) # Create data round(c(Mean = mean(x), SD = sd(x), Min = min(x), Max = max(x)), 2) )) apa_table( my_table , align = c("l", rep("r", 3)) , caption = "A summary table of the cars dataset." ) apa_table( cbind(my_table, my_table) , align = c("l", rep("r", 8)) , caption = "A summary table of the cars dataset." , note = "This table was created using apa\\_table()" , added_stub_head = "Variables" , col_spanners = list(`Cars 1` = c(2, 5), `Cars 2` = c(6, 9)) ) apa_table( list(`Cars 1` = my_table, `Cars 2` = my_table) , caption = "A summary table of the cars dataset." , added_stub_head = "Variables" )
my_table <- t(apply(cars, 2, function(x) # Create data round(c(Mean = mean(x), SD = sd(x), Min = min(x), Max = max(x)), 2) )) apa_table( my_table , align = c("l", rep("r", 3)) , caption = "A summary table of the cars dataset." ) apa_table( cbind(my_table, my_table) , align = c("l", rep("r", 8)) , caption = "A summary table of the cars dataset." , note = "This table was created using apa\\_table()" , added_stub_head = "Variables" , col_spanners = list(`Cars 1` = c(2, 5), `Cars 2` = c(6, 9)) ) apa_table( list(`Cars 1` = my_table, `Cars 2` = my_table) , caption = "A summary table of the cars dataset." , added_stub_head = "Variables" )
Creates one or more violin plots from a data.frame
containing data from
a factorial design and sets APA-friendly defaults.
apa_violinplot(data, ...) ## Default S3 method: apa_violinplot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_points = NULL, args_lines = NULL, args_error_bars = NULL, args_legend = NULL, jit = 0.3, xlab = NULL, ylab = NULL, main = NULL, ... ) ## S3 method for class 'afex_aov' apa_violinplot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
apa_violinplot(data, ...) ## Default S3 method: apa_violinplot( data, id, factors = NULL, dv, tendency = mean, dispersion = conf_int, level = 0.95, fun_aggregate = mean, na.rm = TRUE, use = "all.obs", intercept = NULL, args_x_axis = NULL, args_y_axis = NULL, args_title = NULL, args_points = NULL, args_lines = NULL, args_error_bars = NULL, args_legend = NULL, jit = 0.3, xlab = NULL, ylab = NULL, main = NULL, ... ) ## S3 method for class 'afex_aov' apa_violinplot( data, tendency = mean, dispersion = conf_int, fun_aggregate = mean, ... )
data |
A |
... |
Further arguments passed on to |
id |
Character. Variable name that identifies subjects. |
factors |
Character. A vector of up to four variable names that is used to stratify the data. |
dv |
Character. The name of the dependent variable. |
tendency |
Closure. A function that will be used as measure of central tendency. |
dispersion |
Closure. A function that will be used to construct error bars (i.e., whiskers). Defaults to
|
level |
Numeric. Defines the width of the interval if confidence intervals are plotted. Defaults to |
fun_aggregate |
Closure. The function that will be used to aggregate observations within subjects and factors
before calculating descriptive statistics for each cell of the design. Defaults to |
na.rm |
Logical. Specifies if missing values are removed. Defaults to |
use |
Character. Specifies a method to exclude cases if there are missing values after aggregating.
Possible options are |
intercept |
Numeric. Adds a horizontal line at height |
args_x_axis |
An optional |
args_y_axis |
An optional |
args_title |
An optional |
args_points |
An optional |
args_lines |
An optional |
args_error_bars |
An optional |
args_legend |
An optional |
jit |
Numeric. Determines the amount of horizontal displacement. Defaults to |
xlab |
Character or expression. Label for x axis. |
ylab |
Character or expression. Label for y axis. |
main |
Character or expression. For up to two factors, simply specify the main title. If you stratify the data by more than two factors, either specify a single value that will be added to automatically generated main title, or specify an array of multiple titles, one for each plot area. |
The measure of dispersion can be either conf_int()
for between-subjects confidence intervals, se()
for standard errors,
or any other standard function. For within-subjects confidence intervals, specify wsci()
or within_subjects_conf_int()
.
If between- or within-subjects confidence intervals are requested, you can also specify the area of the cumulative
distribution function that will be covered. For instance, if you want a 98% confidence interval, specify
level = 0.98
. The default is level = 0.95
for 95% confidence intervals.
apa_factorial_plot()
and its descendants apa_barplot()
, apa_lineplot()
,
apa_beeplot()
, and apa_violinplot()
are wrapper functions that sequentially call:
axis()
(once for x axis, once for y axis),
title()
for axis labels and titles,
rect()
for bars in bar plots,
points()
for bee swarms,
lines()
for lines connecting central tendency points,
arrows()
for error bars,
points()
for tendency points,
legend()
for a legend, and
lines()
for intercepts.
These calls can be customized by setting the respective parameters args_*** = list(...)
.
A named (nested) list of plot options including raw and derived data. Note that the structure of the return value is about to change in a forthcoming release of papaja.
Other plots for factorial designs:
apa_barplot()
,
apa_beeplot()
,
apa_factorial_plot()
,
apa_lineplot()
apa_violinplot( data = npk , id = "block" , dv = "yield" , factors = c("N") ) apa_violinplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") , args_legend = list(x = "center") , jit = 0.1 )
apa_violinplot( data = npk , id = "block" , dv = "yield" , factors = c("N") ) apa_violinplot( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") , args_legend = list(x = "center") , jit = 0.1 )
Template for creating an article according to APA guidelines (6th edition) in PDF or DOCX format.
apa6_pdf( fig_caption = TRUE, number_sections = FALSE, toc = FALSE, keep_tex = TRUE, md_extensions = NULL, includes = NULL, ... ) apa6_docx( fig_caption = TRUE, number_sections = FALSE, md_extensions = NULL, ... ) apa6_word(...) apa6_doc(...)
apa6_pdf( fig_caption = TRUE, number_sections = FALSE, toc = FALSE, keep_tex = TRUE, md_extensions = NULL, includes = NULL, ... ) apa6_docx( fig_caption = TRUE, number_sections = FALSE, md_extensions = NULL, ... ) apa6_word(...) apa6_doc(...)
fig_caption |
|
number_sections |
|
toc |
|
keep_tex |
Keep the intermediate tex file used in the conversion to PDF.
Note that this argument does not control whether to keep the auxiliary
files (e.g., ‘.aux’) generated by LaTeX when compiling ‘.tex’ to
‘.pdf’. To keep these files, you may set |
md_extensions |
Markdown extensions to be added or removed from the
default definition of R Markdown. See the
|
includes |
Named list of additional content to include within the
document (typically created using the |
... |
Further arguments to pass to
|
When creating PDF documents the YAML option classoption
is passed
to the class options of the LaTeX apa6 document class. In this case,
additional options are available. Refer to the apa6
document class
documentation
to find out about class options such as paper size or draft watermarks.
Please refer to the papaja online-manual for additional information on available YAML front matter settings. Note that the available settings for DOCX documents are more limited than for PDF documents.
When creating PDF documents the output device for figures defaults to
c("pdf", "png")
, so that each figure is saved in all four formats
at a resolution of 300 dpi.
R Markdown output format to pass to rmarkdown::render()
.
apa6_word()
: Format to create .docx-files. Alias of apa6_docx
.
apa6_doc()
: Format to create .docx-files. Alias of apa6_docx
.
bookdown::pdf_document2()
, bookdown::word_document2()
Remove parentheses, replace colons with $\times$
.
Useful to prettify term names in apa_print()
tables.
beautify_terms(x, ...) ## S3 method for class 'character' beautify_terms(x, standardized = FALSE, retain_period = FALSE, ...) ## S3 method for class 'numeric' beautify_terms(x, standardized = FALSE, ...) ## S3 method for class 'factor' beautify_terms(x, standardized = FALSE, ...) ## S3 method for class 'data.frame' beautify_terms(x, ...)
beautify_terms(x, ...) ## S3 method for class 'character' beautify_terms(x, standardized = FALSE, retain_period = FALSE, ...) ## S3 method for class 'numeric' beautify_terms(x, standardized = FALSE, ...) ## S3 method for class 'factor' beautify_terms(x, standardized = FALSE, ...) ## S3 method for class 'data.frame' beautify_terms(x, ...)
x |
Character. Vector of term names to be prettified. |
... |
Additional arguments passed to |
standardized |
Logical. If |
retain_period |
Logical. If |
A character vector or data.frame
(if x
is a data.frame
)
containing term names modified for nicer printing.
beautify_terms("a:b") beautify_terms("scale(x)", standardized = TRUE) beautify_terms("snake_case")
beautify_terms("a:b") beautify_terms("scale(x)", standardized = TRUE) beautify_terms("snake_case")
Creates character strings to cite R and R packages.
cite_r( file = NULL, prefix = "R-", footnote = FALSE, pkgs = NULL, omit = TRUE, lang = NULL, ... )
cite_r( file = NULL, prefix = "R-", footnote = FALSE, pkgs = NULL, omit = TRUE, lang = NULL, ... )
file |
Character. Path and name of the |
prefix |
Character. Prefix used for all R-package reference handles. |
footnote |
Logical. Indicates if packages should be cited in a footnote. Ignored if no package information is available. |
pkgs |
Character. Vector of package names to cite or omit depending
on |
omit |
Logical. If |
lang |
Character. Language code according to BCP 47. If |
... |
Additional arguments, which are currently ignored. |
If footnote = FALSE
, a character string citing R and R packages
including version numbers is returned. Otherwise a named list with the
elements r
and pkgs
is returned. The former element holds a character
string citing R and a reference to a footnote; the latter element contains
a character string that creates the footnote. For correct rendering, the
footnote string needs to be a separate paragraph in the R Markdown
document.
If footnote = FALSE
a character string is returned, otherwise a
named list with the elements r
and pkgs
.
cite_r()
cite_r()
Calculates the deviation that is needed to construct confidence intervals for a vector of observations.
conf_int(x, level = 0.95, na.rm = TRUE) conf.int(x, level = 0.95, na.rm = TRUE) ci(x, level = 0.95, na.rm = TRUE)
conf_int(x, level = 0.95, na.rm = TRUE) conf.int(x, level = 0.95, na.rm = TRUE) ci(x, level = 0.95, na.rm = TRUE)
x |
Numeric. A vector of observations from your dependent variable. |
level |
Numeric. Defines the width of the interval if confidence intervals are plotted. Defaults to 0.95 for 95% confidence intervals. |
na.rm |
Logical. Specifies if missing values should be removed. |
Returns a single numeric value, the deviation of the symmetric confidence bounds from the mean based on the t distribution.
Downloads and saves a .bib
-reference file form the web, so it can be
used to cite references in a Markdown-document using pandoc or LaTeX.
This function has been defunct. Please use download
from the
downloader instead.
fetch_web_refs(x, bib_name)
fetch_web_refs(x, bib_name)
x |
Character. URL of the |
bib_name |
Character. The path and name of the file to be created. |
If the function is called in an RMarkdown-document the file name
specified as bib_name
can be used in the YAML header as
bibliography
.
Returns NULL
invisibly.
cite_r()
, r_refs()
, knitr::write_bib()
Downloads and saves a Zotero reference library (or a subset) and saves it as
BibTeX file. This function has been defunct. Use ReadZotero()
from the
RefManageR package instead.
fetch_zotero_refs( x, bib_name, API_key = NULL, collection = NULL, lib_type = "user" )
fetch_zotero_refs( x, bib_name, API_key = NULL, collection = NULL, lib_type = "user" )
x |
Character. Zotero user or group ID, see details. |
bib_name |
Character. Name of the BibTeX-file references are saved to. |
API_key |
Character. Zotero API key, see details. |
collection |
Character. Optional ID of a collection in the Zotero library, see details. |
lib_type |
Character. Specifies if the supplied ID is associated with a
Zotero |
This function retrieves references through the Zotero web API. x
takes a Zotero user or group ID that can be retrieved from the Zotero.org
user or group Feeds/API settings.
An authentication key (API_key
) is required to access nonpublic
Zotero libraries. Authentication keys can also be generated in the
Zotero.org user or group Feeds/API settings.
If the requested reference collection is larger than 100 records, multiple API calls are initiated because the number of retrieved records is limited to 100 per API call. Frequent API calls will result in a temporary access block. Thus, there is an (currently unknown) upper limit to the length of reference collections that can be retrieved through this function. It is generally recommended to comment out calls to this function in R Markdown documents during periods of frequent knitting to limit the number of API calls and limit the number of references to those needed for the current document by setting up collections in your Zotero library.
Collection keys (collection
), i.e. identifiers of reference library
subsets, can be retrieved by accessing them via a web browser. They keys
are contained in the URL:
https://www.zotero.org/<USERNAME>/items/collectionKey/<COLLECTIONKEY>
Zotero web API calls can be slow, especially for large reference collections. If available, this function will use the downloader-package, which speeds up reference downloads considerably.
Returns bib_name
invisibly.
Christoph Stahl, Frederik Aust
This function helps organize YAML author and affiliation fields such that authorship order can be changed without having to also update the order of affiliations.
generate_author_yml( researchers, affiliations, corres_name, corres_address, corres_email )
generate_author_yml( researchers, affiliations, corres_name, corres_address, corres_email )
researchers |
a list of named character vectors. Author information is stored in the name of the vector. Abbreviated affiliations are stored in the vector. |
affiliations |
a list of named character strings. Abbreviated affiliations are stored in the names, the full affiliation is stored in the string. |
corres_name |
A character string. The name of the corresponding author, must match the author details in the researcher argument identically. |
corres_address |
A character string. The address of the corresponding author |
corres_email |
A character string. The email of the corresponding author. |
library(papaja) generate_author_yml ( researchers = list( "Emma J. Citizen" = c("example_hospital", "example_college"), "John H. Smith" = "example_college", "Kate C. Jones" = "example_hospital" ), affiliations = list( "example_hospital" = "Southern Example Hospital, NSW, Australia", "example_college" = "New Example College, VIC, Australia" ), corres_name = "Emma J. Citizen", corres_address = "123 Example Street, Epping, NSW 2121", corres_email = "[email protected]" )
library(papaja) generate_author_yml ( researchers = list( "Emma J. Citizen" = c("example_hospital", "example_college"), "John H. Smith" = "example_college", "Kate C. Jones" = "example_hospital" ), affiliations = list( "example_hospital" = "Southern Example Hospital, NSW, Australia", "example_college" = "New Example College, VIC, Australia" ), corres_name = "Emma J. Citizen", corres_address = "123 Example Street, Epping, NSW 2121", corres_email = "[email protected]" )
apa_results
ObjectTypeset the contents of an object according to the specified expression
strings and create a new or extend an existing apa_results
object.
glue_apa_results(x = NULL, term_names = NULL, ...) add_glue_to_apa_results( ..., est_glue, stat_glue, container, sublist = NULL, term_names = NULL, in_paren = FALSE, est_first = TRUE, simplify = TRUE )
glue_apa_results(x = NULL, term_names = NULL, ...) add_glue_to_apa_results( ..., est_glue, stat_glue, container, sublist = NULL, term_names = NULL, in_paren = FALSE, est_first = TRUE, simplify = TRUE )
x |
An environment, list or data frame used to look up values for substitution. |
term_names |
Character. Used as names for the |
... |
[ For |
est_glue |
Character. (Named vector of) expressions string(s) to
format. Each string creates a new (named) element in the
|
stat_glue |
Character. (Named vector of) expressions string(s) to
format. Each string creates a new (named) element in the
|
container |
List of class |
sublist |
Character. Name of (new) sub-list in |
in_paren |
Logical. Whether the formatted string is to be reported in
parentheses. If |
est_first |
Logical. Determines in which order |
simplify |
Logical. Determines whether the |
Returns a list of class apa_results
, see apa_print()
.
# Tidy and typeset output iris_lm <- lm(Sepal.Length ~ Petal.Length + Petal.Width, iris) tidy_iris_lm <- broom::tidy(iris_lm, conf.int = TRUE) tidy_iris_lm$p.value <- apa_p(tidy_iris_lm$p.value) glance_iris_lm <- broom::glance(iris_lm) glance_iris_lm$p.value <- apa_p(glance_iris_lm$p.value, add_equals = TRUE) glance_iris_lm$df <- apa_num(as.integer(glance_iris_lm$df)) glance_iris_lm$df.residual <- apa_num(as.integer(glance_iris_lm$df.residual)) # Create `apa_results`-list lm_results <- glue_apa_results( x = tidy_iris_lm , df = glance_iris_lm$df.residual , est_glue = "$b = <<estimate>>, 95% CI $[<<conf.low>>,~<<conf.high>>]$" , stat_glue = "$t(<<df>>) = <<statistic>>$, $p <<p.value>>$" , term_names = make.names(names(coef(iris_lm))) ) # Add modelfit information add_glue_to_apa_results( .x = glance_iris_lm , container = lm_results , sublist = "modelfit" , est_glue = c( r2 = "$R^2 = <<r.squared>>$" , aic = "" ) , stat_glue = c( r2 = "$F(<<df>>, <<df.residual>>) = <<statistic>>$, $p <<add_equals(p.value)>>$" , aic = "$\\mathrm{AIC} = <<AIC>>$" ) )
# Tidy and typeset output iris_lm <- lm(Sepal.Length ~ Petal.Length + Petal.Width, iris) tidy_iris_lm <- broom::tidy(iris_lm, conf.int = TRUE) tidy_iris_lm$p.value <- apa_p(tidy_iris_lm$p.value) glance_iris_lm <- broom::glance(iris_lm) glance_iris_lm$p.value <- apa_p(glance_iris_lm$p.value, add_equals = TRUE) glance_iris_lm$df <- apa_num(as.integer(glance_iris_lm$df)) glance_iris_lm$df.residual <- apa_num(as.integer(glance_iris_lm$df.residual)) # Create `apa_results`-list lm_results <- glue_apa_results( x = tidy_iris_lm , df = glance_iris_lm$df.residual , est_glue = "$b = <<estimate>>, 95% CI $[<<conf.low>>,~<<conf.high>>]$" , stat_glue = "$t(<<df>>) = <<statistic>>$, $p <<p.value>>$" , term_names = make.names(names(coef(iris_lm))) ) # Add modelfit information add_glue_to_apa_results( .x = glance_iris_lm , container = lm_results , sublist = "modelfit" , est_glue = c( r2 = "$R^2 = <<r.squared>>$" , aic = "" ) , stat_glue = c( r2 = "$F(<<df>>, <<df.residual>>) = <<statistic>>$, $p <<add_equals(p.value)>>$" , aic = "$\\mathrm{AIC} = <<AIC>>$" ) )
Calculates the highest-density interval of a vector of values.
hd_int(x, level = 0.95)
hd_int(x, level = 0.95)
x |
Numeric. A vector of observations. |
level |
Numeric. Defines the width of the interval. Defaults to 95% highest-density intervals. |
Takes a single character or a list of characters and replaces parentheses with brackets. Can be used to prepare a string of statistics (e.g. containing degrees of freedom) for reporting within parentheses.
in_paren(x)
in_paren(x)
x |
Character. Single character or list of characters. |
An object of the same type as x
, where all parentheses have been
replaced by brackets.
t_stat <- t.test(extra ~ group, data = sleep) t_test_res <- apa_print(t_stat) in_paren(t_test_res$stat) in_paren(t_test_res[1:3])
t_stat <- t.test(extra ~ group, data = sleep) t_test_res <- apa_print(t_stat) in_paren(t_test_res$stat) in_paren(t_test_res[1:3])
papaja
is an award-winning R package that facilitates creating computationally reproducible, submission-ready manuscripts which conform to the American Psychological Association (APA) manuscript guidelines (6th Edition).
papaja
provides
an R Markdown template that can be used with (or without) RStudio to create PDF documents (using the apa6 LaTeX class) or Word documents (using a .docx-reference file).
Functions to typeset the results from statistical analyses (e.g., apa_print()
),
functions to create tables (apa_table()
), and
functions to create figures in accordance with APA guidelines (e.g., apa_factorial_plot()
).
To use papaja
you need either an up-to-date version of
RStudio or
pandoc. If you want to create PDF-
in addition to DOCX-documents you additionally need a
TeX distribution. We recommend
TinyTex, which can be installed from within
R via the tinytex package.
Please refer to the papaja
manual
for detailed installation instructions.
For a comprehensive introduction to papaja
, see the current draft of the manual.
If you have a specific question that is not answered in the manual, feel free to ask a question on Stack Overflow using the papaja
tag.
If you believe you have found a bug or would like to request a new feature, open an issue on Github and provide a minimal complete verifiable example.
Frederik Aust (frederik.aust at uni-koeln.de). Marius Barth (marius.barth at uni-koeln.de).
Frederik Aust (frederik.aust at uni-koeln.de).
Maintainer: Frederik Aust [email protected] (ORCID)
Authors:
Marius Barth [email protected] (ORCID)
Other contributors:
Birk Diedenhofen [email protected] [contributor]
Christoph Stahl [email protected] [contributor]
Joseph V. Casillas [email protected] [contributor]
Rudolf Siegel [email protected] [contributor]
Useful links:
Includes a labelled quote from a LaTeX document 'asis'.
quote_from_tex( x, file = paste0(rmarkdown::metadata[["manuscript-tex"]], ".tex") )
quote_from_tex( x, file = paste0(rmarkdown::metadata[["manuscript-tex"]], ".tex") )
x |
Character. One or more quote labels. |
file |
Character. Path to LaTeX file from which to quote. |
Searches the LaTeX document specified in file
for labelled
quotes, i.e. paragraphs that are enclosed in % <@~{#quote-label}
and
% ~@>
tags in LaTeX comments on separate lines. The labelled quote is
then inserted and rendered asis
. To use labelled quote-tags in a
apa6_pdf()
-document, set the YAML front matter options
quote_labels: true
.
A character vector of LaTeX document text of class knit_asis
,
see knitr::asis_output()
.
Creates a .bib
-reference file for the installed R version and R-packages,
so they can be cited in an R Markdown-document.
r_refs( file, append = TRUE, prefix = "R-", type_pref = c("Article", "Book"), tweak = TRUE ) create_bib( x, file, append = TRUE, prefix = "R-", type_pref = c("Article", "Book"), tweak = TRUE )
r_refs( file, append = TRUE, prefix = "R-", type_pref = c("Article", "Book"), tweak = TRUE ) create_bib( x, file, append = TRUE, prefix = "R-", type_pref = c("Article", "Book"), tweak = TRUE )
file |
Character. Path and name of the file to be created or updated. |
append |
Logical. Indicates if existing bibliography should be complemented or overwritten. See details. |
prefix |
Character. Prefix for all R-package reference handles. |
type_pref |
Character. A vector of BibTeX entry types in the order by
which to prioritize packages |
tweak |
Logical. Indicates whether to fix some known problems in
citations (based on |
x |
Character. Names of packages to include in bibliography. |
r_refs
is a wrapper for create_bib
to create a
bibliography for R and all attached or cached packages.
By default, if a file exists at the specified location, r_refs
reads the
file and appends missing citation information to the end of the file
(create_bib
always overwrites existing files). It is
recommended to use a bibliography-file dedicated to R-references.
Beware that chunks loading packages should generally not be cached.
r_refs
will make all packages loaded in cached chunks citable, but it
won't know when you remove a package from a cached chunk. This can result
in unused package references in your bibliography-file that will be cited
when using cite_r
.
If a package provides citation information in a CITATION
file, a
reference is selected based on the preferred order of reference types
specified in type_pref
. By default, available articles are cited rather
than books. If no reference of the specified types is available, the first
reference is used. If multiple references of the preferred type are given
all of them are cited. Finally, if no CITATION
file exists a reference
is generated from the DESCRIPTION
file by citation
.
Invisibly returns the bibliography written to file
.
cite_r()
, knitr::write_bib()
, utils::citation()
, utils::toLatex()
Removes markdown comments from an R Markdown file.
remove_comments(x, file)
remove_comments(x, file)
x |
Character. Path to an R Markdown file. |
file |
Character. Name of the new R Markdown file without comments. |
No return value, called to write text to file
.
Template for creating a journal revision letters.
revision_letter_pdf(...)
revision_letter_pdf(...)
... |
Further arguments passed on to |
This document format is adapted from by the revision letter template by Martin Schrön.
It is possible to reference sections, figures, or tables in the revised
manuscript, either by their number or by page. To do so, specify a path
to the revised manuscript (omitting the file extension) in the YAML
front matter (i.e., manuscript-tex: file_name
) and ensure that
you retain the aux
file when rendering the revised manuscript. To do
so, set the following option in a code chunk of the revised manuscript:
options(tinytex.clean = FALSE)
. To reference section, figure, or
table numbers it is possible to use LaTeX (i.e., \ref{label}
) or
bookdown cross-referencing syntax (i.e., \@ref(label)
). To
reference the corresponding page numbers you must use the LaTeX syntax
(i.e., \pageref{label}
).
To quote entire paragraphs directly from the revised manuscript see
quote_from_tex()
.
R Markdown output format to pass to rmarkdown::render()
.
bookdown::pdf_document2()
], rmarkdown::pdf_document()
Remove characters from term names that will be difficult to address using the $
-operator.
This function is not exported.
sanitize_terms(x, standardized = FALSE) ## S3 method for class 'character' sanitize_terms(x, standardized = FALSE) ## S3 method for class 'factor' sanitize_terms(x, standardized = FALSE) ## S3 method for class 'data.frame' sanitize_terms(x, standardized = FALSE) ## S3 method for class 'list' sanitize_terms(x, standardized = FALSE)
sanitize_terms(x, standardized = FALSE) ## S3 method for class 'character' sanitize_terms(x, standardized = FALSE) ## S3 method for class 'factor' sanitize_terms(x, standardized = FALSE) ## S3 method for class 'data.frame' sanitize_terms(x, standardized = FALSE) ## S3 method for class 'list' sanitize_terms(x, standardized = FALSE)
x |
Character. Vector of term names to be sanitized. |
standardized |
Logical. If |
An object of the same class as x
containing sanitized term names as
characters.
sanitize_terms(c("(Intercept)", "Factor A", "Factor B", "Factor A:Factor B", "scale(FactorA)"))
sanitize_terms(c("(Intercept)", "Factor A", "Factor B", "Factor A:Factor B", "scale(FactorA)"))
Calculates the standard error of the mean.
se(x, na.rm = TRUE)
se(x, na.rm = TRUE)
x |
Numeric. A vector of observations. |
na.rm |
Logical. Specifies if missing values should be removed. |
The standard error of the mean as numeric vector of length 1.
Generate a simple codebook in CSV-format from a (labelled) data.frame
.
simple_codebook(x, ...)
simple_codebook(x, ...)
x |
data.frame. Data to be documented. |
... |
Arguments passed on to
|
If the skimr package is installed, an in-line histogram is added for all numeric variables. If columns are labelled, the labelles are included in the codebook.
Returns NULL
invisibly.
variable_labels(cars) <- c(speed = "Speed [ft/s]", dist = "Distance traveled [m]") simple_codebook(cars, file = file.path(tempdir(), "cars_codebook.csv"))
variable_labels(cars) <- c(speed = "Speed [ft/s]", dist = "Distance traveled [m]") simple_codebook(cars, file = file.path(tempdir(), "cars_codebook.csv"))
Sort rows in ANOVA or regression tables produced by apa_print()
by complexity (i.e., main effects, two-way interactions, three-way interactions, etc.).
sort_terms(x, colname)
sort_terms(x, colname)
x |
A data frame. For example, the table element produced by |
colname |
Character. Column name of the |
Returns the same data.frame
with reordered rows.
## From Venables and Ripley (2002) p. 165. npk_aov <- aov(yield ~ block + N * P * K, npk) npk_aov_results <- apa_print(npk_aov) sort_terms(npk_aov_results$table, "term")
## From Venables and Ripley (2002) p. 165. npk_aov <- aov(yield ~ block + N * P * K, npk) npk_aov_results <- apa_print(npk_aov) sort_terms(npk_aov_results$table, "term")
Calculate upper and lower limits of within-subjects confidence intervals calculated
with wsci()
and return them along their respective means.
## S3 method for class 'papaja_wsci' summary(object, ...)
## S3 method for class 'papaja_wsci' summary(object, ...)
object |
An object of class |
... |
Further arguments that may be passed, currently ignored. |
A data.frame
containing means as well as lower and upper confidence
bounds for each cell of the design.
ggplot2
Themeggplot2 theme with a white panel background, no grid lines, large axis and legend titles, and increased text padding for better readability.
theme_apa(base_size = 12, base_family = "", box = FALSE)
theme_apa(base_size = 12, base_family = "", box = FALSE)
base_size |
Numeric. Base font size; other font sizes and margins are adjusted relative to this. |
base_family |
Character. Base font family. |
box |
Logical. Indicates whether to draw a black panel border. |
Object of class theme
and gg
, see ggplot2::theme()
.
ggplot2::theme_bw()
, ggplot2::theme()
# Copied from ?ggtheme mtcars2 <- within(mtcars, { vs <- factor(vs, labels = c("V-shaped", "Straight")) am <- factor(am, labels = c("Automatic", "Manual")) cyl <- factor(cyl) gear <- factor(gear) }) library("ggplot2") p1 <- ggplot(mtcars2) + geom_point(aes(x = wt, y = mpg, colour = gear)) + labs( title = "Fuel economy declines as weight increases", subtitle = "(1973-1974)", x = "Weight (1000 lbs)", y = "Fuel economy (mpg)", colour = "Gears" ) p1 p1 + theme_apa()
# Copied from ?ggtheme mtcars2 <- within(mtcars, { vs <- factor(vs, labels = c("V-shaped", "Straight")) am <- factor(am, labels = c("Automatic", "Manual")) cyl <- factor(cyl) gear <- factor(gear) }) library("ggplot2") p1 <- ggplot(mtcars2) + geom_point(aes(x = wt, y = mpg, colour = gear)) + labs( title = "Fuel economy declines as weight increases", subtitle = "(1973-1974)", x = "Weight (1000 lbs)", y = "Fuel economy (mpg)", colour = "Gears" ) p1 p1 + theme_apa()
Takes the output from apa_print()
methods and modifies the results table
by transmuting information about degrees of freedom into the variable labels of
test-statistic columns.
transmute_df_into_label(x, check_df = TRUE, ...) df_into_label(x, check_df = TRUE, ...) ## S3 method for class 'apa_results' transmute_df_into_label(x, check_df = TRUE, ...) ## S3 method for class 'apa_results_table' transmute_df_into_label(x, check_df = TRUE, ...)
transmute_df_into_label(x, check_df = TRUE, ...) df_into_label(x, check_df = TRUE, ...) ## S3 method for class 'apa_results' transmute_df_into_label(x, check_df = TRUE, ...) ## S3 method for class 'apa_results_table' transmute_df_into_label(x, check_df = TRUE, ...)
x |
Either the complete output object created by |
check_df |
Logical. If TRUE (the default), checks if degrees-of-freedom-columns contain non-integer values. |
... |
further arguments passed from an to other methods |
An object of the same class as x
, where a redundant column with
degrees of freedom has been incorporated into the column label of the column
statistic
.
apa_out <- apa_print(aov(yield ~ N * P, npk)) # Standard output with separate columns for degrees of freedom: apa_out$table # Modified output where degrees of freedom are incorporated into the variable # label of column 'statistic': transmute_df_into_label(apa_out)$table
apa_out <- apa_print(aov(yield ~ N * P, npk)) # Standard output with separate columns for degrees of freedom: apa_out$table # Modified output where degrees of freedom are incorporated into the variable # label of column 'statistic': transmute_df_into_label(apa_out)$table
Calculate Cousineau-Morey within-subjects confidence intervals.
wsci(data, id, factors, dv, level = 0.95, method = "Morey") within_subjects_conf_int(data, id, factors, dv, level = 0.95, method = "Morey")
wsci(data, id, factors, dv, level = 0.95, method = "Morey") within_subjects_conf_int(data, id, factors, dv, level = 0.95, method = "Morey")
data |
A |
id |
Character. Variable name that identifies subjects. |
factors |
Character. A vector of variable names that is used to stratify the data. |
dv |
Character. The name of the dependent variable. |
level |
Numeric. Defines the width of the interval. Defaults to 0.95 for 95% confidence intervals. |
method |
Character. The method that is used to calculate CIs. Currently, "Morey" and "Cousineau" are supported. Defaults to "Morey". |
A data.frame
with additional class papaja_wsci
.
The summary()
method for this class returns a data.frame
with
means along lower and upper limit for each cell of the design.
Morey, R. D. (2008). Confidence Intervals from Normalized Data: A correction to Cousineau (2005). Tutorials in Quantitative Methods for Psychology, 4(2), 61–64.
Cousineau, D. (2005). Confidence intervals in within-subjects designs: A simpler solution to Loftus and Masson's method. Tutorials in Quantitative Methods for Psychology, 1(1), 42–45.
wsci( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") )
wsci( data = npk , id = "block" , dv = "yield" , factors = c("N", "P") )