Reconstruction of Strings Past. 

C. N. Yee and L. Allison^{*}Preprint to:
Journal of Bioinformatics (was Comp. Appl. BioSci., CABIOS),
9(1), pp.17, Partly
supported by Australian Research Council grant A49030439. SummaryA major use of stringalignment algorithms is to compare macromolecules that are thought to have evolved from a common ancestor to estimate the duration of, or the amount of mutation in, their separate evolution and to infer as much as possible about their most recent common ancestor. Minimum Message Length encoding, a method of inductive inference, is applied to the stringalignment problem. It leads to an alignment method that averages over all alignments in a weighted fashion. Experiments indicate that this method can recover the actual parameters of evolution with high accuracy and over a wide range of values whereas the use of a single optimal alignment gives biased results. Keywords: alignment, evolution, minimum message length encoding, MML, string similarity. IntroductionStringalignment algorithms are used to compare macromolecules, that are thought to be related, to infer as much as possible about their most recent common ancestor and about the duration, amount and form of mutation in their separate evolution since diverging. A key question is how accurately and reliably can this be done. What can we reconstruct of the ancestor and the sequence of events that led to the given strings and how confident can we be in our inferences? Most stringalignment methods[Sank][Bish2] are based on finding an optimal alignment that minimises a cost function (or equivalently maximises a score) of some kind. Rare mutations are given a high cost. An alignment of two strings represents one possible evolutionary relationship, a set of possible ancestors and mutations, in a natural way. An optimal alignment represents, it might be hoped, a most probable relationship. However, we describe experiments that show that estimates of the parameters of the evolutionary process that are based on a single optimal alignment are biased, and that those derived from averaging over all alignments are not. Minimum Message Length (MML) techniques are used to estimate the parameters of the evolutionary process that gave rise to the strings. MML encoding is a method of Bayesian inference. We consider the message length (ML) of an explanation of the given data. An explanation first states an hypothesis H, then states the data using a code which would be optimal if the hypothesis were true. From codingtheory, the message length in an optimal code of an event of probability P is log_{2}(P) bits. For an hypothesis H and data D, in the discrete case:
P(HD) is the posterior probability of hypothesis H given data D. The best hypothesis is the one that is part of the explanation having the shortest message length. We cannot in general talk about the true hypothesis, just "better" or "worse" hypotheses. The posterior oddsratio of two hypotheses, H and H', can be calculated from the following:
Solomonoff[Solo] proposed MML encoding as a basis for inductive inference. It has been applied to classification[Wall1][Wall3], to stringalignment[Alli1][Alli2] and to many other problems[Geor]. Wallace and Freeman[Wall2] gave its statistical foundations. The data in stringalignment consist of a pair of strings. The hypothesis that the strings are related first states the amount and type of mutation to an optimum accuracy. We call this the rtheory. The strings are then encoded using a code based on all alignments  this can be computed efficiently, as described later. Note that a single alignment is a much more detailed hypothesis than the rtheory. There are many possible models of the way that strings mutate. We need a common framework to compare different models. To this end, we use probabilistic finitestate machines which include or can approximate many other models. Such machines have one or more parameters, being the probabilities of certain instructions which include mutations. A complete description of a machine defines a model of the evolutionary process. In what follows we often refer to the instruction probabilities as the parameters of a machine or as the parameters of (a model of) evolution. In general, the parameter values are not known with certainty but must be inferred from the given strings. The simplest model would have at least one parameter related to the "amount" of mutation and thus to the time since two strings diverged. A more flexible model has additional parameters to indicate the probabilities of the different kinds of mutations. MML encoding has practical and theoretical advantages. The message paradigm keeps us honest in that all inferred parameters must be explicitly stated and so proper account is taken of the cost or complexity of the model. This issue includes stating realvalued parameters to optimum accuracy. If an optimal code cannot be devised, codingtheory includes many heuristics which can be used to get a good code. The method is safe because the use of a nonoptimal code cannot decrease the message length and can never make an hypothesis appear better than it really is. There is a natural nulltheory in stringalignment  that the strings are unrelated. This is encoded by transmitting one string and then the other, at about two bits per symbol for DNA. This gives an hypothesis test: any hypothesis that gives a message length greater than that of the nulltheory is not acceptable. Note that the lengths of strings must be included in the message. Reichert at al[Reic] applied `compact encoding' to stringalignment, but used one particular model and a single optimal alignment. Bishop and Thompson[Bish1] defined maximumlikelihood alignment, combining all alignments in what is a 1state model of mutation although they recognised the possibility of other models. Allison et al[Alli2] objectively compared 1, 3 and 5state models of mutation using MML encoding. Thorne et al[Thor1][Thor2] have also recognised the benefits of considering all possible alignments. This paper deals with DNA strings but the techniques are applicable to proteins and to strings over other alphabets. Alignment and Minimum Message Length EncodingWe model the evolutionary process by probabilistic finitestate machines[Alli2]. Such machines lead to efficient inference algorithms and can approximate many other models. The problem is to find the properties of the machine (nature's editor) that gave rise to two given strings A and B. We consider a generationmachine which read a sequence of generationinstructions and produced strings A and B "in parallel". The instructions have the following forms:
Note that the two characters involved in a change differ
and backmutations are counted with matches.
This simplifies the mathematics, particularly for the multistate models,
and allows instruction probabilities to be directly related to
the various costs or weights used in alignment algorithms.
It is also possible to consider an equivalent mutationmachine
which mutates string A into string B
but we use the generationmachine here on grounds of symmetry.
An alignment represents a sequence of generationinstructions
in a natural way:
A generationmachine can have more than one state and the probability of an instruction can depend on the current state of the machine, modelling some kind of context. A 1state machine corresponds to simple editcosts, as in Sellers' editdistance[Sell], because the probability, and thus the messagelength, of an instruction must be constant. On the other hand, a 3state machine can correspond to linearindel costs as described by Gotoh[Goto]. In particular, a run of inserts can have a low probability of beginning (in state S1) and a higher probability of continuing (in S2), giving a message length that is linear in the run length. This is thought to be more realistic in molecular biology. A 5state machine can correspond to piecewise linear indel costs[Goto][Mill].
The message length of an instruction can be calculated when its probability is known; this may depend on the current state `S':
The message length of a match, insert or delete instruction includes two bits to state one symbol for DNA. That of a change instruction includes log_{2}(12) bits to state two different symbols. This assumes that all symbols have equal probability; the correction is straightforward if this is not the case. Given the instruction probabilities, the message length of an instruction sequence, or of the equivalent single alignment, is the sum of the message lengths of the instructions in the sequence plus an encoding of the number of instructions. For long strings, the overheads of stating sequence length and parameters become a small fraction of the total message length. For example, if match, change, ins_{A} and ins_{B} occur in the ratios 80:10:5:5 then the message length in bits per symbol tends to
The well known dynamic programming algorithm (DPA) [Sank][Bish2] can find an optimal alignment for given instructioncosts. It takes O(A*B) time. It uses a matrix D, where D_{ij} is the minimum cost (eg. message length of a sequence of instructions) to generate A[1..i] and B[1..j]. When instruction probabilities are not known apriori they must be inferred from the given strings. An alignment is only optimal for certain instruction probabilities but what are optimal probabilities? To solve this problem, plausible but otherwise arbitrary initial probabilities are assumed and an optimal alignment is found. Probabilities are then reestimated from the observed frequencies of instructions in the alignment. However, these new values may cause another alignment to become optimal with an even lower message length. The process must therefore be iterated; 4 to 8 iterations are usually sufficient. Convergence is guaranteed but could get trapped in a local optimum  see later. Instructions are drawn from a multistate distribution and the calculations for the accuracy with which to state such probabilities are described by Boulton and Wallace[Boul]. This completes the steps required to calculate the message length of a single optimal alignment. We also need the message length for encoding A[1..i] and B[1..j], and finally all of A and B, under the rtheory, ie. according to some unspecified alignment, not according to any particular one. The DPA is modified to do this. In the 1state model, D_{ij} can be reached from three neighbours: D_{i1,j}, D_{i,j1} or D_{i1,j1}. In the standard DPA, each choice represents a different instruction sequence (alignment) for generating A[1..i] and B[1..j]. The standard DPA makes a single minimumcost (maximumprobability) choice. Instead of this, the modified algorithm adds the probabilities of all paths to D_{ij}, for this sum is the probability of generating A[1..i] and B[1..j] in some unspecified way. It avoids making a definite choice. The modified algorithm actually works with message lengths and these are combined by `logplus' instead of `min':
When this is done, D_{ij} represents the message length (log_{2} probability) required to generate A[1..i] and B[1..j] in some unspecified way. A[1..i] and B[1..j] must have been generated by generating either A[1..i1] and B[1..j], or A[1..i] and B[1..j1], or A[1..i1] and B[1..j1], each in some unspecified way, followed by ins_{A}, or ins_{B}, or match/change respectively. Each alternative is included, their probabilities being added. Note that they represent exclusive events. The modified algorithm still takes O(A*B) time and space per iteration. As before, unknown instruction probabilities must be estimated from the strings. The same iterative process is used, except that weighted average instruction frequencies are calculated when the subalignment probabilities are combined by logplus. The rtheory algorithm can be run in reverse to give D', where D'_{i+1,j+1} is the message length required to generate A[i+1..A] and B[j+1..B] in some way. Adding corresponding elements of D and D' gives a (log_{2}) probability density plot of all alignments, as in figure 1. This density plot shows the limits of certainty to inferences of the alignment and hence the most recent common ancestor of A and B. The rtheory algorithm for multistate models is obtained by similar modifications to Gotoh's algorithm. Experimental ResultsExperiments were done to test the ability of different alignment methods to recover the parameters of a known, artificial, evolutionary process. Strings were generated by computer according to known models with known parameter values. Attempts were then made to infer those parameter values by different methods. A good method should be able to recover the true values with reasonable accuracy under such ideal conditions. In the first set of experiments, a 1state generationmachine was used to generate pairs of strings. The parameter settings of the machine were varied systematically. For each setting, ten pairs of strings were generated. The string length was 1500. The observed proportions of the various instructions were recorded for each pair and their means and standarddeviations were calculated for each setting. Message lengths based on the "true" alignments were also calculated. In total, four ways of estimating the machine parameters were tried, all based on the 1state model: (i) Instruction probabilities were estimated from instruction frequencies in an optimal alignment which was obtained by the iterative process described in section 2. In a cheat, the true machine parameters were used as the initial parameter estimates for the process. This starting point would be unknown in reality but its use was expected to avoid the problem of getting trapped in local minima at high levels of mutation  as turned out to be the case. Its use could be simulated by a systematic and slow search through the parameter space. (ii) As for (i) but arbitrary initial parameter estimates were used. (iii) As for (i) (cheat) except that the rtheory algorithm was used, averaging over all alignments. (iv) As for (iii) but arbitrary initial parameter estimates were used. The means and standard deviations of the parameter values estimated in each of the four ways were calculated. Selected results of the experiments on the 1state model are collected in table 1, which gives the actual and inferred parameters, and in figures 2 and 3. They show that all methods perform well for small amounts of mutation but that there are deviations for less similar strings. The rtheory gives good results. If starting from arbitrary initial estimates, it may become trapped in localminima at very high levels of mutation, when P(match) falls below 0.4. However the true values can be detected as such if they are encountered; a systematic search, or the cheat, finds them right down to P(match)~0 (figure 2, dotted line). The searchspace must be very "flat" for strings of such marginal similarity because the message lengths differ very little (but in the right way) for quite different parameter estimates. A single optimal alignment gives biased results, consistently overestimating P(match) when P(match) is above 0.6. As P(match) falls below 0.5 the single alignment tends to favour the main diagonal of the D matrix, giving estimated values close to the chance figure for DNA, 0.25 (figure 3). Interestingly, as the true value of P(match) falls near to 0.0, the strings are increasingly related in a negative way and the estimates by this method improve again, given a good starting point. Similar experiments were performed on the 3state model. The parameters of the machine were varied in a systematic way. Ten pairs of strings were generated for each parameter setting. The string length was 1500. As above, four ways of attempting to recover the parameters, given the strings, were tried. These were all based on the 3state model and involved (i) an optimal alignment starting from the true parameter values (cheat), (ii) an optimal alignment starting from arbitrary initial values, (iii) rtheory starting from true parameter values (cheat) and (iv) rtheory starting from arbitrary initial values. Selected results are given in table 2 and in figures 4 and 5. The rtheory gives good estimates. It is likely to get caught in a local minimum, if started from arbitrary initial parameter estimates, for P(matchS1)<0.5. However, if the true parameters values are found they can be detected as such down to P(matchS1)~0 (figure 4). Inferences based on an optimal alignment underestimate the probability of indels in S1 and overestimate the probability of changes for similar strings. Parameter estimates for states S2 and S3 are poor. Results are of little value when P(matchS1)<0.5 (figure 5). Experiments were not performed on the 5state model due to the large number of degrees of freedom that it has and because of the amount of computer time required. ConclusionsExperiments indicate that the rtheory, based on all alignments, can be used to recover accurate, unbiased estimates of the parameters of the evolutionary process that gave rise to two strings A and B. This is assuming that the true model is known apriori, but that its parameters are not. Previous work[Alli2] indicate that the true model can also be inferred, given enough data. Our probabilistic finitestate machines can approximate many models and are implicit in many alignment algorithms. A probability density plot derived from the rtheory, as in figure 1, indicates the probabilities of possible alignments and thus of possible common ancestors of A and B. The ancestor cannot be assumed to lie on an optimal alignment. In contrast, parameter estimates based on a single optimal alignment are biased. For example in the 1state model, P(match) is overestimated when the true value is greater than 0.6 and the estimate is of no value when the true value is less than 0.5. The reason is easy to see: evolution is a random process and the probability that it follows the optimum path is small! The rtheory programs based on 1, 3 and 5state models are written in C and are available, free for nonprofit, nonclassified teaching and research purposes, by email (only) from: [www]. At least a good workstation with floatingpoint hardware is required for their use. References
Received on December 10, 1991; accepted on June 2, 1992. :PM=0.794(0.005) PC=0.145(0.007) PID=0.061(0.006) ML=4965.4(40.83) B/S=1.655(0.014) opt1:PM=0.803(0.005) PC=0.147(0.007) PID=0.050(0.006) ML=4868.3(44.06) B/S=1.623(0.015) opt2:PM=0.801(0.005) PC=0.151(0.005) PID=0.047(0.004) ML=4868.0(44.05) B/S=1.623(0.015) rth1:PM=0.793(0.006) PC=0.145(0.005) PID=0.062(0.007) ML=4799.1(35.13) B/S=1.600(0.012) rth2:PM=0.793(0.006) PC=0.145(0.005) PID=0.062(0.007) ML=4799.1(35.09) B/S=1.600(0.012)  :PM=0.601(0.009) PC=0.279(0.006) PID=0.120(0.010) ML=6208.7(77.93) B/S=2.070(0.026) opt1:PM=0.624(0.014) PC=0.315(0.019) PID=0.061(0.010) ML=5815.7(65.89) B/S=1.939(0.022) opt2:PM=0.624(0.014) PC=0.315(0.019) PID=0.061(0.010) ML=5815.7(65.89) B/S=1.939(0.022) rth1:PM=0.601(0.013) PC=0.276(0.011) PID=0.123(0.017) ML=5624.7(40.19) B/S=1.875(0.013) rth2:PM=0.601(0.013) PC=0.278(0.011) PID=0.121(0.018) ML=5624.7(40.21) B/S=1.875(0.013)  :PM=0.399(0.008) PC=0.419(0.010) PID=0.182(0.007) ML=7187.2(42.71) B/S=2.396(0.014) opt1:PM=0.334(0.036) PC=0.656(0.042) PID=0.010(0.007) ML=6086.8(42.76) B/S=2.029(0.014) opt2:PM=0.334(0.036) PC=0.656(0.042) PID=0.010(0.007) ML=6086.8(42.76) B/S=2.029(0.014) rth1:PM=0.395(0.012) PC=0.422(0.015) PID=0.183(0.008) ML=5991.2( 9.93) B/S=1.997(0.003) rth2:PM=0.399(0.012) PC=0.439(0.018) PID=0.162(0.015) ML=5991.1(10.02) B/S=1.997(0.003)  :PM=0.198(0.010) PC=0.559(0.012) PID=0.243(0.010) ML=7788.6(56.24) B/S=2.596(0.019) opt1:PM=0.296(0.061) PC=0.693(0.070) PID=0.012(0.011) ML=6118.5(83.02) B/S=2.040(0.028) opt2:PM=0.311(0.044) PC=0.677(0.054) PID=0.012(0.011) ML=6119.4(82.72) B/S=2.040(0.028) rth1:PM=0.202(0.016) PC=0.555(0.018) PID=0.243(0.011) ML=6035.6( 1.76) B/S=2.012(0.001) rth2:PM=0.268(0.025) PC=0.536(0.023) PID=0.196(0.016) ML=6036.3( 2.33) B/S=2.012(0.001)  :PM=0.100(0.007) PC=0.628(0.010) PID=0.272(0.010) ML=7874.1(53.21) B/S=2.625(0.018) opt1:PM=0.187(0.032) PC=0.804(0.025) PID=0.009(0.007) ML=6093.3(60.02) B/S=2.031(0.020) opt2:PM=0.296(0.035) PC=0.695(0.042) PID=0.009(0.007) ML=6102.6(65.93) B/S=2.034(0.022) rth1:PM=0.101(0.008) PC=0.628(0.011) PID=0.272(0.010) ML=6031.7( 3.04) B/S=2.011(0.001) rth2:PM=0.229(0.045) PC=0.572(0.047) PID=0.198(0.013) ML=6035.8( 3.26) B/S=2.012(0.001)  PM=P(match), PC=P(change), PID=P(indel), ML Message Length, B/S bits per symbol (i) : true generation parameters (ii) opt1: single optimal alignment, true initial parameters (iii) opt2: single optimal alignment, arbitrary initial parameters (iv) rth1: rtheory, true initial parameters (v) rth2: rtheory, arbitrary initial parameters Table 1: Results for 1State Model. `Computer Applications in the BioSciences' (CABIOS) became `The Journal of Bioinformatics' c1999 with [Vol.9 (No.1)]. 

↑ © L. Allison, www.allisons.org/ll/ (or as otherwise indicated). Created with "vi (Linux)", charset=iso88591, fetched Sunday, 17Feb2019 09:54:49 EST. Free: Linux, Ubuntu operatingsys, OpenOffice officesuite, The GIMP ~photoshop, Firefox webbrowser, FlashBlock flash on/off. 