GOplot|宝藏R包,拯救你的GO富集结果,杜绝平庸的条形图

本文涉及的产品
函数计算FC,每月15万CU 3个月
简介: `GOplot`是一款R包,专注于GO富集分析的可视化,提供多种图表类型如GOBar、GOBubble、GOCircle、GOChord和GOVenn等。这些函数允许用户轻松修改参数,定制颜色、大小和排序,实现数据的直观展示。示例代码展示了如何使用这些功能创建不同类型的图形,并提到了一个配套的shiny应用。`GOplot`简化了复杂的数据可视化过程,适合快速高效地展示差异分析结果。

前言

今天给大家分享一个宝藏R包:GOplot

包如其名,专作GO富集分析的可视化工具包。函数网上教程不少,但这里笔者已经列出了所有可修改的常用参数,改色改大小排序自定义,整整齐齐。

百行不到的代码,直接上升一个level:

数据准备

下载包,加载数据,这里要留意数据的格式,这是把差异分析的结果也纳入了的

# install.packages('GOplot')
library("GOplot")
data(EC)
head(EC$david)
head(EC$genelist)
circ <- circle_dat(EC$david, EC$genelist)

GOBar

若把order.by.zscore修改为T则改为取绝对值进行排序

GOBar(circ, 
      # category == 'BP',
      display = 'multiple', # single
      order.by.zscore = F, #order
      title = 'Z-score coloured barplot',
      zsc.col = c('yellow', 'black', 'cyan'))

image.png

GOBubble

进行了一步过滤,以减少重叠。若不过滤可直接将数据改为circ

# 筛选重叠
reduced_circ <- reduce_overlap(circ, overlap = 0.75)
GOBubble(reduced_circ, # circ
         title = 'Bubble plot', 
         colour = c("#4DBBD5FF","#EFD500FF","#F39B7FFF"), 
         table.legend = T,
         bg.col = T,
         ID = T, # GO id
         display = 'multiple', 
         labels = 3)

image.png

GOCircle

IDs <- c('GO:0007507', 'GO:0001568', 'GO:0001944', 'GO:0048729', 'GO:0048514', 'GO:0005886', 'GO:0008092', 'GO:0008047')
GOCircle(circ, nsub = IDs,
         rad1 = 2, 
         rad2 = 3,
         table.legend = T,
         zsc.col = c('darkgoldenrod1', 'black', 'cyan1'),
         lfc.col = c("#F39B7FFF","#4DBBD5FF"),
         label.size = 5,
         label.fontface = "bold")

GOChord

这里需要把数据转换成长格式

chord <- chord_dat(data = circ, genes = EC$genes, process = EC$process)
GOChord(chord,
        title = "GOChord Plot",
        space = 0.02, 
        gene.order = 'logFC', 
        gene.space = 0.25, 
        gene.size = 3,
        nlfc = 1,
        lfc.col = c('darkgoldenrod1', 'black', 'cyan1'),
        lfc.min = -4,
        lfc.max = 4,
        border.size = 0.5,
        process.label = 8)

GOHeat

GOHeat(chord[,-8], # 剔除FC列
       nlfc = 0)
GOHeat(chord, 
       nlfc = 1, # 倒数第一列
       fill.col = c("#4DBBD5FF","#EFD500FF","#F39B7FFF"))

第一个是剔除FC列,默认统计富集的功能数量

第二个是保留FC列,指定参照倒数第一列差异倍数

GOCluster

这里是按FC聚类,可以将clust.by指定成按term聚类

GOCluster(circ, 
          EC$process, 
          metric = "euclidean", # 欧式距离
          clust.by = 'logFC', # 'term'
          nlfc = F, # T为多列FC,F则为一列FC
          lfc.col = c('darkgoldenrod1', 'black', 'cyan1'),
          lfc.min = -3,
          lfc.max = 3,
          lfc.space = 0,
          lfc.width = 0.5,
          term.col = ggsci::pal_frontiers(alpha = 0.7)(7), # max = 20
          term.space = 0.5,
          term.width = 2)

image.png

GOVenn

红色为上调基因个数,紫色为下调基因个数,灰色则为交集后上下调冲突的基因个数

l1 <- subset(circ, term == 'heart development', c(genes,logFC))
l2 <- subset(circ, term == 'plasma membrane', c(genes,logFC))
l3 <- subset(circ, term == 'tissue morphogenesis', c(genes,logFC))
GOVenn(l1,l2,l3, 
       label = c('heart development', 'plasma membrane', 'tissue morphogenesis'),
       lfc.col = c("#EE0000FF","#808180FF","#5F559BFF"),
       circle.col = c("#EFD500FF","#4DBBD5FF","#F39B7FFF"),
       plot = T)

image.png

shiny

这里作者还做了个venn的shiny交互网站,有兴趣的小伙伴可以试一试:https://wwalter.shinyapps.io/Venn/ image.png

小总结

告别ggplot2手画,GO富集的红蓝气泡图、柱状图已经审美疲劳了。这个GOplot应该是懒癌晚期拯救者了,都是打包好的函数直接换数据运行即可,记得文献引用上:Walter, Wencke, Fátima Sánchez-Cabo, and Mercedes Ricote. "GOplot: an R package for visually combining expression data with functional analysis." Bioinformatics (2015): btv300.

相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
目录
相关文章
|
1月前
|
存储 Go
Golang语言基于go module方式管理包(package)
这篇文章详细介绍了Golang语言中基于go module方式管理包(package)的方法,包括Go Modules的发展历史、go module的介绍、常用命令和操作步骤,并通过代码示例展示了如何初始化项目、引入第三方包、组织代码结构以及运行测试。
33 3
|
2月前
|
编译器 数据库连接 Go
Go Sync 包:并发的 6 个关键概念
Go Sync 包:并发的 6 个关键概念
|
2月前
|
Go 开发者
|
2月前
|
编译器 Go 开发者
|
2月前
|
缓存 Go
Go引用包版本更新但是被引用的包的子包并没有出现在vendor中的问题和解决方案
文章讨论了在Go模块项目中升级依赖包版本时遇到的子包未出现在vendor目录的问题,并提供了直接删除旧版本引用并重新执行`go mod vendor`的解决方案。
23 0
|
2月前
|
存储 SQL Go
一文弄懂Go语言的Context包,值得收藏!
在开发高效的Go应用程序时,处理超时、取消操作和传递请求范围的数据至关重要。Go标准库中的`context`包提供了一套强大的工具,用于在不同层级间传递取消信号、超时和截止时间等信息。本文首先概述了`context`包的核心功能,接着详细介绍了关键方法,如`WithCancel`、`WithDeadline`、`WithTimeout`和`WithValue`的使用场景。通过创建和派生上下文,开发者能更好地管理请求的生命周期,控制长时间运行的操作,并在并发环境中传递必要的数据。
38 1
|
3月前
|
存储 Go
go语言中fmt格式化包和内置函数汇总
【7月更文挑战第10天】本文介绍fmt包和`Errorf`用于创建格式化的错误消息。`fmt`包还涉及一些接口,如`Formatter`、`GoStringer`、`ScanState`、`Scanner`和`Stringer`,支持自定义格式化和输入/输出处理。
48 1
|
5月前
|
编译器 Go
Go 语言基础:包、函数、语句和注释解析
一个 Go 文件包含以下几个部分: 包声明 导入包 函数 语句和表达式 看下面的代码,更好地理解它:
61 0
|
10月前
|
Go
go 包变量函数
go 包变量函数
37 0
|
Java Go Python
Go基础(包、变量和函数):开启Go语言之旅
开启Go语言之旅 Go编程语言是一个开源项目,可以让程序员提高工作效率。 Go是富有表现力,简洁,干净和高效的。其并发机制使编写充分利用多核和联网机器的程序变得容易,而其新颖类型系统则可实现灵活的模块化程序构建。
1417 0
下一篇
无影云桌面