R 和 Origin 完成细菌 OTU 表、土壤理化性质数据的微生物 Beta 多样性分析

使用 R 进行分析与可视化

1. 数据准备

假设已经有细菌 OTU 表(以表格形式存储,行是样本,列是 OTU)和土壤理化性质表(行是样本,列是不同的理化性质指标)。

r 复制代码
# 读取数据
otu_table <- read.csv("otu_table.csv", row.names = 1)
soil_properties <- read.csv("soil_properties.csv", row.names = 1)

# 确保样本顺序一致
otu_table <- otu_table[rownames(soil_properties), ]
2. 微生物 Beta 多样性分析

使用 vegan 包进行 Beta 多样性分析。

r 复制代码
library(vegan)

# 计算 Bray-Curtis 距离矩阵
bray_curtis_dist <- vegdist(otu_table, method = "bray")

# 进行主坐标分析(PCoA)
pcoa <- cmdscale(bray_curtis_dist, k = 2, eig = TRUE)

# 提取 PCoA 结果
pcoa_scores <- pcoa$points
pcoa_eig <- pcoa$eig
3. 土壤化学性质和细菌群落相关性分析

使用 Mantel 检验分析土壤理化性质与细菌群落结构的相关性。

r 复制代码
# 计算土壤理化性质的距离矩阵
soil_prop_dist <- vegdist(soil_properties, method = "euclidean")

# Mantel 检验
mantel_result <- mantel(bray_curtis_dist, soil_prop_dist, method = "pearson")
print(mantel_result)
4. 数据结果可视化

绘制 PCoA 图展示 Beta 多样性,并可视化相关性结果。

r 复制代码
library(ggplot2)

# 绘制 PCoA 图
pcoa_df <- data.frame(Sample = rownames(pcoa_scores),
                      PC1 = pcoa_scores[, 1],
                      PC2 = pcoa_scores[, 2])

pcoa_plot <- ggplot(pcoa_df, aes(x = PC1, y = PC2)) +
  geom_point() +
  labs(x = paste0("PC1 (", round(pcoa_eig[1] / sum(pcoa_eig) * 100, 2), "%)"),
       y = paste0("PC2 (", round(pcoa_eig[2] / sum(pcoa_eig) * 100, 2), "%)"),
       title = "PCoA of Bacterial Community")
print(pcoa_plot)

# 可视化 Mantel 检验结果
mantel_plot <- ggplot(data.frame(x = 0, y = 0), aes(x, y)) +
  geom_text(aes(label = paste0("Mantel r = ", round(mantel_result$statistic, 3),
                               "\n p = ", round(mantel_result$signif, 3))),
            size = 6) +
  theme_void()
print(mantel_plot)

使用 Origin 进行分析与可视化

1. 数据导入

将细菌 OTU 表和土壤理化性质表导入 Origin。在 Origin 中,选择 "File" -> "Import",然后选择相应的 CSV 文件。

2. 微生物 Beta 多样性分析
  • 计算距离矩阵:在 Origin 中,可以通过编写脚本或使用插件来计算 Bray-Curtis 距离矩阵。例如,使用 "Matrix" 菜单中的 "Distance Matrix" 功能,选择 "Bray-Curtis" 方法计算 OTU 表的距离矩阵。
  • 主坐标分析(PCoA):计算完距离矩阵后,使用 Origin 的 "Analysis" -> "Multivariate Analysis" -> "Principal Coordinates Analysis (PCoA)" 进行 PCoA 分析。
3. 土壤化学性质和细菌群落相关性分析
  • 计算距离矩阵:对土壤理化性质表使用 "Matrix" 菜单中的 "Distance Matrix" 功能,选择 "Euclidean" 方法计算距离矩阵。
  • Mantel 检验:Origin 本身没有直接的 Mantel 检验功能,但可以通过编写外部脚本(如 R 脚本)计算结果后导入到 Origin 中。
4. 数据结果可视化
  • PCoA 图绘制:在 Origin 中,将 PCoA 分析得到的 PC1 和 PC2 数据选中,然后选择 "Plot" -> "Scatter" 绘制散点图。可以进一步调整图形的颜色、标签、坐标轴标题等,使其更加美观。
  • 相关性结果可视化:将 Mantel 检验结果手动输入到 Origin 表格中,然后使用文本工具在图形中添加结果标签,以展示相关性统计量和显著性。

通过以上步骤,无论是在 R 还是 Origin 中,都可以完成细菌 OTU 表、土壤理化性质数据的微生物 Beta 多样性分析、相关性分析以及结果可视化。

相关推荐
艾莉丝努力练剑4 分钟前
【C/C++】类和对象(上):(一)类和结构体,命名规范——两大规范,新的作用域——类域
java·c语言·开发语言·c++·学习·算法
TDengine (老段)34 分钟前
TDengine 中 TDgp 中添加机器学习模型
大数据·数据库·算法·机器学习·数据分析·时序数据库·tdengine
CodeShare44 分钟前
某中心将举办机器学习峰会
人工智能·机器学习·数据科学
天天找自己1 小时前
精通分类:解析Scikit-learn中的KNN、朴素贝叶斯与决策树(含随机森林)
python·决策树·机器学习·分类·scikit-learn
Tisfy2 小时前
LeetCode 2411.按位或最大的最小子数组长度:一次倒序遍历
数据结构·算法·leetcode·题解·位运算·遍历
weixin_464078072 小时前
机器学习sklearn:处理缺失值
人工智能·机器学习·sklearn
2202_756749692 小时前
04 基于sklearn的机械学习-梯度下降(上)
人工智能·算法·机器学习
草莓爱芒果2 小时前
Spring Boot中使用Bouncy Castle实现SM2国密算法(与前端JS加密交互)
java·spring boot·算法
晚云与城2 小时前
【数据结构】-----排序的艺术画卷
数据结构·算法·排序算法