溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集

發(fā)布時(shí)間:2021-11-22 15:59:01 來(lái)源:億速云 閱讀:254 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集”吧!

 基本流程是
  • Hiast2 比對(duì)
  • samtools sam 轉(zhuǎn)bam
  • stringtie組裝轉(zhuǎn)錄本
  • gffcompare將stringtie輸出的gtf文件與參考基因組的注釋文件做比較得到一- 個(gè)merged.combine.gtf
  • 使用merged.combine.gtf 這個(gè)文件對(duì)每個(gè)樣本計(jì)算表達(dá)量,輸出文件存儲(chǔ)到ballgown文件夾下,這一步用到的命令是     stringtie -e -B -p 8 -G merged.combined.gtf -o ballgown/L01/L01.gtf output_bam/L01.sorted.bam
怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集  
image.png
  • 接下來(lái)是R語(yǔ)言的ballgown包讀入數(shù)據(jù)獲取基因和轉(zhuǎn)錄本的表達(dá)量 代碼是
library(ballgown)
library(genefilter)
library(dplyr)

pheno_data<-read.csv("pheno_data.txt",header=T)
grape_expr <- ballgown(dataDir = "ballgown",
                    samplePattern = "L0",
                    pData = pheno_data)
 
怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集  
image.png
怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集  
image.png

這一步可以拿到gene_id還有g(shù)ene_name ,FPKM的表達(dá)量,cov對(duì)用的應(yīng)該是reads count吧。

接下來(lái)是差異表達(dá)分析

代碼是

grape_expr_filter<-subset(grape_expr,
                          "rowVars(texpr(grape_expr))>1",
                          genomesubset=T)
results_genes <- stattest(grape_expr_filter,
                          feature = "gene",
                          covariate = "time_point",
                          getFC = TRUE,
                          meas = "FPKM")
#results_genes <- arrange(results_genes,pval)
results_genes%>%
  filter(abs(fc)>=2&pval<0.05) -> results_genes_diff

dim(results_genes_diff)
head(results_genes_diff)
 

現(xiàn)在有了基因id

怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集  
image.png

接下來(lái)是使用clusterProfiler做go注釋

這里參考 https://guangchuangyu.github.io/cn/2017/07/clusterprofiler-maize/#disqus_thread

首先把這個(gè)基因id對(duì)應(yīng)著轉(zhuǎn)換成 ENTREZID ,這里需要借助對(duì)應(yīng)的gtf注釋文件

這里只關(guān)注蛋白編碼基因

grep 'gene_biotype "protein_coding"' 12X_genomic.gtf > 12X_protein_coding.gtf
#python
from gtfparse import read_gtf
known_proteincoding = read_gtf("12X_protein_coding.gtf")
known_proteincoding.to_csv("all_protein_coding.csv")
 

GO富集分析的R語(yǔ)言代碼

require(AnnotationHub)
hub<-AnnotationHub() #這一步對(duì)網(wǎng)路有要求
# aa<-query(hub,'zea')
# aa$title
# query(hub,'Malus domestica')
bb<-query(hub,"Vitis vinifera")
#bb$title
grape<-hub[['AH85815']]
# length(keys(grape))
# columns(grape)
protein_coding_all<-read.csv("all_protein_coding.csv",header=T)
df<-merge(results_genes_diff,grape_expr_filter@expr$trans,by.x="id",by.y="gene_id")
df1<-merge(df,protein_coding_all,by.x="gene_name",by.y="gene_id")
dim(df1)
gene_ids<- 
  df1$db_xref[!duplicated(df1$db_xref)]
gene_ids<-stringr::str_replace(gene_ids,"GeneID:","")


library(clusterProfiler)
bitr(keys(grape)[2],'ENTREZID',c("REFSEQ","GO",
                                 "ONTOLOGY","GENENAME",
                                 "SYMBOL"),grape)
res = enrichGO(gene_ids, 
               OrgDb=grape, pvalueCutoff=0.05, qvalueCutoff=0.05)
help(package="clusterProfiler")
dotplot(res)
 

最后的結(jié)果是

怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集 

到此,相信大家對(duì)“怎么使用R語(yǔ)言的clusterProfiler對(duì)葡萄做GO富集”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI