niceBar | R Documentation |
Aggregates data from a numeric vector or dataframe using up to three factors to draw a barplot with optional error bars.
niceBar(
x,
by = NULL,
groupLabels = NULL,
aggFun = c("mean", "median", "none"),
errFun = c("sd", "se", "range"),
theme = basicTheme,
legend = FALSE,
stack = FALSE,
main = NULL,
sub = NULL,
ylab = NULL,
minorTick = FALSE,
guides = TRUE,
outliers = FALSE,
width = NULL,
errorMultiple = 2,
plotColors = list(bg = "open", fill = setAlpha("grey", 0.8)),
logScale = FALSE,
trim = FALSE,
axisText = c(NULL, NULL),
showCalc = FALSE,
calcType = "wilcox",
yLim = NULL,
rotateLabels = FALSE,
rotateY = TRUE,
add = FALSE,
minorGuides = NULL,
extendTicks = TRUE,
subgroup = FALSE,
subgroupLabels = NULL,
stackLabels = NULL,
expLabels = FALSE,
sidePlot = FALSE,
errorBars = TRUE,
errorCap = "ball",
errorLineType = 1,
capWidth = 1.2,
lWidth = 1.5,
na.rm = FALSE,
flipFacts = FALSE,
verbose = FALSE,
logAdjustment = 1,
normalize = FALSE,
...
)
x |
numeric vector or data frame; The input to |
by |
factor or data frame of factors; used as the primary grouping factor and the factor levels will be used as group names if |
groupLabels |
character vector; overrides the factor levels of |
aggFun |
character; Determines how the data is summarized by factor level. Valid options are |
errFun |
character; How the data spread is charactarized by the error bars. Valid options are |
theme |
list object; Themes are are an optional way of storing graphical preset options that are compatible with all nicePlot graphing functions. |
legend |
logical/character; if not equal to |
stack |
logical; Should one of the factors in |
main |
character; title for the graph which is supplied to the |
sub |
character; subtitle for the graph which is supplied to the |
ylab |
character; y-axis label. |
minorTick |
positive integer; number of minor tick-marks to draw between each pair of major ticks-marks. |
guides |
logical; will draw guidelines at the major tick-marks if set to |
outliers |
positive numeric; number of interquartile ranges (IQR) past the Q1 (25%) and Q3 (75%) cumulative distribution values. Outliers are often defined as |
width |
numeric; cex-like scaling factor controlling the width of the bars. |
errorMultiple |
numeric; How many standard errors/deviations should be represented by the error bars. |
plotColors |
list; a named list of vectors of colors that set the color options for all NicePlot functions. Names left unspecified will be added and set to default values automatically. |
logScale |
positive numeric; the base for the for log scale data transformation calculated as |
trim |
positive numeric; passed to |
axisText |
character; a length two character vector containing text to be prepended or appended to the major tick labels, respectively. |
showCalc |
logical; if a p-value can be easily calculated for your data, it will be displayed using the |
calcType |
character; should match one of 'none', 'wilcox', 'Tukey','t.test','anova' which will determine which, if any statistical test should be performed on the data. |
yLim |
numeric vector; manually set the limits of the plotting area (eg. |
rotateLabels |
logical; sets |
rotateY |
logical; sets |
add |
logical; causes plotting to be added to the existing plot rather the start a new one. |
minorGuides |
logical; draws guidelines at minor tick-marks |
extendTicks |
logical; extends minor tick-marks past the first and last major tick to the edge of the graph provided there is enough room. Works for both log-scale and regular settings. |
subgroup |
logical; use additional column in |
subgroupLabels |
character vector; sets the labels used for the |
stackLabels |
character; An optional character vector to override the factor labels associated with stacking factor if active. |
expLabels |
logical; prints the major tick labels is |
sidePlot |
logical; switches the axis to plot horizontally instead of vertically. |
errorBars |
Logical; Should error bars be drawn. Defaults to true but is ignored if |
errorCap |
character; Determines the style for the ends of the error bars. Valid options are |
errorLineType |
numeric; Sets |
capWidth |
numeric; Controls the cex like scaling of the ball or width of the cap if they are drawn at the end of the error bars for the bar plot. |
lWidth |
numeric; Line width (lwd) for drawing the bar plot. |
na.rm |
logical; Should |
flipFacts |
logical; When a |
verbose |
logical; Prints summary and p-value calculations to the screen. All data is silently by the function returned either way. |
logAdjustment |
= numeric; This number is added to the input data prior to log transformation. Default value is 1. |
normalize |
logical; Normalizes stacked bars to 100%. If |
... |
additional options for S3 method variants. |
This bar plot function allows for standard barplot features but with error bars, the ability
summaryize dataframes into bar plots with median/mean values, sort by bar hight for waterfall plots,
color bars based on interquartile outlier detection and more. Barplots can be clustered by a secondary factor
or if a dataframe is passed to x
the input values of multiple measurments (dataframe columns) can be
clustered together by the primary factor. As with niceBox
, niceDots
and niceVio
, by
can be a factor or a dataframe factors for forming subgroups.
For most data this would be nonsensical but if you data is say store profits by goods by region one could group by region (first)
vioplot
, boxplot
, niceBox
, beeswarm
, prepCategoryWindow
data(mtcars)
Groups<-data.frame(Cyl=factor(mtcars$cyl),Gear=factor(mtcars$gear))
niceBar(mtcars$mpg,by=Groups,subgroup=TRUE,yLim=c(0,45),main="MpG by Cylinders and Gear")
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.