This is the description of the IARC workflow to call somatic mutations with needlestack on targeted sequencing data.
Usually, IARC data are generating with an IonTorrent Proton sequencer.
Here samples are sequenced twice to remove library-preparation errors.
This workflow contains 5 disctinct steps:
abra2 is a NGS realigner that uses localized assembly and global realignment to improve detection of complex variant such as insertion or deletion.
IARC bioinformatic platform has developed an abra nextflow pipeline for a user-friendly usage of the software.
Command line example:
nextflow run iarcbioinfo/abra-nf --bed myBedFile.bed --ref genome.fasta --abra_path pathToAbra.jar --single --bam_folder BAM/ --output_folder abra_output/
It takes around 30min on one BAM from ~1500 positions in 10,000X.
The process can be parallelized with the option --threads (e.g. --threads 6).
QC3 is a quality control tools for 3 types of data: sequencing, alignment and variant calling.
The tool has been optimized by the IARC bioinformatic platform to decrease computation time when used on target-sequencing data which generates highly covered positions. See our github repo.
Command line example:
qc3.pl -m b -i list_bam.txt -o output_folder -r myBedFile.bed -nod -cm 2 -no_batch -d -d_cumul 1000,5000,10000
This example computes (amongst other things) the median depth, for each postion in the target bed file for each sample in the list_bam.txt file. Thanks to option -nod, untarget depth is not computed at all.
We recommand to reserve a lot of memory and to use option -t
to run the tool on multiple threads (e.g. -t 24).
To contruct the list_bam.txt file, a possibility is to run:
find /whole_path_to_bam_files/*bam > list_bam.txt
Samples are sequenced in technical duplicates, and those with a median coverage less than a particular threshold in at least one of the two libraries need to be remove to avoid technical artifacts.
This R script extracts those samples.
Once the bad samples are identified, the next step is to remove them in the folder used for the variant calling with needlestack (a good practice would be to create a new BAM folder and then make symlinks before removing bad samples).
needlestack is a variant caller developed at IARC. It shows promising results on ctDNA data due to its ability to detect low allelic fraction mutations, until 10-4 if sequencing error rate sufficiently low.
Command line example:
nextflow run iarcbioinfo/needlestack -r v1.0 --bed /data/delhommet/needlestack_callings/ctDNA-TP53-RB1/Bedfile_TP53_Exon2_11_RB1_Exon2_27_04-04-2016.bed --bam_folder abra_output_folder --fasta_ref genome.fasta --nsplit 100 --map_qual 0 --base_qual 13 --max_DP 80000 --out_folder needlestack_output --min_qval 30 --out_vcf variants.vcf
annovar is an efficient tool which performs 3-levels genetic variant annotation (position, gene, region).
Command line example :
nextflow run vcf_annovar.nf --vcf variants.vcf
The script vcf_annovar.nf is a nextflow script to run annovar in parallel, by sample.
The annovar executable table_annovar.pl needs to be present in the $PATH.
If not defined in the nextflow configuration file, the parameter --avdb needs to be defined in input, to precise the location of the annovar database used.
target-seq_analysis.r filters the output of annovar on bad samples and positions, as well as on mutation not present in the two technical duplicates:
-
filtering on samples with at least one of the two libraries harboring an unexpected high number of mutations. This increases the probability to having an error present in the two libraries (code).
-
filtering on positions with a high number of positive libraries that do not cluster in pairs. To extract these positions, we compute the probability of observing the particular number of paired positive libraries given the total number of positive libraries, just by chance (code).
-
filtering on variant that are found near an high allelic variant, to remove alignment artefacts (code).
-
filtering on mutations that are not present in both technical duplicate to remove library-preparation errors (code).