Tax4Fun2分析:基于16S数据预测微生物群落的功能(R语言一句代码搞定)
创作时间:
作者:
@小白创作中心
Tax4Fun2分析:基于16S数据预测微生物群落的功能(R语言一句代码搞定)
引用
CSDN
1.
https://blog.csdn.net/a852232394/article/details/139298633
上期我们介绍了原核生物分类单元功能注释的R语言操作方法:FAPROTAX:微生物群落功能注释分析及可视化(附R语言代码)。
本期我们介绍Tax4Fun2 :基于16S rRNA基因序列的功能预测工具,可以用于预测特定生境中的功能概况和功能冗余。
Tax4Fun2的工作流程如下:首先,16S rRNA基因序列将与Tax4Fun2提供的参考序列进行比对,以找到最近的近缘序列。如果用户提供了自定义数据,还将额外将16S rRNA基因序列与用户添加的序列进行比对。如果两次搜索结果都有显著的匹配,将优先选择用户数据中的最近近缘序列。然后,根据最近近缘序列的搜索结果,对每个样本的OTU(操作分类单元)丰度进行总结。
生成包含16S rRNA搜索中确定的那些参考序列的功能概况的关联矩阵(AM)。将总结的OTU丰度和存储在AM中的功能概况合并,为每个样本预测一个宏基因组。生成的FTU(功能丰度单元)和FSU(功能丰度样本)值将作为日志文件提供。
接下来我们来进行分析和可视化展示:
Step1:数据准备
rm(list=ls())
pacman::p_load(tidyverse,microeco,aplot,ggsci,seqinr)
rep_fasta <- read.fasta('rep.fna')
otu <- read.csv("otu_table.csv", row.names = 1)
otu_table_16S <-
otu %>%
filter(rownames(.) %in% names(rep_fasta)) %>%
select(1:10)
dataset <- microtable$new(otu_table = otu_table_16S,
rep_fasta = rep_fasta)
t1 <- trans_func$new(dataset)
t1
使用Tax4Fun2分析前需要提前下载blast工具和Ref99NR或Ref100NR数据集:
- blast下载路径:https://ftp.ncbi.nlm.nih.gov/blast/executables/blast+/
- Ref99NR下载路径:https://cloudstor.aarnet.edu.au/plus/s/DkoZIyZpMNbrzSw/download
- Ref100NR下载路径:https://cloudstor.aarnet.edu.au/plus/s/jIByczak9ZAFUB4/download
注意:
- 推荐使用2.5.0版本的blast,高版本的blast可能会报错
- 将Ref99NR或Ref100NR文件解压后放到Tax4Fun2_ReferenceData_v2目录中
Step2:执行Tax4Fun2分析
t1$cal_tax4fun2(blast_tool_path = "ncbi-blast-2.5.0+/bin",
path_to_reference_data = "Tax4Fun2_ReferenceData_v2",
database_mode = "Ref99NR",
path_to_temp_folder = "results")
t1$res_tax4fun2_pathway
Step3:整理分析结果
data(Tax4Fun2_KEGG)
func2 <- microtable$new(otu_table = t1$res_tax4fun2_pathway,
tax_table = Tax4Fun2_KEGG$ptw_desc)
func2$tidy_dataset()
func2$cal_abund()
func2$taxa_abund$Level.1
func2$taxa_abund$Level.2
func2$taxa_abund$Level.3
Step4:计算功能冗余性
t1$cal_tax4fun2_FRI()
t1$res_tax4fun2_aFRI
t1$res_tax4fun2_rFRI
Step5:可视化小案例
df1 <-
func2$taxa_abund$Level.3 %>%
rownames_to_column('taxa_abund') %>%
mutate(KO1 = stringr::str_split(taxa_abund, pattern = "\\|", simplify = T)[,1],
KO2 = stringr::str_split(taxa_abund, pattern = "\\|", simplify = T)[,2],
KO3 = stringr::str_split(taxa_abund, pattern = "\\|", simplify = T)[,3]) %>%
select(-taxa_abund)
df2 <-
df1 %>%
column_to_rownames('KO3') %>%
select(-KO1, -KO2) %>%
rowSums() %>%
as.data.frame() %>%
top_n(20)
df1 %>%
filter(KO3 %in% rownames(df2)) %>%
reshape2::melt() %>%
mutate(KO3 = factor(KO3, levels = rownames(df2), ordered = T)) %>%
ggplot(aes(x = KO3, y = value, fill = variable)) +
geom_col(position = 'dodge', width = 0.8, size = 0.05) +
coord_flip() +
scale_fill_npg() +
facet_grid(KO1~., space = 'free', scale = 'free_y') +
theme(panel.grid = element_blank(), panel.background = element_rect(fill = 'transparent', color = 'black'),
legend.title = element_blank(), legend.position = 'right') +
scale_y_continuous(expand = c(0,0)) +
xlab('') +
ylab('')
ggsave('pic.png', height = 8, width = 8)
热门推荐
晶锐车排气管滴水怎么回事,汽车排气管大量出水是不是故障?
上海半导体产业分布一览!撑起了中国芯片的半边天
大庆油田加速构建绿色低碳发展新格局
硬件与软件:如何实现最佳协同工作?
如何利用I3C提升嵌入式系统性能
粉底液的正确用法4大技巧打造轻薄无痕底妆
财政赤字为什么说会增加推动黄金上涨的原因?!
职场隐藏的劳动!带你看懂精力被耗尽的原因
女人刘海遮住额头好吗 额头对于面相的影响
清朝格格的丈夫称谓解析
深圳5条地铁线路将通车,你pick哪一条?
UFS 3.0闪存测试曝光:速度竟是UFS 2.1的3倍
港珠澳入境免税新政策启动,旅客购物福利升级
如何全面挑选适合的篮球鞋:性能与外观解析
公司没有年假可以举报吗?服务行业年假政策解析
如何更换内存条?(教你轻松升级电脑内存)
事业单位备考:如何建立体系化的知识框架?
古代官员的各种罪名及其处罚方式
如何树立正确的思维方式
警察与群众冲突事件案例解析:如何预防和化解警民矛盾
畅游云南:荆州出发全攻略
违反交通法规的后果和影响是什么
容桂一日游景点全攻略
大连商品期货的交易规则有哪些?这些交易规则对投资者有何影响?
无人机锂离子电池使用和保养方法有什么?
数据库如何通过接口实现
世界上最恐怖的鬼屋 葛底斯堡的历史
关于IC电源输入滤波电容的处理
同步整流变换电路中输入/输出电容器的选择方法 (上)
电压力锅和燃气压力锅哪个好?为何电压力锅不建议买?不懂先看看