Predicting the effect of missense mutations on protein function: analysis with Bayesian networks
 Chris J Needham^{1}Email author,
 James R Bradford^{2},
 Andrew J Bulpitt^{1},
 Matthew A Care^{2} and
 David R Westhead^{2}
DOI: 10.1186/147121057405
© Needham et al; licensee BioMed Central Ltd. 2006
Received: 24 May 2006
Accepted: 06 September 2006
Published: 06 September 2006
Abstract
Background
A number of methods that use both protein structural and evolutionary information are available to predict the functional consequences of missense mutations. However, many of these methods break down if either one of the two types of data are missing. Furthermore, there is a lack of rigorous assessment of how important the different factors are to prediction.
Results
Here we use Bayesian networks to predict whether or not a missense mutation will affect the function of the protein. Bayesian networks provide a concise representation for inferring models from data, and are known to generalise well to new data. More importantly, they can handle the noisy, incomplete and uncertain nature of biological data. Our Bayesian network achieved comparable performance with previous machine learning methods. The predictive performance of learned model structures was no better than a naïve Bayes classifier. However, analysis of the posterior distribution of model structures allows biologically meaningful interpretation of relationships between the input variables.
Conclusion
The ability of the Bayesian network to make predictions when only structural or evolutionary data was observed allowed us to conclude that structural information is a significantly better predictor of the functional consequences of a missense mutation than evolutionary information, for the dataset used. Analysis of the posterior distribution of model structures revealed that the top three strongest connections with the class node all involved structural nodes. With this in mind, we derived a simplified Bayesian network that used just these three structural descriptors, with comparable performance to that of an all node network.
Background
An important aspect of the postgenomic era is to understand the biological effects of inherited variations between individuals. For instance, a key problem for the pharmaceutical industry is to understand variations in drug treatment responses among individuals at the molecular level. A single nucleotide polymorphism (SNP) is a mutation, such as an insertion, deletion or substitution, observed in the genomic DNA of individuals of the same species. When the SNP results in an amino acid substitution in the protein product of the gene, it is called a missense mutation. A missense mutation can have various phenotypic effects although we restrict ourselves here to the simplified task of predicting whether a missense mutation has an effect or no effect on protein function.
The wealth of SNP data now available [1–4] has prompted a number of studies on the functional consequences of SNPs. For example, Wang and Moult [5] and Ramensky et al. [6] showed that most of the detrimental missense mutations affect protein function indirectly through effects on protein structural stability particularly disruption to the protein hydrophobic core. The evolutionary properties of the mutated residue may also be important determinants of its effect on protein function [7–9], since conserved amino acids tend to be functionally important or critical in maintaining structural integrity. A number of groups have developed strategies to predict the effects of missense mutations by using structural or evolutionary information, or a combination of both. Most of these methods claim prediction accuracies of between 70 – 80% although comparison is extremely difficult due to the use of different data sets and criteria for assigning a mutation as having an effect or not. Chasman and Adams [7] proposed a probabilistic method, and Krishnan and Westhead [10] evaluated decision trees and support vector machines. Herrgard et al. [11] used structural motifs called Fuzzy Functional Forms to predict the effects of amino acid mutations on enzyme catalytic activity. Deleterious human alleles were predicted by Sunyaev et al. [12] using mostly structural information. By contrast, [13] used purely sequence homology data in their SIFT (Sorting Intolerant From Tolerant) algorithm, although adding structural information resulted in significant improvements [14]. Subsequent work has compared SIFT to SVMs and random forests [15]. Cai et al. [16] used a Bayesian framework to predict pathogenic SNPs. Verzilli et al. [17] applied a hierarchical Bayesian multivariate adaptive regression spline (hierarchical BMARS) model for binary classification of the functional consequences of SNPs. Within this model, samples from the posterior distribution were used to highlight properties of the mutated residue that are most important in predicting its effect on protein function.
All these methods require either structural or evolutionary data to be available for predictions to be possible. However, there are many proteins that lack any detectable sequence homology to known proteins or a solved 3D structure. In these cases, many prediction methods break down. Therefore a method is needed that can combine both structural and evolutionary information but at the same time tolerate the absence of either without manual intervention. With this in mind we have applied Bayesian networks to the problem of predicting the consequences of a missense mutation on protein function. Bayesian networks are probabilistic graphical models which provide a neat compact representation for expressing joint probability distributions and inference. The representation and use of probability theory makes Bayesian networks suitable for learning from incomplete datasets, expressing causal relationships, combining domain knowledge and data, and avoiding overfitting a model to training data. As such, a host of applications in computational biology (for example, see [18–20]) have used Bayesian networks and Bayesian learning methodologies [21–23]. Our detailed evaluation of Bayesian network performance in this work is likely to be valuable to many groups working with Bayesian networks and biological data.
Bayesian networks
Our recent primer [24] introduces Bayesian networks to the computational biologist. Briefly, given a set of variables x = {x_{1},..., x_{ N }}, which are represented as nodes in the Bayesian network, a set of directed edges representing relationships between nodes can be defined in a graph structure. To allow efficient inference and learning, a directed acyclic graph (DAG) must be formed, which exploits the conditional independence relations between variables. Using this model structure, model parameters θ in the form of conditional probability distributions (CPDs) between the connected variables may be learned. With discrete data, these model parameters take the form of conditional probability tables (CPTs). Throughout this work, we have used the Bayes Net Toolbox for MATLAB (BNT) [25]. The code used to produce the results presented in this paper is available on request from the authors.
Learning from complete data
The Bayesian learning paradigm can be summarised as:
p(xD) = ∫p(xθ)p(θD)dθ
I.e., the predictive distribution for a new example observation, given a set of training examples D can be calculated by averaging over all possible models θ the likelihood of the example x given the model, multiplied by the likelihood of the model given the training data. For a given model structure $\mathcal{S}$ the model θ can be thought of as the model parameters that encode the conditional probability distributions between variables and their parents in $\mathcal{S}$.
Learning from incomplete data
One advantage of using Bayesian networks is that it is possible to learn model parameters from incomplete training data i.e. in cases where variables are missing. To learn from incomplete data, we used the ExpectationMaximisation (EM) algorithm, which estimates missing values by computing the expected values and updating parameters using these expected values as if they were observed values.
Structure learning
A fully connected network structure captures relationships (dependencies) between all of the variables. A simpler, more compact model may be produced if conditional independencies between variables are learned. To do this, we used the greedy search algorithm from the Matlabbased structure learning package (SLP) [26] with tabular CPDs and uninformative Dirichlet priors (BDeu). The greedy search algorithm starts with a graph with no edges between the nodes, and aims to maximise a score function: either the full Bayesian posterior or the Bayesian Information Criterion (BIC). At each stage, the neighbourhood of the current graph (the set of graphs that differ by adding, reversing or deleting an edge) are considered, and the one with the highest score is chosen, until convergence. We use the notation of Heckerman, where $\mathcal{S}$^{ h } is a model structure hypothesis. From Bayes' theorem the posterior distribution for network structures p($\mathcal{S}$^{ h }D) is proportional to the marginal likelihood of the data p(D$\mathcal{S}$^{ h }). The full Bayesian posterior can be calculated [[27], equation 35], or the BIC approximation can be used, which contains a term to describe how well the maximum likelihood model $\widehat{\theta}$_{ s }for structure $\mathcal{S}$^{ h } predicts the data D, and a term that punishes model complexity. For a model with d parameters, built from N samples, the BIC score is:
Inference with missing data
Knowledge of the conditional probability distributions between variables allows us to make predictions about the expected states of variables even if some variables are missing from the test data. For example, if structural information about a test missense mutation is not available, we can still infer whether the mutation has a functional effect on the protein or not by marginalising over the unknown variables. This is illustrated in a very simple Bayesian network with three nodes, A, B, C, which can take the values {a_{1},..., ${a}_{{N}_{A}}$}, {b_{1},..., ${b}_{{N}_{B}}$}, and {c_{1},..., ${c}_{{N}_{C}}$} respectively and a structure given by Figure 1. The joint probability over all the variables is:
p(A, B, C) = p(A)p(BA)p(CA, B)
Each of the probabilities can be expressed as a conditional probability table in this discrete case. If we wish to infer the value of C given A = a_{ i }and B = b_{ j }then we can calculate the probability of C taking each of the possible values, C = c_{ k }for k = 1,..., N_{ C }by p(c_{ k }a_{ i }, b_{ j }) read from CPTs. If we wish to infer the value of C given only the value of A, we can marginalise over the unknown variables (in this case, B). Thus:
Results and discussion
The systematic unbiased mutagenesis dataset of lac repressor [28, 29] and T4 lysozyme [30, 31] were used to train and validate the Bayesian networks. Classification of 'effect' and 'no effect' mutations was based on that of [17] in which only those mutations resulting in a significant loss of function were considered 'effect' mutations. As a result, our lac repressor dataset consisted of 823 effect and 2422 no effect mutations, and our T4 lysozyme dataset contained 312 effect and 1320 no effect mutations.
Attributes used for predicting functional effects of missense mutations
Abbreviation  Type  Description  Information 

effect  Discrete  Effect of mutation on functionality  Class 
ac  Continuous  Solvent accessible area of native AA  
rac  Continuous  Accessibility relative to maximum accessibility in training set  
bf  Continuous  Normalised Bfactor of native AA  
nbf  Continuous  Normalised Bfactor of structural neighbourhood of native AA  Structural 
bur  Discrete  Mutant AA is charged AA at buried site  
trn  Discrete  Mutant AA occurs at glycine or proline in a turn  
hlx  Discrete  Mutant AA occurs in helical region and involves glycine or proline  
ifc  Discrete  Native AA is near subunit interface  
nrent  Continuous  Phylogenetic entropy of structural neighbourhood of native AA  Structural + Evolutionary 
rent  Continuous  Normalised phylogenetic entropy of native AA  
cnsd  Discrete  Native AA is at conserved position in phylogenetic profile  
ncnsd  Discrete  Native AA is near conserved position in phylogenetic profile  Evolutionary 
uslaa  Discrete  Mutant AA is not in phylogenetic profile  
uslby  Discrete  Mutant AA is not in the smallest AA class that includes the phylogenetic profile 
We used two basic types of Bayesian network structure in this study: naïve and learned. In the naïve structure, the effec t node is a parent to all the other nodes in the network structure. Details of the learned structure are provided later. On each of these structures we performed seven experiments:

all:all: 15 node network trained and tested using all 14 variables listed in Table 1.

all: noS: 15 node network trained on all variables, tested with evolutionary information only (ac, rac, bf, nbf, bur, trn, hlx, ifc, nrent nodes hidden).

noS:noS: 6 node network (structural nodes missing) trained and tested with evolutionary information only.

all:noE: 15 node network trained on all variables, tested with structural information only (nrent, rent, cnsd, ncnsd, uslaa, uslby nodes hidden).

noE:noE: 9 node network (evolutionary nodes missing) trained and tested with structural information only.

all:key: 15 node network trained on all variables, tested using three key variables (ac, bur, bf). These key variables were identified by analysing a number of learned structures.

key:key: 4 node network trained and tested using key variables only.
Results with a naïve Bayes classifier.
Crossvalidation  Trained on:  All  All  NoS  All  NoE  All  key 

Tested on:  All  NoS  NoS  NoE  NoE  key  key  
mixed  AUC  0.83 ± 0.01  0.70 ± 0.02  0.70 ± 0.02  0.81 ± 0.02  0.81 ± 0.02  0.80 ± 0.02  0.79 ± 0.01 
MCC  0.44 ± 0.04  0.27 ± 0.03  0.27 ± 0.03  0.43 ± 0.03  0.43 ± 0.03  0.41 ± 0.02  0.35 ± 0.06  
Overall error rate  0.19 ± 0.01  0.24 ± 0.01  0.24 ± 0.01  0.18 ± 0.01  0.18 ± 0.01  0.18 ± 0.01  0.21 ± 0.00  
Effect error rate  0.35 ± 0.05  0.52 ± 0.03  0.52 ± 0.03  0.26 ± 0.07  0.26 ± 0.07  0.24 ± 0.07  0.41 ± 0.04  
No effect error rate  0.15 ± 0.02  0.18 ± 0.01  0.18 ± 0.01  0.17 ± 0.01  0.17 ± 0.01  0.17 ± 0.02  0.17 ± 0.03  
sensitivity  0.47 ± 0.12  0.37 ± 0.06  0.37 ± 0.06  0.37 ± 0.06  0.37 ± 0.06  0.36 ± 0.09  0.38 ± 0.16  
specificity  0.92 ± 0.03  0.88 ± 0.02  0.88 ± 0.02  0.96 ± 0.02  0.96 ± 0.02  0.96 ± 0.03  0.92 ± 0.05  
lac rep  AUC  0.84 ± 0.02  0.74 ± 0.02  0.74 ± 0.02  0.82 ± 0.02  0.82 ± 0.02  0.80 ± 0.02  0.80 ± 0.02 
MCC  0.47 ± 0.03  0.33 ± 0.06  0.33 ± 0.06  0.46 ± 0.04  0.46 ± 0.04  0.44 ± 0.03  0.39 ± 0.05  
Overall error rate  0.18 ± 0.01  0.23 ± 0.01  0.23 ± 0.01  0.18 ± 0.01  0.18 ± 0.01  0.19 ± 0.01  0.21 ± 0.00  
Effect error rate  0.27 ± 0.05  0.40 ± 0.04  0.40 ± 0.04  0.20 ± 0.06  0.20 ± 0.06  0.18 ± 0.09  0.36 ± 0.05  
No effect error rate  0.16 ± 0.02  0.19 ± 0.02  0.19 ± 0.02  0.18 ± 0.02  0.18 ± 0.02  0.19 ± 0.03  0.18 ± 0.03  
sensitivity  0.47 ± 0.10  0.36 ± 0.12  0.36 ± 0.12  0.37 ± 0.08  0.38 ± 0.08  0.34 ± 0.12  0.41 ± 0.13  
specificity  0.93 ± 0.03  0.92 ± 0.04  0.92 ± 0.04  0.96 ± 0.02  0.96 ± 0.02  0.97 ± 0.04  0.92 ± 0.04  
lysozyme  AUC  0.83 ± 0.02  0.68 ± 0.04  0.68 ± 0.05  0.81 ± 0.04  0.81 ± 0.04  0.78 ± 0.04  0.77 ± 0.04 
MCC  0.40 ± 0.05  0.23 ± 0.06  0.23 ± 0.06  0.38 ± 0.08  0.38 ± 0.08  0.36 ± 0.11  0.28 ± 0.09  
Overall error rate  0.17 ± 0.02  0.24 ± 0.01  0.24 ± 0.02  0.17 ± 0.03  0.17 ± 0.03  0.16 ± 0.02  0.21 ± 0.03  
Effect error rate  0.40 ± 0.05  0.63 ± 0.05  0.63 ± 0.05  0.39 ± 0.12  0.39 ± 0.12  0.33 ± 0.13  0.54 ± 0.09  
No effect error rate  0.13 ± 0.02  0.15 ± 0.01  0.15 ± 0.01  0.13 ± 0.03  0.13 ± 0.03  0.15 ± 0.02  0.14 ± 0.02  
Sensitivity  0.43 ± 0.11  0.39 ± 0.07  0.39 ± 0.07  0.38 ± 0.17  0.38 ± 0.17  0.28 ± 0.09  0.36 ± 0.11  
Specificity  0.93 ± 0.03  0.84 ± 0.02  0.84 ± 0.02  0.93 ± 0.07  0.93 ± 0.07  0.97 ± 0.01  0.89 ± 0.04  
Train: lac rep  AUC  0.80  0.66  0.67  0.78  0.78  0.77  0.77 
MCC  0.40  0.23  0.23  0.35  0.35  0.35  0.35  
Overall error rate  0.20  0.27  0.24  0.17  0.17  0.16  0.16  
Test: lysozyme  Effect error rate  0.52  0.65  0.63  0.41  0.41  0.32  0.32 
No effect error rate  0.10  0.14  0.15  0.14  0.14  0.15  0.16  
Sensitivity  0.58  0.46  0.39  0.33  0.33  0.26  0.26  
Specificity  0.85  0.80  0.84  0.95  0.95  0.97  0.97  
Train: lysozyme  AUC  0.81  0.71  0.71  0.80  0.80  0.79  0.79 
MCC  0.43  0.37  0.37  0.41  0.41  0.42  0.42  
Overall error rate  0.20  0.22  0.22  0.20  0.20  0.19  0.19  
Test: lac rep  Effect error rate  0.34  0.43  0.43  0.25  0.25  0.18  0.18 
No effect error rate  0.17  0.17  0.17  0.19  0.19  0.20  0.20  
Sensitivity  0.45  0.46  0.46  0.33  0.33  0.30  0.30  
Specificity  0.92  0.88  0.88  0.96  0.96  0.98  0.98 
Results with a learned Bayesian network.
Crossvalidation  Trained on:  All  All  NoS  All  NoE  All  key 

Tested on:  All  NoS  NoS  NoE  NoE  key  key  
mixed  AUC  0.84 ± 0.01  0.64 ± 0.01  0.70 ± 0.02  0.72 ± 0.02  0.82 ± 0.02  0.63 ± 0.03  0.80 ± 0.02 
MCC  0.46 ± 0.03  0.11 ± 0.03  0.10 ± 0.16  0.26 ± 0.22  0.44 ± 0.03  0.40 ± 0.04  0.40 ± 0.04  
Overall error rate  0.17 ± 0.01  0.67 ± 0.01  0.23 ± 0.00  0.36 ± 0.28  0.18 ± 0.01  0.18 ± 0.01  0.18 ± 0.01  
Effect error rate  0.27 ± 0.05  0.75 ± 0.01  0.15 ± 0.24  0.40 ± 0.25  0.29 ± 0.07  0.24 ± 0.06  0.25 ± 0.05  
No effect error rate  0.16 ± 0.01  0.11 ± 0.03  0.21 ± 0.03  0.29 ± 0.18  0.16 ± 0.02  0.18 ± 0.01  0.18 ± 0.01  
sensitivity  0.41 ± 0.07  0.93 ± 0.01  0.13 ± 0.21  0.51 ± 0.33  0.41 ± 0.08  0.31 ± 0.04  0.31 ± 0.09  
specificity  0.95 ± 0.02  0.15 ± 0.02  0.96 ± 0.07  0.68 ± 0.47  0.95 ± 0.03  0.97 ± 0.01  0.97 ± 0.01  
lac rep  AUC  0.85 ± 0.01  0.47 ± 0.03  0.73 ± 0.02  0.70 ± 0.02  0.82 ± 0.02  0.61 ± 0.02  0.81 ± 0.02 
MCC  0.52 ± 0.02  0.11 ± 0.03  0.32 ± 0.04  0.43 ± 0.04  0.46 ± 0.05  0.42 ± 0.04  0.42 ± 0.03  
Overall error rate  0.17 ± 0.01  0.60 ± 0.01  0.24 ± 0.01  0.19 ± 0.01  0.18 ± 0.01  0.19 ± 0.01  0.19 ± 0.01  
Effect error rate  0.25 ± 0.03  0.72 ± 0.01  0.46 ± 0.03  0.20 ± 0.06  0.21 ± 0.05  0.17 ± 0.07  0.22 ± 0.06  
No effect error rate  0.15 ± 0.01  0.16 ± 0.02  0.19 ± 0.01  0.19 ± 0.01  0.18 ± 0.01  0.20 ± 0.01  0.19 ± 0.01  
sensitivity  0.51 ± 0.03  0.86 ± 0.02  0.40 ± 0.03  0.33 ± 0.03  0.38 ± 0.06  0.30 ± 0.02  0.33 ± 0.02  
specificity  0.94 ± 0.01  0.24 ± 0.02  0.88 ± 0.01  0.97 ± 0.01  0.96 ± 0.01  0.98 ± 0.01  0.97 ± 0.01  
lysozyme  AUC  0.86 ± 0.02  0.51 ± 0.06  0.67 ± 0.05  0.78 ± 0.04  0.83 ± 0.05  0.70 ± 0.04  0.78 ± 0.05 
MCC  0.47 ± 0.06  0.09 ± 0.05    0.37 ± 0.10  0.40 ± 0.10  0.37 ± 0.12  0.34 ± 0.12  
Overall error rate  0.17 ± 0.03  0.75 ± 0.02  0.19 ± 0.00  0.16 ± 0.02  0.16 ± 0.02  0.16 ± 0.02  0.16 ± 0.02  
Effect error rate  0.38 ± 0.14  0.80 ± 0.01    0.30 ± 0.13  0.34 ± 0.11  0.32 ± 0.13  0.33 ± 0.14  
No effect error rate  0.10 ± 0.03  0.05 ± 0.08  0.19 ± 0.00  0.15 ± 0.02  0.14 ± 0.02  0.15 ± 0.02  0.15 ± 0.02  
Sensitivity  0.55 ± 0.19  0.98 ± 0.02  0.00 ± 0.00  0.29 ± 0.10  0.36 ± 0.09  0.30 ± 0.09  0.26 ± 0.09  
Specificity  0.90 ± 0.07  0.07 ± 0.02  1.00 ± 1.00  0.97 ± 0.02  0.95 ± 0.02  0.97 ± 0.01  0.97 ± 0.01  
Train: lac rep  AUC  0.72  0.43  0.68  0.70  0.77  0.57  0.75 
MCC  0.30    0.23  0.21  0.36  0.34  0.35  
Overall error rate  0.17  0.19  0.27  0.21  0.17  0.17  0.17  
Test: lysozyme  Effect error rate  0.33    0.65  0.57  0.41  0.35  0.35 
No effect error rate  0.16  0.19  0.14  0.16  0.14  0.15  0.15  
Sensitivity  0.20  0.00  0.46  0.25  0.35  0.26  0.26  
Specificity  0.98  1.00  0.80  0.92  0.94  0.97  0.97  
Train: lysozyme  AUC  0.79  0.44  0.65  0.58  0.78  0.66  0.78 
MCC  0.41  0.11  0.32  0.06  0.42  0.40  0.41  
Overall error rate  0.20  0.39  0.24  0.25  0.20  0.20  0.20  
Test: lac rep  Effect error rate  0.22  0.84  0.46  0.30  0.26  0.23  0.23 
No effect error rate  0.19  0.28  0.19  0.25  0.19  0.20  0.19  
Sensitivity  0.32  0.13  0.40  0.01  0.35  0.30  0.33  
Specificity  0.97  0.78  0.88  1.00  0.96  0.97  0.97 
Naïve Bayes classifier
all:all
As expected, overall error rates of less than 20% were achieved in all cross validation tests with the all:all model (Table 2, column 1). These results are consistent with previous studies reporting accuracies of 70 – 80% on similar datasets using similar variables [7, 10, 17]. Furthermore, all AUC values (Area under ROC curve – see Evaluation measures in Methods section for details of all performance metrics), including those from heterogeneous cross validation were at least 0.80 indicating a robust classifier despite the naïvety of the network structure. We therefore used results on the all:all model as a benchmark for the six other experiments.
Missing structural information (all:noS and noS:noS)
Performance dropped significantly with a 6 node network utilising only evolutionary information (noS:noS, Table 2, Column 3), with most AUC values reduced by over 10% from the all:all model. In particular, with homogeneous cross validation on lysozyme data AUC value decreased from 0.83 to 0.68, and MCC value was as low as 0.23. Even when structural information was used in training the network (all:noS, Table 2, Column 2), results were not improved possibly because variables are treated as independent in a naïve structure and so variables with missing values have little influence when they are marginalised over.
Missing evolutionary information (all:noE and noE:noE)
In contrast to results achieved without structural information, there was little or no effect on performance when evolutionary information was either missing during testing (all:noE, Table 2, Column 4) or missing during both training and testing (noE:noE, Table 2, Column 5). Again, due to the naïvety of the structure, similar results were achieved by the all:noE and noE:noE models with AUC values of around 0.80 and overall error rates below 0.20.
Overall, results suggest that structural information is more important than evolutionary information in predicting the functional consequences of a missense mutation in both lac repressor and T4 lysozyme, for the dataset used. Indeed, although evolutionary information has some predictive power, utilising only structural information appears to be sufficient for accurate prediction, comparable to that of the all:all model.
A note on structural flexibility
It has previously been suggested that the Bfactor and neighbourhood Bfactor of the native amino acid are the most important predictors of functional effects of SNPs [17]. However, the need to use Bfactor information limits a method to structures from Xray crystallography; such information is not available for NMR structures (although these do have their own internal flexibility measures). We found that removing the bf and nbf nodes from the all node network made little significant difference to overall performance with AUCs ranging from 0.80 to 0.83 in homogeneous crossvalidation and 0.78 and 0.82 in heterogeneous crossvalidation (results not in Table). This suggests that accurate prediction is possible without using structural flexibility information, although that is not to say that structural flexibility is not important, rather, other variables have compensated effectively for its loss.
Learned structure
all:all
Little significant improvement in homogeneous cross validation performance was gained from using structure $\mathcal{S}$ (Table 3, column 1) over the simple naïve structure (Table 2, column 1). This was because the naïve structure is specifically designed for classification, whereas our learned structure is the 'best' structure for capturing the relationships between all of the variables. The learned structure $\mathcal{S}$ performs as well in classification of effect as the naïve structure, but has the added advantage that it can be used to predict the values of any of the variables, from any of the other variables.
Missing structural information (all:noS and noS:noS)
The model learned from all the variables and tested using only evolutionary information (all:noS, Table 3, column 2) performed poorly achieving AUC values less than 0.50 (worse than random) and error rates above 0.75. Given the number of connections in $\mathcal{S}$ and the potential for inferring the missing structural information in the test data, the all:noS model was surprisingly worse than the noS:noS model (Table 3, column 3).
There could be a number of reasons for the poor performance of the all:noS model. The model may have learned during training that structural information is more important to prediction than evolutionary information. Consequently, without structural information during testing, the model has problems since it has downweighted the evolutionary nodes relative to the structural nodes. Alternatively, it may not be possible to accurately infer values at the structural nodes from evolutionary information. By contrast, it is essential that the noS:noS model makes full use of the evolutionary information since structural information is unavailable in both training and testing. Even though cross validation results with noS:noS were worse than the all:all model with AUC values ranging from 0.65 – 0.73 and overall error rates up to 0.27, they were better than the all:noS since full weight is given to the evolutionary nodes.
Missing evolutionary information (all:noE and noE:noE)
When marginalising over unknown evolutionary variables (all:noE, Table 3, column 4), predictions in most cases were comparable to the all:all model. However, poor results were achieved during homogeneous cross validation on mixed data and heterogeneous cross validation, especially training on lysozyme and testing on lac repressor data (AUC 0.58). In these cases, it appears that values at the evolutionary nodes with missing data could not be predicted accurately from the structural information during testing thus confusing the model. As expected, the noE:noE model trained and tested using structural variables only performed as well as the all:all model across all cross validation tests (Table 3, column 5).
Tolerance to incomplete training data
Figure 4 shows that the performance of both the naïve and $\mathcal{S}$ structures (measured by AUC value) were robust to incomplete training data, with an area under the ROC curve of over 0.80 maintained even when nine of the fifteen nodes were not observed in every example. With very sparse data (more than 9 nodes hidden), the naïve Bayes classifier performed better than the learned structure. This was probably because the conditional probability tables (CPTs) of the naïve structure only model the relationship of effect with each variable, whereas the CPTs of $\mathcal{S}$ depend on the relationship between multiple variables. From Figure 2, we can see that a number of nodes are dependent on three variables in $\mathcal{S}$, which perhaps explains the performance decrease when the model is not trained on sets of four or more variables. For example, when 11 variables are missing, an AUC value of 0.73 is achieved by $\mathcal{S}$, whereas when 12 variables are missing, performance decreases to that of random classifier (AUC < 0.5). Nevertheless, overall tolerance to incomplete training data by both Bayesian networks was encouraging considering the potential sparsity of either evolutionary and structural information for a significant number of proteins, especially structural genomics targets. Other machine learning methods such as SVMs or decision trees are unable to handle incomplete data in this way.
Training set size
Interpreting the structures
The use of MCMC methods to study the posterior distribution over networks has the advantage of revealing relationships between the input variables. For instance, in Figure 6, the top row shows which variables are most strongly related to effect, and this is used later to develop simplified classifiers.
However, biologically meaningful relationships between the other variables are also revealed. With the exception of the trivial relationship between ac and rac, the second row of Figure 6 shows strong links between ac, nrent, and rent, reflecting a well known biochemical relationship between solvent accessibility of residues and phylogenetic variability: the solvent exposed surface loops of protein structures show greater evolutionary variability than the unexposed hydrophobic core residues. Similar effects that concur with known protein chemistry relate measures of flexibility (nbf, bf) to phylogenetic variability. Equally understandable are the strong link between G and P residues in turns (trn) and evolutionary conservation at the specific sequence position of G/P (indicated by rent, cnsd) but not to a neighbourhood measure (nrent, ncnsd), and the relationship between protein interface positions (ifc) and neighbourhood flexibility measures (nbf).
From Figure 6, one can see that the effect node has the strongest relationships with bur, nbf, ac, uslaa, and uslby (in descending order). There are very few direct connections between effect and trn, hlx, ifc, cnsd, and ncnsd. As expected, nodes such as bf and nbf, and rent and nrent are highly correlated, which suggests some redundancy within the network and one node could be used to predict the value of the other. Both structural and evolutionary information are represented by the nodes most frequently directly connected to effect, although the top three most common nodes, bur, nbf and ac, represent only structural information. This, together with the strong performance of the Bayes classifier without evolutionary information (Table 2, columns 4 and 5), suggests that evolutionary properties of the mutated residue have little direct influence on prediction if structural information is present.
Our finding that solvent accessible area of the native amino acid, whether the amino acid is charged at a buried site, and the flexibility of its structural neighbourhood are all important predictors of effect agrees to some extent with Chasman and Adams (2001) who found that structure based accessibility and Bfactor features have the most discriminatory power. The strong performance of accessibility measures probably reflects the finding of [5] and [6] that mutations affecting the hydrophobic core are more likely to destabilise the protein and thus affect function. Perhaps mutations on the surface are more likely affect function if they are conserved, as suggested by the strong relationship between accessibility and phylogenetic entropy (ac with rent and nrent). Conversely, whether or not the mutation breaks either a helix or turn does not appear to be critical to predicting effect although, again, secondary structure information may become more powerful when used in conjunction with other features.
A simplified Bayesian network
Whilst the nodes directly connected to the effect node are not essential to prediction if certain other nodes are present (as demonstrated by the removal of the structural flexibility nodes nbf and bf, with no significant loss of performance), in theory, the value of the effect node can be predicted using only the nodes which are directly connected to it in the learned structures. The other variables become dseparated from effect; i.e. with a structure, and the conditional independence relations it implies, the effect node is conditionally dependent on only the nodes it is connected to when they are observed.
Across all crossvalidation tests, the four node naïve Bayes classifier trained and tested using only the three key variables (key:key, Table 2, final column) performed extremely well with only a minor decrease in performance over the all:all model. In homogeneous cross validation, AUC values ranged from 0.77 to 0.80 and the maximum overall error rate was just 0.21. In heterogeneous cross validation tests, the AUC also remained high (0.77 and 0.79) with overall error rates as low as 0.16 for training on lac repressor and testing on lysozyme data. There were no significant differences between the performance of the four node learned structure (key:key, Table 3, final column) and that of the naïve structure, which suggests little value in the connections between variables.
Conclusion
We have applied Bayesian networks to the task of predicting whether or not missense mutations will affect protein function with comparable performance to other machine learning methods. However, the strength of the Bayesian network lies in its ability to handle incomplete data and to encode relationships between variables; both of which were exploited here to derive some biological insight into how a missense mutation affects protein function.
A number of models were learned in this work. Due to the unbalanced datasets we analysed ROC curves and selected a suitable cost ratio in order to choose a probability threshold for the classifiers. This allowed us to compare classifiers in a meaningful way. From this analysis we concluded that a naïve network structure is sufficient for accurate prediction of the effect of a missense mutation with AUC values around 0.80. We also found that the structural environment of the amino acid is a far better predictor of the functional consequences of a missense mutation than phylogenetic information. This was demonstrated by the more accurate performance of a naïve classifier that just uses structural information compared to that which uses just evolutionary information. There were no significant performance gains when using a learned network structure, however the learned structure did allow relationships between variables to be analysed, in particular by analysing the posterior distribution of model structures, we found the top three strongest connections with the effect node all involved structural nodes. With this in mind, we derived a simplified Bayesian network that used just these three structural descriptors (solvent accessible area of the native amino acid, whether the amino acid is charged at a buried site, and the flexibility of its structural neighbourhood) without significant decrease in performance. Given the importance of structure, it would be interesting to learn if certain amino acid changes are more predictive of effect than others. For example, both cysteine, which forms disulphide bridges, and proline, with its unique ring structure, are often critical to the integrity of a protein structure so one would expect a mutation involving either of these residues to change the structure significantly. This will provide the basis for future work.
Methods
Evaluation measures
A number of measures were applied to evaluate each classifier: error rates (fraction of misclassified examples), sensitivity (true positive rate) and specificity (true negative rate). We also used Matthews' correlation coefficient (MCC), which is a correlation measure designed for comparison of unbalanced datasets such as ours. A value of +1 indicates perfect classification, and 1 indicates misclassification of every example. The MCC is defined as:
where TP are true positives, TN are true negatives, FP are false positives, and FN are false negatives obtained from evaluating the classifier on the test data.
Since we have a Bayesian network classifier, with a probability associated with each classification, the metrics above depend on the value of the classification threshold p that is used. To assess performance across a range of values of the probability threshold we plotted a receiver operator characteristic (ROC) curve. The ROC curve is a plot of the sensitivity versus (1specificity) for all feasible ratios of costs associated with misclassification errors (equivalent to plotting true positive rate versus false positive rate). The area under the curve (AUC) is a measure of the performance of a binary classifier. A classifier no better than random gives an AUC of 0.5, a perfect classifier gives an AUC of 1.0.
Choosing a classification threshold
In order to perform a fair comparison of classifiers, we choose the classification threshold p, represented by a point on the ROC curve for which the curve has a gradient (ΔTPrate/ΔFPrate) of C_{ FP }/C_{ FN }– the ratio of costs between False Positives and False Negatives, and which is closest to the point (0, 1). In this work we use a cost ratio of 3.0, due to the unbalanced nature of the datasets containing 3742 mutations which have no effect on protein function and 1135 which do effect protein function. This is close to 3:1, and by weighting the cost of a false positive, C_{ FP }, as three times more costly (to the classifier) than a false negative, C_{ FN }, we obtain a classifier with reasonably well balanced error rates. This means the classifier is less likely to predict everything as an effect (than with an equal cost ratio of 1.0) and make many false positive errors, which would give a high effect error rate. (Without doing this, we may be comparing classifiers with very different properties. i.e. ones with quite different specificities and sensitivities). The method is applied to the ROC curves obtained from the probabilistic classification scheme and we present the results for the classification threshold p corresponding to the point on the convex hull of the ROC curve where the gradient is closest 3.0. (We choose a point on the convex hull since any point on the ROC curve not on the convex hull is a nonoptimal classifier [32]).
Data discretization
There were a number of challenges buried in these data. Continuous data was nonGaussian, making it unsuitable for modelling as a continuous Gaussian node in a Bayesian network. There were also no obvious boundaries at which to separate the data into discrete categories. Our solution was to fit a number of Gaussians to the data using an ExpectationMaximisation based algorithm that automatically chooses the number of classes. It begins with one Gaussian, and iteratively splits the Gaussian with the largest weight, until adding extra classes does not increase the maximum likelihood of the model. Full details are provided below. This allowed us to form discrete classes from continuous data, which gave better performance than simply splitting the data into three classes of equal range (results not shown). We therefore used this strategy in all our analyses.
The EM algorithm
The Expectation Maximisation algorithm is a well established efficient algorithm for fitting Gaussian mixture models to data. The main drawback of the algorithm is its sensitivity to initialisation, and the need for multiple runs with different numbers of mixtures in order to choose the maximum likelihood model. Here we present a adaptation to the method which is deterministic and automatically chooses the number of Gaussians. It begins with one Gaussian, and iteratively splits the Gaussian with the largest weight, until adding extra mixtures does not increase the maximum likelihood of the model. Given a data set X = {x_{1},..., x_{ N }} of N cases of ddimensional data, a single cluster μ_{1} is initialised at the mean of the data. A Gaussian with diagonal covariance equal to the standard deviation of the data in each dimension is placed at μ_{1} The weight of this cluster is set to one p(j = 1) = 1.
The probability p(jx_{ i }) is calculated for each data point x_{ i }.
For a set of j mixtures, the update equations follow. These are iteratively performed until the maximum likelihood is reached, i.e. ML = log∑_{ i }∑_{ j }p(jx_{ i })
Estep:
Mstep:
When the ML stops increasing, the Gaussian with the largest weight p(j) described by μ_{ j }and s_{ j }is split into two Gaussians at ${\mu}_{j}^{+}$ and ${\mu}_{j}^{}$, each with the same covariance s_{ j }. The new Gaussians are placed +/ a distance of the largest eigenvalue in the direction of the principle eigenvector of the covariance matrix s_{ j }from μ_{ j }. (The Gaussians are then renamed). The EM steps above are performed until the maximum likelihood configuration is reached. This process is repeated until the ML score is no higher than with one less Gaussian. At each stage, the centres and covariances of the Gaussians are saved. Thus the algorithm terminates with a set of Gaussians that are at best no better than the set at the previous stage with one less Gaussian, so the saved set from the previous stage is used.
Classification of each data point x_{ i }is taken as a hard classification into the most likely class given by arg_{ j }max p(jx_{ i }).
Declarations
Acknowledgements
We would like to thank the BBSRC who funded this research under grant BBSB16585.
Authors’ Affiliations
References
 Thorisson GA, Stein LD: The SNP Consortium website: past, present and future. Nucl Acids Res 2003, 31: 124–127. 10.1093/nar/gkg052PubMed CentralView ArticlePubMedGoogle Scholar
 The SNP Consortium website[http://snp.cshl.org]
 Sherry ST, Ward MH, Kholodov M, Baker J, Phan L, Smigielski EM, Sirotkin K: dbSNP: the NCBI database of genetic variation. Nucleic Acids Res 2001, 29: 308–311. 10.1093/nar/29.1.308PubMed CentralView ArticlePubMedGoogle Scholar
 NCBI dbSNP[http://www.ncbi.nlm.nih.gov/SNP]
 Wang Z, Moult J: SNPs, protein structure, and disease. Hum Mutat 2001, 17: 263–270. 10.1002/humu.22View ArticlePubMedGoogle Scholar
 Ramensky V, Bork P, Sunyaev S: Human nonsynonymous SNPs: server and survey. Nucleic Acids Res 2002, 30: 3894–3900. 10.1093/nar/gkf493PubMed CentralView ArticlePubMedGoogle Scholar
 Chasman D, Adams RM: Predicting the Functional Consequences of Nonsynonymous Single Nucleotide Polymorphisms: Structurebased Assessment of Amino Acid Variation. J Mol Biol 2001, 307: 683–706. 10.1006/jmbi.2001.4510View ArticlePubMedGoogle Scholar
 FerrerCosta C, Orozco M, de la Cruz X: Characterization of diseaseassociated single amino acid polymorphisms in terms of sequence and structure properties. J Mol Biol 2002, 315: 771–786. 10.1006/jmbi.2001.5255View ArticlePubMedGoogle Scholar
 Ng PC, Henikoff S: Predicting deleterious amino acid substitutions. Genome Res 2001, 11: 863–874. 10.1101/gr.176601PubMed CentralView ArticlePubMedGoogle Scholar
 Krishnan VG, Westhead DR: A comparative study of machine learning methods to predict the effects of single nucleotide polymorphisms on protein function. Bioinformatics 2003, 19(17):2199–2209. 10.1093/bioinformatics/btg297View ArticlePubMedGoogle Scholar
 Herrgard S, Cammer SA, Hoffman BT, Knutson S, Gallina M, Speir JA, Fetrow JS, Baxter SM: Prediction of deleterious functional effects of amino acid mutations using a library of structurebased function descriptors. Proteins: Structure, Function, and Genetics 2003, 53(4):806–816. 10.1002/prot.10458View ArticleGoogle Scholar
 Sunyaev S, Ramensky V, Koch I, Lathe W III, Kondrashov AS, Bork P: Prediction of deleterious human alleles. Hum Mol Genet 2001, 10: 591–597. 10.1093/hmg/10.6.591View ArticlePubMedGoogle Scholar
 Ng PC, Henikoff S: SIFT: predicting amino acid changes that affect protein function. Nucl Acids Res 2003, 31(13):3812–3814. 10.1093/nar/gkg509PubMed CentralView ArticlePubMedGoogle Scholar
 Saunders CT, Baker D: Evaluation of structural and evolutionary contributions to deleterious mutation prediction. J Mol Biol 2002, 322: 891–901. 10.1016/S00222836(02)008136View ArticlePubMedGoogle Scholar
 Bao L, Cui Y: Prediction of the phenotypic effects of nonsynonymous single nucleotide polymorphisms using structural and evolutionary information. Bioinformatics 2005, 21(10):2185–2190. 10.1093/bioinformatics/bti365View ArticlePubMedGoogle Scholar
 Cai Z, Tsung EF, Marinescu VD, Ramoni MF, Riva A, Kohane IS: Bayesian Approach to Discovering Pathogenic SNPs in Conserved Protein Domains. Human Mutation 2004, 24: 178–184. 10.1002/humu.20063View ArticlePubMedGoogle Scholar
 Verzilli CJ, Whittaker JC, Stallard N, Chasman D: A hierarchical Bayesian model for predicting the functional consequences of aminoacid polymorphisms. Applied Statistics 2005, 54: 191–206.Google Scholar
 Beaumont MA, Rannala B: The Bayesian Revolution in Genetics. Nature Reviews Genetics 2004, 5: 251–261. 10.1038/nrg1318View ArticlePubMedGoogle Scholar
 Friedman N: Inferring Cellular Networks Using Probabilistic Graphical Models. Science 2004, 303: 799–805. 10.1126/science.1094068View ArticlePubMedGoogle Scholar
 Husmeier D, Dybowski R, Eds: SR: Probabilistic Modeling in Bioinformatics and Medical Informatics. Springer; 2005.Google Scholar
 Jordan MI: Learning in Graphical Models. Kluwer Academic; 1998.View ArticleGoogle Scholar
 Jensen FV: Bayesian Networks and Decision Graphs. Springer; 2001.View ArticleGoogle Scholar
 Pearl J: Causality: models, reasoning and inference. Cambridge; 2000.Google Scholar
 Needham CJ, Bradford JR, Bulpitt AJ, Westhead DR: Inference in Bayesian networks. Nature Biotechnology 2006, 24: 51–53. 10.1038/nbt010651View ArticlePubMedGoogle Scholar
 Murphy KP: The Bayes Net Toolbox for Matlab. Computing Science and Statistics 2001, 331–350.Google Scholar
 Leray P, Francois O: BNT Structure Learning Package: Documentation and Experiments. Tech. rep., Laboratoire PSI, Université et INSA de Rouen; 2004.Google Scholar
 Heckerman D: A tutorial on learning with Bayesian networks. In Learning in Graphical Models. Edited by: Jordan MI. Kluwer Academic; 1998:301–354.View ArticleGoogle Scholar
 Markiewicz P, Kleina LG, Cruz C, Ehret S, Miller JH: Genetic studies of the lac repressor. XIV. Analysis of 4000 altered Esherichia coli lac repressors reveals essential and nonessential residues, as well as 'spacers' which do not require a specific sequence. J Mol Biol 1994, 240: 421–433. 10.1006/jmbi.1994.1458View ArticlePubMedGoogle Scholar
 Suckow J, Markiewicz P, Kleina LG, Miller J, KistersWoike B, MullerHill B: Genetic studies of the lac repressor. XV: 4000 single amino acid substitutions and analysis of the resulting phenotypes on the basis of the protein structure. J Mol Biol 1996, 261: 509–523. 10.1006/jmbi.1996.0479View ArticlePubMedGoogle Scholar
 Alber T, Sun DP, Nye JA, Muchmore DC, Matthews BW: Temperature sensitive mutations of bacteriophage T4 lysozyme occur at sites with low mobility and low slovent accessibility in the folded protein. Biochemistry 1987, 26: 3754–3758. 10.1021/bi00387a002View ArticlePubMedGoogle Scholar
 Rennell D, Bouvier SE, Hardy LW, Poteete AR: Systematic mutation of bacteriophage T4 lysozyme. J Mol Biol 1991, 222: 67–88. 10.1016/00222836(91)90738RView ArticlePubMedGoogle Scholar
 Fawcett T: ROC Graphs: Notes and Practical Considerations for Data Mining Researchers. Tech. rep., HP Labs; 2003.Google Scholar
Copyright
This article is published under license to BioMed Central Ltd. This is an Open Access article distributed under the terms of the Creative Commons Attribution License (http://creativecommons.org/licenses/by/2.0), which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.