国产精品网红尤物福利在线观看_欧美经典一区二区_辽宁老熟女高潮狂叫视频_日日草日日干_成人免费观看毛片_久久激情免费视频

伯豪生物
TCGA and GEO 轉(zhuǎn)錄組數(shù)據(jù)挖掘超級干貨
發(fā)布時(shí)間:2020-09-29 瀏覽次數(shù):10131
伯豪生物鄧?yán)蠋熃o大家介紹一下對轉(zhuǎn)錄組TCGA & GEO的數(shù)據(jù)進(jìn)行分析,包括差異分析、富集分析、單基因展示以及其它個(gè)性化做圖。

信息時(shí)代就是好,沒有自己的數(shù)據(jù)咱可以從免費(fèi)的數(shù)據(jù)庫找數(shù)據(jù)呀!目前 TCGA 和 GEO 數(shù)據(jù)庫簡直就是專為科研人員準(zhǔn)備的免費(fèi)的寶庫。前面一直講的空間轉(zhuǎn)錄組,今天來穿插著講一節(jié) TCGA & GEO 數(shù)據(jù)分析換換口味吧。

今天主要給大家介紹一下對轉(zhuǎn)錄組 TCGA & GEO 的數(shù)據(jù)進(jìn)行分析,包括差異分析、富集分析、單基因展示以及其它個(gè)性化做圖。除了想利用公共數(shù)據(jù)庫挖掘轉(zhuǎn)錄組數(shù)據(jù)的發(fā)文章的同學(xué)之外,這篇教程其實(shí)特別適合自己做了少量轉(zhuǎn)錄組樣本又不想做后期驗(yàn)證,想直接用公共數(shù)據(jù)庫的數(shù)據(jù)來驗(yàn)證自己數(shù)據(jù)結(jié)果的朋友。

目前各種 TCGA & GEO  數(shù)據(jù)下載的教程太多了,所以今天直接省略這部分部分,直接從后面的分析開始。廢話不多說,直接上干貨!

一、準(zhǔn)備文件

基因表達(dá)矩陣文件,可以是 TCGA 下載的轉(zhuǎn)錄組數(shù)據(jù),也可以是 GEO 下載的轉(zhuǎn)錄組數(shù)據(jù),格式如下(行是基因,列是樣本):

1

樣本分組文件,格式如下(type 是分組):

2

二、差異分析

一般 TCGA 或 GEO 上大量樣本數(shù)據(jù)的差異分析 limma 用的比較多,所以這里也使用 limma 包來分析差異基因,注意需要先安裝 limma R 包。

安裝 limma 包:

if (!requireNamespace("BiocManager", quietly = TRUE))

    install.packages("BiocManager")

BiocManager::install("limma")

分析差異:

## 讀取基因表達(dá)件,取 log2

geneexp = read.table("gene_exp_BRCA.txt",header=T,row.names=1,sep="\t")

geneexp = log2(geneexp+1)

## 讀取分組文件

group_file = read.table("sample_group_BRCA.txt",header=T,row.names=1,sep="\t",as.is =TRUE)

rownames(group_file) = gsub('-','.',rownames(group_file))

geneexp = geneexp[,rownames(group_file)]

### 差異分組設(shè)置

samps<-factor(group_file$type)

design <- model.matrix(~0+samps) ;

colnames(design) <- levels(samps)

### 模型擬合

fit <- lmFit(geneexp, design)

cont.matrix<-makeContrasts(Basal-Normal,levels=design)

fit2 <- contrasts.fit(fit, cont.matrix)

fit2 <- eBayes(fit2)

final<-topTable(fit2, coef=1, number=dim(geneexp)[1], adjust.method="BH")

> head(final)

           logFC  AveExpr         t       P.Value     adj.P.Val        B

SDPR   -4.358861 2.679133 -46.10828 8.888505e-122 4.738017e-117 267.4862

TPX2    4.030685 3.807811  45.39822 2.571983e-120 6.854979e-116 264.1584

UBE2C   4.089727 3.270516  43.72542 8.428935e-117 1.497681e-112 256.1483

CDC20   3.971916 3.450304  42.85468 6.270780e-115 8.356598e-111 251.8811

FIGF   -3.220704 1.583802 -40.93757 1.053838e-110 1.123497e-106 242.2399

FAXDC2 -2.179867 1.637909 -39.05494 2.084335e-106 1.851758e-102 232.4283

三、繪制差異基因散點(diǎn)圖和火山圖

這一步需要用到 ggplot2 繪圖,沒有安裝的話需要先安裝 ggplot2 包。

# 繪制差異基因散點(diǎn)圖和火山圖

library(ggplot2)

g1 = "Normal"

g2 = "Basal"

g1_exp = geneexp[rownames(final),rownames(group_file)[which(group_file$type==g1)]]

g2_exp = geneexp[rownames(final),rownames(group_file)[which(group_file$type==g2)]]

g1_mean = apply(g1_exp,1,mean)

g2_mean = apply(g2_exp,1,mean)

type=rep('No',length(g1_mean))

type[which(final$logFC> 1 & final$adj.P.Val <0.05)] = "Up"

type[which(final$logFC < -1 & final$adj.P.Val < 0.05)] = "Down"

datam = data.frame(g1_mean,g2_mean,logFC=final$logFC,FDR=final$adj.P.Val,type,stringsAsFactors=FALSE)

## 散點(diǎn)圖

ggplot(datam,aes(g1_mean,g2_mean,colour=type))+

geom_point(stat="identity",size=1)+theme(legend.title=element_blank())+scale_color_manual(values =c("Down"='blue',"No"='grey',"Up"='orange'))+

    labs(x=paste(g1,'Log2(FPKM+1)'),y=paste(g2,'Log2(FPKM+1)'),title=paste(g2,'VS',g1,sep=""))+

    coord_cartesian(ylim=c(0,10),xlim=c(0,10))+geom_segment(aes(x = 0, y = 0, xend = 10, yend = 10),size=1,colour="#999999",linetype="dotted")+theme(plot.title = element_text(hjust = 0.5),title=element_text(face="bold",size=15,colour="black"),axis.title=element_text(face="bold",size=13,colour="black"),axis.text.x=element_text(face="bold",size=12,colour="black"),axis.text.y=element_text(face="bold",size=12,colour="black"),legend.text=element_text(face="bold",size=13,colour="black"))

散點(diǎn)圖結(jié)果如下:

3

## 繪制火山圖

ggplot(datam,aes(logFC,-log10(FDR),colour=type))+

            geom_point(stat="identity",size=1.2)+theme(legend.title=element_blank())+scale_color_manual(values =c("Down"='blue',"No"='grey',"Up"='orange'))+

            labs(x="Log2 (FC)",y="-Lg10 (FDR)",title=paste(g2,'VS',g1,sep=""))+coord_cartesian(xlim=c(-5,5))+

            geom_hline(aes(yintercept=1.3),colour="white",size=1.1)+

            geom_vline(aes(xintercept =-1),colour="white",size=1.1)+geom_vline(aes(xintercept =1),colour="white",size=1.1)+

            theme(axis.title.y = element_text(vjust=-0.1),axis.title.x = element_text(vjust=-0.6),title = element_text(vjust=0.8))+theme(plot.title = element_text(hjust = 0.5),title=element_text(face="bold",size=15,colour="black"),axis.title=element_text(face="bold",size=13,colour="black"),axis.text.x=element_text(face="bold",size=10,colour="black"),axis.text.y=element_text(face="bold",size=10,colour="black"),legend.text=element_text(face="bold",size=12,colour="black"))

火山圖結(jié)果如下:  

4     

四、差異基因富集分析

這里我們介紹一下怎么用  clusterProfiler R 包來做差異基因富集分析。需要先安裝好 clusterProfiler,org.Hs.eg.db 兩個(gè) R 包。

if (!requireNamespace("BiocManager", quietly = TRUE))

    install.packages("BiocManager")

BiocManager::install("clusterProfiler")

BiocManager::install("org.Hs.eg.db")

GO 富集分析

library(clusterProfiler)

library(org.Hs.eg.db)

### 提取差異基因 list

diffgenes <- final[(final[,"adj.P.Val"]<0.05 & abs(final[,"logFC"])>=1),]

genelist <- diffgenes[,"logFC"]

names(genelist) = rownames(diffgenes)

##id 轉(zhuǎn)換,將 SYMBOL 轉(zhuǎn)換成 ENTREZID

gene = bitr(rownames(diffgenes), fromType = "SYMBOL", toType = "ENTREZID", OrgDb = "org.Hs.eg.db")

#####################GO 富集

ego <- enrichGO(

    gene  = gene$ENTREZID,

    keyType = "ENTREZID", 

    OrgDb   = "org.Hs.eg.db",

    ont     = "ALL",

    pAdjustMethod = "BH",

    pvalueCutoff  = 0.05,

    qvalueCutoff  = 0.05,

    readable      = TRUE)

# 再用 setReadable 函數(shù)將基因 ID 映射到基因 Symbol

ego2 <- setReadable(ego, OrgDb = "org.Hs.eg.db", 'ENTREZID')

繪制柱狀圖:

barplot(ego2,showCategory = 20)

5

繪制氣泡圖:

dotplot(ego2, showCategory = 20)

6

繪制網(wǎng)絡(luò)圖 1:

cnetplot(ego2, showCategory = 3,foldChange=genelist, circular = TRUE, colorEdge = TRUE)

7

繪制網(wǎng)絡(luò)圖 2:

emapplot(ego2, foldChange=genelist, showCategory = 20)

8

KEGG 富集分析

注意這一步需要連接網(wǎng)絡(luò),因?yàn)?clusterProfiler 是在線抓取新的 pathway 數(shù)據(jù)庫的。當(dāng)然也有用 kegg.db R 包直接內(nèi)置數(shù)據(jù)庫的情況,這里不做介紹。

######################KEGG 富集

kegg <- enrichKEGG(

    gene = gene$ENTREZID,

    keyType   = "kegg",

    organism  = 'hsa',

    pvalueCutoff  = 1,

    pAdjustMethod  = "BH",

    qvalueCutoff  = 1,

    use_internal_data = FALSE)

kegg2 <- setReadable(kegg, OrgDb = "org.Hs.eg.db", 'ENTREZID')

繪制柱狀圖:

barplot(kegg2,showCategory = 20)

9

繪制氣泡圖:

dotplot(kegg2, showCategory = 20)

10

繪制網(wǎng)絡(luò)圖 1:

cnetplot(kegg2, showCategory = 10,foldChange=genelist, circular = TRUE, colorEdge = TRUE)

11

繪制網(wǎng)絡(luò)圖 2:

emapplot(kegg2, foldChange=genelist, showCategory = 20)

12


五、差異基因熱圖標(biāo)記基因

當(dāng)我們已經(jīng)用自己的數(shù)據(jù)做過分析得到了差異基因,或者是已經(jīng)有自己關(guān)注的基因,想用  TCGA & GEO 數(shù)據(jù)來驗(yàn)證自己的數(shù)據(jù)或結(jié)論的時(shí)候,用 TCGA & GEO 數(shù)據(jù)差異基因熱圖同時(shí)標(biāo)記特定基因來展示結(jié)果就特別合適。

###### 差異基因熱圖標(biāo)記關(guān)注基因

library("ComplexHeatmap")

library("circlize")

diff_exp = geneexp[rownames(diffgenes),]

# 進(jìn)行 zscore 歸一化

diff_exp_scaled = t(apply(diff_exp, 1, scale)) 

colnames(diff_exp_scaled) = colnames(diff_exp)

# 需要標(biāo)記的基因

genes = c('CDC20','THRB','FAM13A','CCNA2','PRR15','CHI3L1','CLCA2','ABCA10','A2ML1','LCN2')

## 設(shè)置位置

gene_pos = which(rownames(diff_exp) %in% genes)

ha = rowAnnotation(foo = anno_mark(at = gene_pos, labels = genes))

m=round(max(abs(diff_exp_scaled)))

## 畫熱圖

Heatmap(diff_exp_scaled, colorRamp2(c(-m,0,m),c("blue", "#EEEEEE", "red")),

right_annotation = ha,name = "Z-score",show_row_names =FALSE,show_column_names =FALSE)

繪圖結(jié)果如下:

13

六、單個(gè)基因繪圖

要在 TCGA & GEO 數(shù)據(jù)中驗(yàn)證自己的關(guān)注的基因的差異情況,除了前面說的差異基因熱圖標(biāo)記特定基因之外,也可以對單個(gè)基因直接進(jìn)行繪圖。這里我們提供三種展示方式,選擇自己喜歡的一種展示形式就行。

用箱線圖展示:

## 單個(gè)基因箱線圖

exp2 = data.frame(t(diff_exp))

exp2$type = group_file$type

ggplot(exp2, aes(x=type, y=CDC20,fill=type)) + 

    geom_boxplot()+geom_jitter(alpha = .3, width =0.2,size=1)+labs(title = "") + ylab("log2 (FPKM)")+ xlab("")+theme_bw()+

  theme(title=element_text(face="bold",size=16),axis.title=element_text(face="bold",size=15),axis.text.x=element_text(face="bold",angle=80,size=13,hjust=1),

  axis.text.y=element_text(face="bold",size=12),legend.text=element_text(face="bold",size=13),legend.title=element_text(face="bold",size=13))

結(jié)果如下:

   14

小提琴圖展示:

### 單個(gè)基因小提琴圖

ggplot(exp2, aes(x=type, y=CDC20,fill=type)) + 

    geom_violin(alpha=0.5) + geom_boxplot(alpha = .5,fill="white", width= .2)+labs(title = "") + ylab("log2 (FPKM)")+ xlab("")+theme_bw()+

  theme(title=element_text(face="bold",size=16),axis.title=element_text(face="bold",size=15),axis.text.x=element_text(face="bold",angle=80,size=13,hjust=1),

  axis.text.y=element_text(face="bold",size=12),legend.text=element_text(face="bold",size=13),legend.title=element_text(face="bold",size=13))

結(jié)果如下:

15

散點(diǎn)圖展示:

### 單個(gè)基因散點(diǎn)圖   

ggplot(exp2, aes(x=type, y=CDC20)) +

  geom_dotplot(binaxis='y', stackdir='center',binwidth = 0.1)+stat_summary(fun.y=median, geom="point", shape=18,size=3, color="red")+

  theme(axis.title=element_text(face="bold",size=15),axis.text.x=element_text(face="bold",angle=80,size=13,hjust=1),axis.text.y=element_text(face="bold",size=12))

結(jié)果如下:

16

這里只展示一個(gè)基因的情況,如果是有多個(gè)基因需要繪圖的,把代碼里的基因名替換一下就好了。

好啦,今天的分享就到次為止啦,下次再繼續(xù)哦!

更多伯豪生物人工服務(wù):

伯豪學(xué)院單細(xì)胞測序服務(wù)人工客服


在線客服
登錄/注冊
在線留言
返回頂部
主站蜘蛛池模板: 国产精品美女视频网站_中文字幕一区二区三区波多野结衣_手机在线观看国产_你操综合_色婷婷精品久久二区二区蜜臀av_女人黄色特级大片 | 久久久久国产精品老师性教育影院_狠狠的日_超碰日韩_公侵犯一区二区三区四区中文字幕_天天爽夜夜骑_q2002日韩午夜伦高清 | 日韩在线播放视频_91久久精品凹凸一区二区_日韩一区二区三区视频_特级一级黄色片_成人国产精品入口_青青草一区 | 人妻av无码专区_日本无删减版_天天干天天操天天插_中文字幕欧美日韩精品_亚洲tv久久爽久久爽_少妇裸体淫交视频免费看 | 内射夜晚在线观看_一区二区三区四区国产精品_国产精品99久久久久久天美传媒_日韩中字幕_免费看小12萝裸体视频国产_久久重口味 | 国产精品不卡视频_小受咬床单失禁的GV在线观看_好男人网官网在线观看2019_国产成人av一区二区三区在线_免费的成人A级毛片_av毛片免费 | 无码日韩人妻精品久久蜜桃_欧美第一视频_俺来俺去www_日本一极黄色片_国产精品欧美久久久久久_好男人官网资源在线观看 | 性色AV无码专区一ⅤA亚洲_精品人妻无码一区二区三区绿_中文字幕在线精品视频入口一区_国产成人免费9x9x人网站视频_超碰成人福利_久久草精品 | 日韩亚洲欧美一区二区_桃色影院av_台湾佬综合网_噜噜噜av久久av牛牛_亚洲AV成人一区二区三区网站_91亚洲精华国产 | 久久久久久国产精品三级_伊人网在线免费视频_国产成人69视频午夜福利在线观看_美女很黄很黄免费_精品一区二区视频在线观看_中文人妻熟妇乱又伦精品 | 亚洲成人夜色_女同一区_成人av日韩_十八女人毛片_成人免费超碰_x8x8拨牐拨牐x8免费视频8午夜 | 亚洲最新视频在线观看_中文人妻无码一区二区三区在线_91激情小视频_神马久久桃花_三级超碰_色www免费视频 | 国产免费午夜福利在线播放11_日本高清在线免费_com.国产_铠甲勇士免费看_日韩高清在线不卡_成人全黄A片免费看 | 亚洲精品无码不卡AV_亚洲a一片_亚洲综合91_香蕉久久久久久久_午夜dy888国产精品影院_亚洲视频欧洲视频 | 天天操天天干天天插_国产免费99_日日射夜夜操_成人午夜视频观看免费高清第1季_国产精品一色哟哟哟_91欧美视频在线观看 | 国产淫片av片久久久久久_国产亚洲精品一区二三区_九一福利_中文字幕乱码英文字幕正常_黄网站色成年片大免费高清_男人扒开女人桶到爽中国的人 | 亚洲小说区图片区色综合网_国产系列在线观看_特级毛片免费视频_国产三级dvd视频在线观看_欧美va在线观看_免费一级毛片免费播放 | 久久久久亚洲av成人毛片韩_欧美呦呦在线_永久免费的啪啪免费网址_黄在线免费看_欧美日韩不卡在线观看_xxlfreshman中国偷拍 | 天天操天天干天天插_国产免费99_日日射夜夜操_成人午夜视频观看免费高清第1季_国产精品一色哟哟哟_91欧美视频在线观看 | 丁字裤少妇露黑毛_女人一级毛片免费看_www.国产一区二区_污91视频_国产精品第一页在线_精品国产二区三区 | 中文字幕一区二区三区在线看_亚洲AV美女一区二区三区_高潮A片揉搓乳尖乱颤视频_全国免费av_人人九九精品_久久久午夜爽爽一区二区三区三州 | 91丨国产_自由日本语热亚洲人户外_日韩免费黄色大片_久久99精品久久久久久野外_99精品国产免费久久久久久按摩_片多多在线播放 | 久久福利一区_亚洲a∨大乳天堂在线_国内久久久久高清影视_法国《性迷宫》在线播放k8_91天堂素人_亚洲人成精品久久久久久 | 大青草网站_免费乱理伦片在线观看2017_最近中文字幕mv2018在线高清_久久婷婷五月综合色欧美_伊人影院在线视频_日韩一道本 | 日日干夜夜干_樱桃成人精品视频在线播放_免费视频二区三区_韩国国内大量揄拍精品视频_韩国一级片免费在线观看_国产精品久久久久久久密密 | 欧美丰满熟妇BBB久久久_久久人人爽人人爽人人片av免费_中国真实偷乱视频_中文在线一二区_99精品国产成人综合_青春草久久 | 亚洲色图天堂_国产精品久久久久国产a级_成人一区二区免费中文字幕视频_久久涩视频_色综合热_成人午夜看黄在线尤物成人 | 贪婪欲望之岛在线观看_1769免费视频在线观看_免费aa毛片_久久精品在线观看视频_亚洲性爱之日本精品视频_亚洲欧美日韩综合aⅴ | 日韩黄在线观看_成人在线_亚洲欧洲一二区_国产资源中文字幕_美腿制服丝袜国产亚洲_中日韩av在线 | 久久艹逼视频_天堂天躁狠狠躁夜躁2022_美女扒开腿让男人桶爽揉_jiuse地址_久久精品xxx_亚洲极色 | 老妇女人一级毛片_黄色av免费看_日韩jizz_一级性大片_欧美人一级淫片a免费播放_欧美日韩一区二区三区在线观看 | 公交车被多男摁住灌浓精在线观看_亚洲AV无码乱码A片无码_亚洲精品无码专区_蜜桃成人免费视频_视频专区一区二区_久草在线视频福利 | 午夜福利在线观看6080_国内精品三级_中文日产幕无线码一区_np群乱肉欧美精品大黄毛片_精品成人一区_中文字幕有码在线 | 99这里只有精品99_国产丰满麻豆videos天美_国产一区不卡在线_365天天色综合网_日本大尺度吃奶呻吟视频_超碰caoporn香蕉 | 婷婷成人影院_91av在线网站_91网站观看_日韩中文字幕视频在线_久草视频观看_国产一区二区视频在线观看 | 国产不卡一_成人精品一区二区91毛片不卡_91精品国啪老师啪_免费纯肉3D动漫无码网站_欧美视频在线第一页_色综合天天综合狠狠爱亚洲 | 一级大片久久_精精国产xxxx在线视频www_欧美蜜桃网_欧美a在线播放_国产中文视频_99re免费 | 成人乱码_国产视频二区三区_亚洲自拍中文字幕_亚洲人亚洲精品成人网站_色天天躁夜夜躁天干天干_久久中文字幕无码中文字幕有码 | 欧美青草_gogogo免费高清在线中国_99国内精品久久久久久久黑人_国产人妖乱国产精品人妖_久久探花_日韩aa | 4438x成人免费_国产乱子伦XXXX_日本视频在线免费_琪琪在线观看_91肥臀后入_国产午夜高潮熟女精品av | 亚洲va欧美va人人爽春色影视_少妇被粗大的猛进出69影院_亚洲真人无码永久在线观看_亚洲一二_av黄色免费在线观看_国产性×xxx盗摄xxxx |