xtail | 差异翻译基因分析

  基因翻译,即遗传密码从转录本到蛋白质的过程,也是功能基因能够发挥自身作用前的必经之路。基因的翻译效率收到很多因素的调控,这其中最直接的是基因本身的转录丰度,正常情况下,翻译速度与转录丰度成正比。所以,与普通rnaseq寻找差异表达基因不同,寻找差异翻译基因,目的是找到受功能调控而翻译速度变化的基因,首先要排除转录丰度变化引起翻译速度变化的基因。因此,差异翻译基因分析时,会同时利用普通的rna-seq与类似ribo-seq(专门用于定量正在翻译的基因的翻译丰度) 定量结果。

  翻译基因的定量核心目的是捕获ribosome protected fragment (RPF),如下面的流程示意图所示:

  对于像ribo-seq这样的技术,由于其定量的特殊性,会有一些相应质控方式来反映数据的特征与质量。比如,三碱基周期,基因翻译过程中核糖体移动时每隔三个碱基 (一个密码子) 停顿一次,因此正确的RPF信号在CDS上应该呈现三碱基周期,即高-低-低模式如下图C

  就像普通转录组测序一样,翻译组测序最主要的目的也是寻找差异基因。理解差异翻译之前,先说一下翻译效率(TE = RPF/mRNA),即翻译丰度占总转录丰度的比值。很多差异软件从TE这个角度出发,分析不同条件下TE的变化(Δlog2R)来寻找差异翻译基因,比如今天要说的软件xtail也有这方面的考虑。此外,该软件还别出心裁的考虑了另外一个角度,即Δlog2FC,这个出发点假设可以理解为,如果基因的翻译丰度变化是由于实验条件导致而不是转录丰度,那么,不同条件下翻译丰度会有变化,而转录丰度没有变化。综合来看,(Δlog2R)Δlog2FC两种方式都是为了寻找差异翻译基因,理论上应该殊途同归,但实际的做法是取两者中相对更保守的结果作为最终的结果。故而,与其他软件相比,xtail得到的结果相对保守一点。

  本来想安装releases版本的xtail,结果一直安装不上,最后选择了github上的开发版。看着参考文档的示例代码,觉得xtail使用本身不难,实际上却很快就遇到了问题:

mrna_cnt <- read.table('mrna_cnt.txt', header=T, row.names=1, seq='\t')
head(mrna_cnt, 3)
                     case1 case2 ctrl1 ctrl2
ENSMUSG00000000001.4  3968  4546  5738  6049
ENSMUSG00000000003.15    2     1     10     13
ENSMUSG00000000028.15 2203  3112  2836  3390

ribo_cnt <- read.table('ribo_cnt.txt', header=T, row.names=1, seq='\t')
head(ribo_cnt, 3)
                         case1    case2    ctrl1    ctrl2
ENSMUSG00000048696.11      139       45       50      188
ENSMUSG00000028830.14        2       89      459       31
ENSMUSG00000020530.14        5      310      868      418

condition <- c("case","case","ctrl","ctrl")
res_xtail <- xtail(mrna_cnt , ribo_cnt, condition, baseLevel="ctrl", bins=1000, threads=2)
Calculating the library size factors
1. Estimate the log2 fold change in mrna
converting counts to integer mode
2. Estimate the log2 fold change in rpf
3. Estimate the difference between two log2 fold changes
4. Estimate the log2 ratio in first condition
converting counts to integer mode
5. Estimate the log2 ratio in second condition
converting counts to integer mode
6. Estimate the difference between two log2 ratios
Error: logical subscript contains NAs

  这个问题第一次使用软件时,大概率都会遇到,比如网上就有人遇到过,也给出了一种解决方法。

  不可否认,提高minMeanCount可以解决问题,但提高到多少不好说,得看两个表达谱的数据情况。所以,简单一句话,用这个方法不直接,因为阈值设高会丢弃很多基因,设置低了还是会出错。

  那么,到底是什么引发错误的呢?确认问题才能更好地解决问题,于是乎倒腾了一番,最终确定到了问题所在:

# fold change better than ratio
fc_result <- res$pvalue_v1 > res$pvalue_v2
log2FC_determine_num <- sum(fc_result)
res[fc_result,"log2FC_TE_final"] <- res[fc_result,"log2FC_TE_v1"]
res[fc_result,"pvalue_final"] <- res[fc_result,"pvalue_v1"]
# ratio better than fold change
ratio_result <- res$pvalue_v1 <= res$pvalue_v2
log2R_determine_num <- sum(ratio_result)
res[ratio_result,"log2FC_TE_final"] <- res[ratio_result,"log2FC_TE_v2"]
res[ratio_result,"pvalue_final"] <- res[ratio_result,"pvalue_v2"]

  在pvalue_v1pvalue_V2比较时,因为有些pvalue的值是NA,从而造成log2FC_TE_final赋值这一行代码出错。解决了这个问题,便可以正常运行并得到结果:

restab <- resultsTable(res_xtail)
head(restab, 3)
DataFrame with 6 rows and 8 columns
                      log2FC_TE_v1   pvalue_v1 ctrl_log2TE.1 log2FC_TE_v2
                         <numeric>   <numeric>     <numeric>    <numeric>
ENSMUSG00000000001.4     -1.442377 3.21985e-01    -1.5386621    -1.446969
ENSMUSG00000000028.15    -0.822741 6.82438e-01     0.0632993    -0.718147
ENSMUSG00000000037.17     0.698955 3.99256e-01     0.6652733     0.620557
                      pvalue_v2 log2FC_TE_final pvalue_final pvalue.adjust
                      <numeric>       <numeric>    <numeric>     <numeric>
ENSMUSG00000000001.4   0.388114       -1.452377     0.392985      0.999861
ENSMUSG00000000028.15  0.640160       -0.822741     0.792438      0.998961
ENSMUSG00000000037.17  0.710053        0.602557     0.700053      0.998961

  结果看上去好像没什么问题,但仔细一看与文档中resultsTable默认提取的结果相比,好像多出一列ctrl_log2TE.1,看着列名后缀盲猜应该是合并数据时有相同的列名。不过,这个应该仅是保留最终结果时的瑕疵没有影响,可以直接忽略。

  xtail返回结果是一个对象,如果想要完整的结果数据框,可以直接用res_xtail$resultsTable命令获取。现在再回过头看前面的问题,在不改代码的前提下,最好的方式应该是先过滤数据,保留在各条件下都有表达值的基因。

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

推荐阅读更多精彩内容