Deflate Explained

In computing, Deflate (stylized as DEFLATE, and also called Flate[1] [2]) is a lossless data compression file format that uses a combination of LZ77 and Huffman coding. It was designed by Phil Katz, for version 2 of his PKZIP archiving tool. Deflate was later specified in RFC 1951 (1996).[3]

Katz also designed the original algorithm used to construct Deflate streams. This algorithm was patented as, and assigned to PKWARE, Inc.[4] [5] As stated in the RFC document, an algorithm producing Deflate files was widely thought to be implementable in a manner not covered by patents. This led to its widespread use – for example, in gzip compressed files and PNG image files, in addition to the ZIP file format for which Katz originally designed it. The patent has since expired.

Stream format

A Deflate stream consists of a series of blocks. Each block is preceded by a 3-bit header:

The stored block option adds minimal overhead and is used for data that is incompressible.

Most compressible data will end up being encoded using method 10, the dynamic Huffman encoding, which produces an optimized Huffman tree customized for each block of data individually. Instructions to generate the necessary Huffman tree immediately follow the block header. The static Huffman option is used for short messages, where the fixed saving gained by omitting the tree outweighs the percentage compression loss due to using a non-optimal (thus, not technically Huffman) code.

Compression is achieved through two steps:

Duplicate string elimination

See main article: article, LZ77 and LZ78 and LZSS.

Within compressed blocks, if a duplicate series of bytes is spotted (a repeated string), then a back-reference is inserted, linking to the previous location of that identical string instead. An encoded match to an earlier string consists of an 8-bit length (3–258 bytes) and a 15-bit distance (1–32,768 bytes) to the beginning of the duplicate. Relative back-references can be made across any number of blocks, as long as the distance appears within the last 32 KiB of uncompressed data decoded (termed the sliding window).

If the distance is less than the length, the duplicate overlaps itself, indicating repetition. For example, a run of 10 identical bytes can be encoded as one byte, followed by a duplicate of length 9, beginning with the previous byte.

Searching the preceding text for duplicate substrings is the most computationally expensive part of the DEFLATE algorithm, and the operation which compression level settings affect.

Bit reduction

See main article: article and Huffman coding.

The second compression stage consists of replacing commonly used symbols with shorter representations and less commonly used symbols with longer representations. The method used is Huffman coding which creates an unprefixed tree of non-overlapping intervals, where the length of each sequence is inversely proportional to the logarithm of the probability of that symbol needing to be encoded. The more likely it is that a symbol has to be encoded, the shorter its bit-sequence will be.

A tree is created, containing space for 288 symbols:

A match length code will always be followed by a distance code. Based on the distance code read, further "extra" bits may be read in order to produce the final distance. The distance tree contains space for 32 symbols:

Note that for the match distance symbols 2–29, the number of extra bits can be calculated as

\left\lfloorn
2

\right\rfloor-1

.

The two codes (the 288-symbol length/literal tree and the 32-symbol distance tree) are themselves encoded as canonical Huffman codes by giving the bit length of the code for each symbol. The bit lengths are themselves run-length encoded to produce as compact a representation as possible. As an alternative to including the tree representation, the "static tree" option provides standard fixed Huffman trees. The compressed size using the static trees can be computed using the same statistics (the number of times each symbol appears) as are used to generate the dynamic trees, so it is easy for a compressor to choose whichever is smaller.

Encoder/compressor

During the compression stage, it is the encoder that chooses the amount of time spent looking for matching strings. The zlib/gzip reference implementation allows the user to select from a sliding scale of likely resulting compression-level vs. speed of encoding. Options range from 0 (do not attempt compression, just store uncompressed) to 9 representing the maximum capability of the reference implementation in zlib/gzip.

Other Deflate encoders have been produced, all of which will also produce a compatible bitstream capable of being decompressed by any existing Deflate decoder. Differing implementations will likely produce variations on the final encoded bit-stream produced. The focus with non-zlib versions of an encoder has normally been to produce a more efficiently compressed and smaller encoded stream.

Deflate64/Enhanced Deflate

Deflate64, specified by PKWARE, is a proprietary variant of Deflate. It's fundamentally the same algorithm. What has changed is the increase in dictionary size from 32 KB to 64 KB, an extension of the distance codes to 16 bits so that they may address a range of 64 KB, and the length code, which is extended to 16 bits so that it may define lengths of three to 65,538 bytes.[6] This leads to Deflate64 having a longer compression time, and potentially a slightly higher compression ratio, than Deflate.[7] Several free and/or open source projects support Deflate64, such as 7-Zip,[8] while others, such as zlib, do not, as a result of the proprietary nature of the procedure[9] and the very modest performance increase over Deflate.[10]

Using Deflate in new software

Implementations of Deflate are freely available in many languages. Apps written in C typically use the zlib library (under the permissive zlib License). Apps in Borland Pascal (and compatible languages) can use paszlib. Apps in C++ can take advantage of the improved Deflate library in 7-Zip. Both Java and .NET Framework offer out-of-the-box support for Deflate in their libraries (respectively, java.util.zip and System.IO.Compression). Apps in Ada can use Zip-Ada (pure) or ZLib-Ada.

Encoder implementations

AdvanceCOMP uses the higher compression ratio versions of Deflate in 7-Zip, libdeflate, and Zopfli to enable recompression of gzip, PNG, MNG and ZIP files with the possibility of smaller file sizes than zlib is able to achieve at maximum settings.[14]

Hardware encoders

Decoder/decompressor

Inflate is the decoding process that takes a Deflate bitstream for decompression and correctly produces the original full-size data or file.

Inflate-only implementations

The normal intent with an alternative Inflate implementation is highly optimized decoding speed, or extremely predictable RAM usage for micro-controller embedded systems.

Hardware decoders

See also

External links

Notes and References

  1. Web site: The Go Authors . flate package - compress/flate - Go Packages . The Go Programming Language . Google . 5 September 2023 . Package flate implements the DEFLATE compressed data format, described in RFC issue 1951..
  2. Web site: Adobe Systems Incorporated . Adobe Inc. . PDF 32000-1:2008: Document management — Portable document format — Part 1: PDF 1.7 . Adobe Open Source . Adobe . 5 September 2023 . 23 . FlateDecode [...] Decompresses data encoded using the zlib/deflate compression method.
  3. DEFLATE Compressed Data Format Specification version 1.3 . 1951 . Abstract . 1 . L. Peter . Deutsch . L. Peter Deutsch . May 1996 . . 2014-04-23.
  4. US . 5051745 . 1991-09-24 . 1991-09-24 . String Searcher, and Compressor Using Same . Katz. Phillip W.. Phil Katz . PKWare Inc. . patent.
  5. Book: David, Salomon. Data Compression: The Complete Reference . 2007. 4. 241. Springer. 978-1-84628-602-5.
  6. Web site: Binary Essence – Deflate64 . 22 May 2011 . https://web.archive.org/web/20170621195505/http://www.binaryessence.com/dct/imp/en000225.htm . 21 June 2017 . bot: unknown .
  7. Web site: Binary Essence – "Calgary Corpus" compression comparisons . 22 May 2011 . https://web.archive.org/web/20171227131819/http://www.binaryessence.com/dct/apc/en000263.htm . 27 December 2017 . bot: unknown .
  8. Web site: -m (Set compression Method) switch. sevenzip.osdn.jp. 2023-01-21. 2022-04-09. https://web.archive.org/web/20220409225619/https://sevenzip.osdn.jp/chm/cmdline/switches/method.htm. dead.
  9. History of Lossless Data Compression Algorithms – Deflate64
  10. zlib FAQ – Does zlib support the new "Deflate64" format introduced by PKWare?
  11. Web site: Plan 9 from Bell Labs's /n/sources/plan9/sys/src/libflate . plan9.bell-labs.com . Lucent Technologies . 2006-03-15 . https://web.archive.org/web/20060315063934/http://plan9.bell-labs.com/sources/plan9/sys/src/libflate/ . dead .
  12. Web site: High Performance DEFLATE Compression with Optimizations for Genomic Data Sets . Intel Software . 18 January 2020 . 1 October 2019.
  13. Web site: libdeflate . Heavily optimized library for DEFLATE/zlib/gzip compression and decompression.
  14. Web site: Mazzoleni . Andrea . amadvance/advancecomp . . 21 February 2023.
  15. Web site: Intel® Xeon® Processor E5-2600 and E5-2400 Series with Intel® Communications Chipset 89xx Series. 2016-05-18.
  16. Web site: Introducing the IBM z15 - The enterprise platform for mission-critical hybrid multicloud. IBM. 12 September 2019. 2021-11-01.
  17. Book: IBM z15 (8562) Technical Guide, Page 97. 9780738458991. 2021-11-01. Lascu. Octavian. 28 April 2021. IBM Redbooks.
  18. Web site: Data compression by using the zlibNX library - IBM Documentation. IBM. 2021-11-01.
  19. Web site: Exploitation of In-Core Acceleration of POWER Processors for AIX. 2021-11-01.