大家都知道,这十几年来最流行的差异分析软件就是R的limma包了,但是它以前只支持microarray的表达数据。
考虑到大家都熟悉了它,它又发了一个voom的方法,让它从此支持RNA-seq的count数据啦!大家都知道芯片数据跟RNA-seq数据的本质就是value的分布不一样,所以各种针对RNA-seq的差异分析包也就是提出来一个新的normalization方法而已。而我们limma本身就提出了一个voom的方法来对RNA-seq数据进行normalization
使用这个包也需要三个数据:
- 表达矩阵
- 分组矩阵
- 差异比较矩阵
用法与limma一模一样的,只是多了一个normalization而已。
读取自己的数据
一般我们会自己读取表达矩阵和分组信息,下面是一个例子:
options(warn=-1) suppressMessages(library(DESeq2)) suppressMessages(library(limma)) suppressMessages(library(pasilla)) data(pasillaGenes) exprSet=counts(pasillaGenes) head(exprSet) ##表达矩阵如下
## treated1fb treated2fb treated3fb untreated1fb untreated2fb ## FBgn0000003 0 0 1 0 0 ## FBgn0000008 78 46 43 47 89 ## FBgn0000014 2 0 0 0 0 ## FBgn0000015 1 0 1 0 1 ## FBgn0000017 3187 1672 1859 2445 4615 ## FBgn0000018 369 150 176 288 383 ## untreated3fb untreated4fb ## FBgn0000003 0 0 ## FBgn0000008 53 27 ## FBgn0000014 1 0 ## FBgn0000015 1 2 ## FBgn0000017 2063 1711 ## FBgn0000018 135 174
group_list=pasillaGenes$condition
## [1] treated treated treated untreated untreated untreated untreated ## Levels: treated untreated ##这是分组信息,7个样本,3个处理的,4个未处理的对照!
另外一个例子是从airway里面得到表达矩阵和分组信息
library(airway) data(airway) exprSet=assays(airway)$counts ## 表达矩阵 group_list=colData(airway)$dex ## 分组信息
第一步:构建分组矩阵
suppressMessages(library(limma)) design <- model.matrix(~factor(group_list)) colnames(design)=levels(factor(group_list)) rownames(design)=colnames(exprSet) design
## treated untreated ## treated1fb 1 0 ## treated2fb 1 0 ## treated3fb 1 0 ## untreated1fb 1 1 ## untreated2fb 1 1 ## untreated3fb 1 1 ## untreated4fb 1 1 ## attr(,"assign") ## [1] 0 1 ## attr(,"contrasts") ## attr(,"contrasts")$`factor(group_list)` ## [1] "contr.treatment"
第二步:根据分组信息和表达矩阵进行normalization
这里构建了一个对象 An object of class “EList”
v <- voom(exprSet,design,normalize="quantile") ## 下面的代码如果你不感兴趣不需要运行,免得误导你 ## 就是看看normalization前面的数据分布差异 #png("RAWvsNORM.png") exprSet_new=v$E par(cex = 0.7) n.sample=ncol(exprSet) if(n.sample>40) par(cex = 0.5) cols <- rainbow(n.sample*1.2) par(mfrow=c(2,2)) boxplot(exprSet, col = cols,main="expression value",las=2) boxplot(exprSet_new, col = cols,main="expression value",las=2) hist(exprSet) hist(exprSet_new) #dev.off()
可以很明显看到normalization前后数据分布差异非常大!
第三步:做差异分析,提取差异分析结果
这里不需要差异比较矩阵了,因为我的分组矩阵表明样本就分成两组,直接提取coef=2的数据即可
fit <- lmFit(v,design) fit2 <- eBayes(fit) tempOutput = topTable(fit2, coef=2, n=Inf) DEG_voom = na.omit(tempOutput) head(DEG_voom)
## logFC AveExpr t P.Value adj.P.Val ## FBgn0029167 2.1608689 7.880589 41.19142 5.195806e-08 0.0007518331 ## FBgn0003137 -0.9560776 8.421903 -29.97211 2.920473e-07 0.0021129620 ## FBgn0003748 -1.0385933 6.395990 -23.78787 1.020682e-06 0.0049230892 ## FBgn0035085 2.5190255 5.221183 21.01339 1.993995e-06 0.0058809216 ## FBgn0050185 -0.4886279 5.487547 -19.95422 2.635106e-06 0.0058809216 ## FBgn0015568 -1.1040979 3.922438 -19.96954 2.624231e-06 0.0058809216 ## B ## FBgn0029167 9.065020 ## FBgn0003137 7.800063 ## FBgn0003748 6.652695 ## FBgn0035085 5.870585 ## FBgn0050185 5.734162 ## FBgn0015568 5.55756
差异分析结果就不解释啦!
原文来自:www.bio-info-trainee.com