审稿人:火山图是不是没人用了?

文摘   2024-10-23 09:00   爱尔兰  

火山图(Volcano Plot)是一种广泛用于基因表达和差异分析的可视化工具,特别是在生物信息学中。火山图能够帮助我们直观地展示统计显著性(p值)和倍数变化(Fold Change)之间的关系,从而轻松识别出显著差异的基因或数据点。本文将通过R语言从基础到进阶地演示如何绘制火山图,并逐步实现个性化设置,包括颜色、点的大小、显著基因标注、标题、图例等元素。

火山图的定义与应用场景

火山图是一种散点图的变体,通常用于可视化基因表达或其他数据分析中的显著性和效应大小的关系。在火山图中,横轴表示倍数变化(Fold Change),纵轴表示统计显著性(通常取负对数的p值)。通过这种形式,可以快速识别出既具有显著性又具有较大效应的基因或数据点。

火山图的典型应用场景包括差异基因表达分析、生物标志物发现等。例如,在基因组学研究中,火山图可以帮助研究者识别在不同实验条件下表达显著变化的基因;在蛋白质组学或代谢组学中,也可以用火山图分析代谢物或蛋白质的显著差异。这种图表能够让研究人员高效地发现最具研究意义的数据点。

分步教程:如何创建个性化火山图

接下来,我们将通过R语言的 ggplot2 和 EnhancedVolcano 等包,逐步展示如何从一个简单的火山图开始,逐步实现颜色、标注、分组和个性化设置。


步骤 1:安装必要的R包

在绘制火山图之前,确保已经安装了 ggplot2 和 EnhancedVolcano 等R包。如果尚未安装,可以使用以下代码进行安装:

# 安装ggplot2包
install.packages("ggplot2")

# 安装EnhancedVolcano包
if (!requireNamespace("BiocManager", quietly = TRUE))
install.packages("BiocManager")
BiocManager::install("EnhancedVolcano")


步骤 2:准备示例数据

我们将使用一个模拟的差异表达数据集,其中包括基因的倍数变化(log2FoldChange)和p值(pvalue)。通常,这些数据来自差异分析,例如DESeq2分析的输出结果。

# 创建示例数据集
set.seed(123)
data <- data.frame(
gene = paste("Gene", 1:1000, sep = ""),
log2FoldChange = rnorm(1000, 0, 2), # 模拟log2FoldChange数据
pvalue = runif(1000, 0, 1) # 模拟p值
)


步骤 3:使用基础 ggplot2 绘制火山图

我们可以用 ggplot2 包快速绘制出一个基础火山图,将倍数变化和p值进行可视化。

# 加载ggplot2
library(ggplot2)

# 绘制基础火山图
ggplot(data, aes(x = log2FoldChange, y = -log10(pvalue))) +
geom_point() +
labs(title = "基础火山图",
x = "log2 倍数变化",
y = "-log10(p 值)")

在这个基础图中,横轴为 log2FoldChange,纵轴为 -log10(p值),通过散点展示了每个基因的显著性和效应大小。


步骤 4:根据显著性设置颜色和分组

为了更清晰地展示显著差异的基因,我们可以通过自定义颜色来区分显著性较高的基因。通常设定一个p值和倍数变化的阈值来标记显著性基因。

# 添加显著性阈值
data$significance <- ifelse(data$pvalue < 0.05 & abs(data$log2FoldChange) > 1, "Significant", "Not Significant")

# 绘制带有颜色分组的火山图
ggplot(data, aes(x = log2FoldChange, y = -log10(pvalue), color = significance)) +
geom_point() +
scale_color_manual(values = c("Not Significant" = "gray", "Significant" = "red")) +
labs(title = "火山图(显著性基因标记)",
x = "log2 倍数变化",
y = "-log10(p 值)",
color = "显著性")

在这个图中,显著性基因(p值<0.05 且倍数变化绝对值>1)被标记为红色,而非显著性基因则显示为灰色。


步骤 5:使用 EnhancedVolcano 绘制更复杂的火山图

EnhancedVolcano 是一个专门用于绘制火山图的R包,提供了许多强大的定制功能。我们可以利用它来进一步美化火山图,并添加基因标注。

# 加载EnhancedVolcano包
library(EnhancedVolcano)

# 使用EnhancedVolcano绘制火山图
EnhancedVolcano(data,
lab = data$gene, # 基因标注
x = 'log2FoldChange', # 横轴为倍数变化
y = 'pvalue', # 纵轴为p值
xlab = 'log2 倍数变化',
ylab = '-log10(p 值)',
pCutoff = 0.05, # p值显著性阈值
FCcutoff = 1, # 倍数变化显著性阈值
pointSize = 2.0, # 设置点的大小
labSize = 4.0, # 标注字体大小
title = "Enhanced 火山图",
legendLabels = c('非显著', '显著'),
legendPosition = 'top', # 图例位置
col = c('gray', 'red')) # 设置颜色

在这个图中,EnhancedVolcano 自动根据p值和倍数变化的阈值对基因进行分组和颜色标记。我们还可以通过设置 lab 参数对显著基因进行标注,使得最具研究价值的基因一目了然。


步骤 6:进一步个性化火山图

如果希望进一步优化火山图的外观,比如调整点的大小、图例位置或主题,可以继续使用 theme() 函数来自定义图表。以下代码展示了如何添加自定义元素。

# 自定义图表主题和标题
EnhancedVolcano(data,
lab = data$gene,
x = 'log2FoldChange',
y = 'pvalue',
xlab = 'log2 倍数变化',
ylab = '-log10(p 值)',
pCutoff = 0.05,
FCcutoff = 1,
pointSize = 2.0,
labSize = 4.0,
title = "个性化火山图",
legendLabels = c('非显著', '显著'),
legendPosition = 'top',
col = c('gray', 'blue')) +
theme(plot.title = element_text(size = 18, face = "bold", hjust = 0.5),
legend.position = "bottom",
legend.title = element_text(size = 12),
legend.text = element_text(size = 10))

通过这种方式,我们能够灵活地调整火山图的每一个细节,使其符合具体的展示需求。


总结

通过本篇文章的分步教程,我们展示了如何从基础的火山图开始,逐步添加个性化的设置,包括显著性分组、颜色、基因标注、图例和标题等元素。无论是通过 ggplot2 还是专门的 EnhancedVolcano 包,都可以轻松绘制高质量的火山图,适用于基因表达差异分析和其他生物数据可视化需求。希望本文能帮助你掌握火山图的绘制方法,轻松在科研项目中应用这一强大的数据可视化工具。


(请点击标题查看)

科研代码 | 机器学习

ANOVA 描述性统计分析   主成分分析PCA 判别分析 PLSDA LDA KNN 

异常值 贝叶斯统计 调用数据集 模型评价之准确率 Scikit-learn 数据预处理 API 

无监督机器学习 SVM 监督式机器学习  特征选择 ANN SQL 数据转换  特征选择  冗余分析  数据导入   限制性立方样条时间序列分析 数据预处理  随机森林(RF)  

正态分布检测 傅里叶变换 重塑(Reshape)

科研代码 | 数据可视化

散点图  相关性热    柱状图    盒须图 小提琴图 R画地图 ggplot2 雷达 圆形柱状图 

文氏图 显著性差异 条形图 R配色 热图显著性标记 箱线图  XGBoost建模  3D散点图 

图片合并  桑葚图  坐标轴文字排序          

科研代码 | 生产力工具

Pycharm    Rstudio   Dataspell  VScode 四大数据分析软  Copilot R语言教材  基础统计学  R语言入门  SPSS Python编辑器全比较   大名鼎鼎的文献管理软件

科研代码 | 世间万物

Peer pressure  走出舒适区  小老板保命守则 缺的是数据科学家 卷王之王 开放获取   

创新性  不能“卷”的海外博士  英语不好 放弃统计显著性  

谁在用盗版软件 读博心态别崩

感谢关注!

科研代码
专注R和Python的数据分析。
 最新文章