微生物多样性qiime2分析流程(10) 数据可视化分析(中) 之绘制物种组成图

前面一系列可视化教程,都是通过将数据整合成phyloseq对象再运用MicrobiotaProcess包已经封装好的函数进行可视化操作,虽然简洁好用,但是灵活性不足,现在让我们根据已有数据来一套组合拳

1.Hcluster_bar

phylum.xls,otu_table.xls文件可根据之前介绍步骤导出
1.1 自定义颜色
rm(list = ls())
pacman::p_load(tidyverse,reshape,ggtree,aplot,RColorBrewer)   
colors <-c("#E41A1C","#1E90FF","#FF8C00","#4DAF4A","#984EA3",
           "#40E0D0","#FFC0CB","#00BFFF","#FFDEAD","#90EE90",
           "#EE82EE","#00FFFF","#F0A3FF", "#0075DC","#993F00",
           "#4C005C","#2BCE48","#FFCC99","#808080","#94FFB5",
           "#8F7C00","#9DCC00","#C20088","#003380","#FFA405",
           "#FFA8BB","#426600","#FF0010","#5EF1F2","#00998F",
           "#740AFF","#990000","#FFFF00")
1.2 读入数据绘制行聚类树
p <- read.delim("otu_table.xls",header = T,
                sep="\t",check.names = F,row.names = 1) %>% t()

tree <- hclust(dist(p)) %>% 
  ggtree(layout="rectangular", branch.length="none")
1.3 绘制水平柱状图
bar <- read.delim("phylum.xls",header = T,
                  sep="\t",check.names = F) %>% 
  melt() %>% ggplot(aes(variable ,value,fill=OTU))+
  geom_bar(stat="identity")+labs(x="",y="")+
  theme_bw()+
  theme(axis.title.x=element_blank(),
        axis.text.x=element_blank(),
        axis.ticks.x=element_blank())+
  scale_fill_manual(values = colors)+labs(fill="taxon")+
  scale_y_continuous(expand=c(0,0))+coord_flip()
1.4 aplot包将聚类树与柱状图拼接
bar%>%insert_left(tree,width=.3)
treebar_phylum.jpeg

适合大数据的聚类圈图

rm(list = ls())
pacman::p_load(tidyverse,reshape,ggtree,ggtreeExtra,ggnewscale)   
col <- c(34, 51, 142, 26, 31, 371, 
           36, 7, 12, 30, 84, 88, 116, 
           121, 77, 56, 386, 373, 423, 
           435, 438, 471, 512, 130, 52, 
           47, 6, 11, 43, 54, 367, 382, 
           422, 4, 8, 375, 124, 448, 419, 
           614, 401, 403, 613, 583, 652, 
           628, 633, 496, 638, 655, 132, 503, 24)
mycolors <- c(col,colors()[rep(col,5)])
p <- read.tree("otu_hc.tre") %>%
  ggtree(branch.length = "none", layout = "fan", size = 0.3)
dat <- read.delim("phylum.xls") %>% melt()
p2 <- p +
  new_scale_fill() +
  geom_fruit(data = dat,
             mapping = aes(x = value, fill = OTU.ID, y = variable),
             geom = geom_bar,orientation = "y",stat = "identity") +
  geom_tiplab(offset = 7, size = 1)+
  scale_fill_manual(values = mycolors)
p2
Hcluster_bar.jpg

2. 物种组成柱状图

绘制之前需要先对属水平数据进行过滤,可根据https://www.jianshu.com/p/e1dde3571d16中的代码对数据进行过滤

2.1 数据过滤
rm(list=ls())
colors <-c("#E41A1C","#1E90FF","#FF8C00","#4DAF4A","#984EA3",
           "#40E0D0","#FFC0CB","#00BFFF","#FFDEAD","#90EE90",
           "#EE82EE","#00FFFF","#F0A3FF", "#0075DC", 
           "#993F00","#4C005C","#2BCE48","#FFCC99",
           "#808080","#94FFB5","#8F7C00","#9DCC00",
           "#C20088","#003380","#FFA405","#FFA8BB",
           "#426600","#FF0010","#5EF1F2","#00998F",
           "#740AFF","#990000","#FFFF00")

pacman::p_load(tidyverse,magrittr,reshape,RColorBrewer,ggtree)
computed_persent <- function(path) {
  data <- path %>%
    read.delim(check.names = FALSE, row.names = 1)
  data2 <- data %>%
    mutate(sum = rowSums(.), persent = sum / sum(sum) * 100, sum = NULL,) %>%
    rbind(filter(., persent < 1) %>% colSums()) %>%
    mutate(OTU= c(data %>% rownames(),"others"))
  filter(data2[1:(nrow(data2) - 1),], persent > 1) %>%
    rbind(data2[nrow(data2),]) %>%
    select(ncol(.), 1:(ncol(.) - 2)) %>%
    set_rownames(seq_len(nrow(.))) %>%
    return()
}
path <- "genus.xls"
2.2 整合分组文件
a1 <- computed_persent(path) %>% melt()
a2 <- "group.txt" %>% read.delim()
a4 <- NULL

for (i in seq_len(nrow(a1))) { 
  a4[i] <- a2[which(a2[, 1] == a1[i, 2]), 2] }

a1[, 4] <- a4
a1
2.3 ggplot2可视化
ggplot(a1,aes(variable,value,fill=OTU))+
  geom_bar(stat="identity",position = "fill")+
  facet_grid(. ~ V4,scales = "free",space="free_x")+
  labs(x="",y="Proportions")+
  scale_fill_manual(values = colors)+labs(fill="")+
  theme(legend.title=element_blank())+
  scale_y_continuous(expand=c(0,0))+theme_bw()
bar.jpeg

感谢身边的大佬朋友提供代码,没有他的支援某些步骤没法这么顺利进行

未完待续......

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