把显著性添加给玩明白

1.编示例数据

set.seed(10086)
exp = matrix(rnorm(480,mean = 6),ncol = 120)
exp = round(exp,2)
rownames(exp) = paste0("gene",1:4)
colnames(exp) = paste0("test",1:120)
exp[,50:80] = exp[,50:80]+2
exp[,90:120] = exp[,90:120]+4
exp[1:4,1:4]
##       test1 test2 test3 test4
## gene1  6.55  5.37  6.32  4.18
## gene2  3.26  6.25  5.63  5.78
## gene3  6.57  6.80  8.11  6.58
## gene4  6.49  7.08  8.49  4.38

到这一步,拿到了一个编的表达矩阵。

2.格式转换

表达矩阵要画ggplot2箱线图,肯定是要先转变格式的,否则ggplot2代码无法下手写。

library(tidyr)
library(tibble)
library(dplyr)
dat = t(exp) %>% 
  as.data.frame() %>% 
  rownames_to_column() %>% 
  mutate(group = rep(c("control","treat1","treat2"),each = 40))

pdat = dat%>% 
  pivot_longer(cols = starts_with("gene"),
               names_to = "gene",
               values_to = "value")
head(pdat)
## # A tibble: 6 × 4
##   rowname group   gene  value
##   <chr>   <chr>   <chr> <dbl>
## 1 test1   control gene1  6.55
## 2 test1   control gene2  3.26
## 3 test1   control gene3  6.57
## 4 test1   control gene4  6.49
## 5 test2   control gene1  5.37
## 6 test2   control gene2  6.25

3.画箱线图

library(ggplot2)
p1 = ggplot(pdat, aes(y=value, x=gene))+
  geom_boxplot(aes(fill=group),outlier.shape = NA)+
  theme_bw()+
  scale_fill_manual(values = c("#2fa1dd", "#f87669", "#e6b707"))
p1

[图片上传失败...(image-382a55-1692258856792)]

p2 = ggplot(pdat, aes(y=value, x=gene))+
  geom_bar(aes(fill=group),position = position_dodge(0.9),stat = "summary")+
  theme_bw()+
  scale_fill_manual(values = c("#2fa1dd", "#f87669", "#e6b707"))+
  stat_summary(aes(group = group), fun.data = 'mean_se', 
               geom = "errorbar", colour = "black",
               width = 0.2,position = position_dodge(0.9))

p2

[图片上传失败...(image-297a28-1692258856792)]

4.加显著性标记

4.1习以为常版

library(ggpubr)
p1 + 
  stat_compare_means(aes(group = group, label = after_stat(p.signif)),method = "wilcox.test")

[图片上传失败...(image-ee95bd-1692258856792)]

p2 + stat_compare_means(aes(group = group, label = after_stat(p.signif)),method = "wilcox.test",label.y = 10.5)

[图片上传失败...(image-2a7112-1692258856792)]

这个超级简单,但显著性统一在头顶上,然后也不支持每个基因在两两分组中的显著性单独计算。

4.2 错落有致版

用rstatix里的函数计算出显著性和添加显著性的横纵坐标位置,再用stat_pvalue_manual添加上去。

library(rstatix)
stat.test <- pdat %>% 
  group_by(gene) %>% 
  wilcox_test(value ~ group) %>%
  adjust_pvalue() %>% 
  add_significance("p.adj") %>% 
  add_xy_position(x="gene")
p1 + stat_pvalue_manual(stat.test,label = "p.adj.signif",hide.ns = F,
                   tip.length = 0.01)

[图片上传失败...(image-241141-1692258856792)]

p2 + stat_pvalue_manual(stat.test,label = "p.adj.signif",hide.ns = F,
                   tip.length = 0.01)

[图片上传失败...(image-16df19-1692258856792)]

4.3 手动添加版

例如上次画的AUC值柱状图,它的纵坐标和误差棒不是画图时计算出来的,而是拿了现成的数值来画,就无法用上面的方法计算。如果能自行用其他方法计算出组间比较的显著性如何,可以手动添加。

rm(list = ls())
load("dats.Rdata")
p = ggplot(dats, aes(x = category, y = y, fill = x)) +
  geom_bar(stat = "identity", position = "dodge") +
  geom_text(aes(label = round(y,2)), vjust = 4, size = 3,
            position = position_dodge(width = 0.9)) +
  geom_errorbar(aes(ymin = min, ymax = max), 
                width = 0.2,
                position = position_dodge(width = 0.9)) +
  scale_fill_manual(values = c("#2fa1dd", "#f87669", "#e6b707"))+
  theme_bw()
p

[图片上传失败...(image-c65f9d-1692258856792)]

p +   geom_signif(data = dats,y_position=c(1,0.97,0.83,0.89,0.89,0.92), 
              xmin=c(0.7,1,1.7,2,2.7,3), 
              xmax=c(1,1.3,2,2.3,3,3.3), 
              annotation=c("*","**","***","ns","*","**"), 
              tip_length=0.01, 
              vjust = 0.3)

[图片上传失败...(image-75aa38-1692258856791)]

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,978评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,954评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,623评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,324评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,390评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,741评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,892评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,655评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,104评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,451评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,569评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,254评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,834评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,725评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,950评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,260评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,446评论 2 348

推荐阅读更多精彩内容