This disclosure relates to the lossless compression of aligned genomic sequence reads with the associated alignment information and the reference genomes, or portions thereof, used to align said genomic sequences. A genomic sequence is generally intended as a concatenation of molecules called nucleotides to form fragments of deoxyribonucleic acid (DNA) or Ribonucleic acid (RNA). The present invention can be applied to any reference sequence of symbols used to align shorter sequences using the same alphabet.
The present invention applies to aligned genomic sequences which have been compressed by means of a reference-less compression method. An initial attempt in this direction is the one described in Voges, J., Munderloh, M., Ostermann, J., “Predictive Coding of Aligned Next-Generation Sequencing Data” (2016 Data Compression Conference (DCC)) or the in Benoit, G., et al. “Reference-free compression of high throughput sequencing data with a probabilistic de Bruijn graph” (BMC Bioinformatics. 2015; 16: 288.) with, however, several limitations addressed in the present invention.
In the context of this disclosure, reference-less compression of aligned genomic sequences comprises the creation of one or more local reference sequences named “contig” built by overlapping and concatenating genomic sequences mapped in adjacent or overlapping regions of the reference genome used for alignment. For an exhaustive description of contig see https://en.wikipedia.org/wiki/Contig. Said contigs do not need to be included in the compressed bitstream since they are reconstructed at the decoding end as part of the decoding process. Once a contig has been built for a genomic region where one or more genomic sequences have been mapped, reference-based compression is applied to said genomic sequences by describing them in terms of genomic descriptors and compressing each block of genomic descriptors of the same type with a specific entropy coder. This approach enables reaching better compression ratios than general purpose compression schemes such as GZIP, LZMA, BZ and preserves random access.
Reference-based compression of aligned genomic sequences is based on representing said aligned sequences in terms of their mapping positions and differences with respect to the one or more reference sequences used for alignment and encoding only said positions and differences. Whereas such approach permits to reach very high compression ratios (roughly linearly increasing with the coverage, wherein with the term coverage is intended the average number of reads which contain each nucleotide of a reference genome), both the encoding and decoding process require the availability of the specific reference sequences used for the alignment and the compression. A drawback of the approach is that if the reference sequence used for the alignment and the compression is not available at the decoding side (for example due to the lack of a unique identification of the reference genome or its version, or in case the original data source is no more available), the compressed content cannot be recovered. Solutions based on including the reference genomes in the compressed representation for storage or transmission would result to be detrimental in terms of compression efficiency.
To address such problem, reference-less compression methods enabling compression and decompression of aligned genomic sequence reads without using the reference genome used for alignment do exist. Some of these methods adopt general purpose compressors such as GZIP, BZIP2, LZMA and reach poor compression ratios in the order to 3:1. More efficient methods are based on the construction of one or more reference sequences from the aligned reads themselves by means of a process called “assembly” in which reads mapped on adjacent genomic intervals of the reference genome used for alignment are used to build longer sequences by finding shared subsequences and concatenating them. The longer sequence obtained from the concatenation or merge of shorter ones is called “contig”. Such methods include the already cited publication from Voges, J., Munderloh, M., Ostermann, J., “Predictive Coding of Aligned Next-Generation Sequencing Data” (2016 Data Compression Conference (DCC)) and the paper from Benoit, G., et al. “Reference-free compression of high throughput sequencing data with a probabilistic de Bruijn graph” (BMC Bioinformatics. 2015; 16: 288.).
This disclosure addresses the problem of the efficient compression of the reference genome used for the alignment of genomic sequence reads when jointly applying reference-less compression of genomic sequences.
The features of the claims below solve the problem of existing prior art solutions by providing a method for lossless compression of reference genomes in case of reference-less compression of genomic sequences, said method comprising the steps of:
In another aspect of the compression method assembling said aligned reads comprises the step of selecting, for each position on the reference sequence, the nucleotide that is present with the highest frequency in the aligned reads at that position.
In another aspect of the compression method said information related to position of mismatches and the type of mismatches are indicated using, respectively a first descriptor (203) and a second descriptor (204)
In another aspect of the compression method said first descriptor and second descriptor are encapsulated in a same Access Unit so to enable the selective reconstruction of the reference sequence used for the alignment at the decoding device.
In another aspect of the compression method the length of said contig is defined as input parameter to the encoder or dynamically adapted by the encoder.
In another aspect of the compression method said first descriptor is binarized using a Split Unit-wise Truncated Unary binarization, wherein said Split Unit-wise Truncated Unary is a concatenation of repeated truncated unary binarizations, where each truncated unary binarization is applied to portions of the value to be binarized which are N bits long, wherein N is a preselected parameter.
In another aspect of the compression method said second descriptor is binarized using a Truncated Unary binarization, wherein the value of said second descriptor is followed by a zero and if said value is equal to the largest possible value to be binarized the trailing 0-bit is discarded.
In another aspect of the compression method said method does not encode information signalling the usage of a specific reference genome.
In another aspect of the compression method said length of said contig is contained in a syntax header.
An apparatus for encoding genome sequence data, said genome sequence data comprising reads of sequences of nucleotides, said apparatus comprising means for:
An apparatus for encoding genome sequence data, wherein said means for assembling said aligned reads further comprise means for selecting, for each position on the reference sequence, the nucleotide that is present with the highest frequency in the aligned reads at that position.
An apparatus for encoding genome sequence data, further comprising means to indicate said information related to the position of mismatches and the type of mismatches by, respectively a first descriptor (203) and a second descriptor (204).
An apparatus for encoding genome sequence data, further comprising means for encapsulating said first descriptor and second descriptor in the same Access Unit so to enable the selective reconstruction of the reference sequence used for the alignment at the decoding device.
An apparatus for encoding genome sequence data, further comprising means to receive the length of said contig as input parameter and means for dynamically adapting length of said contig.
An apparatus for encoding genome sequence data, further comprising binarization means for binarizing said first descriptor by employing a Split Unit-wise Truncated Unary binarization, wherein said Split Unit-wise Truncated Unary is a concatenation of repeated truncated unary binarizations, where each truncated unary binarization is applied to portions of the value to be binarized which are N bits long, wherein N is a preselected parameter.
An apparatus for encoding genome sequence data, further comprising binarization means for binarizing said second descriptor by employing a Truncated Unary binarization, wherein the value of said second descriptor is followed by a zero and if said value is equal to the largest possible value to be binarized the trailing 0-bit is discarded.
An apparatus for encoding genome sequence data, further comprising means for coding said length of said contig in a syntax header.
A method for decoding encoded genome sequence data, comprising the steps of:
In another aspect of the decoding method, disassembling the contig by employing said information related to position of a mismatch and type of mismatch in a contig thereby obtaining a genomic sequence of nucleotide further comprises entropy decoding of a first descriptor (203) and a second descriptor (204)
In another aspect, the decoding method further comprises decapsulating from the same Access Unit said first descriptor and second descriptor so to obtain the selective reconstruction of the genomic sequence of nucleotides.
In another aspect, the decoding method further comprises decoding the length of said contig from a syntax header contained in the input file.
In another aspect, the decoding method further comprises g a reverse binarization of said first descriptor, wherein said first descriptor is binarized using a Split Unit-wise Truncated Unary binarization, wherein said Split Unit-wise Truncated Unary is a concatenation of repeated truncated unary binarizations, where each truncated unary binarization is applied to portions of the value to be binarized which are N bits long, wherein N is a preselected parameter
In another aspect, the decoding method further comprises a reverse binarization of said second descriptor wherein said second descriptor is binarized using a Truncated Unary binarization, wherein the value of said second descriptor is followed by a zero and if said value is equal to the largest possible value to be binarized the trailing 0-bit is discarded.
In another aspect of the decoding method said input file does not contain information signalling the usage of a specific reference genome.
An apparatus for decoding encoded genome sequence data, comprising means for:
An apparatus for decoding encoded genome sequence data, wherein said means for disassembling the contig by employing said information related to position of a mismatch and type of mismatch in a contig thereby obtaining a genomic sequence of nucleotide further comprise means for entropy decoding of a first descriptor (203) and a second descriptor (204)
An apparatus for decoding encoded genome sequence data, further comprising means for the selective reconstruction of the genomic sequence of nucleotides, by decapsulating from a same Access Unit said first descriptor and second descriptor
An apparatus for decoding encoded genome sequence data, further comprising means for decoding from a syntax header contained in the input file the information relating to the length of said contig.
An apparatus for decoding encoded genome sequence data, further comprising means for a reverse binarization of said first descriptor, wherein said first descriptor is binarized using a Split Unit-wise Truncated Unary binarization, wherein said Split Unit-wise Truncated Unary is a concatenation of repeated truncated unary binarizations, where each truncated unary binarization is applied to portions of the value to be binarized which are N bits long, wherein N is a preselected parameter.
An apparatus for decoding encoded genome sequence data, further comprising means for a reverse binarization of said second descriptor wherein said second descriptor is binarized using a Truncated Unary binarization, wherein the value of said second descriptor is followed by a zero and if said value is equal to the largest possible value to be binarized the trailing 0-bit is discarded.
The genomic or proteomic sequences referred to in this invention include, for example, and not as a limitation, nucleotide sequences, Deoxyribonucleic acid (DNA) sequences, Ribonucleic acid (RNA), and amino acid sequences. Although the description herein is in considerable detail with respect to genomic information in the form of a nucleotide sequence, it will be understood that the methods and systems for compression can be implemented for other genomic or proteomic sequences as well, albeit with a few variations, as will be understood by a person skilled in the art.
Genome sequencing information is generated by High Throughput Sequencing (HTS) machines in the form of sequences of nucleotides (a.k.a. “bases”) represented by strings of letters from a defined vocabulary. The smallest vocabulary is represented by five symbols: {A, C, G, T, N} representing the 4 types of nucleotides present in DNA namely Adenine, Cytosine, Guanine, and Thymine. In RNA Thymine is replaced by Uracil (U). N indicates that the sequencing machine was not able to call any base and so the real nature of the nucleotide at that position is undetermined. In case the IUPAC ambiguity codes are adopted by the sequencing machine as vocabulary, the alphabet used for the symbols is composed of the following symbols: {A, C, G, T, U, W, S, M, K, R, Y, B, D, H, V, N or -}. In case of amino acids the supported symbols are: {A, C, D, E, F, G, H, I, K, L, M, N, P, Q, R, S, T, V, W, Y}.
In the context of this disclosure the nucleotides sequences produced by sequencing machines are called reads. Sequence reads can be composed of a number of nucleotides ranging between a few dozens to several thousand. Some sequencing technologies produce sequence reads composed of pairs of which one read is originated from one DNA strand and the other is originated from the other strand. A read associated to another read in a sequencing process producing pairs is said to be its mate.
A common element of efficient approaches to genomic sequence reads compression is the exploitation of the correlation of sequence data with respect to a reference sequence. Even if the somatic profile of the human population is extremely diversified, the actual portion of the number of nucleotides that differs from person to person is about only 0.1% of the total number of nucleotides composing an entire genome. Therefore, the specific genomic information characterizing each individual is very limited with respect to the entire information carried by an entire genome. When a pre-existing reference genome is available, be it for previous sequencing or as a published “average” consensus reference, the most common way as of today to encode the information is to identify and encode only the differences with respect to the reference genome.
In order to do so with raw sequence reads, generally expressed in the form of FASTQ data files, a preliminary pre-processing step the mapping on a reference genome. In case an appropriate reference genome is not available, or if the bias introduced by the usage of a specific reference is not desirable, the construction of a new reference sequence by means of assembling the sequence reads at hand into longer sequences called contigs, is a possible alternative.
Throughout this disclosure, a reference sequence is a sequence of nucleotides associated to a mono-dimensional integer coordinate system for which each integer coordinate is associated to a single nucleotide. Coordinate values can only be equal or larger than zero. This coordinate system in the context of this invention is zero-based (i.e. the first nucleotide has coordinate 0 and it is said to be at position 0) and linearly increasing from left to right.
When mapping sequence reads on a reference sequence, said reference sequence is used as axis of a mono-dimensional coordinate system in which the left-most position is denoted as position 0. For each sequence read, mapped to a reference sequence, the nucleotide mapped at the reference sequence position identified by the smallest coordinate number is usually referred to as the “left-most” nucleotide, whereas the nucleotide mapped at the reference sequence position identified by the largest coordinate number is referred to as the “right-most” nucleotide. This is illustrated in
When a sequence read is mapped to a reference sequence, the coordinate of the left-most mapped base is said to represent the mapping position of the read on the reference sequence.
A base present in the aligned read and not present in the reference sequence (a.k.a. insertion) and bases preserved by the alignment process but not mapped on the reference sequence (a.k.a. soft clips) do not have mapping positions.
When a sequence read cannot be mapped to any mapped position of the used reference sequences according to the specified matching rules, it is said to be unmapped.
The process of building longer genomic sequences by looking for overlapping regions among sequence reads is called assembly.
A longer genomic sequence built assembling shorter reads is called contig (see https://en.wikipedia.org/wiki/Contig).
Sequence reads that fail to build any contig during an assembly process are said to be unaligned.
A reference genome is composed by one or more reference sequences and it is assembled by scientists as a representative example of a species' set of genes. For example GRCh37, the Genome Reference Consortium human genome (build 37) is derived from thirteen anonymous volunteers from Buffalo, N.Y. However, a reference sequence could also consist of a synthetic sequence conceived and merely constructed to improve the compressibility of the reads in view of their further processing.
In this disclosure the read composing a read pair with a base mapping on the smallest coordinate on a reference sequence is referred to as “Read 1” whereas its mate is referred to as “Read 2”.
The distance, expressed as number of nucleotides (or bases), separating two reads generated as a pair, by a sequencing machine using current state of the art sequencing technology, is unknown, and it is determined by mapping both reads composing the pair (i.e. minimizing appropriate matching functions) to a reference sequence.
Throughout this disclosure, an Access Unit (AU) is defined as a logical data structure containing a coded representation of genomic information or related metadata to facilitate the bit stream access and manipulation. It is the smallest data organization that can be decoded by a decoding device implementing the invention described in this disclosure. According to the type of coded information, an AU can be decoded either independently of any other AU or using information contained in other AUs.
AUs can be classified into a multiplicity of types according to the nature of the coded sequence data. An Access Unit contains either a reference sequence, or a portion thereof, or encoded reads or read pairs belonging to a single class of data. Any single AU cannot contain two or more types of sequence data. For example an Access Unit may contain the entire chromosome 1 of GRCh37, the Genome Reference Consortium human genome (build 37). Another Access Unit may contain the coded representation of nucleotides of chromosome 1 of GRCh37 that are located between coordinates 50'000 and 150'000. Another Access Unit may contain only reads or read pairs that perfectly map on the reference sequence without any mismatch. Another Access Unit may contain reads or read pairs that only contain “N” symbols as mismatches with respect to the reference sequence. Another Access Unit may contain reads or read pairs that contain any type of substitutions (e.g. one base present in the read or read pair is different from the base at the corresponding mapping position in the reference sequence). Another Access Unit may contain reads or read pairs that contain mismatches, insertions, deletions and soft clipped bases. Another Access Unit may contain only read or read pairs that do not map on the reference sequence. Another Access Unit may contain only read pairs in which one read is mapped and the other is not mapped on the reference sequence. Another type of Access Unit may contain only encoded segments of a reference genome composed by one or more reference sequences (for example chromosomes).
The essential characteristic of an Access Unit is that it contains in compressed form all elements needed to reconstruct the genomic information of sequence reads or read pairs, reference sequences, associated alignment information and metadata of reads or read pairs. In other words, to fully reconstruct the reads, or the read pairs, or the reference sequence and the associated information carried by an Access Unit it is only necessary to retrieve and decompress the Access Unit itself and, when applicable, the Access Units containing the reference sequence to which the Access Units refers to.
In each Access Unit the descriptors listed in the next section and representing the information on encoded read or read pairs, are aggregated in separate data blocks—one per type—in order to exploit their homogeneous statistical properties for achieving high performance entropy coding.
Each Access Unit contains the compressed sub-set of descriptors representing sequence reads or read pairs belonging to the same data class mapped to a genomic region on a reference sequence. Such genomic region on the reference sequence is defined by a start coordinate (or start position) and an end coordinate (or end position).
An example of Access Unit is illustrated in
In the context of this disclosure, genomic descriptors are syntax elements representing part of the information (and also elements of a syntax structure of a file format and/or a bitstream) necessary to reconstruct (i.e. decode) coded reference sequences, sequence reads and the associated mapping information.
The genomic descriptors disclosed in this invention are listed in Table 1.
According to the method disclosed in this invention, reference sequences or portion thereof, sequence reads and the associated alignment information are coded using a sub-set of the descriptors listed above which are then entropy coded using a multiplicity of entropy coders according to each descriptor specific statistical properties. Blocks of compressed descriptors with homogeneous statistical properties are structured in Access Units which represent the smallest coded representation of one or more genomic sequence that can be manipulated by a device implementing the invention described in this disclosure.
The invention described in this disclosure defines a method to represent in terms of genomic descriptors a reference sequence used to aligning genomic sequence reads. Such genomic descriptors are compressed using specific entropy coders. The blocks of compressed descriptors are then encapsulated in the same Access Unit containing the compressed genomic descriptors enabling reconstruction of sequence reads mapped on said reference sequence so as to enable efficient transport and selective access.
In an embodiment, the present principles are directed to the lossless compression of both genomic sequence reads with associated alignment information and reference sequences used for alignment. Efficient compression is obtained by building longer sequences called contigs by merging or concatenating sequence reads mapped in contiguous regions of the reference sequence and then performing reference-based compression of sequence reads with respect to the constructed contig. Better compression is obtained by using separate syntax elements called “genomic descriptors” to represent all the features characterizing genomic sequence reads mapped on a reference sequence. The SAM format stores alignment information with the nucleotides sequence and other metadata such as the quality scores associated to base pairs, pairing information in case of paired end reads, and so forth. According to the principles of the present invention, each of the features associated to a mapped or unmapped genomic sequence read is represented by a genomic descriptor. Genomic descriptors of the same type are concatenated in blocks which are compressed using different entropy coders. It has to be appreciated that the present invention does not compress any of the SAM fields such as the CIGAR string, the mapping flags, nucleotides strings or quality values strings, but represent the same type of information using the 16 genomic descriptors or specific sub-sets of them. Round-trip transcoding to/from SAM and the presented format is possible for the eleven mandatory fields of SAM.
State of the art solutions store assembled genomes in the form of compressed FASTA files where each reference sequence (e.g. chromosomes) is stored as a sequence of symbols representing the four nucleotides. Each reference sequence is part of a reference genome (a.k.a. genome assembly) which is compressed and stored in a database. Several genome assemblies obtained at different moments in time from organic material belonging to the same organism or individual are stored to represent its genetic history. When genomic analysis requires comparing genome sequence data with existing reference genomes, the genomic analysis applications perform queries to a database to retrieve the one or more reference genomes of interest and perform the genomic analysis.
In a preferred embodiment, the principles disclosed in this invention can be applied to implement efficient storage of collections of reference genomes embedded in compressed genome sequence data without the need of storing the compressed genomes as separate resources. Instead of storing the genome assemblies as separate data structures from the genome sequence data, the method and principles disclosed in this invention permit to store only the genome sequence data with associated metadata enabling reconstruction of the genomes used for alignment.
When sequence reads have been mapped with respect to a pre-existing or to a constructed reference sequence, each sequence read can be fully represented by a number of elements denoted in this disclosure as “genomic descriptors” or simply “descriptors”.
For example, in the case of a sequence read that perfectly matches a segment of a reference sequence, the only sub-set of descriptors needed to represent the sequence read is composed by the coordinate of the mapping position on the reference (usually the coordinate of the mapping position of the left-most base of the sequence read), the length of the sequence read itself and the information indicating if the read is mapping on the direct or reverse DNA strand with respect to the reference sequence strand.
In case it is not possible to find any mapping position for which all the bases of the sequence read match all bases of the reference sequence, the mapping (or mappings) with the minimal number of mismatches are retained. In such case a different sub-set of descriptors is needed to also express the substitutions, the insertions, the deletions and the clipped bases that may occur in correspondence of the mapping position with the minimal or close to minimal number of mismatches. With such sub-set of descriptors the sequence reads can be reconstructed using the information carried by the descriptors and the information carried by the reference sequence.
The genome sequencing process may generate read duplicates (i.e. two or more exact copies of the same genomic sequence) for two main physical reasons:
The mapping process can also produce other types of information such as: multiple possible mapping positions and the related scores, the quality of mapping, the specification of spliced reads, the mapping on two different references (usually chromosomes) of reads belonging to a pair, features of the sequencing process (e.g. PCR or optical duplicate). All such information requires specific additional descriptors that extend each sub-sets that then is compressed by applying for each sub-set of descriptors appropriate entropy coding algorithms.
Therefore each read or read pair can be uniquely represented by a specific sub-set of descriptors according to the results of the mapping process.
The sequence reads generated by sequencing machines are classified by the disclosed invention into six different “classes” according to the matching results of the alignment with respect to one or more “pre-existing” reference sequences.
When aligning a DNA sequence of nucleotides with respect to a reference sequence the following cases can be identified:
The classification specified in the previous section concerns single sequence reads. In the case of sequencing technologies that generates read in pairs (i.e. Illumina Inc.) in which two reads are known to be separated by an unknown sequence of variable length, it is appropriate to consider the classification of the entire pair to a single data class. A read that is coupled with another is said to be its “mate”.
If both paired reads belong to the same class the assignment to a class of the entire pair is obvious: the entire pair is assigned to the same class for any class (i.e. P, N, M, I, U).
In the case the two reads belong to a different class, but none of them belongs to the “Class U”, then the entire pair is assigned to the class with the highest priority defined according to the following expression:
P<N<M<I
in which “Class P” has the lowest priority and “Class I” has the highest priority.
In case only one of the reads belongs to “Class U” and its mate to any of the Classes P, N, M, I a sixth class is defined as “Class HM” which stands for “Half Mapped”.
The definition of such specific class of reads is motivated by the fact that it is used for attempting to determine gaps or unknown regions existing in reference genomes (a.k.a. little known or unknown regions). Such regions are reconstructed by mapping pairs at the edges using the pair read that can be mapped on the known regions. The unmapped mate is then used to build the so called “contigs” of the unknown region as it is shown in
The table below summarizes the matching rules applied to reads in order to define the class of data each read belongs to. The rules are defined in the first five columns of the table in terms of presence or absence of type of mismatches (n, s, d, i and c type mismatches). The sixth column provide rules in terms of maximum threshold for each mismatch type and any function f(n,s) and w(n,s,d,i,c) of the possible mismatch types.
Comparison with State of the Art Approaches
Commonly used approaches such as SAM and CRAM do not encode reads or read pairs according to the specific sub-set of descriptors needed to represent their mapping information. SAM and CRAM do not classify sequence reads into data classes according to the number and type of mismatches they contain with respect to the reference sequence they are mapped to. Furthermore, these formats do not code sequence reads separately into Access Units containing in compressed form only sequence reads belonging to a single data class. In the case of sequence reads generated in pairs, state of the art approaches do not code them as single elements partitioned into classes according to their mapping accuracy with respect to the reference sequence. Such state of the art approaches are characterized by the following limitations and drawbacks:
When coding read pairs by means of a single sub-set of descriptors, the following technical advantages are evident to a person skilled in the art:
In order to enable efficient selective access to specific portions of sequencing data and being able to transport them on a digital data network, the set of descriptors used to represent sequence reads aligned to a reference are structured in logically separate and independent data blocks called Access Units (AU). Each Access Unit contains only the compressed representation of a single data class, and can be decoded either independently of any other Access Units or using only Access Units carrying the coded representation of the reference sequence region used for mapping. This enables selective access and out-of-order transport capabilities.
In order to increase the compression efficiency this invention eliminates the need of specifying the “mapping reference identifier” descriptor for each read pair having both pairs mapped on the same reference sequence. Each Access Unit can contain only reads or pairs that map on the same reference. Using such solution the descriptor representing the reference sequence identifier needs to be encoded only once per each Access Unit or set of Access Units (and not repeated for each read as currently done in SAM/BAM formats).
The only exception of the rule expressed above is the case of read pairs having the two reads mapped on different reference sequences (e.g. chromosomes). In this case the pair is split and the two reads are coded as two separate genomic records and each encoded read contains the identifier of the reference sequence its mate is mapped to.
Experimental data, have demonstrated that developing entropy coders suited to the statistical properties of the genomic descriptors provide better compression performance with respect to the usage of a general purpose compressor (e.g. LZ type algorithm) applied to a heterogeneous set of data. As a consequence, when encoding genomic sequence reads in pairs by means of a specific sub-set of descriptors, higher compression is achieved thanks to the lower entropy characterizing each separate sub-set of descriptors and higher processing efficiency when reconstructing and retrieving read pairs.
The advantages in terms of achievable compression ratios provided by the approach disclosed in this invention are described in the next sections where the different binarizations and transformations applied to different blocks of genomic descriptors prior to entropy coding are described with the related performance.
Encoding Reference Genomes with Sequence Data
In an embodiment the present principles are directed to the lossless compression of reference sequences such as reference genomes or genome assemblies when reference-less compression of aligned sequence data is performed. Reference-less compression of aligned sequence data according to Voges, J., Munderloh, M., Ostermann, J., “Predictive Coding of Aligned Next-Generation Sequencing Data” (2016 Data Compression Conference (DCC)) can be implemented using the genomic descriptors from 1 to 12 defined in Table 1 of this disclosure. Voges uses a circular buffer to progressively store encoded sequence reads and build the related contig by using the SAM CIGAR string associated to each aligned sequence. While this mentioned approach can achieve efficient compression of genome sequencing data 101 mapped on a reference sequence 100, it does not support the representation and compression of the reference sequence 100 itself, because a decoding engine will only be able to reconstruct the contig and the compressed genomic sequence reads, but the original reference genome used for the alignment is not contained in the compressed data. This disclosure aims at using the genomic descriptors no. 13 and 14 in Table 1 to achieve efficient compression of the reference genome used for alignment when reference-less compression is applied to the genome sequence data. This is achieved by storing in the compressed data the differences between the contigs assembled during the compression process and the reference genome used for alignment. At the decoding end, the decoding process will reconstruct the contig used for genomic sequence reads decompression and—by means of descriptors 13 and 14—it will be able to reconstruct the reference genome used for alignment.
Moreover, in the present invention the length of the contig can be defined by the user (for example in a input parameter file) or dynamically updated by the encoder. The information about the length of the contig can be sent from the encoder to the decoder in a data structure contained in the file format used to store or transmit the compressed genomic information such as the one shown in Table 18. Such new feature has the considerable advantage that it is defined by a parameter, it can be adapted to the various encoder and decoder architectures and their relevant limitations, and it is also adaptable to the evolution of the various architectures that will be used for encoding and decoding the genome sequences and to the computational complexity of the sequence to be coded.
The contig length can be expressed in terms of both the number of nucleotides and/or the number of reads used in the encoding and decoding process. This process is shown in figure
Additionally,
In another embodiment of the invention, regions of the reference genome used for the alignment that are not covered by any of the mapped reads, can be compressed (i.e. entropy coded), encapsulated and carried in specific Access Units. Such Access Units contain only the compressed representation of the reference genome used for the alignment and cover the genomic regions on which no sequence reads are mapped. This is shown in
The technical advantages of such approach with respect to the solution of Voges et al. cited here are the following:
The transformations and binarizations applied to the descriptors together with the necessary configuration parameters for the entropy coders of said descriptors providing better compression ratios than state of the art solution and are disclosed in this invention as reported below.
The transformation of descriptors is a process whereby a descriptor's value representing a genomic feature such as a mismatch position within a genomic sequence or a mismatch type is transformed in a different corresponding value in order to achieve better compression performance. In an embodiment, according to the principles of this disclosure, the mismatches positions represented by the rftp descriptor are transformed according to the following steps:
In an embodiment, according to the principles of this disclosure, the mismatches types represented by the rftt descriptor are transformed according to the following steps:
In an embodiment, the present invention uses context-adaptive binary arithmetic coding (CABAC) for the compression of the genomic descriptors. CABAC first converts to a binary representation all symbols to be encoded. The process of binarization converts a non-binary-valued symbol (e.g. a mapping position, a mapped read length or a mismatch type) into a binary code prior to arithmetic coding.
The selection of appropriate binarizations adapted to the statistical properties of each descriptor provides better compression ratios than existing formats based on general purpose compressor applied on blocks of heterogeneous elements.
In the following sections these variables are defined:
While the following binarization tables are calculated for fixed values of these variables, it has to be appreciated that the present principles are not limited to these values, and thus other values can also be used in accordance with the present principles, while maintaining the spirit of the present principles.
Each binarization algorithm used in this disclosure is identified by an identifier as shown in Table 3.
This is a standard binary representation whereby each numerical value is coded in its binary representation. The variable cLength—shown in Table 15 when binarization_id=0—represents the numbers of bits with which the value will be represented.
A TU binary string is the concatenation of symVal ones followed by one zero. If symVal==cMax, the trailing 0-bit is discarded. Table 4 illustrates the bin strings of this truncated unary binarization with cMax=3.
The syntax for this binarization process along with arithmetic decoding is described below.
binValue is the binarized value which can be either 0 or 1.
The parsing process for genomic descriptors binarized using this technique begins with reading the bits starting at the current location in the bitstream up to and including the first non-zero bit, and counting the number of leading bits that are equal to 0.
This process is specified as follows:
The variable symVal is then assigned as follows:
symVal=leading ZeroBits−1+read_bits(leadingZeroBits)
where the function call read bits reads a number of bits from a storage medium equal to the parameter passed as input. The value returned from read_bits(leadingZeroBits) is interpreted as a binary representation of an unsigned integer with the most significant bit written first.
Error! Reference source not found. Table 5 illustrates the structure of the Exp-Golomb code by separating the bit string into “prefix” and “suffix” bits. The “prefix” bits are those bits that are parsed as specified above for the computation of leadingZeroBits, and are shown as either 0 or 1 in the bit string column of Table 5. The “suffix” bits are those bits that are parsed in the computation of symVal and are shown as xi in Table 5Error! Reference source not found., with i in the range of 0 to leadingZeroBits−1, inclusive. Each x, is equal to either 0 or 1.
Error! Reference source not found. Table 6 illustrates the explicit assignments of bit strings to symVal values.
Depending on the genomic descriptor, the value of a binarized syntax element is decoded using one of the following methods:
According to this binarization method the genomic descriptor is associated to the symVal by ordering the syntax element by its absolute value in increasing order and representing the positive value for a given absolute value with the lower symVal. Table 7 shows the assignment rule.
This binarization process requires the use of an additional input parameter tegParam which defines how the binarization is calculated.
Output of this process is the TEG binarization of the syntax element.
A TEG bin string is the concatenation of 1 (in case of symVal==0) or 2 (in case of symVal>0) types of binarization:
Min(symVal,tegParam)
Abs(symVal)−tegParam
Table 8 illustrates the bin strings of this Truncated Exponential Golomb binarization with tegParam==2.
This binarization process requires the use of an additional input parameter stegParam.
A STEG binary string is the concatenation of 1 (in case of symVal==0) or 2 (for other cases) binarizations:
Table 9 illustrates the bin strings of this Signed Truncated Exponential Golomb binarization with stegParam=2.
This binarization process requires the use of two input parameters splitUnitSize and outputSymSize. outputSymSize must always be a multiple of splitUnitSize.
The SUTU binary string is a concatenation of repeated TU binarizations, where each TU binarization is applied to portions of symVal which are splitUnitSize bits long. In other words, symVal is represented by x binary string obtained with the TU binarization, where x=outputSymSize/splitUnitSize. The cMax parameter for each binary string is defined as cMax=(1<<splitUnitSize)−1.
Table 10 illustrates the binary strings of split unit-wise truncated unary binarizations with splitUnitSize=2 and outputSymbSize=8.
The bitstream syntax for this binarization process is described below.
This binarization process requires the use of two input parameters splitUnitSize and outputSymSize.
The SSUTU binary string is obtained by an extension of the SUTU binarization process with the sign of symVal coded as a separate flag.
Table 12 illustrates the binary strings of the Signed Split Unit-wise Truncated Unary binarization with splitUnitSize=2, outputSymbSize=8.
The syntax for this binarization process is described below.
sign_flag represents the cabac decoding of a bit on context variable identified by ctxIdx. decode_cabac_SUTU( ) represents the cabac decoding process for the SUTU binarization.
This binarization process requires the use of two input parameters splitUnitSize and outputSymSize.
The DTU binary string is a concatenation of two binarizations, namely the TU binarization and the SUTU binarization. The parameter cMax is used for the TU binarization, and parameters splitUnitSize and outputSymSize are used for the SUTU binarization (where its cMax is derived internally).
Table 13 illustrates the binary strings of the Double Truncated Unary binarization with cMax=1, splitUnitSize=2, outputSymSize=8.
The binarization process is described below.
decode_cabac_TU( ) represents the cabac decoding process for TU binarization.
decode_cabac_SUTU ( ) represents the cabac decoding process for SUTU binarization.
This binarization process requires the use of two additional input parameters splitUnitSize and outputSymSize.
The SDTU binary string is obtained by an extension of the DTU binarization process with the sign of symVal coded as a flag.
Table 14 illustrates the bin strings of double truncated unary binarization with with cMax=1, splitUnitSize=2, outputSymSize=8.
The syntax for this binarization process is described below.
sign_flag represents the cabac decoding of a bit on context variable identified by ctxIdx.
decode_cabac_DTU( ) represents the cabac decoding with DTU binarization.
Each binarization algorithm introduced in the previous sections requires configuration parameters at the encoding and decoding ends. In an embodiment, said configuration parameters are encapsulated in a data structure described in Table 15. Each binarization algorithm is identified by an identifier as listed in Table 3.
In Table 15 the following semantics applies:
cMax represents the largest value to be binarized. Larger values will be truncated.
cLength represents the numbers of bits with which the value is binarized.
tegParam represents the tegParam variable defined in this document for TEG binarization.
stegParam represents the stegParam variable defined in this document for STEG binarization.
splitUnitSize represents the splitUnitSize variable defined in this document for SUTU, SSUTU and DTU binarizations.
outputSymSize represents the outputSymSize variable defined in this document for SUTU, SSUTU DTU and SDTU binarizations.
By applying the indicated CABAC binarization to the respective genomic descriptors as indicated in Table 16, the compression performance reported in * no additional information is necessary since it is already available in the compressed representation according to the principles of this disclosure
Table 17 can be obtained. The improvement in compression performance of the method described in this disclosure can be appreciated by comparison with the corresponding file sizes of BAM and CRAM approaches and one of the best compressors in literature known as DeeZ (see Numanagic, I., et al “Comparison of high-throughput sequencing data compression tools”, Nature Methods (ISSN: 1548-7091), vol. 13, p. 1005-1008 London: Nature Publishing Group, 2016). It has to be appreciated that the DeeZ, BAM and CRAM compression performance are calculated by adding the size of the compressed reference genome used for alignment to the sizes of the compressed genome sequence data. According to the principles of the present disclosure, the reference genome is embedded in the compressed file. In today practice said compressed reference genome is a FASTA (ASCII text) file compressed using general purpose compressors such as GZIP, LZMA, Bzip2. In the proposed comparison the reference genome hs37d5.fa was compressed using the xz Linux command with the option of maximum compression (−9).
An example of binarization of rftp and rftt is provided in this section and illustrated in
The descriptors associated to five mismatches between a contig and a reference genome used for alignment are shown below:
Each nucleotide symbol is associated to an integer code:
After transformation the values become:
The binarized values for rftp are calculates as follows:
The binarized values for rftt are calculates as follows:
With the binarization approach shown above the following compression results are achieved:
In an embodiment, the parameters needed to encode and decode each Access Unit are encapsulated in a data structure named as defined in Table 18.
Encoding apparatus
The inventive techniques herewith disclosed may be implemented in hardware, software, firmware or any combination thereof. When implemented in software, these may be stored on a computer medium and executed by a hardware processing unit. The hardware processing unit may comprise one or more processors, digital signal processors, general purpose microprocessors, application specific integrated circuits or other discrete logic circuitry.
The techniques of this disclosure may be implemented in a variety of devices or apparatuses, including mobile phones, desktop computers, servers, tablets and similar devices.
Number | Date | Country | Kind |
---|---|---|---|
PCT/US2017/017842 | Feb 2017 | US | national |
PCT/US2017/041579 | Jul 2017 | US | national |
This application claims priority to and the benefit of Patent Applications PCT/US2017/041579 filed on Jul. 11, 2017 and PCT/US17/17842 filed on Feb. 14, 2017
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2017/066458 | 12/14/2017 | WO | 00 |