【PCA】scaffold等级的群体重测序可能遇到的坑

这阵子在做红树的群体重测序分析,一开始在PCA这个坎上遇到了一个网上普遍的教程都没有怎么提及的坑,加之下午有人发邮件给我,问了类似的问题,所以在这里写下这篇可能对大部分只有scaffold的参考基因在做pca分析时有帮助的文章。

在一开始,确定软件使用的时候,我在简书里找到西澳老哥lakeseafly这一篇介绍gwas常用做pca的软件使用的文章,里面提到了三个软件,分别是gcta,eigensoft以及r里面一个叫vcfR的包。然后我就试了一下,结果发现gcta只设计了针对人的基因组的pca分析(即基因组组装到染色体等级并且少于22条染色体的才能使用),而vcfR里面有一个依赖包poppr这个包我安装不上,故而只剩下eigensoft这个软件可以用。

下载,安装之后,我就看了一下readme,然后被绕的有点晕,所以惯性的去请教鲍大哥怎么用。鲍大哥跟我讲了输入文件的格式以及需要注意的一些坑,然后我就按照他说的,开始了一波瞎折腾,然后就遇到了第一个坑,LD过滤报错???

具体的报错就是使用plink的-ld-pairwise这个参数时,它提示too much variants were pass,这个就有点蓝瘦了,然后我就用信鸽搜索,将报错打进去,大概知道了是由于snp莫得id导致,故而我再次用信鸽搜了一下怎么加id,然后就搜到了大神严涛的博客,在他那篇用emmax做gwas分析的博文中,我看到了黎明的曙光,原来gatk生成的vcf文件中是没有snp_id的,需要自己去加,具体怎么加,照搬大神的代码

plink --vcf test.vcf --maf 0.05 --geno 0.1 --recode vcf-iid --out test.maf0.05.int0.9 --allow-extra-chr

其中maf跟geno是常用的过滤条件,vcf-iid这个参数就是加入snp_id,由于没有达到染色体级别,所以需要用到allow-extra-chr这个参数

而后的话,过滤就正常的进行了下去,而之所以做这一步的意义在于过滤掉这些冗余的信息,加快计算的速度,而过滤的具体参数需要根据自己的物种特点(自交or杂交)去查类似的物种别人怎么过滤。

质控就算正常进行下去了,然后就是eigensoft的输入文件的准备了,在自己折腾了半天还是没搞对格式之后,我在qq上问了三楼的王师姐,师姐因为有事,所以让我去服务器上看一下她的输入文件,然后我就把师姐的输入文件down了一份下来,仔细观摩发现,我傻逼了,ped文件上次不知道哪个步骤被替换成另一种格式,但仍然以ped结尾,难怪搞半天没反应。意识到自己的傻逼了之后,我重新准备了输入文件,然后按照流程,迅速的得到了下一个坑。

只看到那smartpca检测完我的输入文件无误之后,开始了分析,而后,warning,bad chromosome,然后就一堆东西类似的出来之后,退出了。

看来在成为一名称职的帅哥前,还是需要接受很多磨难,然后我再次把报错内容交给了信鸽,然后就搜出了罪魁祸首,map文件中的染色体为0,嘤嘤嘤(╥╯^╰╥),没有染色体水平的基因组就是个离了婚的臭男人。然后在众多搜索结果中,我发现了一位仁兄分析了他的报错经历。照着他说的,我把map文件第一列改为1,然后就成功运行了。

然后在那个外面天气我也不知道怎么样的下午,我又找到了宇宙实验媛的知乎,在她的知乎上,我看到了另一种输入文件格式

在本人的不定期吐槽小文最后,稍微正经一下,把上面这些东西规整一下,别看得云里雾里。

第一步,使用plink进行过滤,并且加上snp的id,加法见上面的那道疑似的命令行,当然,更希望你们去看一下严涛大神的原文,他写得更好。

第二步,使用plink对加上id的vcf文件进行ld的过滤,得到prune.in跟out两个id文件,而后再使用plink的--extract选择in那个文件对加了id的vcf文件进行过滤。

第三步,将bed文件转为vcf文件,反正后面做其他分析可能还需要以vcf为输入文件,所以建议输出

第四步,eigensoft的输入文件准备,看下面:

输入文件有很多种形式可以选择,其中推荐两种,一种是ped文件作为输入格式,另一种是bed文件作为输入格式

首先是以ped文件为输入文件的格式

需要的三个文件分别是ped,map,pedind,需要注意的是这三种格式是怎么来的。

ped跟map直接由plink生成,pedind需要自己生成。

pedind其实就是ped文件的前六列,这个可以通过脚本轻易的实现。

将map文件第一列的0全部改为同一个大于0数字。

smartpca.perl -i myfile.ped -a myfile.map-b myfile.ind -o myfile.PCA -p myfile.plot -e myfile.evel -l myfile.log

这样就ok了。

第二种的输入文件是bed,bim,ind。

Bed,bim都是plink转换生成的,其中bim的第一列是染色体也一样需要改变一下

Ind由三列构成第一列为样本ID,第二列为性别(M,F,U),第三列为所属子群。

然后我们可以把输入文件写成一个文件,例如这样:


numoutevec是保留多少pca主成分

然后搞定之后就可以运行了,smartpca –p runningpca.conf > smartpca.log && echo"----smartpca----done"

这样就完成了pca的运算了。

然后,这里补充一下后面鲍大哥看了我的步骤提出来的几点修改建议,map文件的chr位置均为0是由于vcftools转换的时候不能识别,解决的方法可以是在转换的后面加上--chrom-map,然后给个对应的列表就加上去了,而这时添加snp_ID就并不是必要的。修改染色体名字就相当于强行把不同的scaffold变成一条scaffold。这样在计算的时候是有问题的。(由于我用别的软件算完pca结果其实跟修改map的结果差不多,所以这里其实是可以修改染色体的,但后面其他的运算可能就必须注意,所以大家得注意一下)

最后,如果不会脚本,也可以用plink进行pca运算

Plink –bfile myfile –pca 10 –out myfile.pca,简单,快捷,而且结果跟eigensoft差不多。

而后在看到牛奶的这篇知乎,觉得这个东西很有用,所以分享一下

当跑完pca之后,一般需要进行群体分层,分层的依据可以根据structure,pca以及nj_tree的综合判断,而至于pca要怎么判断,eigensoft里面其实内置了一个计算pca结果是否显著的工具,我们只要调用就行

twstats -t twtable -i myfile.pca.eval -o myfile.eigenvaltw.out

最后less看一下就行,p值小于0.05的都是显著

最后的最后,推广一下我们专栏跟公众号,知乎专栏【高通量测序技术】,我的知乎【生信小撰】,我们的微信公众号【高通量测序技术】,欢迎大家关注,也欢迎各位新手跟大神来互相交流。

如果大家遇到什么疑问,也欢迎将文件发送到这个邮箱:825526231@qq.com,只要是我知道的,我会尽力解答~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念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

推荐阅读更多精彩内容