Arithmetic coding
Arithmetic coding is a form of entropy encoding used in lossless data compression. Normally, a string of characters such as the words "hello there" is represented using a fixed number of bits per character, as in the ASCII code. When a string is converted to arithmetic encoding, frequently used characters will be stored with fewer bits and not-so-frequently occurring characters will be stored with more bits, resulting in fewer bits used in total. Arithmetic coding differs from other forms of entropy encoding, such as Huffman coding, in that rather than separating the input into component symbols and replacing each with a code, arithmetic coding encodes the entire message into a single number, an arbitrary-precision fraction q where 0.0 ≤ q < 1.0. It represents the current information as a range, defined by two numbers. Recent family of entropy coders called asymmetric numeral systems allows for faster implementations thanks to directly operating on a single natural number representing the current information.
Implementation details and examples
Equal probabilities
In the simplest case, the probability of each symbol occurring is equal. For example, consider a set of three symbols, A, B, and C, each equally likely to occur. Simple block encoding would require 2 bits per symbol, which is wasteful: one of the bit variations is never used. That is to say, A=00, B=01, and C=10, but 11 is unused.A more efficient solution is to represent a sequence of these three symbols as a rational number in base 3 where each digit represents a symbol. For example, the sequence "ABBCAB" could become 0.0112013, in arithmetic coding as a value in the interval 0, 1). The next step is to encode this ternary number using a fixed-point binary number of sufficient precision to recover it, such as 0.00101100102 – this is only 10 bits; 2 bits are saved in comparison with naïve block encoding. This is feasible for long sequences because there are efficient, in-place algorithms for converting the base of arbitrarily precise numbers.
To decode the value, knowing the original string had length 6, one can simply convert back to base 3, round to 6 digits, and recover the string.
Defining a model
In general, arithmetic coders can produce near-optimal output for any given set of symbols and probabilities. Compression algorithms that use arithmetic coding start by determining a model of the data – basically a prediction of what patterns will be found in the symbols of the message. The more accurate this prediction is, the closer to optimal the output will be.Example: a simple, static model for describing the output of a particular monitoring instrument over time might be:
- 60% chance of symbol NEUTRAL
- 20% chance of symbol POSITIVE
- 10% chance of symbol NEGATIVE
- 10% chance of symbol END-OF-DATA.
Encoding and decoding: overview
In general, each step of the encoding process, except for the very last, is the same; the encoder has basically just three pieces of data to consider:- The next symbol that needs to be encoded
- The current interval
- The probabilities the model assigns to each of the various symbols that are possible at this stage
Example: for the four-symbol model above:
- the interval for NEUTRAL would be
0, 0.6) - the interval for POSITIVE would be
[0.6, 0.8) - the interval for NEGATIVE would be
[0.8, 0.9) - the interval for END-OF-DATA would be
[0.9, 1) .
It is not necessary to transmit the final interval, however; it is only necessary to transmit one fraction that lies within that interval. In particular, it is only necessary to transmit enough digits of the fraction so that all fractions that begin with those digits fall into the final interval; this will guarantee that the resulting code is a prefix code.
Encoding and decoding: example
Consider the process for decoding a message encoded with the given four-symbol model. The message is encoded in the fraction 0.538The process starts with the same interval used by the encoder:
Next divide the interval
- the interval for NEUTRAL would be
[0, 0.36) , 60% of[0, 0.6) . - the interval for POSITIVE would be
[0.36, 0.48) , 20% of[0, 0.6) . - the interval for NEGATIVE would be
[0.48, 0.54) , 10% of[0, 0.6) . - the interval for END-OF-DATA would be
[0.54, 0.6) , 10% of[0, 0.6) .
Again divide our current interval into sub-intervals:
- the interval for NEUTRAL would be
[0.48, 0.516) . - the interval for POSITIVE would be
[0.516, 0.528) . - the interval for NEGATIVE would be
[0.528, 0.534) . - the interval for END-OF-DATA would be
[0.534, 0.540) .
Adaptive arithmetic coding
One advantage of arithmetic coding over other similar methods of data compression is the convenience of adaptation. Adaptation is the changing of the frequency tables while processing the data. The decoded data matches the original data as long as the frequency table in decoding is replaced in the same way and in the same step as in encoding. The synchronization is, usually, based on a combination of symbols occurring during the encoding and decoding process.Precision and renormalization
The above explanations of arithmetic coding contain some simplification. In particular, they are written as if the encoder first calculated the fractions representing the endpoints of the interval in full, using infinite precision, and only converted the fraction to its final form at the end of encoding. Rather than try to simulate infinite precision, most arithmetic coders instead operate at a fixed limit of precision which they know the decoder will be able to match, and round the calculated fractions to their nearest equivalents at that precision. An example shows how this would work if the model called for the interval [0,1) to be divided into thirds, and this was approximated with 8 bit precision. Note that since now the precision is known, so are the binary ranges we'll be able to use.A process called renormalization keeps the finite precision from becoming a limit on the total number of symbols that can be encoded. Whenever the range is reduced to the point where all values in the range share certain beginning digits, those digits are sent to the output. For however many digits of precision the computer can handle, it is now handling fewer than that, so the existing digits are shifted left, and at [the right, new digits are added to expand the range as widely as possible. Note that this result occurs in two of the three cases from our previous example.
Symbol | Probability | Range | Digits that can be sent to output | Range after renormalization |
A | 1/3 | 0 | ||
B | 1/3 | |||
C | 1/3 | 1 |
Arithmetic coding as a generalized change of radix
Recall that in the case where the symbols had equal probabilities, arithmetic coding could be implemented by a simple change of base, or radix. In general, arithmetic coding may be interpreted as a generalized change of radix. For example, we may look at any sequence of symbols:as a number in a certain base presuming that the involved symbols form an ordered set and each symbol in the ordered set denotes a sequential integer A = 0, B = 1, C = 2, D = 3, and so on. This results in the following frequencies and cumulative frequencies:
Symbol | Frequency of occurrence | Cumulative frequency |
A | 1 | 0 |
B | 2 | 1 |
D | 3 | 3 |
The cumulative frequency for an item is the sum of all frequencies preceding the item. In other words, cumulative frequency is a running total of frequencies.
In a positional numeral system the radix, or base, is numerically equal to a number of different symbols used to express the number. For example, in the decimal system the number of symbols is 10, namely 0, 1, 2, 3, 4, 5, 6, 7, 8, and 9. The radix is used to express any finite integer in a presumed multiplier in polynomial form. For example, the number 457 is actually 4×102 + 5×101 + 7×100, where base 10 is presumed but not shown explicitly.
Initially, we will convert DABDDB into a base-6 numeral, because 6 is the length of the string. The string is first mapped into the digit string 301331, which then maps to an integer by the polynomial:
The result 23671 has a length of 15 bits, which is not very close to the theoretical limit, which is approximately 9 bits.
To encode a message with a length closer to the theoretical limit imposed by information theory we need to slightly generalize the classic formula for changing the radix. We will compute lower and upper bounds L and U and choose a number between them. For the computation of L we multiply each term in the above expression by the product of the frequencies of all previously occurred symbols:
The difference between this polynomial and the polynomial above is that each term is multiplied by the product of the frequencies of all previously occurring symbols. More generally, L may be computed as:
where are the cumulative frequencies and are the frequencies of occurrences. Indexes denote the position of the symbol in a message. In the special case where all frequencies are 1, this is the change-of-base formula.
The upper bound U will be L plus the product of all frequencies; in this case U = L + = 25002 + 108 = 25110. In general, U is given by:
Now we can choose any number from the interval L, U) to represent the message; one convenient choice is the value with the longest possible trail of zeroes, 25100, since it allows us to achieve compression by representing the result as 251×102. The zeroes can also be truncated, giving 251, if the length of the message is stored separately. Longer messages will tend to have longer trails of zeroes.
To decode the integer 25100, the polynomial computation can be reversed as shown in the table below. At each stage the current symbol is identified, then the corresponding term is subtracted from the result.
Remainder | Identification | Identified symbol | Corrected remainder |
25100 | 25100 / 65 = 3 | D | / 3 = 590 |
590 | 590 / 64 = 0 | A | / 1 = 590 |
590 | 590 / 63 = 2 | B | / 2 = 187 |
187 | 187 / 62 = 5 | D | / 3 = 26 |
26 | 26 / 61 = 4 | D | / 3 = 2 |
2 | 2 / 60 = 2 | B | — |
During decoding we take the floor after dividing by the corresponding power of 6. The result is then matched against the cumulative intervals and the appropriate symbol is selected from [look up table. When the symbol is identified the result is corrected. The process is continued for the known length of the message or while the remaining result is positive. The only difference compared to the classical change-of-base is that there may be a range of values associated with each symbol. In this example, A is always 0, B is either 1 or 2, and D is any of 3, 4, 5. This is in exact accordance with our intervals that are determined by the frequencies. When all intervals are equal to 1 we have a special case of the classic base change.
Theoretical limit of compressed message
The lower bound L never exceeds nn, where n is the size of the message, and so can be represented in bits. After the computation of the upper bound U and the reduction of the message by selecting a number from the interval iid strings. By contrast, using the extension of Huffman coding does not reach entropy unless all probabilities of alphabet symbols are [powers of two">Independent and identically distributed random variables">iid strings. By contrast, using the extension of Huffman coding does not reach entropy unless all probabilities of alphabet symbols are [powers of two, in which case both Huffman and arithmetic coding achieve entropy.When naively Huffman coding binary strings, no compression is possible, even if entropy is low. Huffman encoding assigns 1 bit to each value, resulting in a code of the same length as the input. By contrast, arithmetic coding compresses bits well, approaching the optimal compression ratio of
One simple way to address Huffman coding's suboptimality is to concatenate symbols to form a new alphabet in which each new symbol represents a sequence of original symbols – in this case bits – from the original alphabet. In the above example, grouping sequences of three symbols before encoding would produce new "super-symbols" with the following frequencies:
- : 85.7%
- ,, : 4.5% each
- ,, : 0.24% each
- : 0.0125%
An alternative is encoding run lengths via Huffman-based Golomb-Rice codes. Such an approach allows simpler and faster encoding/decoding than arithmetic coding or even Huffman coding, since the latter requires a table lookups. In the example, a Golomb-Rice code with a four-bit remainder achieves a compression ratio of, far closer to optimum than using three-bit blocks. Golomb-Rice codes only apply to Bernoulli inputs such as the one in this example, however, so it is not a substitute for blocking in all cases.
Patents
A variety of specific techniques for arithmetic coding have historically been covered by US patents, although various well-known methods have since passed into the public domain as the patents have expired. Techniques covered by patents may be essential for implementing the algorithms for arithmetic coding that are specified in some formal international standards. When this is the case, such patents are generally available for licensing under what is called "reasonable and non-discriminatory" licensing terms. In some well-known instances,, such licenses were available for free, and in other instances, licensing fees have been required. The availability of licenses under RAND terms does not necessarily satisfy everyone who might want to use the technology, as what may seem "reasonable" for a company preparing a proprietary commercial software product may seem much less reasonable for a free software or open source project.At least one significant compression software program, bzip2, deliberately discontinued the use of arithmetic coding in favor of Huffman coding due to the perceived patent situation at the time. Also, encoders and decoders of the JPEG file format, which has options for both Huffman encoding and arithmetic coding, typically only support the Huffman encoding option, which was originally because of patent concerns; the result is that nearly all JPEG images in use today use Huffman encoding although JPEG's arithmetic coding patents have expired due to the age of the JPEG standard. There are some archivers like PackJPG, that can losslessly convert Huffman encoded files to ones with arithmetic coding, showing up to 25% size saving.
The JPEG image compression format's arithmetic coding algorithm is based on the following cited patents.
- – Filed 4 February 1986, granted 24 March 1987 – Kottappuram M. A. Mohiuddin, Jorma Johannen Rissanen – Multiplication-free multi-alphabet arithmetic code
- – Filed 18 November 1988, granted 27 February 1990 – Glen George Langdon, Joan L. Mitchell, William B. Pennebaker, Jorma Johannen Rissanen – Arithmetic coding encoder and decoder system
- – Filed 20 July 1988, granted 19 June 1990 – William B. Pennebaker, Joan L. Mitchell – Probability adaptation for arithmetic coders
- – Filed 21 January 1989, granted 10 August 1990 – Toshihiro Kimura, Shigenori Kino, Fumitaka Ono, Masayuki Yoshida – Coding system
- – Filed 26 February 1990, granted 5 November 1991 – Fumitaka Ono, Tomohiro Kimura, Masayuki Yoshida, Shigenori Kino – Coding apparatus and coding method
- – Filed 4 March 1977, granted 24 October 1978 – Glen George Langdon, Jorma Johannen Rissanen – Method and means for arithmetic string coding
- – Filed 28 November 1979, granted 25 August 1981 – Glen George Langdon, Jorma Johannen Rissanen – Method and means for arithmetic coding utilizing a reduced number of operations
- – Filed 30 March 1981, granted 21 August 1984 – Glen George Langdon, Jorma Johannen Rissanen – High-speed arithmetic compression coding using concurrent value updating
- – Filed 15 September 1986, granted 2 January 1990 – Joan L. Mitchell, William B. Pennebaker – Arithmetic coding data compression/de-compression by selectively employed, diverse arithmetic coding encoders and decoders
- – Filed 13 May 1987, granted 18 November 1988 – Michio Shimada – Data compressing arithmetic encoding device
- – Filed 18 June 1987, granted 22 December 1988 – Shuichi Matsumoto, Masahiro Saito – System for preventing carrying propagation in arithmetic coding
- – Filed 3 May 1988, granted 12 June 1990 – William B. Pennebaker, Joan L. Mitchell – Probability adaptation for arithmetic coders
- – Filed 19 June 1989, granted 29 January 1991 – Dan S. Chevion, Ehud D. Karnin, Eugeniusz Walach – Data string compression using arithmetic encoding with simplified probability subinterval estimation
- – Filed 5 January 1990, granted 24 March 1992 – William B. Pennebaker, Joan L. Mitchell – Probability adaptation for arithmetic coders
- – Filed 17 August 1992, granted 21 December 1993 – James D. Allen – Method and apparatus for entropy coding
Patents on arithmetic coding may exist in other jurisdictions; see software patents for a discussion of the patentability of software around the world.