SilVA: Silent variant analysis using random forests. "When a synonymous mutation falls in the exome, does it make a sound?"
SilVA is a tool for the automated harmfulness prediction of SYNONYMOUS single-nucleotide variants. Given variants in a VCF file, SilVA will rank the rare synonymous variants according to their predicted harmfulness. SilVA predicts the harmfulness of mutations using features that include conservation, codon usage, splice sites, splicing enhancers and suppressors, and mRNA folding free energy.
If you use this tool, please cite:
Buske OJ, Manickaraj A, Mital S, Ray PN, Brudno M. (2013)
Identification of deleterious synonymous variants in human genomes.
Bioinformatics, doi:10.1093/bioinformatics/btt308
Send questions, comments, and difficulties to: silva-snv@cs.toronto.edu
- Download SilVA:
wget http://compbio.cs.toronto.edu/silva/release/silva-1.1.1.tar.gz
tar -xzf silva-1.1.1.tar.gz
cd silva-1.1.1
- Install dependencies:
./setup.sh
- Preprocess VCF file:
./silva-preprocess OUTDIR VCF
- Run models and print highest-scoring synonymous variants:
./silva-run OUTDIR | head
- Linux or Mac OS, x86
- 6GB of RAM
- Python 2.6 or 2.7 in your PATH
- The 'numpy' Python package
- Perl in your PATH (for maxentscan)
- R in your PATH (for randomForest)
SilVA requires several tools and databases to run. Most of these were included with this release, but the setup.sh
script will download and configure the rest.
- included: twobitreader, available on pypi: https://pypi.python.org/pypi/twobitreader
- setup.sh: maxentscan, available from: http://genes.mit.edu/burgelab/maxent/download/
- setup.sh: randomForest package, available on CRAN: http://cran.r-project.org/web/packages/randomForest/
- setup.sh: SilVA databases, available from: http://compbio.cs.toronto.edu/silva/release/silva-1.1.1_data.tar.gz
- setup.sh: hg19.2bit, available from: http://hgdownload.cse.ucsc.edu/goldenPath/hg19/bigZips/hg19.2bit
- setup.sh: UNAfold (optional), available from: http://mfold.rna.albany.edu/?q=DINAMelt/software
- setup.sh: ViennaRNA (optional), available from: http://www.tbi.univie.ac.at/~ronny/RNA/
Note: if you have the SilVA databases already installed, you can point SilVA to them by changing the appropriate lines in the init.sh
file.
After running setup.sh, all necessary data files should be automatically downloaded into the data/ directory. Here is a list of the files that should be there:
refGene.ucsc.gz
1000gp.refGene.vcf.gz
gerp.refGene.table.gz
hg19.2bit
Note: The very first time you run SilVA, it will take much longer than normal (~45min longer) because the reference genome needs to be processed and mapped to the refSeq gene annotations and data files need to be parsed. This only needs to be done once, since the following pre-processed databases are saved to the data/ directory for future runs:
refGene.pkl
1000gp.refGene.pkl
gerp.refGene.pkl
Single-nucleotide variants should be given to SilVA in VCF or a VCF-like file format. This file may be gzip'd, but then must have a '.gz' extension. There should be one line per variant, with tab-delimited fields:
chrom
- chromosome (any 'chr' prefix will be trimmed)pos
- the position of the variant, 1-indexedid
- the id field is ignored, but is here to provide compatibility with the VCF format.ref
- the reference nucleotidealt
- the alternate nucleotide (if multiple are present, comma-separated, only the first will be used) ... Additional columns can be present and are ignored
SilVA will print the synonymous variants to stdout, ordered by score, with the variants most likely to be harmful listed first. Variants are first filtered down to just rare and novel synonymous variants. The variants are then annotated with a number of features and the machine learning model is used to rank the variants. The output contains the following tab-delimited columns:
- The variant rank, out of all synonymous variants considered.
- The SilVA score, between 0 and 1, where close to 1 is more likely to be harmful.
- The variant classification, based upon several SilVA score thresholds (see the paper).
- HGNC gene name
- RefSeq mRNA identifier ... Fields from the input file
SilVA is packaged with most of its dependencies. The remaining few can be downloaded and configured by running the 'setup.sh' script from the root directory of this package:
- Download, untar, and unzip the package tarball:
wget http://compbio.cs.toronto.edu/silva/release/silva-1.1.1.tar.gz
tar -xzf silva-1.1.1.tar.gz
cd silva-1.1.1
- Run the setup script in the package's root directory:
./setup.sh
Note: SilVA uses a number of environment variables to communicate important paths and parameters, such as what directory to use for temporary files and what allele frequency threshold to use. SilVA has default settings that should work, but will defer to any settings in your environment (so you can hard-code values by exporting variables in your ~/.bashrc
, for example). To see a list of these variables or to change their settings, see the init.sh
script.
In addition to running SilVA on your local machine, we provide a convenience script to dispatch multiple SilVA runs across an SGE cluster. SilVA uses TMPDIR for all temporary files. If TMPDIR is not set, it will use the current directory.
To run SilVA on your local machine, you should have already installed dependencies with the 'setup.sh' script. You can then run SilVA on your file of variants, , (see Input Format) from the root directory of this package (or add this directory to your PATH):
- Filter an annotate the variants in the VCF file (this takes a while):
./silva-preprocess <OUTDIR> <VCF>
- Run the trained models on the annotated variants and print the top variants in order of decreasing predicted harmfulness (this is fast):
./silva-run <OUTDIR> | head
SilVA should handle errors and early termination gracefully, so if something goes wrong, you can re-run the same command and it will pick up where it left off.
The 'example/' folder in the root directory of this package contains a sample input file for you to test SilVA on. You can run SilVA on it with the following commands:
./silva-preprocess example example/example.vcf
./silva-run example | head
You should see the known-harmful ACVRL1 variant appear at the top! Granted, for simplicity, the example only has 28 other rare synonymous variants in it. SilVA's expected output on this example is included in 'example/example.out'.
In case you have a large number of VCF files and an SGE cluster, we have provided a dispatch script for your convenience, 'sge/dispatch.sh'. Because SGE configurations vary widely, you should first open the file and take a look at the three SGE configuration variables at the top of the script. Edit them as you see fit. You can then dispatch SGE jobs for a number of VCF files from the root directory of the package with:
./sge/dispatch.sh <OUTDIR> <VCF1> <VCF2> ...
Send questions, comments, and difficulties to: silva-snv@cs.toronto.edu