Many-Core Algorithms for Statistical PhylogeneticsSuchard MA & Rambaut A
(2009) Bioinformatics 25, 1370-1376.
Statistical phylogenetics is computationally intensive, resulting in considerable attention meted on techniques for parallelization. Codon-based models allow for independent rates of synonymous and replacement substitutions and have the potential to more adequately model the process of protein coding sequence evolution with a resulting increase in phylogenetic accuracy. Unfortunately, due to the high number of codon states, computational burden has largely thwarted phylogenetic reconstruction under codon models, particularly at the genomic-scale. Here we describe novel algorithms and methods for evaluating phylogenies under arbitrary molecular evolutionary models on Graphics Processing Units (GPUs), making use of the large number of processing cores to efficiently parallelize calculations even for large state-size models. Results:
We implement the approach in an existing Bayesian framework and apply the algorithms to estimating the phylogeny of 62 complete mitochondrial genomes of carnivores under a 60-state codon model. We see a near 90-fold speed increase over an optimized CPU-based computation and a >140-fold increase over the currently available implementation, making this the first practical use of codon models for phylogenetic inference over whole mitochondrial or microorganism genomes.Availability and implementation:
Source code provided in BEAGLE: Broad-platform Evolutionary Analysis General Likelihood Evaluator, a cross-platform/processor library for phylogenetic likelihood computation:
We employ a BEAGLE-implementation using the Bayesian phylogenetics framework BEAST: