Since boxplots have become the de facto standard for plotting the distribution of data most users are familiar with these and the formula input for dataframes. However this input is not available in the standard vioplot
package. Thus it has been restored here for enhanced backwards compatibility with boxplot
.
As shown below for the iris
dataset, violin plots show distribution information taking formula input that boxplot
implements but vioplot
is unable to. This demonstrates the customisation demonstrated in the main vioplot vignette using vioplot syntax with the formula method commonly used for boxplot
, t.test
, and lm
.
library("vioplot")
data(iris)
boxplot(Sepal.Length~Species, data = iris)
Whereas performing the same function does not work with vioplot
(0.2).
::install_version("vioplot", version = "0.2")
devtoolslibrary("vioplot")
vioplot(Sepal.Length~Species, data = iris)
Error in min(data) : invalid 'type' (language) of argument
vioplot(Sepal.Length~Species, data = iris)
Another concern we see here is that the vioplot
defaults are not aesthetically pleasing, with a rather glaring colour scheme unsuitable for professional or academic usage. Thus the plot default colours have been changed as shown here:
vioplot(Sepal.Length~Species, data = iris, main = "Sepal Length")
Plot colours can be further customised as with the original vioplot package using the col
argument:
vioplot(Sepal.Length~Species, data = iris, main = "Sepal Length", col="lightblue")
However the vioplot
(0.2) function is unable to colour each violin separately, thus this is enabled with a vectorised col
in vioplot
(0.3):
vioplot(Sepal.Length~Species, data = iris, main = "Sepal Length", col=c("lightgreen", "lightblue", "palevioletred"))
legend("topleft", legend=c("setosa", "versicolor", "virginica"), fill=c("lightgreen", "lightblue", "palevioletred"), cex = 0.5)
Colours can also be customised for the violin fill and border separately using the col
and border
arguments:
vioplot(Sepal.Length~Species, data = iris, main = "Sepal Length", col="lightblue", border="royalblue")
Similarly, the arguments lineCol
and rectCol
specify the colours of the boxplot outline and rectangle fill. For simplicity the box and whiskers of the boxplot will always have the same colour.
vioplot(Sepal.Length~Species, data = iris, main = "Sepal Length", rectCol="palevioletred", lineCol="violetred")
The same applies to the colour of the median point with colMed
:
vioplot(Sepal.Length~Species, data = iris, main = "Sepal Length", colMed="violet")
### Combined customisation
These can be customised colours can be combined:
vioplot(Sepal.Length~Species, data = iris, main = "Sepal Length", col="lightblue", border="royalblue", rectCol="palevioletred", lineCol="violetred", colMed="violet")
These colour and shape settings can also be customised separately for each violin:
vioplot(Sepal.Length~Species, data = iris, main="Sepal Length", col=c("lightgreen", "lightblue", "palevioletred"), border=c("darkolivegreen4", "royalblue4", "violetred4"), rectCol=c("forestgreen", "blue", "palevioletred3"), lineCol=c("darkolivegreen", "royalblue", "violetred4"), colMed=c("green", "cyan", "magenta"), pchMed=c(15, 17, 19))