问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

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数据集:

注意:

  1. 推荐使用2.5.0版本的blast,高版本的blast可能会报错
  2. 将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)  

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号