ANNOVAR


ANNOVAR is a bioinformatics software tool for the interpretation and prioritization of single nucleotide variants, insertions, deletions, and copy number variants of a given genome. It has the ability to annotate human genomes hg18, hg19, hg38, and model organisms genomes such as: mouse, zebrafish, fruit fly '', roundworm, yeast and many others. The annotations could be used to determine the functional consequences of the mutations on the genes and organisms, infer cytogenetic bands, report functional importance scores, and/or find variants in conserved regions. ANNOVAR along with SNP effect and Variant Effect Predictor are three of the most commonly used variant annotation tools.

Background

The cost of high throughput DNA sequencing has reduced drastically from around $100 million/human genome in 2001 to around $1000/human genome in 2017.. Due to this increase in accessibility, high throughput DNA sequencing has become more widely used in research and clinical settings. Some common areas that utilize high throughput DNA sequencing extensively are: Whole Exome Sequencing, Whole Genome Sequencing, and genome wide association studies.
There are a growing number of tools available seeking to comprehensively manage, analyze and interpret the enormous amount of data generated from high-throughput DNA sequencing. The tools are required to be efficient and robust enough to analyze a large number of variants though sensitive enough to identify rare and clinically relevant variants that are likely harmful/deleterious. ANNOVAR was developed by Dr. Kai Wang in 2010 at the Center for Applied Genomics in the University of Pennsylvania. It is a type of variant annotation tool that compiles deleterious genetic variant prediction scores from programs such as PolyPhen, ClinVar, and CADD and annotates the SNVs, insertions, deletions, and CNVs of the provided genome. ANNOVAR is one of the first efficient, configurable, extensible and cross-platform compatible variant annotation tools created.
In terms of the larger bioinformatics workflow, ANNOVAR fits in near the end, after DNA sequencing reads having between mapped, aligned, and variants have been predicted from an alignment file, also known as variant calling. This process will produce a resultant VCF file, a tab-separated text file in a tabular like structure, containing genetic variants as rows. This file can then be used as input into the ANNOVAR software program for the variant annotation process, outputting interpretations of the variants identified from the upstream bioinformatics pipeline.

Types of functional annotation of genetic variants

Gene-based annotation

This approach identifies whether the input variants cause protein coding changes and the amino acids that are affected by the mutations. The input file can be composed of exons, introns, intergenic regions, splice acceptor/donor sites, and 5′/3′ untranslated regions. The focus is to explore the relationship between non-synonymous mutations and their functional impact on known genes. Especially, gene-based annotation will highlight the exact amino acid change if the mutation is in the exonic region and the predicted effect on the function of the known gene. This approach is useful for identifying variants in known genes from Whole Exome Sequencing data.

Region-based annotation

This approach identifies deleterious variants in specific genomic regions based on the genomic elements around the gene. Some categories region-based annotation will take into account are:
1) Is the variant in a known conserved genomic region?
Mutations occur during mitosis and meiosis. If there is no selective pressure for specific nucleotide sequences, then all areas of a genome would be mutated are equal rates. The genomic regions that are highly conserved indicate genomic sequences that are essential to the organism's survival and/or reproductive success. Thus, if the variant disrupts a highly conserved region, the variant is likely highly deleterious.
2) Is the variant in a predicted transcription factor binding site?
DNA is transcribed into messenger RNA by RNA polymerase II. This process can be modulated transcription factors which can enhance or inhibit binding of RNApol II. If the variant disrupts a transcription factor binding site then transcription of the gene could be altered causing changes in gene expression level and/or protein production amount. This changes could cause phenotypic variations.
3) Is the variant in a predicted miRNA target site?
MicroRNA is a type of RNA that complementary binds to targeted mRNA sequence to suppress or silence the translation of the mRNA. If the variant disrupts the miRNA target location, the miRNA could have altered binding affinity to the corresponding gene transcript thus changing the mRNA expression level of the transcript. This could further impact protein production levels which could cause phenotypic variations.
4) Is the variant predicted to interrupt a stable RNA secondary structure?
RNA can function at the RNA level as non-coding RNA or be translated into proteins for downstream processes. RNA secondary structures are extremely important in determining the correct half-life and function of those RNA. Two RNA species with tightly regulated secondary structures are ribosomal RNA and transfer RNA which are essential in translation of mRNA to protein. If the variant disrupts the stability of the RNA secondary structure, the half-life of the RNA could be shortened thus lowering the concentration of RNA in the cell.
Non-coding regions encompasses 99% of the human genome and region-based annotation is extremely useful in identifying variants in those regions. This approach can be used on WGS data.

Filter-based annotation

This approach identifies variants that are documented in specific databases. The variants could be obtained from dbSNP, 1000 Genomes Project, or user-supplied list. Additional information could be obtained from the frequency of the variants from the above databases or the predicted deleterious scores created by PolyPhen, CADD, ClinVar or many others. The more infrequent a variant appears in the public database, the more deleterious it is likely to be. Results from different deleterious score prediction tools can combined together by the researcher to make a more accurate call on the variant.
Taken together, these approaches complement one another to filter through over 4 million variants in a human genome. Common, low-deleterious score variants are eliminated to reveal the rare, high-deleterious score variants which could be causal for congenital diseases.

Technical information

ANNOVAR is a command-line tool written in the Perl programming language and can be run on any operating system that has a Perl interpreter installed. If used for non-commercial purposes, it is available free as an open-source package that is downloadable through the ANNOVAR website. ANNOVAR can process most next-generation sequencing data which has been run through a variant calling software.
ScriptPurposeDescriptionInputOutputRequirements
annotate_variation.plvariant annotatorThe core script, which functionally annotates the genetic variants via gene-based, region-based, and/or filter-based annotation..avinput.avinputData sources are downloaded for annotation, e.g. hg38, UCSC, 1000 Genomes Project.
convert2annovar.plfile converterConverts various file formats to the custom ANNOVAR input file format.See "Conversion to the ANNOVAR input file format" section..avinput
table_annovar.plautomated variant annotatorA wrapper around annotate_variation.pl that can take VCF format along with the ANNOVAR format, performs annotation and outputs an Excel-compatible file. Ideal for beginners..avinput, CSV, TSV, VCFCSV, TSV, VCF, TXTData sources are downloaded for annotation, e.g. hg38, UCSC, 1000 Genomes Project.
variants_reduction.plvariant reducerPerforms stepwise variant reduction on a large set of input variants to narrow down to a subset of functionally important variants. Filtering procedures include: Applies a stepwise procedure of filtering to identify subsets of variants that are likely to be related to a disease. Such filtering procedures include:
  • identifying non-synonymous and splicing variants
  • removing variants in segmental duplication regions
  • identifying conserved genomic regions
  • removing variants from 1000 Genomes Project, ESP6500 and dbSNP
.avinput.avinputGene-based annotation data sources and various filter-based annotation data sources are downloaded.

File formats

The ANNOVAR software accepts text-based input files, including VCF, the gold standard for describing genetic loci.
The program's main annotation script, annotate_variation.pl requires a custom input file format, the ANNOVAR input format. Common file types can be converted to ANNOVAR input format for annotation using a provided script. It is a simple text file where each line in the file corresponds to a variant and within each line are tab-delimited columns representing the basic genomic coordinate fields, followed by optional columns
The ANNOVAR file input contains the following basic fields:
For basic "out-of-the-box" usage:
A popular function of the ANNOVAR tool is the use of the table_annovar.pl script which simplifies the workflow into one single command-line call, given that the data sources for annotation have already been downloaded. File conversion from VCF file is handled within the function call, followed by annotation and output to an Excel-compatible file. The script takes a number of parameters for annotation and outputs a VCF file with the annotations as key-value pairs inside of the INFO column of the VCF file for each genetic variant, e.g. "genomic_function=exonic".

Conversion to the ANNOVAR input file format

File conversion to the ANNOVAR input format is possible using the provided file format conversion script convert2annovar.pl. The program accepts common file formats outputted by upstream variant calling tools. Subsequent functional annotation scripts annotate_variation.pl use the ANNOVAR input file. File formats that are accepted by the convert2annovar.pl include the following:
Generating input files based on specific variants, transcripts, or genomic regions:
When investigating candidate loci that are linked to diseases, using the above variant calling file formats as input to ANNOVAR is a standard workflow for functional annotation of genetic variants outputted from an upstream bioinformatics pipeline. ANNOVAR can also be used to in other scenarios, such as interrogating a set of genetic variants of interest based on a list of dbSNP identifiers as well as variants within specific genomic or exomic regions.
In the case of dbSNP identifiers, providing to the convert2annovar.pl script a list of identifiers in a text file along with the reference genome of interest as a parameter, ANNOVAR will output an ANNOVAR input file with the genomic coordinate fields for those variants which can then be used for functional annotation.
In the case of genomic regions, one can provide a genomic range of interest along with the reference genome of interest and ANNOVAR will generate an ANNOVAR input file of all the genetic loci spanning that range. In addition, insertion and deletion size could also be specified in which the script will select all the genetic loci where a specific size of interest insertion or deletion is found.
Last, if looking at variants within specific exonic regions, users can generate ANNOVAR input files for all possible variants in exons when theconvert2annovar.pl script is provided an RNA transcript identifier based on the standard HGVS nomenclature.

Output file

The possible output files are an annotated.avinput file, CSV, TSV, or VCF. Depending on the annotation strategy taken, the input and output files will differ. It is possible to configure the output file types given a specific input file, by providing the program the appropriate parameter.
For example, for the table_annovar.pl program, if the input file is VCF, then the output will also be a VCF file. If the input file is of the ANNOVAR input format type, then the output will be a TSV by default, with the option to output to CSV if the -csvout parameter is specified. By choosing CSV or TSV as the output file type, a user could open the files to view the annotations in Excel or a different spreadsheet software application. This is a popular feature among users.
The output file will contain all the data from the original input file with additional columns for the desired annotations. For example, when annotating variants with characteristics such as genomic function and the functional role of the coding variant, the output file will contain all the columns from the input file, followed additional columns "genomic_function" and "coding_variant_function".

System efficiency

Benchmarked on a modern desktop computer, for 4.7 million variants, ANNOVAR requires ~4 minutes to perform gene-based functional annotation, or ~15 minutes to perform stepwise "variants reduction". It is said to be practical for performing variant annotation and variant prioritization on hundreds of human genomes in a day.
ANNOVAR could be sped up by using the -thread argument which enables multi-threading so that input files could be processed in parallel.

Data resources

To use ANNOVAR for functional annotation of variants, annotation datasets can be downloaded using the annotate_variation.pl script, which saves them to local disk. Different annotation data sources are used for the three major types of annotation.
These are some of the data sources for each annotation type:

Gene-based annotation

Given the large number of data sources for filter-based annotation, here are examples of which subsets of the datasets to use for a few of the most common use cases.
  1. For frequency of variants in whole-exome data:
  2. # ExAC: with allele frequencies for all ethnic groups
  3. # NHLBI-ESP: from 6500 exomes, use three population groupings
  4. # gnomAD allele frequency: with allele frequencies for multiple populations
  5. For disease-specific variants:
  6. # ClinVar: with individual columns for each ClinVar field for each variant
  7. # COSMIC: somatic mutations from cancer and the frequency of occurrence in each subtype of cancer
  8. # ICGC: mutations from the International Cancer Genome Consortium
  9. # NCI-60: human tumor cell panel exome sequencing allele frequency data

    Example application

Using ANNOVAR for prioritization of genetic variants to identify mutations in a rare genetic disease

ANNOVAR is one of the common annotation tools for identifying candidate and causal mutations and genes for rare genetic diseases.
Using a combination of gene-based and filter-based annotation followed by variant reduction based on the annotation values of the variants, the causal gene in a rare recessive Mendelian disease called Miller syndrome can be identified.
This will involve synthesizing a genome-wide data set of ~4.2 million single nucleotide variants ' and ~0.5 million insertions and deletions.. Two known causal mutations for Miller syndrome are also included
Steps in identifying the causal variants for the disease using ANNOVAR:
  1. Gene-based annotation to identify exonic/splicing variants of the combination of SNVs and indels where a total of 24,617 exonic variants are identified.
  2. Since Miller syndrome is a rare Mendelian disease, exonic protein-changing variants are of interest only, which makes up 11,166.. From that, 4860 variants are identified that falls in highly conserved genomic regions
  3. As public databases such as dbSNP and 1000 Genomes Project archive previously reported variants which are often common, it is less likely that they will contain the Miller syndrome causal variants which are rare. Hence, variants found in those data sources are filtered out and 413 variants remain.
  4. Then, genes are assessed for whether multiple variants exist in the same gene as compound heterozygotes and 23 genes are left.
  5. Finally, ‘dispensable’ genes are removed, those which have high-frequency non-sense mutations which are susceptible to sequencing and alignment errors in short-read sequencing platform.. These genes are considered less likely to be causal of a rare Mendelian disease. Three genes as result are filtered out, and 20 candidate genes are leftover, including the causal gene DHODH''

    Limitations of ANNOVAR

Two limitations of ANNOVAR relate to detection of common diseases and larger structural variant annotations. These problems are present in all current variant annotation tools.
Most common diseases such as diabetes and Alzheimer have multiple variants throughout the genome which are common in the population. These variants are expected to have low individual deleterious scores and cause disease though the accumulation of multiple variants. However ANNOVAR has default "variant-reduction" schemes that provides a small list of rare and highly predicted deleterious variants. These default settings could be optimized so the output data would display additional variants with decreasing predicted deleterious scores. ANNOVAR is primarily used for identifying variants involved rare diseases where the causal mutation is expected to be rare and highly deleterious.
Larger structural variants such as chromosomal inversions, translocations, and complex SVs have been shown to cause diseases such as haemophilia A and Alzheimer's.. However, SVs are often difficult to annotate because it is difficult to assign specific deleterious scores to large mutated genomic regions. Currently, ANNOVAR can only annotate genes contained within deletions or duplications, or small indels of <50bp. ANNOVAR cannot infer complex SVs and translocations

Alternate variant annotation tools

There are also two other types of SNP annotation tools that are similar to ANNOVAR: SNP effect and Variant Effect Predictor. Many of the features between ANNOVAR, SnpEFF, and VEP are the same including the input and output file format, regulatory region annotations, and know variant annotations. However, the main differences are that ANNOVAR cannot annotate for loss of function predictions whereas both SnpEFF and VEP can. Also, ANNOVAR cannot annotate microRNA structural binding locations whereas VEP can. MicroRNA structural binding location predictions can be informative in revealing post-transcriptional mutations’ role in disease pathogenesis. Loss of function mutations are changes in the genome that results in the total dysfunction of the gene product. Thus, these predictions could be extremely informative in regards to disease diagnosis, especially in rare monogenic diseases.
ClassFeatureVEPAnnovarSnpEff
GeneralAvailabilityFreeFree Free
InputVCFYesYesYes
InputSequence variantsYesYesYes
InputStructural variantsYesYesYes
OutputVCFYesYesYes
Transcript setsEnsemblYesYesYes
Transcript setsRefSeqYesYesYes
Transcript setsUser-created databasesYesYesYes
InterfacesLocal packageYesYesYes
InterfacesInstant prediction web interfaceYesNoNo
Consequence typesSplicing predictionsYes Yes Yes
Consequence typesLoss of function predictionYes NoYes
Non-codingRegulatory featuresYesYesYes
Non-codingSupport multiple cell linesYesNoYes
Non-codingmiRNA structure locationYes NoNo
Known variantsReport known variantsYesYesYes
Known variantsFilter by frequencyYesYesYes
Known variantsClinical significanceYesYesYes
Other filtersPre-set filtersYesYesYes

*Table adapted from McLaren et al..