NCCL 肿瘤生信室间质评
注:此篇文章介绍2024年卫健委肿瘤生信室间质评的分析方案,纯手工敲命令,未建立流程(意味着用相同版本的相同软件和相同命令能获得相同的结果哦)。
使用Illumina平台的数据作为例子。
检测要求: 1,检测出测序 Panel 中包含的所有体细胞突变(somatic mutation); 2,Illumina 测序文件:需对突变频率VAF≥1%且原始数据测序深度(Read depth)>500X的位 点进行回报。
叠甲: 此篇文章在2024年7月18日发布,2024年7月17日 质评已截止回报。
数据处理
先对202411以及2024NC两个样本均使用相同的方案获得bam文件,以202411为例。使用更新的软件理论可获得更准确的效果或者更佳的效率,但是环境里有啥就用啥了。
mkdir cleandata bam vcf fusion cnv annotation QC
数据质控
使用fastp(0.14.1)对原始数据进行质控。
fastp \
-i 202411_R1.fq.gz \
-I 202411_R2.fq.gz \
-o cleandata/202411_R1.fq.gz \
-O cleandata/202411_R2.fq.gz \
-j QC/202411.json \
-h QC/202411.html \
-w 16
比对
使用bwa(0.7.17-r1188)/ samtools(1.5)进行比对。用自己的hg19参考基因组就好,应该没人没有bwa吧。
bwa mem -t 16 -M -Y \
-R "@RG\tPL:NCCL\tPU:illumina\tSM:202411\tID:mapping" \
ucsc.hg19.fasta \
cleandata/202411_R1.fq.gz cleandata/202411_R2.fq.gz | \
samtools view -bSh | samtools sort -@ 16 - -o bam/202411.sort.bam
samtools index bam/202411.sort.bam
标记重复
使用gatk(4.5.0.0,下同)MarkDuplicates进行重复标记。
gatk MarkDuplicates \
-I bam/202411.sort.bam \
-O bam/202411.marked.bam \
-M bam/202411.marked.txt \
--CREATE_INDEX true
mv bam/202411.marked.bai bam/202411.marked.bam.bai
接下来本应进行BQSR的,但是考虑室间质评的数据质量足够好,省去这一步。预处理完成的bam就可以同时进行下面的分析了。
质控统计
使用bamdst(1.0.9)进行统计。
mkdir QC/202411
bamdst -p Illumina.bed bam/202411.marked.bam -o QC/202411
变异检测
使用gatk Mutect2 进行SNV/InDel检测。这里也不加入人群数据库和PoN了。常规生产中,还要使用-ip参数将bed放大一定大小来覆盖剪接区,这里也不用。
# gatk 4.5不需要指定tumor样本名称,默认都是tumor样本
gatk Mutect2 \
-R ucsc.hg19.fasta \
-I bam/202411.marked.bam \
-I bam/2024NC.marked.bam \
-normal 2024NC \
--max-reads-per-alignment-start 0 \
-L Illumina.bed \
-O vcf/202411.vcf.gz \
--native-pair-hmm-threads 16
gatk FilterMutectCalls \
-R ucsc.hg19.fasta \
-V vcf/202411.vcf.gz \
-O vcf/202411.filtered.vcf.gz
# 我习惯最后做一个左对齐和切割多方向突变位点
gatk LeftAlignAndTrimVariants \
-R ucsc.hg19.fasta \
-V vcf/202411.filtered.vcf.gz \
-O vcf/202411.filtered.left.vcf \
--split-multi-allelics
使用bcftools(1.17)提取出PASS的位点,并进行深度和突变丰度过滤,满足室间质评要求。为了避免过滤过于严苛,不要直接把深度设置为500。不建议直接提取PASS的突变,这样可能会导致某些突变假阴性,根据NCCL的规则,去掉对照背景就好。
bcftools filter -i 'FORMAT/DP>=200 && FORMAT/AF>=0.01' -o vcf/202411.pass.vcf -O v vcf/202411.filtered.left.vcf
cat vcf/202411.pass.vcf | grep -v "normal_artifact" > vcf/202411.final.vcf
经过上述处理,获得29个体细胞突变。
下面可以各自用自己的注释方案进行注释,按照3'原则进行校正等等咯,VEP等工具在设置参数里可以指定3'原则,在结果中的HGVSg即是已校正的基因组坐标了。最终的结果是必然需要人工复核的,不要想着结果直出直接回报。经过核对,上述的29个突变均可回报。
融合检测
使用manta(1.6.0)进行融合检测。
# manta需要bgzip压缩的bed文件,当然,也可以选择不传入
bgzip Illumina.bed -c > Illumina.bed.gz
tabix -p bed Illumina.bed.gz
# 配置manta
configManta.py \
--bam bam/2024NC.marked.bam \
--tumorBam bam/202411.marked.bam \
--exome --runDir fusion \
--referenceFasta ucsc.hg19.fasta \
--callRegions Illumina.bed.gz
# 运行
runWorkflow.py -j 16
zcat fusion/results/variants/somaticSV.vcf.gz > fusion/202411.manta.vcf
# 使用snpeff注释
java -jar snpEff.jar hg19 fusion/202411.manta.vcf > fusion/202411.manta.snpeff.vcf
CNV检测
使用CNVkit(0.9.11)进行检测,需要先建立target和antitarget区域。anti region和refFlat都可以在ucsc找到。
# bed文件预处理
cnvkit.py access ucsc.hg19.fasta \
-x wgEncodeDukeMapabilityRegionsExcludable.bed \
-o access.hg19.bed
cnvkit.py target Illumina.bed \
--annotate refFlat.txt \
-o Illumina.target.bed \
--short-names
cnvkit.py antitarget Illumina.target.bed \
-g access.hg19.bed \
-o Illumina.antitarget.bed
# 接下来获得coverage文件
cnvkit.py coverage bam/202411.marked.bam Illumina.target.bed -o cnv/202411.targetcoverage.cnn
cnvkit.py coverage bam/202411.marked.bam Illumina.antitarget.bed -o cnv/202411.antitargetcoverage.cnn
cnvkit.py coverage bam/2024NC.marked.bam Illumina.target.bed -o cnv/2024NC.targetcoverage.cnn
cnvkit.py coverage bam/2024NC.marked.bam Illumina.antitarget.bed -o cnv/2024NC.antitargetcoverage.cnn
# 将对照样本形成参考基线
cnvkit.py reference cnv/2024NC.targetcoverage.cnn cnv/2024NC.antitargetcoverage.cnn -f ucsc.hg19.fasta -o cnv/reference.cnn
# 分析CNV
cnvkit.py fix cnv/202411.targetcoverage.cnn cnv/202411.antitargetcoverage.cnn cnv/reference.cnn -o cnv/202411.cnr
# 获得每个划窗的拷贝数值
cnvkit.py call cnv/202411.cnr -o cnv/202411.cns
# 获得segment后的结果
cnvkit.py segment cnv/202411.cnr -o cnv/202411.seg.cnr
cnvkit.py call cnv/202411.seg.cnr -o cnv/202411.seg.cns
CNVkit输出的结果非常多,我建议是将划窗结果复制到excel表中,通过log2值计算确切的Copy Number,然后再手动筛选。
根据经验,筛选CN值大于4的外显子即可,从筛选结果中挑选回报基因和确认外显子,貌似未试过回报缺失。