# Finishing bacterial genome assemblies with Mix

- Hayssam Soueidan
^{1}, - Florence Maurier
^{2}, - Alexis Groppi
^{2}, - Pascal Sirand-Pugnet
^{3, 4}, - Florence Tardy
^{5}, - Christine Citti
^{6, 7}, - Virginie Dupuy
^{8}and - Macha Nikolski
^{2, 9}Email author

**14(Suppl 15)**:S16

https://doi.org/10.1186/1471-2105-14-S15-S16

© Soueidan et al.; licensee BioMed Central Ltd. 2013

**Published: **15 October 2013

## Abstract

### Motivation

Among challenges that hamper reaping the benefits of genome assembly are both unfinished assemblies and the ensuing experimental costs. First, numerous software solutions for genome *de novo* assembly are available, each having its advantages and drawbacks, without clear guidelines as to how to choose among them. Second, these solutions produce draft assemblies that often require a resource intensive finishing phase.

### Methods

In this paper we address these two aspects by developing *Mix* , a tool that mixes two or more draft assemblies, without relying on a reference genome and having the goal to reduce contig fragmentation and thus speed-up genome finishing. The proposed algorithm builds an *extension graph* where vertices represent extremities of contigs and edges represent existing alignments between these extremities. These alignment edges are used for contig extension. The resulting output assembly corresponds to a set of paths in the extension graph that maximizes the cumulative contig length.

### Results

We evaluate the performance of Mix on bacterial NGS data from the GAGE-B study and apply it to newly sequenced *Mycoplasma* genomes. Resulting final assemblies demonstrate a significant improvement in the overall assembly quality. In particular, Mix is consistent by providing better overall quality results even when the choice is guided solely by standard assembly statistics, as is the case for *de novo* projects.

### Availability

*Mix* is implemented in Python and is available at https://github.com/cbib/MIX, novel data for our *Mycoplasma* study is available at http://services.cbib.u-bordeaux2.fr/mix/.

## Background

Moving a genome from the draft assembly stage to a complete finished genome is a labor-intensive task requiring time and further experimental work. This *finishing* step aims to improve previously assembled draft sequences that are often fragmented into hundreds of contigs. Finishing frequently requires targeted sequencing to resolve remaining issues such as misassembled regions and sequence gaps, and tries to improve coverage and accuracy in poorly covered regions of the genome. Consequently, the task of producing a complete genome requires extensive experimental work and is often out of reach for small labs. While *in silico* finishing can not resolve all of these issues, it represents a considerable speed-up of the finishing process.

Genome assembly is a lively field that has produced in the recent years numerous algorithms and tools, such as MIRA [1], CLC (http://www.clcbio.com/genomics), ABySS [2], etc. Assemblers differ in their algorithmic foundations and present different advantages and pitfalls. In addition to the sheer number of algorithmic solutions, any given assembler can be run using a number of variations of its parameter values (such as different *k*-mer sizes) and produce different results. Bring into that the fact that re-assembling an already assembled genome based on a new sequencing technology (e.g., Illumina vs Sanger) can reveal sequences that are missing in the reference assembly [3], and we end up with a very large space of easily obtainable *de novo* draft assemblies.

Armed with this observation, a number of projects aim to take advantage of either different sources of sequencing data or different assembly tools. Indeed, cross-platform data merging is advantageous because sequencing platforms have different biases [4] and thus assemblies generated from different platforms' data can complement each other [5]; [6]. Several software packages were developed in order to capitalize on different advantages of existing assemblers. Among these tools are GAM [7], minimus2 [8], MAIA [9], Reconciliator [10], Zorro [11] and GAM-NGS [12].

MAIA relies on a finished reference in order to guide the contig integration process; it is available as a MATLAB package. Zorro proceeds by masking the repeated regions known to cause problems during assembly. The minimus2 pipeline uses nucmer [13] to compute overlaps between contigs. GAM-NGS, Reconciliator and Zorro rely on reads in addition to assemblies for the merging process.

Even when there is no clearly defined reference assembly, some tools still treat the two input assemblies differently; when referring to such setup we will use the term of *asymmetry*. Graph Accordance Assembly tool GAA [14] was developed in order to improve global assembly quality starting from two assemblies, one being the target and the other being the query. It is based on the construction of an accordance graph that encodes the alignment information between the target and query assemblies. The user has to evaluate and to choose the most reliable assembly that will be the target - for which no clear-cut solution currently exists.

The specific problem that we aimed to address in current work is the high fragmentation of existing assemblies and the related to it reduced contig length. Such a problem is particularly salient for the "old" and very short (35nt to 45nt) NGS reads as for example those generated by the very first NGS chemistry of Illumina (formerly Solexa) technologies. The resulting draft assemblies are highly fragmented. The challenge in the case of *Mycoplasma* assembly project was to assemble these genomes and to develop an *in silico* finishing method in order to reduce the cost of returning back to the wet laboratory.

*Mycoplasma* are a genus of mollicutes that are a class of wall-less bacteria. Consequently, the most pertinent evaluation of assembly tools' performance is against bacterial benchmarks. A recent thorough evaluation of both assemblers and assembly merging tools has been done by Magoc and co-authors and provides a benchmark of 12 bacterial datasets called GAGE-B [15]. Most interestingly, at the end of their manuscript the authors mention that "over a large number of computational experiments, most combinations of assemblers, k-mer values, and merging algorithms did not produce improvements, and often produced inferior assemblies to the best individual assembly", with one exception where GAA produced superior results. Thus, GAA was chosen to be tested along with assembly tools in present work.

A very recent application GAM-NGS [12] attempts to merge two different assemblies by avoiding a mutual alignment step and mapping the raw reads on the two assemblies instead. The merging is based on the construction of a graph where the number of reads mapped on different regions is used to weight the edges and determine the correctness of merging two regions. An asymmetry is introduced between the two assemblies, one called the master and the other the slave, master assembly driving the merging process. Even if no clear assembly improvement is reported in the paper, since GAM-NGS was not included in the GAGE-B study, we have included it in our own benchmarking.

In the current manuscript we describe *Mix* a *finishing algorithm* that generates an assembly starting from different genome assemblies with the main objective of reducing contig fragmentation and maximizing the cumulative contig length. We address this question for the case where no reference genome is available and no asymmetry is introduced in dealing with assemblies, case not previously considered in literature. Moreover, we do not restrict ourselves to using only two assemblies. To address the excessive fragmentation, we propose a solution based on the maximal path problem in order to extend the contig length. To do this, we build a *extension graph* that connects contigs by their mutual alignments and is used to mix contigs when appropriate. We evaluate our *Mix* algorithm on GAGE-B benchmark and apply it to novel NGS data for 10 genomes from bacteria belonging to the genus *Mycoplasma*. We show that contrary to other tools that merge different assemblies, *Mix* clearly provides an advantage in terms of genome fragmentation while preserving the original assemblies characteristics in terms of missing bases and misassemblies. We argue that it is thus a good choice for *de novo* projects.

## Methods

*Mix* algorithm takes two (or more) assemblies and generates another one that *mixes* them in order to extend the length of resulting contigs. It builds an *extension graph* in which for each alignment involving extremities of two contigs we create vertices representing terminal aligned fragments. Edges of this extension graph encode how contigs are connected by an alignment. The resulting output assembly corresponds to a set of longest paths in this extension graph.

### Preliminaries

A contig *C* is composed of its identifier *id* and its sequence *s*, that is *C* = 〈*id, s*〉, its length is denoted by *|C|* and is equal to *|s|*. An assembly is a set of contigs $\mathbb{\text{A}}=\left\{{C}_{i}\right\}$. Input assemblies are combined together $\mathbb{\text{A}}=\cup {\mathbb{\text{A}}}_{i}$, where ${\mathbb{\text{A}}}_{i}$ are different assemblies, ideally produced by assemblers relying on different algorithmic principles.

**Definition 1**

*An*alignment

*between two contigs C*

_{ i }

*and C*

_{ j }

*is a tuple a*= 〈

*C*

_{ i }

*, C*

_{ j }

*, b*

_{ i }

*, e*

_{ i }

*, b*

_{ j }

*, e*

_{ j }

*, l*〉

*, where b*

_{ i }

*and e*

_{ i }

*(b*

_{ j }

*and e*

_{ j }

*, respectively) are the beginning and end coordinates of the part of C*

_{ i }

*aligned on C*

_{ j }

*(of C*

_{ j }

*on C*

_{ i }

*, respectively) and l is the alignment length. A*terminal alignment

*is an alignment involving extremities of C*

_{ i }

*and C*

_{ j }

*, that is at least one of the following is true*.

An alignment set is denoted by $\mathcal{A}=\left\{{a}_{i}\right\}$. The set $\phantom{\rule{0.1em}{0ex}}\mathcal{A}$ is built by aligning each assembly within $\phantom{\rule{0.1em}{0ex}}\mathbb{\text{A}}$ against the others. When the context does not require otherwise, we denote an alignment *a* by 〈*C*_{
i
}*, C*_{
j
}〉.

An *extension graph* is an overlap graph built over terminal alignments in $\phantom{\rule{0.1em}{0ex}}\mathcal{A}$. They are considered to have the potential to "glue" contigs, lower their number and maximize the cumulative contig length. Notice that to do this, we only consider terminal alignments, i.e. those that involve contigs' extremities. Indeed, in current work we do not question the internal logic of assembly tools that produce input contig sets.

*a*= 〈

*C*

_{ i }

*, C*

_{ j }

*, b*

_{ i }

*, e*

_{ i }

*, b*

_{ j }

*, e*

_{ j }

*, l*〉 is encoded by eight vertices that correspond to the extremities of

*a*on

*C*

_{ i }and

*C*

_{ j }. We distinguish boundary

*b*and internal

*i*locations as well as how a contig is being read (forward or reverse). Edges represent a way to "glue"

*C*

_{ i }and

*C*

_{ j }together and are weighted. Edges that connect boundary or internal nodes of different contigs carry weight equal to

*l*, those that represent the remaining chunks of

*C*

_{ i }and

*C*

_{ j }carry weights equal to

*|C*

_{ i }

*| − l*and

*|C*

_{ j }

*| − l*, respectively. See Figure 2 for illustration. When a contig is involved in more than one alignment, its internal nodes are connected by edges, thus allowing for "gluing" more than two contigs. Weights for these edges are deduced according to the intervals defined by alignments on contigs.

To finalize the graph construction, two artificial nodes are added: In and Out. These nodes are connected to both extremities of each contig, allowing it to be read in forward and reverse direction. In this extension graph we look for paths that maximize the cumulative contig length.

### Mix algorithm

**Preprocessing**Input alignment set $\phantom{\rule{0.1em}{0ex}}\mathcal{\text{A}}$ is generated by aligning each assembly in $\phantom{\rule{0.1em}{0ex}}\mathbb{\text{A}}$ against all of the others. Before attempting to extend contigs,

*Mix*first proceeds to clean up the alignment set $\phantom{\rule{0.1em}{0ex}}\mathcal{\text{A}}$ in the following fashion.

- 1.
If any self alignments 〈

*C*_{ i }*, C*_{ i }〉 are present, they are eliminated. - 2.
If two alignments 〈

*C*_{ i }*, C*_{ j }〉 and 〈*C*_{ j }*, C*_{ i }〉 covering the same region, are present in $\phantom{\rule{0.1em}{0ex}}\mathcal{A}$, only one is kept. - 3.
Only alignments whose length

*l*is greater than a certain threshold*t*_{ a }are kept in $\phantom{\rule{0.1em}{0ex}}\mathcal{A}$. - 4.
Alignments for which

*l/|s*_{ i }*| >*99% or*l/|s*_{ j }*| >*99% are eliminated from $\phantom{\rule{0.1em}{0ex}}\mathcal{A}$. - 5.
Alignments involving spurious contigs are eliminated; spurious contigs are those that have been aligned an abnormally high number of times. They are detected by looking for outliers in the distribution of the number of alignments per contig.

Starting with $\phantom{\rule{0.1em}{0ex}}\mathbb{\text{A}}$ filtered by criteria 1-5 and $\phantom{\rule{0.1em}{0ex}}\mathcal{A}$, *Mix* proceeds to build the corresponding extension graph *G*.

**Algorithm** Once the extension graph is built we are looking for ways to traverse this graph while maximizing the path length. More formally, we identify in the extension graph the *Maximal Independent Longest Path Set* problem (MILPS) that we define as follows. Let *G* = 〈*V, E, w*, In, Out〉 be a directed weighted graph *G* with positive weights denoted by *w*(*e*) for any edge *e* ∈ *E*; and let In ⊆ *V* and Out ⊆ *V* be two pre-defined sets of nodes corresponding to the entry and exit points of *G*. In general, one can add two vertices: one of in-degree 0 to serve as entry point and one of out-degree 0 to serve as exit point. A path *P* in *G* is a sequence of *|P|* vertices and we denote by *P*_{(i)}the vertex at position *i* in *P*. A path is said to be simple if none of its vertices appears twice.

**Definition 2** *An* Independent Longest Path Set (ILPS) of G is a set of simple paths $\phantom{\rule{0.1em}{0ex}}\mathcal{P}$ *such that*

*1.* $\forall P\in \mathcal{P}$, *P starts in* In *and ends in* Out*, i.e. P*_{(0)} ∈ In *and P*_{
|P|
} ∈ Out,

*2*. ∀ *P*_{
i
}, ${P}_{j}\in \mathcal{P}$; *i* ≠ *j implies P*_{
i
} *∩ P*_{
j
} ⊆ In ∪ Out,

*3*. ∀ *P* of *G* from In to Out and $\forall {\mathcal{P}}_{i}\in \mathcal{P}$, either *P* and ${\mathcal{P}}_{i}$ are independant, i.e. $P\cap {\mathcal{P}}_{i}\subseteq \text{In}\cup \text{Out}$; or *P* is subsumed by ${\mathcal{P}}_{i}$, i.e. ${\sum}_{k}w\left({P}_{\left(k\right)}\right)\le {\sum}_{k}w\left({P}_{i\left(k\right)}\right)$; or *P* is not simple.

**Definition 3** *A* Maximal Independent Longest Path Set (MILPS) *is an* ILPS $\phantom{\rule{0.1em}{0ex}}\mathcal{P}$*such that* $|\cup \mathcal{P}|$*is maximal over all possible ILPS, that is it covers a maximum number of vertices*.

Note that for any graph *G*, the MILPS is uniquely defined up to a relabeling of vertices. It follows immediately that if a vertex *o* ∈ Out is reachable from a vertex *i* ∈ In, then $\exists \mathcal{P}\ne \varnothing $ and $\phantom{\rule{0.1em}{0ex}}\mathcal{P}$ contains the longest simple path between *i* and *o*. Similarly, if an non empty MILPS exists for a graph *G*, it necessarily contains the longest path between In and Out.

In general, the longest path problem (LPP) is NP-hard (by reduction from a Hamiltonian path problem) and is hard to approximate. Even if a graph admits an Hamiltonian path of length *n*, it is impossible to find paths of length *n* - *n*^{
ε
} for any *ε >* 0 unless P = NP [16]. However, trees and directed acyclic graphs are examples of non-trivial graph classes for which the longest path problem can be solved in linear time. In the same paper the authors show that LPP can be solved in polynomial time for (vertex/edge) weighted tree-like graphs. Authors of [17] proposed another practical solution for the LPP for the case of combinational circuits that contain cycles. We propose here a solution exploiting the relative tree-like structure of our extension graphs.

As we impose no restrictions on $\phantom{\rule{0.1em}{0ex}}\mathcal{A}$, we have no guarantee that the resulting extension graphs are acyclic, and thus solving MILPS is at least NP-hard. However, we empirically determined that we obtain extension graphs that are most of the time sparse and often even acyclic. Given that sparse graphs are "locally tree-like" (meaning that a typical node is not part of a short cycle) [18], a simple algorithm based on local cycle decomposition is computationally tractable. The main idea behind our algorithm is to iteratively identify longest paths in *G*, where at each iteration we work on the restriction of *G* where no elements of the previous longest path can be traversed. To compute the longest path, *G* is decomposed into acyclic and cyclic parts. The cyclic parts of *G* correspond to its strongly connected components (SCCs). For each SCC, we determine the subset of vertices that are entry and exit points; and enumerate all simple paths between them. This set of enumerated paths is then inserted in *G* in lieu of the SCC. This operation yields an acyclic graph. In such a graph, longest paths between In and Out are determined by a greedy approach based on topological ordering. The complete solution is described in Algorithm 1.

**Algorithm 1** Maximal Independant Longest Path Set

**Require:** Directed weighted graph *G* = 〈*V, E, w*, In, Out〉

**Ensure:** Maximal Independant Longest Path Set $\phantom{\rule{0.1em}{0ex}}\mathcal{P}$

1: Let *C* be the set of non singleton strongly connected components of *G*

2: Let *R* be a mapping *V* → *V* used to store the initial label *R*(*v*) of a vertex *v*; *R*(*V*) ← *V*

3: **if** *C* ≠ ∅ **then**

4: **for** each strongly connected component *c* ∈ *C* **do**

5: Mark entry {*v*^{
in
}} (resp. exit {*v*^{
out
}}) vertices of *c*, s.t. (*v, v*^{
in
}) ∈ *E, v;* $\phantom{\rule{0.1em}{0ex}}\notin $*c* (resp. (*v*^{
out
}*, v*) ∈ *E, υ* $\phantom{\rule{0.1em}{0ex}}\notin $*c*)

6: Let *P* be the set of all simple paths from {*v*^{
in
}} to {*v*^{
out
}} in *c*, by performing *|c|* iterations of a breadth-first traversal rooted at the entry vertices

7: **for** each path *p* ∈ *P* **do**

8: Insert a novel path *p*' in *G*, with $w\left({p}_{\left(i\right)}^{\prime}\right)\leftarrow {p}_{\left(i\right)}$ and with $R\left({p}_{\left(i\right)}^{\prime}\right)\leftarrow {p}_{\left(i\right)}$

9: **end for**

10: **end for**

11: **end if**

**Ensure:** *G* is acyclic

12: Let *W* be a mapping $V\to \mathbb{R}$ indicating the accumulated length *W*(*v*) down to node *v*; *W*(In) ← 0

13: Let Pred be a mapping *V* → *V* indicating the predecessor Pred(*v*) of *v* in the current longest path; *Pred*(In) ← ∅

14: $\mathcal{P}\leftarrow \varnothing $

15: **repeat**

16: **for** *v* in the topological ordering of G starting at In and ending at Out **do**

17: Let ${V}^{\prime}=\{{\upsilon}^{\prime}\in V|({\upsilon}^{\prime},\upsilon )\in E,\phantom{\rule{0.1em}{0ex}}\overline{)\exists}\phantom{\rule{0.1em}{0ex}}p\in \mathcal{P},{\upsilon}^{\prime}\in p\vee {\upsilon}^{\prime}\in R(p)\}$

18: Pred(*v*) *←* arg max_{
v'
}_{∈V'}(*W*(*υ*') + *w*(*v*', *v*))

19: *W*(*υ*) *←* max_{
υ'
}_{∈V'}(*W*(*υ*') + *w*(*υ*', *υ*))

20: **end for**

21: Walk up the graph to construct the path *p* by letting *p ←* Pred^{∗}(*Out*)

22: $\mathcal{P}\leftarrow \mathcal{P}\cup \left\{p\right\}$

23: **until** *p* = ∅

24: **return** $R\left(\mathcal{P}\right)$, the MILPS with re-labeled vertices

In the case where *G* is acyclic, this algorithm is linear in the number of vertices. However, if *G* contains a cycle, the number of vertices that are added during the decomposition of a strongly connected component is exponential in the size of the strongly connected component. In our experiments (see Results section), we applied Mix over 300 different combinations of assemblies of bacterial genomes, and only two of them yielded assembly graphs with cycles, that were of tractable size.

Once the MILPS in the extension graph are built, we use the information stored in the graph to glue and stitch contigs corresponding to each extension path.

**Pruning** A pruning step is performed over the set of remaining contigs and extension paths. This step ensures that duplication is lowered. Indeed, one of the main drawbacks of merging two assemblies of the same genome is that most of the information is duplicated. In order to reduce this effect, we compute a coverage graph which is a directed graph with an edge between *v* and *v*' if portions of the nucleotide sequence of *v* is found in *v*'. Based on this graph, we can determine which contigs are entirely or to a large extent contained into other contigs or paths. These covered contigs are then removed from the final assembly. To build the coverage graph, we start by generating a coverage matrix that indicates how much an element of the current assembly graph (either a contig or an extension path) is covered by another element. To compute the coverage, we reuse the initial set of alignments $\phantom{\rule{0.1em}{0ex}}\mathcal{A}$ to determine how many nucleotides of a source element are found in the target element. This coverage is computed for each possible pair. The coverage matrix is then thresholded to only keep pairs of elements with high coverage (90 % in our experiments). We then consider this thresholded matrix to be the adjacency matrix of a directed graph. This requires to decide the direction of inclusion for each pair where the coverage is above the threshold. This direction is determined by selecting as source the element with the highest ratio of covered nucleotides. In the case of ties, the shortest element is elected as source. This edge-orientation strategy can nonetheless produce cycles in the coverage graph as several contigs from different assemblies can be highly similar. In such cases, cycles are broken by selecting the element with the longest nucleotide sequence from each strongly connected component. We then perform a topological sort on the coverage graph and systematically remove contigs that are not covering any contig but that are covered by other contigs or paths.

## Results

### Performance evaluation

We evaluated the performance of *Mix* on the GAGE-B data set [15] against both raw assemblies and two tools that allow combining assemblies, GAA (best in GAGE-B study) and GAM-NGS (not previously evaluated). The benchmark provided by GAGE-B concerns 8 bacterial genomes. Starting point data consists of HiSeq and MiSeq Illumina reads (sometimes both, sometimes just HiSeq). Tools tested in the GAGE-B study include 8 assemblers and 2 merging algorithms, minimus2 and GAA. These latter have been chosen since they are (almost) reference free, contrary to the others. As already stated in the Background section, mixing assembly tools mostly provided inferior results, however for some cases GAA managed to improve the N50 size with an increase of *>* 80%.

We applied GAA and GAM-NGS for all pairwise combinations of 8 assemblers twice (accounting for the asymmetry). We evaluated *Mix* results against those for the 8 assemblers, as well as merged assemblies produced by GAA and GAM-NGS. All evaluations were performed using QUAST [19] under the same parameters as GAGE-B. Three different types of metrics are used by QUAST. First, classical assembly statistics based on the distribution of the length of each contig of an assembly. These statistics do not require any reference genome and are used to measure the fragmentation of an assembly. A second set of statistics is derived from an alignment of the assembly against a reference genome. Contigs that are aligned over distant locations in the reference genome or that contain misassemblies are split, and fragmentation is measured over the split contigs. Using these alignments, additional measures report the ratio of duplication as well as the fraction of the reference genome that is covered by an assembly. A third, more robust, statistics is derived from the conservation of gene products. These last two statistics can be measured only if a fully assembled and annotated reference genomes is provided.

*Mix*. All original assemblies were downloaded from the GAGE-B website, they consist of contigs assemblies and correspond to HiSeq libraries, with the exception of

*B. cereus*for which we used assemblies based on MiSeq libraries in order to match the GAGE-B setup. Only 13 species/merger/assemblers combination are missing from the full factorial setup. Figure 3 reports the NA50 distributions per species and assembly merger contrasted with single (unmerged) assemblies. Two species are missing from this figure,

*X. axonopodis*and

*A. hydrophila*, since the strain sequenced during the GAGE-B project is too distant from the reference genome to compute a NA50 value (this holds for all assemblies for these two species). In setups where a close-enough reference genome is not available, the sole statistics available to "score" assemblies are based on fragmentation measures, notably the N50. To simulate such reference-less setup, we selected for each species and each assembly merger the top 5 assemblies when ranked by N50. By analyzing how these "blindly" selected top N50 assemblies are scored with regards to statistics based on a reference genome, we can analyze the soundness of this selection heuristic.

In Figure 3, we observe that for all but *S. aureus* either GAM-NGS or *Mix* improve the single assembly substantially. Notably for *B. cereus*, for which the authors of GAGE-B already reported some improvement over single assemblies when using GAA, we manage with GAM or *Mix* to improve even more. The best *Mix* assembly for *B. cereus* stitches 90 contigs from MaSuRCA and 105 from SOAP into 47 contigs (including 4 extension paths), improving the NA50 score by 97%(NA50 of 487kb). For five out of six species, one of the top 5 assemblies generated by *Mix* is better than the best GAA, GAM and single assemblies. In particular, *Mix* significantly improves statistics measuring fragmentation of assemblies (for complete results, see results and figures available at https://github.com/cbib/MIX), as well as alignments of contigs. Similar plots and tabular data for other QUAST statistics are available on the accompanying MIX website. These also show the asymmetry in the results when one or another of assemblies is treated as target (resp., master) by GAA (resp., GAM-NGS).

Of particular concern when merging multiple assemblies is the potential increase in duplication. Indeed, the bottom panel of Figure 3 shows that overall, the mean duplication ratio for *Mix* is higher than for other assemblers, the worst case happening for *V. cholera* where one of *Mix* top 5 assemblies has a duplication that is out of range of the others. It is worth noting however that generally the duplication ratio of *Mix* assemblies stays within the same range as that produced by other assemblers (on the order of 1-2%). Finally and most importantly, we also observe that selecting assemblies solely based on the N50 value often selects the best assemblies, as validated by additional reference-genome based statistics.

### Application to Mycoplasma genomes

*Mycoplasma. Mycoplasmas*are small bacteria often portrayed as the best representative of the minimal cell. Indeed, their genomes are extremely reduced (

*i.e*., 0.58 to 1.4 Mbp) with a low GC-content, most of them ranging from 24 to 30%. For the

*Mycoplasma*genomes the available NGS data consisted in 454 and Illumina (mate paired) reads, produced in the frame of the ANR

*EVOLMYCO*project (see Table 1).

Summary of NGS reads volume used for genome assembly of 10 Mycoplasma genomes

Genomes | Abbreviations | 454 mate pair | Illumina | ||
---|---|---|---|---|---|

#reads | med. size | #reads | size | ||

| MAUR | 107423 | 152.32 | 4386186 | 36 |

| MBVG | 132462 | 156.01 | 28752688 | 36 |

| MOVI | 97641 | 160.49 | 6889585 | 36 |

| MBOVb | 203245 | 166.97 | 35808407 | 36 |

| MMC | 265968 | 145.12 | 4817991 | 36 |

| MCCP | 150110 | 134.31 | 32510614 | 36 |

| MSCb | 247991 | 142.42 | 5342924 | 36 |

| MSCc | 186553 | 162.18 | 3585785 | 36 |

| MSCe | 132717 | 168.14 | 28776419 | 36 |

| MSCd | 163636 | 169.86 | 31781063 | 36 |

- 1.
SPAdes [20] was the winner in terms of N50. However it produced a large number of small, unaligned contigs and was consequently excluded from our study.

- 2.
ABySS consistently produced assemblies with the fewest errors and had the second best N50.

- 3.
MIRA produced a large corrected N50 with errors occurring mostly in smaller contigs.

Moreover, MIRA and ABySS rely on different algorithmic methods (overlap/layout/consensus and deBruijn graph construction, respectively). Two other considerations were taken into the account for the *Mycoplasma* case-study. First, ABySS was specifically developed for very short reads, which is the case for our application (see Table 1). Second, MIRA aims at combining reads from different sequencing technologies, which is the case for the *Mycoplasma* data (Illumina and 454). We have added the CLC Assembly Cell (based on the deBruijn graph), a commercial solution that was not part of the GAGE-B evaluation, but shows high N50 statistics.

ABySS was run over a large span of k-mer values (25 to 36) for each genome and the best solution in terms assembly statistics was retained each time for further assembly combination.

*Mycoplasma*genomes were combined using GAA, GAM-NGS and

*Mix*. GAA and GAM-NGS were applied twice to each pair of input assemblies, owing for the asymmetry in their solutions.

*Mix*was applied once to each pair of input assemblies as well as to all three input assemblies taken together. Results of these computations as well as NGS reads are available at http://services.cbib.u-bordeaux2.fr/mix/. In Figure 4 we compare these assemblies using the standard genome assembly statistics applicable when no reference genome or annotations are available. We observe that we are able to significantly reduce the fragmentation with

*Mix*, as exemplified by the substantial decrease in the number of contigs as well as the size of the largest contigs. This improvement is not counterbalanced by an increased duplication or by a loss of putative functional genomic content.

**Core genome conservation** GAGE-B study was based on genomes having a complete reference sequence with known proteome. This was particularly useful in order to evaluate the biological pertinence of assembly results. Our *Mycoplasma* study is though truly *de novo* and we do not have reference genomes. However, *Mycoplasmas* are a well studied genus where a large number of genomes are fully sequenced and annotated.

*core genome*is defined as the set of genes present in all strains. We have computed the core genome based on the 31

*Mycoplasma*complete genomes (Table 2) according to two criteria. First, predicted proteins from each of the genomes included in the set have to be present in each cluster. Second, one single homolog per genome has to exist to avoid paralog ambiguity. The 10 draft genomes used for our study were naturally excluded from the genome set. The computed

*Mycoplasma*core genome contains 170 clusters of direct orthologs, most of which are related to basic cell machinery. The sequences of the core genome depend on the genomes already available (thanks notably to the

*EVOLMYCO*project).

Genomes used for the core genome computation

M. gallisepticum R High | M. gallisepticum R Low | M. gallisepticum F |

M. genitalium G37 | M. pneumoniae M129 | M. penetrans HF-2 |

U. parvum 21815 | U. urealyticum 33699 | U. parvum 700970 |

M. agalactiae 5632 | M. agalactiae PG2 | M. bovis PG45 |

M. bovis Hubei | M. fermentans JER | M. synoviae 53 |

M. pulmonis UABCTIP | M. hyopneumoniae 232 | M. hyopneumoniae J |

M. hyopneumoniae 7448 | M. hyorhinis HUB-1 | M. mobile 163K |

M. mycoides subsp. capri GM12 | M. arthitidis 158L3-1 | Mesoplasma florum L1 |

M. mycoides subsp. capri 95010 | M. hominis PG21 | M. leachii 99 |

M. mycoides subsp. mycoides PG1 | M. mycoides subsp. mycoides Gladysdale | M. leachii PG50 |

M. capricolum subsp. capricolum 27343 |

Since these clusters represent highly conserved sequences corresponding to essential genes, ideally, each cluster should be found in the assembled genomes. Moreover, sequence conservation should be preserved over entire length of the protein. To measure this, we first align each protein sequence of each cluster against each assembly. For each cluster, the alignment with the highest e-value is retained. Since our aim is to find entire protein/gene sequences, the alignment length is very important. Indeed, if the sequence is not entirely conserved, this can signify that it has been fragmented during assembly: either one part is located at an extremity of one contig and another part at the extremity of an another contig, or in the worse case, it can be the marker of a misassembly.

*l*

_{ A }of the best scoring alignment, and the length

*l*

_{ P }of the protein representing the cluster, we use the percentage of the expected length that is effectively aligned against the assembly,

*l*

_{ A }

*/l*

_{ P }. For a given threshold 0

*≤ t ≤*100, we count clusters that have at least one protein that aligns with

*l*

_{ A }

*/l*

_{ P }

*> t*. In Figure 5, we present the results for all the studied genomes, and for three values of

*t*: 50%, 85% and 99.99%.

Notable negative cases for our approach are MCCP and MBVG, where *Mix* produced lower quality results. However, on the other cases it shows better conservation of core genome. Importantly, in the case of *Mix* this conservation is consistent between different combinations of input assemblies, as exemplified by a shorter inter-quartile range than that of other tools.

## Discussion

Despite the progress of sequencing technologies and of bioinformatics methods, *de novo* assembly of genomes remains a challenge with a lot of hurdles. The cost of sequencing falling down and the computing capacity increasing, *de novo* assemblies of genomes are released at an increasingly fast pace.

The goal of our work was to combine the strengths and to balance the weaknesses of different assembly programs in order to lower contig fragmentation. A similar goal has been previously explored by a number of papers, and in particular by the authors of GAA [14] and GAM-NGS [12]. A recent GAGE-B evaluation for bacterial genomes of assemblers and assembly mergers concluded that the latter did not provide any advantage and even sometimes worsened the results. GAM-NGS was not included in that study.

In current work we have described *Mix* , the first truly reference-free assembly merger. Our solution is based on solving the *Maximal Independent Longest Path Set* problem, known to be NP-hard, but tractable for this particular application and problem sizes. Evaluating *Mix* on the GAGE-B bacterial dataset, we show that our approach consistently lowers genome fragmentation without compromising biological relevance (ex., as measured by the alignment against the reference). Moreover, in the case of *Mix* choosing the final result based on N50 statistics maintains high assembly quality. Comparatively to *Mix*, both single assemblers as well as GAA and GAM-NGS provide poorer results in these terms. Nevertheless, a certain drawback of our approach lies in the duplication ratio. This should however be modulated by the fact that it generally stays within 1 to 2% range.

We conclude that *Mix* provides a sound approach for genome finishing in the context of *de novo* projects, where the final choice can be done based on the N50 statistics. Best resulting assemblies for *Mycoplasma* genomes are currently being annotated and will be shortly submitted to the EMBL.

## Declarations

### Acknowledgements

This work was supported by *EVOLMYCO* French Ministry of Research ANR-07-GMGE-001 grant. HS is supported by an ERASysBio+ EU ERA-NET Plus scheme in FP7 (project LymphoSys). Genome sequencing was done by the Genoscope (Centre National de Séquençage, Evry, France). Computer resources for assembly were provided by the computing facilities MCIA (Mésocentre de Calcul Intensif Aquitain) of the Université de Bordeaux and of the Université de Pau et des Pays de l'Adour.

This article has been published as part of BMC Bioinformatics Volume 14 Supplement 15, 2013: Proceedings from the Eleventh Annual Research in Computational Molecular Biology (RECOMB) Satellite Workshop on Comparative Genomics. The full contents of the supplement are available online at http://www.biomedcentral.com/bmcbioinformatics/supplements/14/S15.

## Authors’ Affiliations

## References

- Chevreux B, Pfisterer T, Drescher B, Driesel A, Muller W, Wetter T, Suhai S: Using the MiraEST assembler for reliable and automated mRNA transcript assembly and SNP detection in sequenced ESTs. Genome Res. 2004, 14 (6): 1147-59. 10.1101/gr.1917404.PubMed CentralView ArticlePubMedGoogle Scholar
- Simpson J, Wong K, Jackman S, Schein J, Jones S, Birol I: ABySS: a parallel assembler for short read sequence data. Genome Res. 2009, 19 (6): 1117-23. 10.1101/gr.089532.108.PubMed CentralView ArticlePubMedGoogle Scholar
- Ye L, Hillier L, Minx P, Thane N, Locke D, Martin J, Chen L, Mitreva M, Miller J, Haub K, Dooling D, Mardis E, Wilson R, Weinstock G, Warren W: A vertebrate case study of the quality of assemblies derived from next-generation sequences. Genome Biol. 2011, 12 (3): R31-10.1186/gb-2011-12-3-r31.PubMed CentralView ArticlePubMedGoogle Scholar
- Harismendy O, Ng P, Strausberg R, Wang X, Stockwell T, Beeson K, Schork N, Murray S, Topol E, Levy S, Frazer K: Evaluation of next generation sequencing platforms for population targeted sequencing studies. Genome Biol. 2009, 10: R32-10.1186/gb-2009-10-3-r32.PubMed CentralView ArticlePubMedGoogle Scholar
- Diguistini S, Liao N, Platt D, Robertson G, Seidel M, Chan S, Docking T, Birol I, Holt R, Hirst M, Mardis E, Marra M, Hamelin R, Bohlmann J, Breuil C, Jones S: De novo genome sequence assembly of a filamentous fungus using Sanger, 454 and Illumina sequence data. Genome Biol. 2009, 10: R94-10.1186/gb-2009-10-9-r94.PubMed CentralView ArticlePubMedGoogle Scholar
- Nagarajan H, Butler J, Klimes A, Qiu Y, Zengler K, Ward J, Young N, Meth B, Palsson B, Lovley D, Barrett C: De Novo assembly of the complete genome of an enhanced electricity-producing variant of Geobacter sulfurreducens using only short reads. PLoS One. 2010, 5 (6): e10922-10.1371/journal.pone.0010922.PubMed CentralView ArticlePubMedGoogle Scholar
- Casagrande A, Del FC, Scalabrin S, Policriti A: GAM: Genomic Assemblies Merger: A Graph Based Method to Integrate Different Assemblies. Bioinformatics and Biomedicine. 2009, 10.1109/BIBM.2009.28Google Scholar
- Sommer D, Delcher A, Salzberg A, Pop M: Minimus: a fast, lightweight genome assembler. BMC Bioinformatics. 2007, 8: 64-10.1186/1471-2105-8-64.PubMed CentralView ArticlePubMedGoogle Scholar
- Nijkamp J, Winterbach W, van dBM, Daran J, Reinders M, de Ridder R: Integrating genome assemblies with MAIA. Bioinformatics. 2010, 26 (18): i433-9. 10.1093/bioinformatics/btq366.PubMed CentralView ArticlePubMedGoogle Scholar
- Zimin A, Smith D, Sutton G, Yorke J: Assembly reconciliation. Bioinformatics. 2008, 24: 42-5. 10.1093/bioinformatics/btm542.View ArticlePubMedGoogle Scholar
- Argueso J, Carazzolle M, Mieczkowski P, Duarte F, Netto O, Missawa S, Galzerani F, Costa G, Vidal R, Noronha M, Dominska M, Andrietta M, Andrietta S, Cunha A, Gomes L, Tavares F, Alcarde A, Dietrich F, McCusker J, Petes T, Pereira G: Genome structure of a Saccharomyces cerevisiae strain widely used in bioethanol production. Genome Res. 2009, 19 (12): 2258-2270. 10.1101/gr.091777.109.PubMed CentralView ArticlePubMedGoogle Scholar
- Vicedomini R, Vezzi F, Scalabrin S, Arvestad L, Policriti A: GAM-NGS: genomic assemblies merger for next generation sequencing. BMC Bioinformatics. 2013, 14 (7): 1-18.Google Scholar
- Kurtz A, Phillippy A, Delcher A, Smoot M, Shumway A, Antonescu C, Salzberg S: Versatile and open software for comparing large genomes. Genome Biology. 2004, 5 (2): R12-10.1186/gb-2004-5-2-r12.PubMed CentralView ArticlePubMedGoogle Scholar
- Yao G, Ye L, Gao H, Minx P, Warren W, Weinstock G: Graph accordance of next-generation sequence assemblies. Bioinformatics. 2011, 28: 13-6.PubMed CentralView ArticlePubMedGoogle Scholar
- Magoc T, Pabinger S, Canzar S, Liu X, Su Q, Puiu D, Tallon L, Salzberg S: GAGE-B: An Evaluation of Genome Assemblers for Bacterial Organisms. Bioinformatics. 2013Google Scholar
- Karger D, Motwani R, Ramkumar G: On Approximating the longest path in a graph. Algorithmica. 1997, 18: 82-98. 10.1007/BF02523689.View ArticleGoogle Scholar
- Hsu YC, Sun S, Du DC: Finding the longest simple path in cyclic combinational circuits. Computer Design: VLSI in Computers and Processors, 1998 ICCD '98 Proceedings International Conference on. 1998, 530-535.Google Scholar
- Bollobas B: Random Graphs. 1985, Academic PressGoogle Scholar
- Gurevich A, Saveliev V, Vyahhi N, Tesler G: QUAST: quality assessment tool for genome assemblies. Bioinformatics. 2013, 29 (8): 1072-1075. 10.1093/bioinformatics/btt086.PubMed CentralView ArticlePubMedGoogle Scholar
- Bankevich A, Nurk S, Antipov D, Gurevich A, Dvorkin M, Kulikov A, Lesin V, Nikolenko S, Pham S, Prjibelski A, Pyshkin A, Sirotkin A, Vyahhi N, Tesler G, Alekseyev M, Pevzner P: SPAdes: a new genome assembly algorithm and its applications to single-cell sequencing. J Comput Biol. 2012, 19: 455-477. 10.1089/cmb.2012.0021.PubMed CentralView 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.