ImageVerifierCode 换一换
格式:DOCX , 页数:32 ,大小:217.39KB ,
资源ID:30284943      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/30284943.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(GATK使用方法.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

GATK使用方法.docx

1、GATK使用方法原创】GATK使用方法详解(包含bwa使用)第一部分 (2014-03-03 11:07:29)转载标签:gatkbwasnpindel分类:生物信息由于新浪博客规定,每篇文章不可超过2万字符,因此分4篇发布。一、使用GATK前须知事项:(1)对GATK的测试主要使用的是人类全基因组和外显子组的测序数据,而且全部是基于illumina数据格式,目前还没有提供其他格式文件(如Ion Torrent)或者实验设计(RNA-Seq)的分析方法。(2)GATK是一个应用于前沿科学研究的软件,不断在更新和修正,因此,在使用GATK进行变异检测时,最好是下载最新的版本,目前的版本是2.8.

2、1(2014-02-25)。下载网站:http:/www.broadinstitute.org/gatk/download。(3)在GATK使用过程中(见下面图),有些步骤需要用到已知变异信息,对于这些已知变异,GATK只提供了人类的已知变异信息,可以在GATK的FTP站点下载(GATK resource bundle)。如果要研究的不是人类基因组,需要自行构建已知变异,GATK提供了详细的构建方法。(4)GATK在进行BQSR和VQSR的过程中会使用到R软件绘制一些图,因此,在运行GATK之前最好先检查一下是否正确安装了R和所需要的包,所需要的包大概包括ggplot2、gplots、bito

3、ps、caTools、colorspace、gdata、gsalib、reshape、RColorBrewer等。如果画图时出现错误,会提示需要安装的包的名称。二、GATK的使用流程GATK最佳使用方案:共3大步骤。原始数据的处理变异检测初步分析。第一大步:原始数据的处理1.对原始下机fastq文件进行过滤和比对(mapping)对于Illumina下机数据推荐使用bwa进行mapping。Bwa比对步骤大致如下:(1)对参考基因组构建索引:例子:bwa index -a bwtsw hg19.fa。最后生成文件:hg19.fa.amb、hg19.fa.ann、hg19.fa.bwt、hg19

4、.fa.pac和hg19.fa.sa。构建索引时需要注意的问题:bwa构建索引有两种算法,两种算法都是基于BWT的,这两种算法通过参数-a is和-a bwtsw进行选择。其中-a bwtsw对于短的参考序列是不工作的,必须要大于等于10Mb;-a is是默认参数,这个参数不适用于大的参考序列,必须要小于等于2G。(2)寻找输入reads文件的SA坐标。对于pair end数据,每个reads文件单独做运算,single end数据就不用说了,只有一个文件。例子:pair end:bwaalnhg19.faread1.fq.gz-l 30-k 2-t 4-I read1.fq.gz.saibw

5、aalnhg19.faread2.fq.gz-l 30-k 2-t 4-I read2.fq.gz.saisingle end:bwaalnhg19.faread.fq.gz-l 30-k 2-t 4-I read.fq.gz.sai主要参数说明:-o int:允许出现的最大gap数。-e int:每个gap允许的最大长度。-d int:不允许在3端出现大于多少bp的deletion。-i int:不允许在reads两端出现大于多少bp的indel。-l int:Read前多少个碱基作为seed,如果设置的seed大于read长度,将无法继续,最好设置在25-35,与-k 2配合使用。-k i

6、nt:在seed中的最大编辑距离,使用默认2,与-l配合使用。-t int:要使用的线程数。-R int:此参数只应用于pair end中,当没有出现大于此值的最佳比对结果时,将会降低标准再次进行比对。增加这个值可以提高配对比对的准确率,但是同时会消耗更长的时间,默认是32。-I int:表示输入的文件格式为Illumina 1.3+数据格式。-B int:设置标记序列。从5端开始多少个碱基作为标记序列,当-B为正值时,在比对之前会将每个read的标记序列剪切,并将此标记序列表示在BC SAM标签里,对于pair end数据,两端的标记序列会被连接。-b:指定输入格式为bam格式。bwaaln

7、hg19.faread.bam read.fq.gz.sai(3)生成sam格式的比对文件。如果一条read比对到多个位置,会随机选择一种。例子:single end:bwasamsehg19.faread.fq.gz.sairead.fq.gz read.fq.gz.sam参数:-n int:如果reads比对次数超过多少次,就不在XA标签显示。-r str:定义头文件。RGtID:footSM:bar,如果在此步骤不进行头文件定义,在后续GATK分析中还是需要重新增加头文件。pair end:bwa sampe -a 500 read1.fq.gz.sai read2.fq.gz.sai

8、read1.fq.gz read2.fq.gz read.sam参数:-a int:最大插入片段大小。-o int:pair end两reads中其中之一所允许配对的最大次数,超过该次数,将被视为single end。降低这个参数,可以加快运算速度,对于少于30bp的read,建议降低-o值。-r str:定义头文件。同single end。-n int:每对reads输出到结果中的最多比对数。对于最后得到的sam文件,将比对上的结果提取出来(awk即可处理),即可直接用于GATK的分析。注意:由于GATK在下游的snpcalling时,是按染色体进行callsnp的。因此,在准备原始sam文

9、件时,可以先按染色体将文件分开,这样会提高运行速度。但是当数据量不足时,可能会影响后续的VQSR分析,这是需要注意的。2.对sam文件进行进行重新排序(reorder)由BWA生成的sam文件时按字典式排序法进行的排序(lexicographically)进行排序的(chr10,chr11chr19,chr1,chr20chr22,chr2,chr3chrM,chrX,chrY),但是GATK在进行callsnp的时候是按照染色体组型(karyotypic)进行的(chrM,chr1,chr2chr22,chrX,chrY),因此要对原始sam文件进行reorder。可以使用picard-to

10、ols中的ReorderSam完成。e.gjava -jar picard-tools-1.96/ReorderSam.jarI=hg19.samO=hg19.reorder_00.samREFERENCE=hg19.fa注意:1.这一步的头文件可以人工加上,同时要确保头文件中有的序号在下面序列中也有对应的。虽然在GATK网站上的说明chrM可以在最前也可以在最后,但是当把chrM放在最后时可能会出错。2.在进行排序之前,要先构建参考序列的索引。e.g. samtools faidx hg19.fa。最后生成的索引文件:hg19.fa.fai。3. 如果在上一步想把大文件切分成小文件的时候,头

11、文件可以自己手工加上,之后运行这一步就好了。3.将sam文件转换成bam文件(bam是二进制文件,运算速度快)这一步可使用samtools view完成。e.g. samtools view -bS hg19.reorder_00.sam -o hg19.sam_01.bam4.对bam文件进行sort排序处理这一步是将sam文件中同一染色体对应的条目按照坐标顺序从小到大进行排序。可以使用picard-tools中SortSam完成。e.g.java -jar picard-tools-1.96/SortSam.jarINPUT=hg19.sam_01.bamOUTPUT=hg19.sam.s

12、ort_02.bamSORT_ORDER=coordinate5.对bam文件进行加头(head)处理GATK2.0以上版本将不再支持无头文件的变异检测。加头这一步可以在BWA比对的时候进行,通过-r参数的选择可以完成。如果在BWA比对期间没有选择-r参数,可以增加这一步骤。可使用picard-tools中AddOrReplaceReadGroups完成。e.g.java -jar picard-tools-1.96/AddOrReplaceReadGroups.jarI=hg19.sam.sort_02.bamO=hg19.reorder.sort.addhead_03.bamID=hg19

13、IDLB=hg19IDPL=illuminePU=hg19PUSM=hg19ID str:输入reads集ID号;LB:read集文库名;PL:测序平台(illunima或solid);PU:测序平台下级单位名称(run的名称);SM:样本名称。注意:这一步尽量不要手动加头,本人尝试过多次手工加头,虽然看起来与软件加的头是一样的,但是程序却无法运行。6.Merge如果一个样本分为多个lane进行测序,那么在进行下一步之前可以将每个lane的bam文件合并。e.g.java -jar picard-tools-1.70/MergeSamFiles.jarINPUT=lane1.bamINPUT=

14、lane2.bamINPUT=lane3.bamINPUT=lane4.bamINPUT=lane8.bamOUTPUT=sample.bam7.Duplicates Marking在制备文库的过程中,由于PCR扩增过程中会存在一些偏差,也就是说有的序列会被过量扩增。这样,在比对的时候,这些过量扩增出来的完全相同的序列就会比对到基因组的相同位置。而这些过量扩增的reads并不是基因组自身固有序列,不能作为变异检测的证据,因此,要尽量去除这些由PCR扩增所形成的duplicates,这一步可以使用picard-tools来完成。去重复的过程是给这些序列设置一个flag以标志它们,方便GATK的识

15、别。还可以设置REMOVE_DUPLICATES=true来丢弃duplicated序列。对于是否选择标记或者删除,对结果应该没有什么影响,GATK官方流程里面给出的例子是仅做标记不删除。这里定义的重复序列是这样的:如果两条reads具有相同的长度而且比对到了基因组的同一位置,那么就认为这样的reads是由PCR扩增而来,就会被GATK标记。e.g.java -jar picard-tools-1.96/MarkDuplicates.jarREMOVE_DUPLICATES= falseMAX_FILE_HANDLES_FOR_READ_ENDS_MAP=8000INPUT=hg19.reor

16、der.sort.addhead_03.bamOUTPUT=hg19.reorder.sort.addhead.dedup_04.bam METRICS_FILE=hg19.reorder.sort.addhead.dedup_04.metrics注意:dedup这一步只要在library层面上进行就可以了,例如一个sample如果建了多个库的话,对每个库进行dedup即可,不需要把所有库合成一个sample再进行dedup操作。其实并不能准确的定义被mask的reads到底是不是duplicates,重复序列的程度与测序深度和文库类型都有关系。最主要目的就是尽量减小文库构建时引入文库的PCR

17、 bias。8.要对上一步得到的结果生成索引文件可以用samtools完成,生成的索引后缀是bai。e.g.samtools index hg19.reorder.sort.addhead.dedup_04.bam【原创】GATK使用方法详解(包含bwa使用)第二部分(2014-03-03 11:16:18)转载标签:gatkindelsnpbwa分类:生物信息9.Local realignment around indels这一步的目的就是将比对到indel附近的reads进行局部重新比对,将比对的错误率降到最低。一般来说,绝大部分需要进行重新比对的基因组区域,都是因为插入/缺失的存在,因为

18、在indel附近的比对会出现大量的碱基错配,这些碱基的错配很容易被误认为SNP。还有,在比对过程中,比对算法对于每一条read的处理都是独立的,不可能同时把多条reads与参考基因组比对来排错。因此,即使有一些reads能够正确的比对到indel,但那些恰恰比对到indel开始或者结束位置的read也会有很高的比对错误率,这都是需要重新比对的。Local realignment就是将由indel导致错配的区域进行重新比对,将indel附近的比对错误率降到最低。主要分为两步:第一步,通过运行RealignerTargetCreator来确定要进行重新比对的区域。e.g.java -jar Gen

19、omeAnalysisTK.jar-R hg19.fa-T RealignerTargetCreator-I hg19.reorder.sort.addhead.dedup_04.bam-o hg19.dedup.realn_06.intervals-known Mills_and_1000G_gold_standard.indels.hg19.vcf-known 1000G_phase1.indels.hg19.vcf参数说明:-R:参考基因组;-T:选择的GATK工具;-I:输入上一步所得bam文件;-o:输出的需要重新比对的基因组区域结果;-maxInterval:允许进行重新比对的基因

20、组区域的最大值,不能太大,太大耗费会很长时间,默认值500;-known:已知的可靠的indel位点,指定已知的可靠的indel位点,重比对将主要围绕这些位点进行,对于人类基因组数据而言,可以直接指定GATK resource bundle里面的indel文件(必须是vcf文件)。对于known sites的选择很重要,GATK中每一个用到known sites的工具对于known sites的使用都是不一样的,但是所有的都有一个共同目的,那就是分辨真实的变异位点和不可信的变异位点。如果不提供这些known sites的话,这些统计工具就会产生偏差,最后会严重影响结果的可信度。在这些需要知道k

21、nown sites的工具里面,只有UnifiedGenotyper和HaplotypeCaller对known sites没有太严格的要求。如果你所研究的对象是人类基因组的话,那就简单多了,因为GATK网站上对如何使用人类基因组的known sites做出了详细的说明,具体的选择方法如下表,这些文件都可以在GATKresource bundle中下载。TooldbSNP 129dbSNP 132Mills indels1KG indelsHapMapOmniRealignerTargetCreatorXXIndelRealignerXXBaseRecalibratorXXX(UnifiedG

22、enotyper/ HaplotypeCaller)XVariantRecalibratorXXXXVariantEvalX但是如果你要研究的不是人类基因组的话,那就有点麻烦了,http:/www.broadinstitute.org/gatk/guide/article?id=1243,这个网站上是做非人类基因组时,大家分享的经验,可以参考一下。这个known sites如果实在没有的话,也是可以自己构建的:首先,先使用没有经过矫正的数据进行一轮SNP calling;然后,挑选最可信的SNP位点进行BQSR分析;最后,在使用这些经过BQSR的数据进行一次真正的SNP calling。这几步

23、可能要重复好多次才能得到可靠的结果。第二步,通过运行IndelRealigner在这些区域内进行重新比对。e.g.java -jar GenomeAnalysisTK.jar-R hg19.fa-T IndelRealigner-targetIntervals hg19.dedup.realn_06.intervals-I hg19.reorder.sort.addhead.dedup_04.bam-o hg19.dedup.realn_07.bam-known Mills_and_1000G_gold_standard.indels.hg19.vcf-known 1000G_phase1.i

24、ndels.hg19.vcf运行结束后,生成的hg19.dedup.realn_07.bam即为最后重比对后的文件。注意:1.第一步和第二步中使用的输入文件(bam文件)、参考基因组和已知indel文件必须是相同的文件。2.当在相同的基因组区域发现多个indel存在时,这个工具会从其中选择一个最有可能存在比对错误的indel进行重新比对,剩余的其他indel不予考虑。3.对于454下机数据,本工具不支持。此外,这一步还会忽略bwa比对中质量值为0的read以及在CIGAR信息中存在连续indel的reads。10.Base quality score recalibration这一步是对bam

25、文件里reads的碱基质量值进行重新校正,使最后输出的bam文件中reads中碱基的质量值能够更加接近真实的与参考基因组之间错配的概率。这一步适用于多种数据类型,包括illunima、solid、454、CG等数据格式。在GATK2.0以上版本中还可以对indel的质量值进行校正,这一步对indel calling非常有帮助举例说明,在reads碱基质量值被校正之前,我们要保留质量值在Q25以上的碱基,但是实际上质量值在Q25的这些碱基的错误率在1%,也就是说质量值只有Q20,这样就会对后续的变异检测的可信度造成影响。还有,在边合成边测序的测序过程中,在reads末端碱基的错误率往往要比起始部

26、位更高。另外,AC的质量值往往要低于TG。BQSR的就是要对这些质量值进行校正。BQSR主要有三步:第一步:利用工具BaseRecalibrator,根据一些known sites,生成一个校正质量值所需要的数据文件,GATK网站以“.grp”为后缀命名。e.g.java -jar GenomeAnalysisTK.jar-T BaseRecalibrator-R hg19.fa-I ChrALL.100.sam.dedup.realn.07.bam-knownSites dbsnp_137.hg19.vcf-knownSites Mills_and_1000G_gold_standard.i

27、ndels.hg19.vcf-knownSites 1000G_phase1.indels.hg19.vcf-o ChrALL.100.sam.recal.08-1.grp第二步:利用第一步生成的ChrALL.100.sam.recal.08-1.grp来生成校正后的数据文件,也是以“.grp”命名,这一步主要是为了与校正之前的数据进行比较,最后生成碱基质量值校正前后的比较图,如果不想生成最后BQSR比较图,这一步可以省略。e.g.java -jar GenomeAnalysisTK.jar-T BaseRecalibrator-R hg19.fa-I ChrALL.100.sam.dedup

28、.realn.07.bam-BQSR ChrALL.100.sam.recal.08-1.grp-o GATK/hg19.recal.08-2.grp-knownSites dbsnp_137.hg19.vcf-knownSites Mills_and_1000G_gold_standard.indels.hg19.vcf-knownSites 1000G_phase1.indels.hg19.vcf第三步:利用工具PrintReads将经过质量值校正的数据输出到新的bam文件中,用于后续的变异检测。e.g.java -jar GenomeAnalysisTK.jar-T PrintReads

29、-R hg19.fa-I ChrALL.100.sam.dedup.realn.07.bam-BQSR ChrALL.100.sam.recal.08-1.grp-o ChrALL.100.sam.recal.08-3.grp.bam主要参数说明:-bqsrBAQGOP:BQSR BAQ gap open罚值,默认值是40,如果是对全基因组数据进行BQSR分析,设置为30会更好。-lqt:在计算过程中,该算法所能考虑的reads两端的最小质量值。如果质量值小于该值,计算过程中将不予考虑,默认值是2。注意:(1)当bam文件中的reads数量过少时,BQSR可能不会正常工作,GATK网站建议base数量要大于100M才能得到比较好的结果。(2)除非你所研究的样本所得到的reads数实在太少,或者比对结果中的mismatch基本上都是实际存在的变异,否则必须要进行BQSR这一步。对于人类基因组,即使有了dbSNP和千人基因组的数据,还有很多mismatch是错误的。因此,这一步能做一定要做。11.分析和评估BQSR结果这一步会生成评估前后碱基质量值的比较结果,可以选择使用图片和表格的形式展示。e.g.java -jar GenomeAnalysisTK.jar-T Analy

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1