Jpeg and Mpeg
Jpeg and Mpeg
Jpeg and Mpeg
MPEG
Ingemar J. Cox
University College London
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 2
Outline
Elementary information theory
Lossless compression
Quantization
Fundamentals of images
Discrete Cosine Transform (DCT)
JPEG
MPEG-1, MPEG-2
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 3
Bibliography
D. MacKay, Information Theory, Inference and learning
Algorithms, Cambridge University Press, 2003.
http://www.inference.phy.cam.ac.uk/itprnn/book.html
W. B. Pennebaker and J. L. Mitchell, JPEG Still Image
Data Compression Standard, Chapman Hall, 1993
(ISBN 0-442-01272-1).
G. K. Wallace, The JPEG Still-Picture Compression
Standard, IEEE Trans. On Consumer Electronics, 38,
1, 18-34, 1992.
http://en.wikipedia.org/wiki/JPEG
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 4
Bibliography
http://en.wikipedia.org/wiki/MPEG-2
T. Sikora, MPEG Digital Video-Coding
Standards, IEEE Signal Processing Magazine,
82-100, September 1997
Elementary Information Theory
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 6
Elementary Information Theory
How much information does a symbol convey?
Intuitively, the more unpredictable or surprising
it is, the more information is conveyed.
Conversely, if we strongly expected something,
and it occurs, we have not learnt very much
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 7
Elementary Information Theory
If p is the probability that a symbol will occur
Then the amount of information, I, conveyed is:
The information, I, is measured in bits
It is the optimum code length for the symbol
|
|
.
|
\
|
=
p
I
1
log
2
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 8
Elementary Information Theory
The entropy, H, is the average information per
symbol
Provides a lower bound on the compression
that can be achieved
)
) (
1
( log ) (
2
s p
s p H
s
=
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 9
Elementary Information theory
A simple example. Suppose we need to
transmit four possible weather conditions:
1. Sunny
2. Cloudy
3. Rainy
4. Snowy
If all conditions are equally likely, p(s)=0.25,
and H=2
i.e. we need a minimum of 2 bits per symbol
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 10
Elementary information theory
Suppose instead that it is:
1. Sunny 0.5 of the time
2. Cloudy 0.25 of the time
3. Rainy 0.125 of the time, and
4. Snowy 0.125 of the time
Then the entropy is
75 . 1 75 . 0 5 . 0 5 . 0
3 125 . 0 2 2 25 . 0 1 5 . 0
125 . 0
1
log 125 . 0 2
25 . 0
1
log 25 . 0
5 . 0
1
log 5 . 0
2 2 2
= + + =
+ + =
+ + =
H
H
H
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 11
Elementary Information Theory
Variable length codewords
Huffman code integer code lengths
Arithmetic codes non-integer code lengths
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 12
Elementary Information Theory
Huffman code
Weather Probability Information Integer code
Sunny 0.5 1 0
Cloudy 0.25 2 10
Rainy 0.125 3 110
Snowy 0.125 3 111
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 13
Elementary Information Theory
Previous illustration is an example of a lossless
code
I.e. we are able to recover the information exactly
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 14
Elementary Information Theory
Note that we have assumed that each symbol
is independent of the other symbols
I.e. the current symbol provides no information
regarding the next symbol
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 15
Quantization
Quantization is the process of approximating a
continuous (or range of values) by a (much)
smaller range of values
Where Round(y) rounds y to the nearest integer
A is the quantization stepsize
|
.
|
\
|
A
+
= A
5 . 0
Round ) , (
x
x Q
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 16
Quantization
Example: A=2
0 1 -3 -2 -1 2 3 4 5 -5 -4
0 -1 1 2 -2
0 -2 2 4 -4
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 17
Quantization
Quantization plays an important role in lossy
compression
This is where the loss happens
Fundamentals of Images
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 19
Fundamentals of images
An image consists of pixels (picture elements)
Each pixel represents luminance (and colour)
Typically, 8-bits per pixel
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 20
Fundamentals of images
Colour
Colour spaces (representations)
RGB (red-green-blue)
CMY (cyan-magenta-yellow)
YUV
Y = 0.3R+0.6G+0.1B (luminance)
U=R-Y
V=B-Y
Greyscale
Binary
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 21
Fundamentals of images
A TV frame is about 640x480 pixels
If each pixels is represented by 8-bits for each
colour, then the total image size is
640480*3=921,600 bytes or ~7.4Mbits
At 30 frames per second, this would be
~ 220Mbits/second
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 22
Fundamentals of images
Do we need all these bits?
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 23
Fundamentals of images
Here is an image represented with 8-bits per
pixel
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 24
Fundamentals of images
Here is the same image at 7-bits per pixel
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 25
Fundamentals of images
And at 6-bits per pixel
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 26
Fundamentals of images
And at 5-bits per pixel
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 27
Fundamentals of images
And at 4-bits per pixel
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 28
Fundamentals of images
Do we need all these bits?
No!
The previous example illustrated the eyes
sensitivity to luminance
We can build a perceptual model
Only code what is important to the human visual
system (HVS)
Usually a function of spatial frequency
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 29
Fundamentals of Images
Just as audio has temporal frequencies
Images have spatial frequencies
Transforms
Fourier transform
Discrete cosine transform
Wavelet transform
Hadamard transform
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 30
Discrete cosine transform
Forward DCT
Inverse DCT
=
|
.
|
\
|
+ =
1
0
) 5 . 0 (
8
cos ) (
2
) (
) (
N
n
n
u
n s
u C
u S
t
|
.
|
\
|
+ =
=
) 5 . 0 (
8
cos ) (
2
) (
) (
1
0
n
u
u S
u C
n s
N
u
t
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 31
Basis functions
DC term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 32
Basis functions
First term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 33
Basis functions
Second term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 34
Basis functions
Third term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 35
Basis functions
Fourth term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 36
Basis functions
Fifth term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 37
Basis functions
Sixth term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 38
Basis functions
Seventh term
DCT Example
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 40
Example
Signal
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 41
Example
DCT coefficients are:
4.2426
0
-3.1543
0
0
0
-0.2242
0
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 42
Example: DCT decomposition
DC term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 43
Example: DCT decomposition
2
nd
AC term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 44
Example: DCT decomposition
6
th
AC term
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 45
Example: summation of DCT terms
First two non-zero coefficients
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 46
Example: summation of DCT terms
All 3 non-zero coefficients
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 47
Example
What if we quantize DCT coefficients?
A=1
Quantized DCT coefficients are:
4
0
-3
0
0
0
0
0
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 48
Example
Approximate reconstruction
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 49
Example
Exact reconstruction
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 50
2-D DCT Transform
Let i(x,y) represent an image with N rows and
M columns
Its DCT I(u,v) is given by
where
(
|
.
|
\
|
+
|
.
|
\
|
+
=
= =
M
x
N
y
v y u x
y x i v C u C v u I
1 1
16
) 1 2 (
cos
16
) 1 2 (
cos ) , ( ) ( ) (
4
1
) , (
t t
2
1
) 0 ( = C
1 ) ( = u C
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 51
Fundamentals of images
Discrete cosine transform
Coefficients are approximately uncorrelated
Except DC term
C.f. original 88 pixel block
Concentrates more power in the low frequency
coefficients
Computationally efficient
Block-based DCT
Compute DCT on 88 blocks of pixels
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 52
Fundamentals of images
Basis functions for the 88 DCT (courtesy
Wikipedia)
Fundamentals of JPEG
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 54
Fundamentals of JPEG
DCT Quantizer Entropy coder
IDCT Dequantizer
Entropy
decoder
Compressed
image data
Encoder
Decoder
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 55
Fundamentals of JPEG
JPEG works on 88 blocks
Extract 88 block of pixels
Convert to DCT domain
Quantize each coefficient
Different stepsize for each coefficient
Based on sensitivity of human visual system
Order coefficients in zig-zag order
Entropy code the quantized values
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 56
Fundamentals of JPEG
A common quantization table is
16 11 10 16 24 40 51 61
12 12 14 19 26 58 60 55
14 13 16 24 40 57 69 56
14 17 22 29 51 87 80 62
18 22 37 56 68 109 103 77
24 35 55 64 81 104 113 92
49 64 78 87 103 121 120 101
72 92 95 98 112 100 103 99
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 57
Fundamentals of JPEG
Zig-zag ordering
0 1 5 6 14 15 27 28
2 4 7 13 16 26 29 42
3 8 12 17 25 30 41 43
9 11 18 24 31 40 44 53
10 19 23 32 39 45 52 54
20 22 33 38 46 51 55 60
21 34 37 47 50 56 59 61
35 36 48 49 57 58 62 63
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 58
Fundamentals of JPEG
Entropy coding
Run length encoding followed by
Huffman
Arithmetic
DC term treated separately
Differential Pulse Code Modulation (DPCM)
2-step process
1. Convert zig-zag sequence to a symbol sequence
2. Convert symbols to a data stream
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 59
Fundamentals of JPEG
Modes
Sequential
Progressive
Spectral selection
Send lower frequency coefficients first
Successive approximation
Send lower precision first, and subsequently refine
Lossless
Hierarchical
Send low resolution image first
Fundamentals of MPEG-1/2
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 61
Fundamentals of MPEG
A sequence of 2D images
Temporal correlation as well as spatial
correlation
TV broadcast
Frame-based
Field-based
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 62
MPEG
Moving Picture Experts Group
Standard for video compression
Similarities with JPEG
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 63
MPEG
Design is a compromise between
Bit rate
Encoder/decoder complexity
Random access capability
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 64
MPEG
Images
Spatial redundancy
Perceptual redundancy
Video
Spatial redundancy
Intraframe coding
Temporal redundancy
Interframe coding
Perceptual redundancy
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 65
MPEG
Consider a sequence of n frames of video.
It consists of:
I-frames
P-frames
B-frames
A sequence of one I-frame followed by P- and
B-frames is known as a GOP
Group of Pictures
E.g. IBBPBBPBBPBBP
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 66
MPEG
I-frames
Intraframe coded
No motion compensation
P-frames
Interframe coded
Motion compensation
Based on past frames only
B-frames
Interframe coded
Motion compensation
Based on past and future frames
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 67
MPEG
Motion-compensated prediction
Divide current frame, i, into disjoint 1616
macroblocks
Search a window in previous frame, i-1, for closest
match
Calculate the prediction error
For each of the four 88 blocks in the macroblock,
perform DCT-based coding
Transmit motion vector + entropy coded prediction
error (lossy coding)
U
C
L
A
d
a
s
t
r
a
l
P
a
r
k
P
o
s
t
g
r
a
d
u
a
t
e
C
a
m
p
u
s
Nov 27th 2006 Ingemar J. Cox 68
MPEG
Like JPEG, the DC term is treated separately
DPCM
B-frame compression high
Need buffer and delay