小鬼的m6A图文复现07-Peak结果以及分布特征图

上一期提到使用exomePeak2进行m6A的Peak Calling,结果如下,每个样本一个结果:

├── ADDInfo
│ ├── ADDInfo_GLM_allDesigns.csv:Peak识别过程中的一些模型统计参数值
│ ├── ADDInfo_ReadsCount.csv:每个Peak的count值
│ └── ADDInfo_RPKM.csv:每个peak的RPKM值
├── Mod.bed :peak的bed格式
├── Mod.csv:peak的csv格式
├── Mod.rds:peak的Rdata格式
└── RunInfo.txt:运行过程中的一些参数文件

其中Mod.csv与Mod.bed前12列相同,bed为bed12,具体每一列如下,exomePeak2的结果不仅直接对每一个peak进行了基因注释,还输出了对应Peak的IP与Input样本的count值与RPKM值。筛选Peak主要根据pvalue或者padj。默认为pvalue<1e-05

image
  • 第1列 chr:染色体编号
  • 第2列 chromStart:Peak起始位点
  • 第3列 chromEnd:Peak终止位点
  • 第4列 name:Peak名字
  • 第5列 score:the -log2 p value of the peak
  • 第6列 strand:Peak在参考基因组上的链信息,+表示正链,-表示负链
  • 第7列 thickStart:同第二列
  • 第8列 thickEnd: 同第三列
  • 第9列 itemRgb: the column for the RGB encoded color in BED file visualization.
  • 第10列 blockCount: the block (exon) number within the peak.
  • 第11列 blockSizes: the widths of the blocks.
  • 第12列 blockStarts: the start positions of the blocks.
  • 第13列 geneID: Peak区间内注释到的基因ID
  • 第14列 ReadsCount.input:the total read count of input samples.
  • 第15列 ReadsCount.IP: the total read count of IP samples.

这一列作为重点给予以下说明:

  • 第16列 log2FoldChange: the estimate of IP over input log2 fold change (coefficient estimates of βi,1βi,1 in GLM), the Bayesian estimation implemented in the bioconductor package apeglm[3] will be returned if the regularized NB GLMs are fitted using DESeq2.

这一列很多人会有个误解,主要跟作者给的注释也有一定关系

包中的注释是这个样子的:

log2FC_cutoff a numeric value for the cutoff on log2 IP over input fold changes in peak calling; default = 0.

看着就是每一个Peak的IP样本中count/ Input样本中的count之后的log2值,即倍数关系

但是,当用户设置了这个参数,比如log2FC_cutoff=1的时候,发现结果中依然会有小于1的结果,后来给作者写信,给出答复如下,供大家参考:

回复1:

函数中的p_cutoff和log2FC_cutoff其实是peak calling时设定的阈值,exomePeak2的算法是这样的:
先在外显子组上生成划窗,对每个划窗收集到的IP / input 样本count做统计检验,并对其p-value (one-sided) 和 log2FC进行cut (即p_cutoff和log2FC_cutoff所指定的),显著的划窗会被merge成为peak region,并再次count和计算统计值。
所以在exomePeak2最终输出的表格中,其实是基于merge的peak所计算的统计值,本身已经包含了一些positive bias了。而差异甲基化也是基于所有样本peak calling后得到的peak进行的统计。

回复2:

那个log2FC是peak calling时针对sliding window用的filter,而输出的结果是在peak 层面上从新计算的统计值,并未和sliding window共用filter。为了避免给后来使用者造成困惑,我在更新的版本中将默认的peak calling log2FC cutoff改成0了 (在peak calling中log2FC并不影响很大,主要的影响还是p value)。

  • 第17列*pvalue: the Wald test p value on the βi,1βi,1 coefficient in the GLM.
  • 第18列*padj: 对pvalue进行BH矫正后的fdr值

这个结果中已经有了Peak区间的相关基因注释,但是没有功能区域注释,即所有文章中最常见的这幅图:

image

对于左图,我们这里给大家介绍绘制m6A修饰位点在基因组上的分布特征图可视化包:Guitar包

Guitar包与exomePeak2开发者来自同一个课题组,熟悉这个课题组的应该知道他们在关于m6A的分析上开发了许多的包。

这个包目前维护比较少,为了避免踩坑,建议安装"2.6.0"的版本。

Guitar包出来的结果特征如下:

image

Figure 3: m6 A sites on mRNA and lncRNA. In mRNA, the strongest binding sites (“IP/input ratio” larger than 8) are highly enriched near stop codon side of 3󸀠 UTR and deficient on TSS (transcription starting site) side of 5󸀠 UTR and the phenomena are more prominent than lowly methylated sites. In contrast, the m6 A sites are almost uniformly distributed on lncRNA despite the “IP/input ratio” specified. Please note that, in this figure, the size of 5󸀠 UTR, CDS, and 3󸀠 UTR reflects their true width within the transcriptome, so the 5󸀠 UTR region is much shorter compared with the other two components. This result is based on peaks called on human HepG2 dataset [10].

参考:Biomed Research International, 28 Apr 2016, 2016:8367534

代码如下:

rm(list=ls())
options(stringsAsFactors = F)

# load package
library(Guitar)
package.version("Guitar")
# [1] "2.6.0"

stBedFiles <- list("data/KO1/Mod.bed")
txdb <- makeTxDbFromGFF(file = "data/KO1/Mus_musculus.GRCm38.101.gtf.gz", 
                        format="gtf", 
                        dataSource="Ensembl", 
                        organism="Mus musculus")

p <- GuitarPlot(txTxdb = txdb, 
                stBedFiles = stBedFiles, 
                headOrtail = FALSE,
                enableCI = FALSE, 
                mapFilterTranscript = TRUE, 
                pltTxType = c("mrna"), 
                stGroupName = "KO1")

p <- p + ggtitle(label = "Distribution on mRNA") + 
         theme(plot.title = element_text(hjust = 0.5)) + theme_bw()

png(file="data/KO1_guitarPlot_mRNA.pdf",width=8,height=6)
print(p)
dev.off()

png(filename="data/KO1_guitarPlot_mRNA.png",width = 1000,height = 800, res = 180)
print(p)
dev.off()

结果图如下:Peaks主要富集在终止密码子以及3'UTR上。

image

对于右图,一般用ChIPseeker软件来进行区间注释。

rm(list=ls())
options(stringsAsFactors = F)
#BiocManager::install("ChIPseeker",ask = F)
library(ChIPseeker)
library(org.Hs.eg.db)
library(clusterProfiler)
library(GenomicFeatures)

# annotation file gtf
txdb <- makeTxDbFromGFF(file = "data/KO1/Mus_musculus.GRCm38.101.gtf.gz", format="gtf", 
                        dataSource="Ensembl", organism="Mus musculus")

# overlap
peak_file <- readPeakFile("data/KO1/Mod.bed")

## peak annotation
#region select:"Promoter", "5UTR", "3UTR", "Exon", "Intron", "Downstream", "Intergenic"
peak_anno <- annotatePeak(peak_file,
                          tssRegion = c(-3000, 3000),
                          TxDb = txdb,
                          assignGenomicAnnotation = TRUE,
                          genomicAnnotationPriority = c("5UTR", "3UTR", "Exon","Intron","Intergenic"),
                          addFlankGeneInfo = TRUE,
                          flankDistance = 5000)

pdf(file = "KO1.Anno.Pie.pdf",width = 6,height = 5)
plotAnnoPie(peak_anno)
dev.off()

png(filename="KO1.Anno.Pie.png" ,width=1000, height=850, res=200)
plotAnnoPie(peak_anno)
dev.off()

注释结果如下:

image

如果不喜欢这种注释,当然还可以直接用bedtools进行注释~

下一期分享另类可视化方法,如何与文献中的图片一样好看!

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

推荐阅读更多精彩内容