小提琴图与箱形图相似,不同之处在于它也显示了数据在不同值处的概率密度
带有误差线的小提琴图
library(ggpubr)
ggviolin(data, x=, y=,
combine = FALSE,
merge = FALSE,
color = "black",
fill = "white",
palette = NULL,
alpha = 1,
title = NULL,
xlab = NULL,
ylab = NULL,
facet.by = NULL,
panel.labs = NULL,
short.panel.labs = TRUE,
linetype = "solid",
trim = FALSE,
size = NULL,
width = 1,
draw_quantiles = NULL,
select = NULL,
remove = NULL,
order = NULL,
add = "mean_se",
add.params =list(),
error.plot = "pointrange",
label = NULL,
font.label =list(size = 11, color = "black"),
label.select = NULL,
repel = FALSE,
label.rectangle = FALSE,
position = position_dodge(0.8),
ggtheme = theme_pubr()
...)
Example
library(ggpubr)
data("ToothGrowth")
df<-ToothGrowth
str(df)
'data.frame': 60 obs. of 3 variables:
$ len : num 4.2 11.5 7.3 5.8 6.4 10 11.2 11.2 5.2 7 ...
$ supp: Factor w/ 2 levels "OJ","VC": 2 2 2 2 2 2 2 2 2 2 ...
$ dose: num 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 0.5 ...
p<-ggviolin(df, x = "dose", y = "len")
p
data:image/s3,"s3://crabby-images/f743a/f743a5bff93f3b48c2d0d24b32fccb273fe65589" alt=""
# Change the plot orientation: horizontal(改变图片方向)
p<-ggviolin(df, x = "dose", y = "len",orientation = "horiz")
data:image/s3,"s3://crabby-images/358b6/358b6271d224058e51b57605522a1df6d97ace23" alt=""
# Add summary statistics
# ++++++++++++++++++++++++++
# Draw quantiles(画分位数)
p<-ggviolin(df, "dose", "len", add = "none",draw_quantiles = 0.5)
data:image/s3,"s3://crabby-images/9ff23/9ff230d0db87f101311d59900a11a846193d97db" alt=""
# Add box plot
p<-ggviolin(df, x = "dose", y = "len",add = "boxplot")
data:image/s3,"s3://crabby-images/55074/55074b331e8e9f456dd8cd0b8f6f3bd5fb2b0c10" alt=""
p<-ggviolin(df, x = "dose", y = "len",add = "dotplot")
data:image/s3,"s3://crabby-images/4f137/4f13718d3a67901d7f7c42976beaea5b53cdd2c1" alt=""
# Add jitter points and
# change point shape by groups ("dose")
p<-ggviolin(df, x = "dose", y = "len",add = "jitter", shape = "dose")
data:image/s3,"s3://crabby-images/dca47/dca47e44e6ba45acdbb9fe8c04763881d62b06aa" alt=""
# Add mean_sd + jittered points
p<-ggviolin(df, x = "dose", y = "len", add = c("jitter", "mean_sd"))
data:image/s3,"s3://crabby-images/8041b/8041b823a62d2e16b8eea52950d41c8772618c59" alt=""
# Change error.plot to "crossbar"
p<-ggviolin(df, x = "dose", y = "len",add = "mean_sd", error.plot = "crossbar")
#可视化误差线,("pointrange", "linerange", "crossbar", "errorbar", "upper_errorbar", "lower_errorbar", "upper_pointrange", "lower_pointrange", "upper_linerange", "lower_linerange")
data:image/s3,"s3://crabby-images/3bdf6/3bdf635921efef762e2449f8c7ab00794acf5c22" alt=""
# Change colors
# +++++++++++++++++++++++++++
# Change outline and fill colors
p<-ggviolin(df, "dose", "len",color = "black", fill = "gray")
data:image/s3,"s3://crabby-images/ac816/ac8167eff546bb834f8d572adc6cd402816d329c" alt=""
# Change outline colors by groups: dose
# Use custom color palette and add boxplot
p<-ggviolin(df, "dose", "len", color = "dose",palette = c("#00AFBB", "#E7B800", "#FC4E07"),add = "boxplot")
data:image/s3,"s3://crabby-images/fe2b1/fe2b18b7d12cc04a02898b4bc263991dacf91a2c" alt=""
# Change fill color by groups: dose
# add boxplot with white fill color
ggviolin(df, "dose", "len", fill = "dose", palette = c("#00AFBB", "#E7B800", "#FC4E07"), add = "boxplot", add.params = list (fill = "white"))
data:image/s3,"s3://crabby-images/5acbd/5acbdf7ec0ca1ee9023e54cbfd26fc96532bd6a1" alt=""
# Plot with multiple groups
# fill or color box plot by a second group : "supp"
ggviolin(df, "dose", "len", color = "supp", palette = c("#00AFBB", "#E7B800"), add = "boxplot")
data:image/s3,"s3://crabby-images/4791c/4791ceabdbf3aa20e937d26dcfa2d6ed3be470b7" alt=""
参考链接:https://rpkgs.datanovia.com/ggpubr/reference/ggviolin.html
http://www.sthda.com/english/wiki/ggplot2-violin-plot-quick-start-guide-r-software-and-data-visualization
网友评论