Professional Documents
Culture Documents
introduction
basic coding schemes
an application
entropy
LZW codes
References:
Algorithms 2nd edition, Chapter 22
http://www.cs.princeton.edu/introalgsds/65compression
1
introduction
basic coding schemes
an application
entropy
LZW codes
2
Data Compression
3
Applications
Multimedia.
• Images: GIF, JPEG.
• Sound: MP3.
• Video: MPEG, DivX™, HDTV.
Communication.
• ITU-T T4 Group 3 Fax.
• V.42bis modem.
Databases. Google.
4
Encoding and decoding
Message. Binary data M we want to compress. uses fewer bits (you hope)
5
Food for thought
7
Fixed length encoding
a b r a c a d a b r a !
1100001 1100010 1110010 1100001 1100011 1100001 1100100 1100001 1100010 1110010 1100001 1111111
8
Fixed length encoding
a X000
b X001
c X010
d X011
r X100
12 symbols 3 bits
! X111 36 bits in code
a b r a c a d a b r a !
X000 X001 X100 X000 X010 X000 X011 X000 X001 X100 X000 X111
a c t a c a g a t g a
X00X X01X 10 X00X X01X X00X 11 X00X 10 11 X00X
• Amazing but true: initial databases in 1990s did not use such a code!
Decoder needs to know the code
• can amortize over large number of files with the same code
• in general, can encode an N-char file with N lg M + 16 lg M bits
10
Variable-length encoding
Issue: ambiguity.
••••••
SOS ?
IAMIE ?
EEWNI ?
V7O ?
11
Variable-length encoding
a b r a c a d a b r a !
0 1 1 1 1 1 0 0 1 0 1 0 0 1 0 0 0 1 1 1 1 1 0 0 1 0 1 1
Encoding. 0 1 0 1
13
Providing the code
0 1
c !
preorder traversal *a**d*c!*rb
# chars to decode 12
the message bits 0111110010100100011111001011
boolean isInternal() { }
}
15
Prefix-free decoding iImplementation
0 1
16
Introduction to compression: summary
a b r a c a d a b r a !
1100001 1100010 1110010 1100001 1100011 1100001 1100100 1100001 1100010 1110010 1100001 1111111
a b r a c a d a b r a !
X000 X001 X100 X000 X010 X000 X011 X000 X001 X100 X000 X111
a b r a c a d a b r a !
0111110010100100011111001011
David Huffman
18
Huffman coding example
a b r a c a d a b r a !
5 7
a
1 1 1 2 2 5
3 4
c ! d r b a
2 2
1 2
1 2 2 2 5 r b
d
d r b a 1 1
1 1
c !
c !
12
2 2 3 5
r b a
1 2 5 7
d a
1 1
3 4
c !
2 2
1 2
r b
d
1 1
3 4 5
c !
a
2 2
1 2
r b
d
1 1
c ! 19
Huffman trie construction code
20
Huffman encoding summary
Implementation.
• pass 1: tabulate symbol frequencies and build trie
• pass 2: encode file by traversing trie or lookup table.
output distinct
bits symbols
21
introduction
basic coding schemes
an application
entropy
LZW codes
22
An application: compress a bitmap
300 pixels/inch
8.5 by 11 inches
23
Natural encoding of a bitmap
000000000000000000000000000011111111111111000000000
000000000000000000000000001111111111111111110000000
000000000000000000000001111111111111111111111110000
000000000000000000000011111111111111111111111111000
000000000000000000001111111111111111111111111111110
000000000000000000011111110000000000000000001111111
000000000000000000011111000000000000000000000011111
000000000000000000011100000000000000000000000000111
000000000000000000011100000000000000000000000000111
000000000000000000011100000000000000000000000000111
000000000000000000011100000000000000000000000000111
000000000000000000001111000000000000000000000001110
000000000000000000000011100000000000000000000111000
011111111111111111111111111111111111111111111111111
011111111111111111111111111111111111111111111111111
011111111111111111111111111111111111111111111111111
011111111111111111111111111111111111111111111111111
011111111111111111111111111111111111111111111111111
011000000000000000000000000000000000000000000000011
24
Run-length encoding of a bitmap
to encode number of bits per line
51
000000000000000000000000000011111111111111000000000 28 14 9
000000000000000000000000001111111111111111110000000 26 18 7
000000000000000000000001111111111111111111111110000 23 24 4
000000000000000000000011111111111111111111111111000 22 26 3
000000000000000000001111111111111111111111111111110 20 30 1
000000000000000000011111110000000000000000001111111 19 7 18 7
000000000000000000011111000000000000000000000011111 19 5 22 5
000000000000000000011100000000000000000000000000111 19 3 26 3
000000000000000000011100000000000000000000000000111 19 3 26 3
000000000000000000011100000000000000000000000000111 19 3 26 3
000000000000000000011100000000000000000000000000111 19 3 26 3
000000000000000000001111000000000000000000000001110 20 4 23 3 1
000000000000000000000011100000000000000000000111000 22 3 20 3 3
011111111111111111111111111111111111111111111111111 1 50
011111111111111111111111111111111111111111111111111 1 50
011111111111111111111111111111111111111111111111111 1 50
011111111111111111111111111111111111111111111111111 1 50
011111111111111111111111111111111111111111111111111 1 50
011000000000000000000000000000000000000000000000011 1 2 46 2
25
Run-length encoding
15 bits 20 bits
26
Run-length encoding and Huffman codes in the wild
1 000111 010
2 0111 11
3W 1B 2W 2B 194W … 3 1000 10
… … …
… … …
Huffman codes built from 1728+ 010011011 0000001100101
frequencies in huge sample
27
BW bitmap compression: another approach
Idea:
• use OCR to get back to ASCII (!)
• use Huffman on ASCII string (!)
Bottom line: Any extra information about file can yield dramatic gains 28
introduction
basic coding schemes
an application
entropy
LZW codes
29
What data can be compressed?
30
Perpetual Motion Machines
31
What data can be compressed?
Pf 1.
• consider all 1,000 bit messages.
• 21000 possible messages.
• only 2999 + 2998 + … + 1 can be encoded with 999 bits.
• only 1 in 2499 can be encoded with 500 bits!
Pf 2 (by contradiction).
• given a file M, compress it to get a smaller file M1.
• compress that file to get a still smaller file M2.
• continue until reaching file size 0.
• implication: all files can be compressed with 0 bits!
33
A difficult file to compress
% javac Rand.java % ls –l
% java Rand > temp.txt 231 Rand.java
% compress –c temp.txt > temp.Z 1000000 temp.txt
% gzip –c temp.txt > temp.gz 576861 temp.Z
% bzip2 –c temp.txt > temp.bz2 570872 temp.gz
499329 temp.bz2
35
Language model
36
Entropy
4 1 0 0
"... randomising letters in the middle of words [has] little or no effect on the
ability of skilled readers to understand the text. This is easy to
denmtrasote. In a pubiltacion of New Scnieitst you could ramdinose all the
letetrs, keipeng the first two and last two the same, and reibadailty would
hadrly be aftcfeed. My ansaylis did not come to much beucase the thoery at
the time was for shape and senqeuce retigcionon. Saberi's work sugsegts we
may have some pofrweul palrlael prsooscers at work. The resaon for this is
suerly that idnetiyfing coentnt by paarllel prseocsing speeds up regnicoiton.
We only need the first and last two letetrs to spot chganes in meniang."
A. Quite a bit.
39
Entropy of the English Language
# of guesses 1 2 3 4 5 6
40
introduction
basic coding schemes
an application
entropy
LZW codes
41
Statistical Methods
Adaptive model. Progressively learn and update model as you read text.
• More accurate modeling produces better compression.
• Decoding must start from beginning.
• Ex: LZW.
42
LZW Algorithm
To send (encode) M.
•Find longest string s in ST that is a prefix of unsent part of M
•Send codeword associated with s.
•Add s x to ST, where x is next char in M.
input code
a 97
b 98
r 114
a 97
c 99
a 97
d 100
a 130
c
a 132
d
a 134
b
r 129
a 97 Key point: no need to send ST (!)
STOP 255 45
LZW encode ST implementation
ASCII ST
Q. How to do longest prefix match? key value key value
A. Use a trie for the ST 0 ab 128
br 129
Encode.
... ra 130
•
ac 131
lookup string suffix in trie.
•
a 97 ca 132
output ST index at bottom. b 98 ad 133
while (!in.isEmpty())
{
encode text
int codeword = st.getput(in); and build
StdOut.println(codeword); TST
}
}
}
postprocess
to encode in
Use specialized TST binary
public LZWst()
{
roots = new Node[128]; initialize
with ASCII
for (i = 0; i < 128; i++)
roots[i] = new Node((char) i, i);
}
}
48
LZW encoder: Java implementation (TST search/insert) caution:
tricky
recursive
public int getput(LookAheadIn in) code
{
char c = in.readChar();
if (c == '!') return 255;
roots[c] = getput(c, roots[c], in);
in.backup();
longest prefix
return codeword; codeword
}
To send (encode) M.
•Find longest string s in ST that is a prefix of unsent part of M
•Send integer associated with s.
•Add s x to ST, where x is next char in M.
99 c ac 131 ac
97 a 132 ca
97 a ca
98 b 133 ad
100 d ad Use an array
99 c 134 da
128 a to implement ST
100 d 135 abr
b da
... 136 rac
130 r 114 r 137 cad
a abr 138 dab
132 c ... 139 bra
a rac ...
134 d it_ 127 255
a cad
To decode received message to M.
129 b
Let s be ST entry associated with received integer
r dab
Add s to M.
97 a bra
Add p x to ST, where x is first char in s, p is previous value of s.
255 STOP
52
LZW decoder: Java implementation
55
LZW in the real world
PNG: LZ77.
Winzip, gzip, jar: deflate.
Unix compress: LZW.
Pkzip: LZW + Shannon-Fano.
GIF, TIFF, V.42bis modem: LZW.
Google: zlib which is based on deflate.
56
Lossless compression ratio benchmarks
57
Data compression summary
Lossless compression.
• Represent fixed length symbols with variable length codes. [Huffman]
• Represent variable length symbols with fixed length codes. [LZW]
Butch: I don’t mean to be a sore loser, but when it’s done, if I’m dead, kill him.
Sundance: Love to.
Butch: No, no, not yet. Not until me and Harvey get the rules straightened out.
Harvey: Rules? In a knife fight? No rules.
Butch: Well, if there ain’t going to be any rules, let’s get the fight started...
58