基因功能富集调控网络分析--FGNet

FGNet介绍

  FGNet(Functional Gene Networks derived from biological enrichment analyses)允许在基因或表达集列表上执行功能富集分析(FEA),并将结果转换为网络。由此产生的功能网络提供了基因/术语的生物学功能的概述,并且允许容易地看到基因之间的链接,簇之间的重叠,发现关键基因等。

Examples of functional network for different analyses

  其实主要是通过输入基因list,然后使用别的工具进行注释富集分析(比如:DAVID、GeneTerm Linker、TopGO、GAGE ),然后对某个或者几个功能进行富集分析。最后进行网络可视化、寻找核心基因。

FGNet安装

  通过bioconductor安装,并且由于需要其他第三方包进行注释富集分析,建议也安装其他必须的软件包。

if (!requireNamespace("BiocManager", quietly=TRUE))
    install.packages("BiocManager")
BiocManager::install("FGNet")
BiocManager::install(c("RGtk2", "RCurl","RDAVIDWebService", "gage", "topGO",  "GO.db", "KEGG.db", "reactome.db", "org.Sc.sgd.db"))

测试

  注释富集一共有四个工具可以进行,但是由于集群的问题,只能有三个工具能够用,分别为:DAVID、TopGO、GAGE,并在这里展示着三个工具初步结果。

基因集准备

#Here is an example analyzing a gene list with the different tools:
genesYeast <- c("ADA2", "APC1", "APC11", "APC2", "APC4", "APC5", "APC9", "CDC16", 
                "CDC23", "CDC26", "CDC27", "CFT1", "CFT2", "DCP1", "DOC1", "FIP1", 
                "GCN5", "GLC7", "HFI1", "KEM1", "LSM1", "LSM2", "LSM3", "LSM4", 
                "LSM5", "LSM6", "LSM7", "LSM8", "MPE1", "NGG1", "PAP1", "PAT1", 
                "PFS2", "PTA1", "PTI1", "REF2", "RNA14", "RPN1", "RPN10", "RPN11", 
                "RPN13", "RPN2", "RPN3", "RPN5", "RPN6", "RPN8", "RPT1", "RPT3", 
                "RPT6", "SGF11", "SGF29", "SGF73", "SPT20", "SPT3", "SPT7", "SPT8", 
                "TRA1", "YSH1", "YTH1")
library(org.Sc.sgd.db)
geneLabels <- unlist(as.list(org.Sc.sgdGENENAME))
genesYeast <- sort(geneLabels[which(geneLabels %in% genesYeast)])

# Optional: Gene expression (1=UP, -1=DW)
genesYeastExpr <- setNames(c(rep(1,28), rep(-1,30)),genesYeast) 

注释富集分析

#######DAVID
feaResults_David <- fea_david(names(genesYeast), geneLabels=genesYeast)#email="example@email.com"
#######TopGO
feaResults_topGO <- fea_topGO(genesYeast, geneIdType="GENENAME", organism="Sc") 
#######Gene-Term Linker  报错
# jobID <- fea_gtLinker(geneList=genesYeast, organism="Sc")
# ?fea_gtLinker
# jobID <- 3907019
# feaResults_gtLinker <- fea_gtLinker_getResults(jobID=jobID, organism="Sc")
######GAGE
library(gage)
data(gse16873)
# Set gene labels? (they need to have unique identifiers)
library(org.Hs.eg.db)
geneSymbols <- select(org.Hs.eg.db,columns="SYMBOL",keytype="ENTREZID",keys=rownames(gse16873))
geneLabels <- geneSymbols$SYMBOL
names(geneLabels) <- geneSymbols$ENTREZID
head(geneLabels)
#GAGE:
feaResults_gage <- fea_gage(eset=gse16873,refSamples=grep('HN',colnames(gse16873)),compSamples=grep('DCIS',colnames(gse16873)),geneLabels=geneLabels, annotations="REACTOME",geneIdType="ENTREZID", organism="Hs")
###生成结题报告
FGNet_report(feaResults_David, geneExpr=genesYeastExpr)
FGNet_report(feaResults_topGO, geneExpr=genesYeastExpr)  
#FGNet_report(feaResults_gtLinker, geneExpr=genesYeastExpr)
FGNet_report(feaResults_gage)

测试结果

  Functional enrichment with DAVID:

DAVID结果概览

Distances between Clusters

  Functional enrichment with topGO:

topGO结果概览

  Functional enrichment with gage:

gage结果概览

  上述三种结果的内容几乎一样,虽然输入基因list一样,但是他们富集聚类结果不一样,主要是三种富集的方式方法不一致造成的。

其他结果筛选

  上文介绍了普通的功能忘了富集网络分析结果,但是我们对得到初步结果往往不能直接用于后续分析,因此我们需要对结果进行筛选,这里将介绍接种筛选的方式,其他的筛选方式见官方说明文档

  Genes - Terms networks筛选命令如下:

##Genes - Terms networks
gtSets <- feaResults_David$geneTermSets
gtSets <- gtSets[gtSets$Cluster %in% c(9),] 
gtSets <- gtSets[gtSets$Pop.Hits<500,]
termsGenes <- t(fea2incidMat(gtSets, clusterColumn="Terms")$clustersMatrix)
library(R.utils)
rownames(termsGenes) <- sapply(strsplit(rownames(termsGenes), ":"),function(x) capitalize(x[length(x)]))
termsGenes[1:5,1:5]
pdf('Genes_Terms_networks.pdf',w=12,h=8)
functionalNetwork(t(termsGenes), plotType="bipartite", keepAllNodes=TRUE,legendPrefix="", plotTitle="Genes - Terms network", plotTitleSub="",geneExpr=genesYeastExpr, plotExpression="Fill")
functionalNetwork(termsGenes, plotType="bipartite", keepAllNodes=TRUE,legendPrefix="", plotTitle="Genes - Terms network", plotTitleSub="")
dev.off()

Genes - Terms networks

  上述图中方块代表关键的基因,圆圈代表GO Term
.

  Selecting specific clusters筛选命令如下:

##Selecting specific clusters
incidMat <- fea2incidMat(feaResults_David)
distMat <- clustersDistance(incidMat)
selectedClusters <- rep(FALSE, nrow(feaResults_David$clusters))
selectedClusters[c(8,9,11)] <- TRUE
tmpFea <- feaResults_David
tmpFea$clusters <- cbind(tmpFea$clusters, select=selectedClusters)
incidMatSelection <- fea2incidMat(tmpFea, filterAttribute="select", filterOperator="!=",filterThreshold="TRUE")
pdf('Selecting_specific_clusters.pdf',w=12,h=8)
functionalNetwork(incidMatSelection, eColor=NA)
dev.off()

Selecting specific clusters

  上述图中不同颜色代表不同的聚类,这里我们只选择了8,9,11三个聚类,因此图只展示了这三个聚类,通过此方法,可以只展示任何感兴趣的聚类。

此文仅仅记录了FGNet简单的使用,如果对计算分析原理感兴趣的话,可以看看官方说明文档。官方说明文档

2019年7月7日

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352