Grammar-based distance in progressive multiple sequence alignment
- David J Russell^{1}Email author,
- Hasan H Otu^{2} and
- Khalid Sayood^{1}
https://doi.org/10.1186/1471-2105-9-306
© Russell et al; licensee BioMed Central Ltd. 2008
Received: 21 February 2008
Accepted: 10 July 2008
Published: 10 July 2008
Abstract
Background
We propose a multiple sequence alignment (MSA) algorithm and compare the alignment-quality and execution-time of the proposed algorithm with that of existing algorithms. The proposed progressive alignment algorithm uses a grammar-based distance metric to determine the order in which biological sequences are to be pairwise aligned. The progressive alignment occurs via pairwise aligning new sequences with an ensemble of the sequences previously aligned.
Results
The performance of the proposed algorithm is validated via comparison to popular progressive multiple alignment approaches, ClustalW and T-Coffee, and to the more recently developed algorithms MAFFT, MUSCLE, Kalign, and PSAlign using the BAliBASE 3.0 database of amino acid alignment files and a set of longer sequences generated by Rose software. The proposed algorithm has successfully built multiple alignments comparable to other programs with significant improvements in running time. The results are especially striking for large datasets.
Conclusion
We introduce a computationally efficient progressive alignment algorithm using a grammar based sequence distance particularly useful in aligning large datasets.
Background
Generation of meaningful multiple sequence alignments (MSAs) of biological sequences is a well-studied NP-complete problem, which has significant implications for a wide spectrum of applications [1, 2]. In general, the challenge is aligning N sequences of varying lengths by inserting gaps in the sequences so that in the end all sequences have the same length. Of particular interest to computational biology are DNA/RNA sequences and amino acid sequences, which are comprised of nucleotide and amino acid residues, respectively.
MSAs are generally used in studying phylogeny of organisms, structure prediction, and identifying segments of interest among many other applications in computational biology [3].
Given a scoring scheme to evaluate the fitness of an MSA, calculating the best MSA is an NP-complete problem [1]. Variances in scoring schemes, need for expert-hand analysis in most applications, and many-to-one mapping governing elements-to-functionality (codon mapping and function) make MSA a more challenging problem when considered from a biological context as well [4].
Generally, three approaches are used to automate the generation of MSAs. The first offers a brute-force method of multidimensional dynamic programming [5], which may find a good alignment but is generally computationally expensive and, therefore, unusable beyond a small N. Another method uses a probabilistic approach where Hidden Markov Models (HMMs) are approximated from unaligned sequences. The final method, progressive alignment, is possibly the most commonly used approach when obtaining MSAs [6].
A progressive alignment algorithm begins with an optimal alignment of two of the N sequences. Then, each of the remaining N sequences are aligned to the current MSA, either via a consensus sequence or one of the sequences already in the MSA. Variations on the progressive alignment method include PRALINE [7], ProbCons [8], MAFFT [9, 10], MUSCLE [11, 12], T-Coffee [13], Kalign [14], PSalign [15], and the most commonly used CLUSTALW [16]. In most cases, the algorithms attempt to generate accurate alignments while minimizing computational time or space. Advances in DNA sequencing technology with next generation sequencers such as ABI's SOLID and Roche's GC FLX provide vast amount of data in need of multiple alignment. In case of large sequencing projects, high number of fragments that lead to longer contigs to be combined are generated with much less time and money [17]. In addition, as more organisms' genomes are sequenced, approaches that require MSA of the same gene in different organisms now find a more populated data set. In both cases computational time in MSA is becoming an important issue that needs to be addressed.
This work presents GramAlign, a progressive alignment method with improvements in computational time. In particular, the natural grammar inherent in biological sequences is estimated to determine the order in which sequences are progressively merged into the ongoing MSA. The following sections describe the algorithm and present initial results as compared with other alignment algorithms.
Methods
Distance Estimation
The first step in the procedure involves the formation of an estimate of the distance between each sequence s_{ m }and all other sequences s_{ n }∀ n ≠ m. The distance used in GramAlign is based on the natural grammar inherent to all information-containing sequences. Unfortunately, the complete grammar for biological sequences is unknown, and so cannot be used when comparing sequences. However, we do know that biological sequences have structures which correspond to functions. This in turn implies that biological sequences which correspond to proteins with similar functions will have similarities in their structure. Therefore, we use a grammar based on Lempel-Ziv (LZ) compression [18, 19] used in [20] for phylogeny reconstruction. This measure uses the fact that sequences with similar biological properties share commonalities in their sequence structure. It is also known that biological sequences contain repeats, especially in the regulatory regions [21]. When comparing sequences with functional similarity, non-uniform distribution of repeats among the sequences poses a problem to assess sequence similarity. As shown below, the proposed distance naturally handles such cases, which are difficult to be accounted for by alignment or sequence edit based measures.
In the next step shown in Figure 2, each sequence is compared with all other sequences. In particular, consider the process of comparing sequences m and n. Initially, the dictionary ${G}_{m,n}^{1}$ = G_{ m }is set to that of sequence m, a fragment f^{1} = s_{ n }(1) is set to the first residue of the n th sequence, and the visible sequence is all of s_{ m }. The algorithm operates as described previously, resulting in a new dictionary size E_{ m, n }= |G_{ m,n }|. When complete, more grammatically-similar sequences will have a new dictionary size with fewer entries as compared to sequences that are less grammatically-similar. Therefore, the size of the new dictionary E_{m,n}will be close to the size of the original dictionary E_{ m,m }.
where m, n ∈ {1,...,N} are indices of two sequences being compared. This particular metric accounts for differences in sequence lengths, and normalizes accordingly. Thus, the final distance matrix D is composed of grammar-based distance entries given by (1). Smaller entries in D indicate a stronger similarity, at least in terms of the LZ-based grammar estimate. Intuitively, sequences with a similar grammar should be pairwise aligned with each other in order for progressive combining into an MSA.
To further improve the execution time, D is only partially calculated as follows. An initial sequence is selected and compared with all other sequences. The resulting distances are split evenly into two groups based on d, one containing the smallest distances, and the other containing the largest distances. The process is repeated recursively on each group until the number of sequences in a group is two. The benefit is that only N log(N) distances need to be calculated. The validity of only calculating these sets of distances stems from the transitivity of the LZ grammars being inferred. That is, if the grammar-based distances d_{ i, j }and d_{ j, k }are small, it is likely that d_{ i, k }is also small. By recursively dividing groups of extreme distances, only those distances which would likely be used in the spanning-tree creation process will actually be calculated.
Sequence Alphabet
Thus, GramAlign offers the option to use a "Merged Amino Acid Alphabet" when calculating the distance matrix. The merged alphabet contains 11 elements corresponding to the 23 amino acid letters grouped into the sets {'A','S','T','X'}, {'B','D','N'}, {'C'}, {'E','K','Q','R','Z'}, {'F'}, {'G'}, {'H'}, {'I','L','M','V'}, {'P'}, {'W'}, and {'Y'}. These groupings were determined by considering all 23 rows of the BLOSUM45, BLOSUM62, BLOSUM80 and GONNET250 substitution matrices, and only grouping elements that had a strong similarity across the entire row in all four matrices. The merged alphabet has the benefit of containing fewer elements allowing for more accurate distance estimates based upon shorter observed sequences. Also, the resultant merged-alphabet substitution matrices are more consistent in that a merged-letter score is high only when compared to itself. In practice, the average alignment scores increased when aligning the same data sets using the merged alphabet within the distance calculation, as compared to using the actual alphabet (results not shown). In either case, once the distances have been calculated, a tree based on these distances is used to determine which sequences should be pairwise aligned.
Tree Construction
The next step in the algorithm consists of constructing a minimal spanning tree T based on the distance matrix D. In particular, consider a completely connected graph of N vertices and $\frac{N(N-1)}{2}$ edges, where the weight of an edge between vertices i and j is given by the (i, j)th element of the distance matrix, D_{ i, j }. This work uses Prim's Algorithm [22] to determine a minimal spanning tree T which may be used as a guide in determining the order for progressively aligning the set of sequences S.
Align Sequences
In the following we describe the pairwise alignment procedure, the scoring system and the method for progressive alignment.
Dynamic Programming
At the core of most progressive MSA algorithms is some method for performing pairwise alignments between two sequences. This work uses a version of the [23] dynamic programming algorithm with affine gap scores as discussed in [2] to generate each pairwise alignment.
Scoring System
A significant ambiguity regarding the dynamic programming procedure is the scoring function used when comparing two elements, or when comparing an element with a gap.
Typically, the pairwise scoring function c() is simply a matrix of values, where each column and row represent one element in the alphabet. In this way, each cell of the matrix corresponds to some measure representing the likelihood that two sequence elements should be aligned with each other. The most well-known amino acid scoring matrices are the Percent Accepted Mutation (PAM) [24], BLOck SUbstitution Matrix (BLOSUM) [25] and GONNET [26]. GramAlign defaults to the GONNET250 substitution matrix for the scoring function c(), as other progressive alignment algorithms generally use it as the default choice (e.g., [14] and [16]).
Determining the best gap-open and gap-extension penalties is a challenging problem, made more difficult by introducing two different penalties to account for the beginning and ending tail gaps of alignments. The default gap penalties used by GramAlign have been adjusted to perform well based on the alignment sets presented in the results section.
Progressive Alignment
The ensemble is implemented as a doubly-linked list, where each node of the list represents a single column of the alignment. Each node of the ensemble contains an array of letters corresponding to the respective column alignment, a tally of gaps in the column, a weighted combination of substitution scores, and two gap penalties. Once the initial ensemble A_{(0,1)} is constructed between the first two entries in T, the remaining sequences need to be added to the ensemble in the order defined by T. This is accomplished by checking T for the next sequence not already in the ensemble, call it sequence s_{ j }where j corresponds to the order in which the sequence was added to T; that is, j is the priority of the sequence. To progressively add s_{ j }to the alignment, a pairwise alignment between the ensemble A_{(0,...,j-1)}and s_{ j }is created via the afore mentioned dynamic programming algorithm. While the algorithm used is a pairwise alignment algorithm the distance calculated at each step of the pairwise alignment is an average of the distances between the particular position being aligned in the new sequence and the corresponding amino acides or bases in the ensemble at that node. The new pairwise alignment is merged into the ongoing ensemble based on the trace-back. The process continues until all sequences have been added to the ensemble of sequences. When sequence s_{ j }is added to the current ensemble A_{(0,...,j-1)}, each node is updated to reflect the new column element.
Gap Adjustment
- 1.
If the current row has a gap, move to the next row;
- 2.
Otherwise, scan the current row of the neighboring columns within the window, beginning with the nearest columns and work outward;
- 3.
If a neighboring column has a gap in the current row and the neighboring column has fewer total gaps than the center column, shift the gap from the neighboring column into the column under consideration.
where original indices are kept to depict which entries are shifted into which locations.
The result is a blind movement of sparse gaps into dense regions of gaps. Numeric simulations have shown this post-processing stage does not affect alignment scoring based upon the method used in the Results and Discussion section (results not shown). And so, the user-defined parameters are set to a threshold of 1.0 and a window of 0 columns by default thereby disabling the gap adjustment block. Should it be known there are conserved regions of gaps, the user may decide to enable this process to encourage gap grouping.
Algorithm Complexity
The algorithm complexity of GramAlign may be broken into five pieces, beginning with the generation of each sequence grammar dictionary, G_{ i }for i ∈ {1,...,N}, where N is the number of sequences. Suppose the average sequence length is L, then each G_{ i }results in complexity $\mathcal{O}$(L), so all dictionaries are generated with complexity $\mathcal{O}$(LN). Next, the distance matrix D is formed by recursively extending a grammar by all other sequences within it's neighborhood, each of which results in complexity $\mathcal{O}$(L), then splitting the neighborhood into two halves, resulting in a complexity $\mathcal{O}$(LN log(N)). The spanning tree T is constructed by searching over D with a complexity of $\mathcal{O}$(N^{2}). The tree is used as a map in determining the order in which to perform N - 1 pairwise alignments, each requiring a complexity of $\mathcal{O}$(L^{2} + L). Thus, the progressive alignment process takes $\mathcal{O}$(L^{2}N). The alignment ensemble is scanned and has gaps shifted in $\mathcal{O}$(LN) time. Thus, the entire time complexity for GramAlign is $\mathcal{O}$(LN + LN log(N) + N^{2} + L^{2}N + LN), which simplifies to $\mathcal{O}$(N^{2} + L^{2}N).
Results and Discussion
In this section, example alignments are used to study the possible advantages of GramAlign. All results were generated by compiling and executing the respective MSA programs on the same computer; specifically, an Apple iBook with a PowerPC G4 operating at 1.2 GHz with 1.25 Gb system memory and 512 Kb L2 cache. Two sets of experiments were conducted. The first set of experiments were conducted using the unaligned FASTA files from the BAliBASE 3.0 [27] data-set, a well-accepted benchmark database containing example amino acid sequences. The resulting aligned FASTA files from each algorithm were scored using bali score, a program provided with the BAliBASE distribution that generates a Sum-of-Pairs (SP) score and a Total-Column (TC) score based on predetermined reference alignments. The size of the sequences in the BAliBASE distribution are relatively small and, therefore, not very useful in demonstrating the advantages to be obtained using a fast algorithm. The second set of experiments were conducted using sequences generated by Rose version 1.3 to demonstrate algorithms' capabilities on large data sets containing either long or numerous sequences. Rose is a software tool that implements a probabilistic model of sequence evolution, so that a user is able to generate families of related sequences from a common ancestor sequence via insertion, deletion and substitution [28]. Rose allows for many parameter adjustments including rate of mutation, desired average final sequence length and number of desired sequences. The tool outputs the unaligned sequences, as well as the real alignment based on how mutations occur, and an evolutionary tree. The set of sequences generated by Rose were based on the default seed file provided with the Rose software distribution, where the seed file is the method used to input parameters to Rose.
Note the use of simulated data here is to demonstrate the speed advantage of GramAlign, while maintaining a similar qualitative score. The default values were used to generate the data and the algorithms were not tuned to the data. The use of simulated data may actually provide a biased advantage in quality score to any given alignment program, depending on how the simulated data is generated. A wider breadth of simulated data, such as was done in [29], would provide a better assessment of overall alignment quality.
BAliBASE Experiments
Average SP scores on BAliBASE.
Algorithm | RV11 | RV12 | RV20 | RV30 | RV40 | RV50 |
---|---|---|---|---|---|---|
MUSCLE (fast) | 0.4904 | 0.8303 | 0.8359 | 0.7076 | 0.6904 | 0.6823 |
MAFFT (fast) | 0.4801 | 0.8161 | 0.8404 | 0.7345 | 0.7187 | 0.7089 |
MAFFT v6 (parttree, n = 50) | 0.4790 | 0.8066 | 0.8096 | 0.6801 | 0.6610 | 0.6985 |
MAFFT | 0.4914 | 0.8258 | 0.8459 | 0.7437 | 0.7347 | 0.7253 |
GramAlign | 0.5089 | 0.8328 | 0.8270 | 0.6855 | 0.7239 | 0.6903 |
Kalign | 0.5029 | 0.8504 | 0.8410 | 0.7389 | 0.7259 | 0.7299 |
ClustalW (fast) | 0.4748 | 0.8367 | 0.8258 | 0.6843 | 0.6705 | 0.6715 |
MUSCLE | 0.5578 | 0.8583 | 0.8548 | 0.7492 | 0.7623 | 0.7384 |
ClustalW | 0.4908 | 0.8197 | 0.8219 | 0.6841 | 0.6950 | 0.6698 |
PSAlign | 0.5924 | 0.8804 | 0.8720 | 0.7554 | 0.7937 | 0.7739 |
T-Coffee | 0.5181 | 0.8650 | 0.8660 | 0.7588 | 0.7452 | 0.7715 |
Average TC scores on BAliBASE.
Algorithm | RV11 | RV12 | RV20 | RV30 | RV40 | RV50 |
---|---|---|---|---|---|---|
MUSCLE (fast) | 0.2421 | 0.6349 | 0.2599 | 0.2457 | 0.2614 | 0.2719 |
MAFFT (fast) | 0.2354 | 0.6209 | 0.3094 | 0.2910 | 0.3108 | 0.3087 |
MAFFT v6 (parttree, n = 50) | 0.2461 | 0.6320 | 0.2978 | 0.2987 | 0.3104 | 0.3435 |
MAFFT | 0.2532 | 0.6256 | 0.3168 | 0.3158 | 0.3073 | 0.3303 |
GramAlign | 0.2993 | 0.6701 | 0.2917 | 0.2503 | 0.3292 | 0.3006 |
Kalign | 0.2538 | 0.6749 | 0.2765 | 0.2955 | 0.3253 | 0.3223 |
ClustalW (fast) | 0.2317 | 0.6651 | 0.2680 | 0.2513 | 0.2808 | 0.2752 |
MUSCLE | 0.3217 | 0.6961 | 0.3077 | 0.3087 | 0.3484 | 0.3397 |
ClustalW | 0.2395 | 0.6417 | 0.2602 | 0.2478 | 0.3024 | 0.2658 |
PSAlign | 0.3503 | 0.7384 | 0.3517 | 0.2992 | 0.3951 | 0.3816 |
T-Coffee | 0.2716 | 0.6986 | 0.3257 | 0.3637 | 0.3659 | 0.3974 |
Execution time.
Algorithm | Execution Time (sec) |
---|---|
MUSCLE (fast) | 301 |
MAFFT (fast) | 313 |
MAFFT v6 (parttree, n = 50) | 341 |
MAFFT | 564 |
GramAlign | 680 |
Kalign | 1,329 |
ClustalW (fast) | 2,071 |
MUSCLE | 6,129 |
ClustalW | 8,720 |
PSAlign | 152,168 |
T-Coffee | 403,815 |
Experiments with Large Data Sets
Long Sequence Experiments
In order to compare the performance of MSA algorithms on long data sets, two sets of seven FASTA files each containing ten sequences were generated using Rose version 1.3. The first set of seven FASTA files contains protein sequences and the second set contains DNA sequences. In both sets, the first file contains sequences with an average length of 5,000 residues, with each file increasing the average sequence length by 5,000 residues. Thus, the seventh file contains ten sequences with an average sequence length of 35,000 residues.
MUSCLE in fast mode encountered a segmentation fault during the Root Alignment step while running on the longest test sequences, and so the execution time is not included in Figures 6 and 7.
Numerous Sequence Experiments
In order to compare the performance of MSA algorithms on data sets with many sequences, two sets of seven FASTA files each containing sequences with an average length of 100 residues were generated using Rose version 1.3. The first set of seven FASTA files contains protein sequences and the second set contains DNA sequences. In both sets, the first file contains 100 sequences, with each file increasing the number of sequences up to the seventh file, which contains 10,000 sequences.
The results imply the promising viability of the proposed algorithm, especially when aligning either long or numerous sequences such as in whole-genome applications. Further, better alignment scores may be achieved with little change in execution time via the user-alterable parameters.
Conclusion
The primary goal of this work was to introduce a computationally-efficient progressive alignment algorithm which can be used for aligning large data sets. The grammar-based distance work presented in [20] was adapted to generate an estimation of the proper order in which sequences are to be aligned. Additionally, a merged amino acid alphabet was determined to allow an improved grammar-based distance when operating on protein sequences. Results from extensive alignments were presented in an attempt to study the overall quality of the resultant alignments as well as the computation time necessary to achieve the alignments. Correctly aligning multiple biological sequences in an efficient amount of time is an important and challenging problem with a wide spectrum of applications. In this work, we adapt existing ideas in a novel way introducing innovative improvements. The proposed algorithm achieves reasonable alignments compared to existing methods while significantly reducing execution time. Future work will focus on determining the best set of user-defined parameters for generating the highest overall SP and TC scores.
Availability
The current version of GramAlign may be run on-line, or the source code may be downloaded from the web server http://bioinfo.unl.edu/GramAlign.html.
Declarations
Acknowledgements
We would like to thank the National Institutes of Health (NIH) for partial funding of this work. We would also like to thank the editor and anonymous referees for their insightful comments. KS thanks NIH for support under grant K25AI068151.
Authors’ Affiliations
References
- Clote P, Backofen R: Computational Molecular Biology, An Introduction. New York, NY: Cambridge University Press; 1998.Google Scholar
- Durbin R, Eddy S, Krogh A, Mitchison G: Biological Sequence Analysis, Probabilistic Models of Proteins and Nucleic Acids. New York, NY: Cambridge University Press; 1998.View ArticleGoogle Scholar
- Edgar RC, Batzoglou S: Multiple Sequence Alignment. Current Opinion in Structural Biology 2006, 16: 368–373. 10.1016/j.sbi.2006.04.004View ArticlePubMedGoogle Scholar
- Mitrophanov AY, Borodovsky M: Statistical Significance in Biological Sequence Analysis. Briefings in Bioinformatics 2006, 7: 2–24. 10.1093/bib/bbk001View ArticlePubMedGoogle Scholar
- Lipman DJ, Altschul SF, Kececioglu JD: A Tool for Multiple Sequence Alignment. Proc Natl Acad Sci USA 1989, 86(12):4412–4415. 10.1073/pnas.86.12.4412PubMed CentralView ArticlePubMedGoogle Scholar
- Notredame C: Recent Evolutions of Multiple Sequence Alignment Algorithms. PLoS Computational Biology 2007, 3(8):1405–1408. 10.1371/journal.pcbi.0030123View ArticleGoogle Scholar
- Simossis VA, Heringa J: PRALINE: a Multiple Seqeunce Alignment Toolbox that Inegrates Homology-Extended and Secondary Structure Information. Nucleic Acids Research 2005, (33 Web Server):W289-W294. 10.1093/nar/gki390Google Scholar
- Do CB, Mahabhashyam MSP, Brudno M, Batzoglou S: ProbCons: Probabilistic Consistency-Based Multiple Sequence Alignment. Genome Research 2005, 15(2):330–340. 10.1101/gr.2821705PubMed CentralView ArticlePubMedGoogle Scholar
- Katoh K, Misawa K, Kuma K, Miyata T: MAFFT: A Novel Method for Rapid Multiple Sequence Alignment Based on Fast Fourier Transform. Nucleic Acids Research 2002, 30(14):3059–3066. 10.1093/nar/gkf436PubMed CentralView ArticlePubMedGoogle Scholar
- Katoh K, Kuma K, Toh H, Miyata T: MAFFT version 5: Improvement in Accuracy of Multiple Sequence Alignment. Nucleic Acids Research 2005, 33(2):511–518. 10.1093/nar/gki198PubMed CentralView ArticlePubMedGoogle Scholar
- Edgar RC: MUSCLE: Multiple Sequence Alignment with High Accuracy and High Throughput. Nucleic Acids Research 2004, 32(5):1792–1797. 10.1093/nar/gkh340PubMed CentralView ArticlePubMedGoogle Scholar
- Edgar RC: MUSCLE: A Multiple Sequence Alignment Method with Reduced Time and Space Complexity. BMC Bioinformatics 2004., 5(113):Google Scholar
- Notredame C, Higgins DG, Heringa J: T-Coffee: A Novel Method for Fast and Accurate Multiple Sequence Alignment. Journal of Molecular Biology 2000, 302: 205–217. 10.1006/jmbi.2000.4042View ArticlePubMedGoogle Scholar
- Lassmann T, Sonnhammer E: Kalign – an Accurate and Fast Multiple Sequence Alignment Algorithm. BMC Bioinformatics 2005., 6(298):Google Scholar
- Sze S, Lu Y, Yang Q: A Polynomial Time Solvable Formulation of Multiple Sequence Alignment. Journal of Computational Biology 2006, 13(2):309–319. 10.1089/cmb.2006.13.309View ArticlePubMedGoogle Scholar
- Thompson JD, Higgins DG, Gibson TJ: CLUSTAL W: Improving the Sensitivity of Progressive Multiple Sequence Alignment Through Sequence Weighting, Position-Specific Gap Penalties and Weight Matrix Choice. Nucleic Acids Research 1994, 22(22):4673–4680. 10.1093/nar/22.22.4673PubMed CentralView ArticlePubMedGoogle Scholar
- Sundquist A, Ronaghi M, Tang H, Pevzner P, Batzoglou S: Whole-Genome Sequencing and Assembly with High-Throughput, Short-Read Technologies. PLoS ONE 2007., 2(5):Google Scholar
- Ziv J, Lempel A: A Universal Algorithm for Sequential Data Compression. IEEE Transactions on Information Theory 1977, 23: 337–343. 10.1109/TIT.1977.1055714View ArticleGoogle Scholar
- Ziv J, Lempel A: Compression of Individual Sequences via Variable-Rate Coding. IEEE Transactions on Information Theory 1978, 24: 530–536. 10.1109/TIT.1978.1055934View ArticleGoogle Scholar
- Otu HH, Sayood K: A New Sequence Distance Measure for Phylogenetic Tree Construction. Bioinformatics 2003, 19(16):2122–2130. 10.1093/bioinformatics/btg295View ArticlePubMedGoogle Scholar
- Gusev VD, Nemytikova LA, Chuzhanova NA: On the Complexity Measures of Genetic Sequences. Bioinformatics 1999, 15(12):994–999. 10.1093/bioinformatics/15.12.994View ArticlePubMedGoogle Scholar
- Albertson MO, Hutchinson JP: Discrete Mathematics with Algorithms. New York: John Wiley & Sons, Inc; 1988.Google Scholar
- Needleman SB, Wunsch CD: A General Method Applicable to the Search for Similarities in the Amino Acid Sequence of Two Proteins. Journal of Molecular Biology 1970, 48(3):443–453. 10.1016/0022-2836(70)90057-4View ArticlePubMedGoogle Scholar
- Dayhoff MO, Schwartz RM, Orcutt BC: Atlas of Protein Sequence and Structure, National Biomedical Research Foundation, 1978 chap. A Model of Evolutionary Change in Proteins. 5: 345–352.Google Scholar
- Henikoff S, Henikoff JG: Amino acid substitution matrices from protein blocks. Proc Natl Acad Sci USA 1992, 89: 10915–10919. 10.1073/pnas.89.22.10915PubMed CentralView ArticlePubMedGoogle Scholar
- Gonnet GH, Cohen MA, Benner SA: Exhaustive matching of the entire protein sequence database. Science 1992, 256(5062):1443–1445. 10.1126/science.1604319View ArticlePubMedGoogle Scholar
- Thompson JD, Plewniak F, Poch O: BAliBASE: a benchmark alignment database for the evaluation of multiple alignment programs. Bioinformatics 1999, 15: 87–88. 10.1093/bioinformatics/15.1.87View ArticlePubMedGoogle Scholar
- Stoye J, DEvers , Meyer F: Rose: Generating Sequence Families. Bioinformatics 1998, 14(2):157–163. 10.1093/bioinformatics/14.2.157View ArticlePubMedGoogle Scholar
- Nuin PA, Wang Z, Tillier ER: The Accuracy of Several Multiple Sequence Alignment Programs for Proteins. BMC Bioinformatics 2006., 7(471):Google Scholar
- Katoh K, Toh H: PartTree: an Algorithm to Build an Approximate Tree from a Large Number of Unaligned Sequences. Bioinformatics 2007, 23(3):372–374. 10.1093/bioinformatics/btl592View ArticlePubMedGoogle 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.