PentaPlot: A software tool for the illustration of genome mosaicism
 Lutz Hamel^{1},
 Olga Zhaxybayeva^{2, 3} and
 J Peter Gogarten^{2}Email author
DOI: 10.1186/147121056139
© Hamel et al; licensee BioMed Central Ltd. 2005
Received: 04 March 2005
Accepted: 06 June 2005
Published: 06 June 2005
Abstract
Background
Dekapentagonal maps depict the phylogenetic relationships of five genomes in a visually appealing diagram and can be viewed as an alternative to a single evolutionary consensus tree. In particular, the generated maps focus attention on those gene families that significantly deviate from the consensus or plurality phylogeny. PentaPlot is a software tool that computes such dekapentagonal maps given an appropriate probability support matrix.
Results
The visualization with dekapentagonal maps critically depends on the optimal layout of unrooted tree topologies representing different evolutionary relationships among five organisms along the vertices of the dekapentagon. This is a difficult optimization problem given the large number of possible layouts. At its core our tool utilizes a genetic algorithm with demes and a local search strategy to search for the optimal layout. The hybrid genetic algorithm performs satisfactorily even in those cases where the chosen genomes are so divergent that little phylogenetic information has survived in the individual gene families.
Conclusion
PentaPlot is being made publicly available as an open source project at http://pentaplot.sourceforge.net.
Background
Trees have a long history as models for the evolutionary history of organisms [1, 2]. Lineage sorting and reticulate evolution have long been recognized as processes that make it difficult to infer species evolution from gene trees [3, 4]. However, the extent of gene transfer between divergent species, particularly in case of microorganisms, has initiated a reassessment of the applicability of a treebased concept for organismal evolution [5, 6]. Individual genes coexisting in a present day genome can have very different evolutionary histories [7, 8]. In particular, horizontal gene transfer is recognized as an alternative to within lineage processes like duplication and denovo evolution of genes for an organism to acquire new properties [9]. Here we present a software tool, which computes dekapentagonal maps to depict the phylogenetic relationships of five genomes in a visually appealing diagram as an alternative to bifurcating trees. Dekapentagonal maps allow for the recognition of a plurality or majority signal and they can serve as a visual tool to prescreen for putative instances of horizontally transferred genes (e.g., see [10]).
Computing the optimal layout of the tree topologies along the vertices of the dekapentagon presents a difficult optimization problem given the large number of possible layouts: (151)!/2 = 14!/2≈4*10^{10} (only free circular permutations [13] are counted, and the arrangements that become equivalent by rotation or flipping of the dekapentagon are considered the same arrangements).
This setting seems ideally suited for optimization based on genetic algorithms [14]. At the core of the software tool presented here is the design and implementation of a hybrid genetic algorithm which computes optimal tree topology layouts along the dekapentagon vertices using demes in order to avoid premature convergence and which employs a local search strategy to complement the global search behavior of the crossover and mutation operators.
Implementation
Design overview
PentaPlot is written as a program, which is comprised of multiple processing steps implemented both in Perl and C++. The processing steps are hidden from the user by means of a master Perl script that ties all the processing steps together. In normal usage the user prepares a probability matrix (see software documentation for formatting details), which provides information about the support of particular tree topologies by the families of orthologous genes. This matrix is processed by the program into the visual dekapentagonal map as shown in Figure 1. The individual processing steps are as follows:

Compute tree topology layout from probability matrix.

Map the polar coordinates for orthologous gene family into a Cartesian coordinates.

Summarize the number of genes, which fall into the individual zones that support particular tree topologies.

Construct the dekapentagonal map.
The generated dekapentagonal map is available as an image, which either can be viewed in an interactive previewer or saved in the postscript and PDF formats. The implementation heavily relies on Wall's genetic algorithm C++ component library [15] and TeX [16].
PentaPlot also provides access to a number of tuning parameters for the construction of the maps, which are accessible via command line arguments:

Iterations (default 50): Optimizing tree topology layouts with a genetic algorithm is a stochastic approach, therefore, in order to obtain some confidence in the computed solutions the solutions should be recomputed a number of times. This parameter controls how often the computation is to be repeated.

Populations (default 10): A fundamental concept in genetic algorithms is the notion of a population. Here we apply a genetic algorithm that utilizes multiple populations at the same time in order to prevent premature convergence. This parameter specifies how many populations the algorithm should use.

Population sizes (default 30): Population sizes are critical in genetic algorithms. If the population size is too small there will not be enough genetic diversity in the population to effectively explore the search space. If the population size is too large then a large amount of computation time might be wasted. This parameter controls the sizes of the populations.

Maximum number of generations (default 500): The genetic algorithm as implemented in PentaPlot has an automatic stopping criteria built in based on 99% convergence within 50 generations, that is, if the performance of the best layout of the current generation T and the performance of the best layout of the generation T50 are within 1% from each other then the genetic algorithm terminates. However, in particularly difficult optimization landscapes this convergence might never occur and the genetic algorithm might run forever (or at least for a very long time). To avoid this situation the maximum generation parameter allows the user to limit the number of generations the genetic algorithm is allowed to compute.
Data preparation: The probability matrix
The first step in the phylogenetic analysis of genomes is the detection of sets of orthologous genes from the genomes making up the set of five genomes under consideration, i.e., genes that share common ancestry and are related through speciation and not gene duplication events. We use reciprocal top scoring hits as a criterion to select orthologous genes, i.e., each of the genes picks the other members of the quintet as the top scoring hit in a BLAST search [12, 17, 18]. While this selection scheme aims at detecting orthologous genes, the resulting sets can only be considerate to be putatively orthologous. While this selection scheme aims at detecting orthologous genes, the resulting sets only can be considered to be putatively orthologous. These gene sets include horizontally transferred genes (xenologs), especially those instances, where the transferred gene replaced its ortholog, synologs that were brought into a single genome through lineage fusion [19, 20] and duplicated genes where one or the other paralog was lost in each the analyzed genomes [11]. When we refer to sets of orthologous genes in the rest of the manuscript we mean that those orthologs are putative. Once these putatively orthologous genes are detected, they are aligned and all possible unrooted tree topologies are evaluated (fifteen topologies for five genomes) and either their posterior probabilities or bootstrap support values are calculated (see [12] for details on methodology). Therefore, each family of putatively orthologous genes is associated with a 15dimensional support value vector. This construction results in probability matrices where each row represents a family of orthologous genes and each column represents a particular unrooted tree topology. A value in a matrix represents the probability of support for a particular tree topology by a particular gene family. It is important to note that all the probabilities in one record have to sum up to one. Any other method that calculates support value vectors can be used to produce valid probability matrices. Please note that the construction of the probability matrix is a preprocessing step and is not included in the PentaPlot program.
Mapping of probabilities into barycentric coordinate systems
A simple probability matrix (see Figure 1 and text for more details)
Tree #1 (T_{1})  Tree #2 (T_{2})  Tree #3 (T_{3})  

Support value vector for a set of orthologous genes  P_{1}  P_{2}  P_{3} 
A three dimensional probability matrix that is used to calculate support value map depicted in Figure 3 where n is the number of orthologous genes considered. An analogous matrix with 15 columns can be constructed for 15dimensional support value vectors.
Tree #1 (T_{1})  Tree #2 (T_{2})  Tree #3 (T_{3})  

Support value vector for a set #1 of orthologous genes  P_{11}  P_{12}  P_{13} 
Support value vector for a set #2 of orthologous genes  P_{21}  P_{22}  P_{23} 
...  ...  ...  ... 
Support value vector for a set #n of orthologous genes  P_{n1}  P_{n2}  P_{n3} 
Computing the center of gravity in a dekapentagon
Computing the center of gravity in a triangle is straightforward; however, the same computation in a dekapentagon deserves some remarks. To construct the center of gravity we place the dekapentagon into a Cartesian coordinate system with its origin coinciding with the center of the dekapentagon. Then the Cartesian coordinates (x_{ i }, y_{ i }) of a vertex i can be computed with the equations:
where R is the distance from origin to the vertex (equal for all the vertices due to the location of the origin of the coordinate system and here we assume that R is equal to 1), and 1 ≤ i ≤ 15. For each pair of vertices i and j the coordinates (x_{ M }, y_{ M }) of the center of gravity M_{ ij }are calculated according to the law of the lever:
where p_{ i }and p_{ j }represent the support ("weights") at the vertices i and j, respectively. The process is repeated for all pairs of vertices, and then iteratively for all "intermediate" centers of gravities until only one pair of coordinates remains, which represents the center of gravity of the dekapentagon using all the "weights". The resulting coordinates of the dekapentagon's center of gravity do not depend on the order in which the masses are combined but they do depend on the particular arrangement of the support p along the vertices, i.e. on the way the 15 different tree topologies are assigned to the vertices. For example, one could envision a family of orthologous genes that supports only two of the fifteen possible tree topologies. If these two topologies were assigned to two opposing vertices, the support value vector would map to the center of the dekapentagonal map, indicating no particular support for any tree topology, whereas if the two topologies are assigned to neighboring vertices, the support value vector will map onto the periphery between these two vertices, revealing support for these two topologies over the other 13 alternatives. Therefore, it is crucial to compute a layout that moves the centers of gravity as close to the periphery as possible.
As mentioned above, in our case we not only compute a single center of gravity or barycentric point, but instead, given a data set with N orthologous genes we will compute N different barycentric points, one for each record in the data set.
The layout algorithm
There are about 4*10^{10} possible arrangements of topologies on a dekapentagon's vertices. An arrangement is considered optimal when the topologies are arranged at the polygon vertices in a way that maximizes the sum of the distances of all barycentric points from the center of the polygon. There are too many arrangements of topologies around the dekapentagon to search for the optimal arrangement exhaustively. Therefore, we used a heuristic search based on genetic algorithms [21].
In the genetic algorithm setup, each generation consists of a population of arrangements where each individual in a population encodes a particular mapping of the possible tree topologies identified by numerical identifiers (1 through 15) to vertices of the dekapentagon. The fittest individuals in a population maximize the sum of all distances of the barycentric points from the center of the polygon. As is typical in evolutionary computation, the genetic algorithm applies mutation and crossover operations to each successive generation of arrangements until an optimal solution is obtained [14]. Genetic algorithms today provide many different implementation strategies beyond the basic bit string genetic algorithm first developed by Holland [14]. We chose an arraybased, hybrid genetic algorithm that uses demes to avoid premature convergence [15].
Genetic algorithms are good at finding approximate solutions in large search spaces but they are notoriously inefficient when it comes to fine tuning these solutions. By equipping a genetic algorithm with a local search strategy we avoid these problems. This is referred to as hybrid genetic algorithms [21] (sometimes also referred to as memetic algorithms [22]). Our hybrid genetic algorithm is summarized by the following pseudo code:
function evolve
create initial population
do
// perform crossover and mutation
population : = computenewpopulation (population)
best : = fittestindividual (population)
optimized : = localoptimization (best)
// if optimized is fitter than best replace best
// with optimized in the population
if (fitness (optimized) > fitness (best))
replace (population,best,optimized)
until (stoppingcondition)
return fittestindividual (population)
This algorithm is replicated over the demes giving rise to our hybrid deme genetic algorithm. It is noteworthy that we deviate from the standard notion of hybrid genetic algorithm slightly by only applying the local optimization function to the fittest individual of the population at each generation in each deme due to the computational cost of our local optimization: given the tree topology layout of the fittest individual, our local optimization strategy attempts to find an even better layout by systematically swapping tree topologies in the layout. The pseudo code of the local search heuristic follows:
function localoptimization (layout [1..15])
bestScore : = bestSource : = bestTarget : = 1
for s : = 1 to 14 do
for t : = s+1 to 15 do
swaptopologies (layout [s], layout [t])
score : = scoreArrangement (layout)
if (score > bestScore)
bestScore : = score
bestSource : = s
bestTarget : = t
endif
undoswap (layout [s], layout [t])
endfor
endfor
swaptopologies (layout [bestSource], layout [bestTarget])
return layout
This procedure steps through all topologies in a layout and evaluates the score obtained by swapping each topology with all other positions. Here 'scoreArrangement' is a procedure that computes the barycentric coordinates for each record in the data set and the score is derived from the sum of all the distances of the barycentric points from the center of the polygon. Most likely we can improve the computational requirements of this local search procedure by sampling possible swaps in the layouts instead of trying them all [23].
Another key notion beyond the local search strategy is that we have to constrain the structure of the individuals in the populations in such a way that each individual can only encode legal sequences of topologies, that is, each individual can only encode layouts of topologies around the perimeter of the polygon that do not have repetitions. This is analogous to the term closure condition that arises in genetic programming where any term constructor combined with any other legal term constructor must give rise to a legal term [24]. Here we opted for an array representation where each position in the array denotes a vertex on the polygon. The contents at each array position denote a tree topology assigned to that vertex. Each individual is initialized in such a way that the tree topologies 1 through 15 are assigned to the vertices in such a way that there are no repetitions. In order to make this work the crossover and mutation operators have to preserve the uniqueness property of the topology layouts. Goldberg's PMX (partially matched crossover) operator [21] and Wall's swap mutation implemented in GALIB [15] fulfill our uniqueness requirement and have been implemented in PentaPlot.
Results and discussion
 1.
An interdomain genome quintet consisting of representatives of all three domains of life: Saccharomyces cerevisiae (Y), Rhodobacter capsulatus (R), Bacillus subtilis (B), Archaeoglobus fulgidus (A), Sulfolobus solfataricus (S).
 2.
Bacterial genomes representing the five phyla that contain organisms with chlorophyllbased photosynthesis: Chlorobium tepidum (Ct), Chloroflexus aurantiacus (Ca), Heliobacillus mobilis (H), Rhodobacter capsulatus (R), Sulfolobus solfataricus (S).
The two datasets resulting from the first genome quintet each had 53 records, that is, 53 families of orthologous genes with one representative in each of the five genomes. The datasets resulting from the second genome quintet each had 188 records. Our investigation reported in [10] corroborated the layouts produced by our algorithm. The increase in difficulty in these experiments arises from the fact that (a) maximum likelihood mappings tend to produce barycentric points which lay close to the circumference of the polygon making it more difficult to discern an optimal layout and (b) the bacterial genomes contained a large number of orthologous genes, that is, there were a large number of barycentric points that needed to be considered during optimization.
Application of the different genetic algorithms to four experiments with increasing difficulty (the percentages indicate reproducability of solutions over fifty runs).
Experiments \ GA Type  Binary  Array  Deme  Hybrid Deme 

1) Interdomain Bootstrap  0%  0%  100%  100% 
2) Interdomain ML Mapping  0%  0%  84%  84% 
3) Bacterial Bootstrap  0%  0%  62%  72% 
4) Bacterial ML Mapping  0%  0%  56%  72% 
In the case of the binary string and array genetic algorithms it was interesting to see that we did not achieve reproducible solutions. Introducing demes into the genetic algorithms produced the most dramatic performance jump as can be seen from Table 3. In the case of the first experiment the performance jumped from 0% to 100% and dropped off with increasing difficulty of the experiments. The deme genetic algorithm performed well over the range of the experiments. However, in the fourth experiment it only converged on an optimal solution on every other run. The fourth column shows the performance of our hybrid deme genetic algorithm. We can see that it shares the performance characteristics of the deme genetic algorithm on the easier experiments but the performance of the hybrid deme genetic algorithm did not degenerate as fast with increasing difficulty of the experiments.
Investigating the genetic algorithm with different population and size settings.
Pop. Number \ Pop. Size  10  20  30  50  80  100  300  500 

1  12%  24%  26%  34%  44%  44%  20%  10% 
2  36%  28%  38%  42%  54%  52%  16%  12% 
3  24%  34%  46%  70%  60%  56%  24%  12% 
Assuming population sizes of 30 and 50, investigating the behavior of the genetic algorithm with different numbers of populations.
Pop. Number \ Pop. Size  30  50 

2  38%  42% 
4  52%  68% 
8  60%  78% 
10  72%  88% 
15  82%  88% 
20  82%  88% 
Conclusion
Dekapentagonal maps provide an alternative to a single evolutionary tree to visualize phylogenetic relationships between organisms. Here we presented a tool, which computes such dekapentagonal maps given an appropriate probability matrix. The visualization critically depends on the optimal layout of unrooted tree topologies along the vertices of the dekapentagon. Given the large number of possible layouts, this represents a difficult optimization problem well suited for genetic algorithms. At its core our tool utilizes a genetic algorithm with demes and a local search strategy. The chosen optimality criterion moves the individual barycentric points representing orthologous genes as far to the periphery as possible. The resulting arrangement places tree topologies between which individual data sets frequently do not decide next to each other. The developed hybrid genetic algorithm performs satisfactorily even in those cases where the chosen genomes are so divergent that little phylogenetic information has survived in the individual gene families.
Availability and requirements

Project name: PentaPlot

Project home page: http://pentaplot.sourceforge.net

Operating system(s): linux, kernel version 2.4.18 and above

Programming language: Perl, C++, LaTeX

Other requirements: Perl 5, BioPerl 1.4, LaTeX 2e, GAlib 2.4.5

License: GNU GPL

Any restrictions to use by nonacademics: contact authors
Declarations
Acknowledgements
This work was supported through NASA's Exobiology (NAG511470) and Applied Information Systems Research (NNG04GP90G) Programs, and in part through the NSF award MCB0237197 to JPG.
Authors’ Affiliations
References
 Darwin C: On the Origin of Species by Means of Natural Selection, or the Preservation of Favoured Races in the Struggle for Life. London: John Murray, Albemarle Street; 1859.Google Scholar
 Lamarck JB: Histoire naturelle des animaux sans vertebras. Paris 1815.Google Scholar
 Gogarten JP, Murphey RD, Olendzenski L: Horizontal gene transfer: pitfalls and promises. Biol Bull 1999, 196: 359–361.View ArticlePubMedGoogle Scholar
 Li WH: Molecular Evolution. Sunderland, MA: Sinauer Associates; 1997.Google Scholar
 Doolittle WF: Phylogenetic classification and the universal tree. Science 1999, 284: 2124–9. 10.1126/science.284.5423.2124View ArticlePubMedGoogle Scholar
 Olendzenski L, Zhaxybayeva O, Gogarten JP: What's in a Tree? Does Horizontal Gene Transfer Determine Microbial Taxonomy? In Cellular Origin and Life in Extreme Habitats. Vol. 4: Symbiosis. Edited by: Seckbach J. Netherlands: Kluwer Academic Publishers; 2001.Google Scholar
 Koonin EV, Makarova KS, Aravind L: Horizontal gene transfer in prokaryotes: quantification and classification. Annu Rev Microbiol 2001, 55: 709–42. 10.1146/annurev.micro.55.1.709View ArticlePubMedGoogle Scholar
 Hilario E, Gogarten JP: Horizontal transfer of ATPase genes – the tree of life becomes a net of life. Biosystems 1993, 31: 111–9. 10.1016/03032647(93)90038EView ArticlePubMedGoogle Scholar
 Gogarten JP, Doolittle WF, Lawrence JG: Prokaryotic evolution in light of gene transfer. Mol Biol Evol 2002, 19: 2226–38.View ArticlePubMedGoogle Scholar
 Zhaxybayeva O, Hamel L, Raymond J, Gogarten JP: Visualization of Phylogenetic content of Five Genomes with Dekapentagonal Maps. Genome Biology 2004, 5: R20. 10.1186/gb200453r20PubMed CentralView ArticlePubMedGoogle Scholar
 Zhaxybayeva O, Gogarten JP: An Improved Probability Mapping Approach to Assess Genome Mosaicism. BMC Genomics 2003, 4: 37. 10.1186/14712164437PubMed CentralView ArticlePubMedGoogle Scholar
 Zhaxybayeva O, Gogarten JP: Bootstrap, Bayesian probability and maximum likelihood mapping: Exploring new tools for comparative genome analyses. BMC Genomics 2002, 3: 4. 10.1186/1471216434PubMed CentralView ArticlePubMedGoogle Scholar
 Weisstein EW: Circular Permutations, In: Eric Weisstein's World of Mathematics.[http://mathworld.wolfram.com/CircularPermutation.html]
 Holland JH: Adaptation in Natural and Artificial Systems. University of Michigan Press; 1975.Google Scholar
 Wall M: GALIB: A C++ Library of Genetic Algorithm Components. Distributed through.1996. [http://lancet.mit.edu/ga/]Google Scholar
 Knuth DE: The TeXbook. Reading, Mass.: AddisonWesley; 1986.Google Scholar
 Altschul SF, Madden TL, Schaffer AA, Zhang J, Zhang Z, Miller W, Lipman DJ: Gapped BLAST and PSIBLAST: a new generation of protein database search programs. Nucleic Acids Res 1997, 25: 3389–402. 10.1093/nar/25.17.3389PubMed CentralView ArticlePubMedGoogle Scholar
 Montague MG, Hutchison CA 3rd: Gene content phylogeny of herpesviruses. Proc Natl Acad Sci U S A 2000, 97: 5334–9. 10.1073/pnas.97.10.5334PubMed CentralView ArticlePubMedGoogle Scholar
 Fitch WM: Homology a personal view on some of the problems. Trends Genet 2000, 16: 227–31. 10.1016/S01689525(00)020059View ArticlePubMedGoogle Scholar
 Gogarten JP: Which is the most conserved group of proteins? Homologyorthology, paralogy, xenology, and the fusion of independent lineages. J Mol Evol 1994, 39: 541–3. 10.1007/BF00173425View ArticlePubMedGoogle Scholar
 Goldberg DE: Genetic Algorithms in Search, Optimization and Machine Learning. AddisonWesley; 1989.Google Scholar
 Moscato P: An introduction to population approaches for optimization and hierarchical objective functions: The role of tabu search. Annals of Operations Research 1993, 41: 85–121.View ArticleGoogle Scholar
 Krasnogor N, Smith J: Emergence of Profitable Search Strategies Based on a Simple Inheritance Mechanism. Proceedings of the Genetic and Evolutionary Computation Conference 2001, 432–439.Google Scholar
 Koza JR: Genetic programming: on the programming of computers by means of natural selection. Cambridge, Mass.: MIT Press; 1992.Google Scholar
 Strimmer K, von Haeseler A: Likelihoodmapping: a simple method to visualize phylogenetic content of a sequence alignment. Proc Natl Acad Sci, USA 1997, 94: 6815–6819. 10.1073/pnas.94.13.6815PubMed CentralView ArticlePubMedGoogle Scholar
 Raymond J, Zhaxybayeva O, Gogarten JP, Gerdes SY, Blankenship RE: Wholegenome analysis of photosynthetic prokaryotes. Science 2002, 298: 1616–20. 10.1126/science.1075558View 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.