Skip to content

Latest commit

 

History

History
207 lines (139 loc) · 14.2 KB

README.md

File metadata and controls

207 lines (139 loc) · 14.2 KB

nf-core/variantbenchmarking

GitHub Actions CI Status GitHub Actions Linting StatusAWS CICite with Zenodo nf-test

Nextflow run with conda run with docker run with singularity Launch on Seqera Platform

Get help on SlackFollow on TwitterFollow on MastodonWatch on YouTube

Introduction

nf-core/variantbenchmarking is designed to evaluate and validate the accuracy of variant calling methods in genomic research. Initially, the pipeline is tuned well for available gold standard truth sets (for example, Genome in a Bottle and SEQC2 samples) but it can be used to compare any two variant calling results. The workflow provides benchmarking tools for small variants including SNVs and INDELs, Structural Variants (SVs) and Copy Number Variations (CNVs) for germline and somatic analysis.

The pipeline is built using Nextflow, a workflow tool to run tasks across multiple compute infrastructures in a very portable manner. It uses Docker/Singularity containers making installation trivial and results highly reproducible. The Nextflow DSL2 implementation of this pipeline uses one container per process which makes it much easier to maintain and update software dependencies. Where possible, these processes have been submitted to and installed from nf-core/modules in order to make them available to all nf-core pipelines, and to everyone within the Nextflow community!

The workflow involves several key processes to ensure reliable and reproducible results as follows:

Standardization and normalization of variants:

This initial step ensures consistent formatting and alignment of variants in test and truth VCF files for accurate comparison.

  • Subsample if input test vcf is multisample (bcftools view)
  • Homogenization of multi-allelic variants, MNPs and SVs (including imprecise paired breakends and single breakends) (variant-extractor)
  • Reformatting test VCF files from different SV callers (svync)
  • Rename sample names in test and truth VCF files (bcftools reheader)
  • Splitting multi-allelic variants in test and truth VCF files (bcftools norm)
  • Deduplication of variants in test and truth VCF files (bcftools norm)
  • Left aligning of variants in test and truth VCF files (bcftools norm)
  • Use prepy in order to normalize test files. This option is only applicable for happy benchmarking of germline analysis (prepy)
  • Split SNVs and indels if the given test VCF contains both. This is only applicable for somatic analysis (bcftools view)

Filtering options:

Applying filtering on the process of benchmarking itself might makes it impossible to compare different benchmarking strategies. Therefore, for whom like to compare benchmarking methods this subworkflow aims to provide filtering options for variants.

Liftover of vcfs:

This sub-workflow provides option to convert genome coordinates of truth VCF and test VCFs and high confidence BED file to a new assembly. Golden standard truth files are build upon specific reference genomes which makes the necessity of lifting over depending on the test VCF in query. Lifting over one or more test VCFs is also possible.

Statistical inference of input test and truth variants:

This step provides insights into the distribution of variants before benchmarking by extracting variant statistics:.

Benchmarking of variants:

Actual benchmarking of variants are split between SVs and small variants:

Available methods for germline and somatic structural variant (SV) benchmarking are:

Note

Please note that there is no somatic specific tool for SV benchmarking in this pipeline.

Available methods for germline and somatic CNVs (copy number variations) are:

Note

Please note that there is no somatic specific tool for CNV benchmarking in this pipeline.

Available methods for small variants: SNVs and INDELs:

  • Germline variant benchmarking using (rtg vcfeval)
  • Germline variant benchmarking using (hap.py)
  • Somatic variant benchmarking using (som.py)

Intersection of benchmark regions:

Intersecting test and truth BED regions produces benchmark metrics. Intersection analysis is especially recommended for CNV benchmarking where result reports may variate per tool.

  • Convert SV or CNV VCF file to BED file, if no regions file is provided for test case using (SVTK vcf2bed)
  • Convert VCF file to BED file, if no regions file is provided for test case using (Bedops convert2bed)
  • Intersect the regions and gether benchmarking statistics using (bedtools intersect)

Comparison of benchmarking results per TP, FP and FN files

It is essential to compare benchmarking results in order to infer uniquely or commonly seen TPs, FPs and FNs.

  • Merging TP, FP and FN results for happy, rtgtools and sompy (bcftools merge)
  • Merging TP, FP and FN results for Truvari and SVanalyzer (SURVIVOR merge)
  • Conversion of VCF files to CSV to infer common and unique variants per caller (python script)

Reporting of benchmark results

The generation of comprehensive report that consolidates all benchmarking results.

  • Merging summary statistics per benchmarking tool (python script)
  • Plotting benchmark metrics per benchmarking tool (R script)
  • Create visual HTML report for the integration of NCBENCH (datavzrd)
  • Apply MultiQC to visualize results

Usage

Note

If you are new to Nextflow and nf-core, please refer to this page on how to set-up Nextflow. Make sure to test your setup with -profile test before running the workflow on actual data.

First, prepare a samplesheet with your input data that looks as follows:

samplesheet.csv:

id,test_vcf,caller
test1,test1.vcf.gz,delly
test2,test2.vcf,gatk
test3,test3.vcf.gz,cnvkit

Each row represents a vcf file (test-query file). For each vcf file and variant calling method (caller) have to be defined.

User has to provide truth_vcf and truth_id in config files.

Note

There are publicly available truth sources. For germline analysis, it is common to use genome in a bottle (GiAB) variants. There are variate type of golden truths and high confidence regions for hg37 and hg38 references. Please select and use carefully. For somatic analysis, SEQC2 project released SNV, INDEL and CNV regions. One, can select and use those files.

For more details and further functionality, please refer to the usage documentation and the parameter documentation.

Now, you can run the pipeline using:

nextflow run nf-core/variantbenchmarking \
   -profile <docker/singularity/.../institute> \
   --input samplesheet.csv \
   --outdir <OUTDIR> \
   --genome GRCh37 \
   --analysis germline \
   --truth_id HG002 \
   --truth_vcf truth.vcf.gz

Warning

Please provide pipeline parameters via the CLI or Nextflow -params-file option. Custom config files including those provided by the -c Nextflow option can be used to provide any configuration except for parameters; see docs. Conda profile is not available for SVanalyzer (SVBenchmark) tool, if you are planing to use the tool either choose docker or singularity.

Pipeline output

To see the results of an example test run with a full size dataset refer to the results tab on the nf-core website pipeline page. For more details about the output files and reports, please refer to the output documentation.

This pipeline outputs benchmarking results per method besides to the inferred and compared statistics.

Credits

nf-core/variantbenchmarking was originally written by Kübra Narcı (@kubranarci) as a part of benchmarking studies in German Human Genome Phenome Archieve Project (GHGA).

We thank the following people for their extensive assistance in the development of this pipeline:

Acknowledgements

GHGA

Contributions and Support

If you would like to contribute to this pipeline, please see the contributing guidelines.

For further information or help, don't hesitate to get in touch on the Slack #variantbenchmarking channel (you can join with this invite).

Citations

If you use nf-core/variantbenchmarking for your analysis, please cite it using the following doi: 110.5281/zenodo.14916661

An extensive list of references for the tools used by the pipeline can be found in the CITATIONS.md file.

You can cite the nf-core publication as follows:

The nf-core framework for community-curated bioinformatics pipelines.

Philip Ewels, Alexander Peltzer, Sven Fillinger, Harshil Patel, Johannes Alneberg, Andreas Wilm, Maxime Ulysse Garcia, Paolo Di Tommaso & Sven Nahnsen.

Nat Biotechnol. 2020 Feb 13. doi: 10.1038/s41587-020-0439-x.