EE465: Introduction to Digital Image Processing 1 Data Compression: Advanced Topics  Huffman Coding Algorithm Motivation Procedure Examples  Unitary.

Slides:



Advertisements
Similar presentations
Low-Complexity Transform and Quantization in H.264/AVC
Advertisements

ECE 8443 – Pattern Recognition ECE 8423 – Adaptive Signal Processing Objectives: The Linear Prediction Model The Autocorrelation Method Levinson and Durbin.
Michael Alves, Patrick Dugan, Robert Daniels, Carlos Vicuna
Information Theory EE322 Al-Sanie.
Bounds on Code Length Theorem: Let l ∗ 1, l ∗ 2,..., l ∗ m be optimal codeword lengths for a source distribution p and a D-ary alphabet, and let L ∗ be.
Image Processing A brief introduction (by Edgar Alejandro Guerrero Arroyo)
Data Compression.
School of Computing Science Simon Fraser University
1 Huffman Codes. 2 Introduction Huffman codes are a very effective technique for compressing data; savings of 20% to 90% are typical, depending on the.
Spatial and Temporal Data Mining
Introduction to Wavelets
Methods of Image Compression by PHL Transform Dziech, Andrzej Slusarczyk, Przemyslaw Tibken, Bernd Journal of Intelligent and Robotic Systems Volume: 39,
T.Sharon-A.Frank 1 Multimedia Image Compression 2 T.Sharon-A.Frank Coding Techniques – Hybrid.
Department of Computer Engineering University of California at Santa Cruz Data Compression (2) Hai Tao.
Digital Image Processing Final Project Compression Using DFT, DCT, Hadamard and SVD Transforms Zvi Devir and Assaf Eden.
EEE377 Lecture Notes1 EEE436 DIGITAL COMMUNICATION Coding En. Mohd Nazri Mahmud MPhil (Cambridge, UK) BEng (Essex, UK) Room 2.14.
Orthogonal Transforms
Image Compression - JPEG. Video Compression MPEG –Audio compression Lossy / perceptually lossless / lossless 3 layers Models based on speech generation.
Lossy Image Compression
©2003/04 Alessandro Bogliolo Background Information theory Probability theory Algorithms.
Huffman Coding Vida Movahedi October Contents A simple example Definitions Huffman Coding Algorithm Image Compression.
Chapter 2 Source Coding (part 2)
Computer Vision – Compression(2) Hanyang University Jong-Il Park.
Presented by Tienwei Tsai July, 2005
Digital Image Processing, 3rd ed. © 1992–2008 R. C. Gonzalez & R. E. Woods Gonzalez & Woods Matrices and Vectors Objective.
CS654: Digital Image Analysis Lecture 15: Image Transforms with Real Basis Functions.
Prof. Amr Goneid Department of Computer Science & Engineering
CMPT 365 Multimedia Systems
Part I: Image Transforms DIGITAL IMAGE PROCESSING.
Digital Image Processing Image Compression
Image Compression – Fundamentals and Lossless Compression Techniques
Image Compression Fasih ur Rehman. Goal of Compression Reduce the amount of data required to represent a given quantity of information Reduce relative.
Huffman coding Content 1 Encoding and decoding messages Fixed-length coding Variable-length coding 2 Huffman coding.
CHAPTER 5 SIGNAL SPACE ANALYSIS
CS654: Digital Image Analysis
CS654: Digital Image Analysis Lecture 13: Discrete Fourier Transformation.
STATISTIC & INFORMATION THEORY (CSNB134) MODULE 11 COMPRESSION.
ELE 488 F06 ELE 488 Fall 2006 Image Processing and Transmission ( ) Image Compression Review of Basics Huffman coding run length coding Quantization.
Chapter 8 Lossy Compression Algorithms. Fundamentals of Multimedia, Chapter Introduction Lossless compression algorithms do not deliver compression.
INFORMATION THEORY Pui-chor Wong.
EE465: Introduction to Digital Image Processing1 Lossy Image Compression: a Quick Tour of JPEG Coding Standard Why lossy for grayscale images?  Tradeoff.
Chapter 13 Discrete Image Transforms
EE465: Introduction to Digital Image Processing Lossless Image Compression 4 Recall: run length coding of binary and graphic images –Why does it not work.
BYST Xform-1 DIP - WS2002: Fourier Transform Digital Image Processing Bundit Thipakorn, Ph.D. Computer Engineering Department Fourier Transform and Image.
Entropy vs. Average Code-length Important application of Shannon’s entropy measure is in finding efficient (~ short average length) code words The measure.
Unsupervised Learning II Feature Extraction
1 Objective To provide background material in support of topics in Digital Image Processing that are based on matrices and/or vectors. Review Matrices.
ENTROPY Entropy measures the uncertainty in a random experiment. Let X be a discrete random variable with range S X = { 1,2,3,... k} and pmf p k = P X.
Fourier Transform (Chapter 4) CS474/674 – Prof. Bebis.
Signal Prediction and Transformation Trac D. Tran ECE Department The Johns Hopkins University Baltimore MD
Digital Image Processing Lecture 8: Fourier Transform Prof. Charlene Tsai.
Chapter 8 Lossy Compression Algorithms
Image Transformation Spatial domain (SD) and Frequency domain (FD)
Image Compression (Chapter 8)
IMAGE PROCESSING IMAGE COMPRESSION
EE465: Introduction to Digital Image Processing
IMAGE COMPRESSION.
An Example of 1D Transform with Two Variables
Matrices and Vectors Review Objective
Fourier Transform and Data Compression
4. DIGITAL IMAGE TRANSFORMS 4.1. Introduction
1-D DISCRETE COSINE TRANSFORM DCT
Image Coding and Compression
Objective To provide background material in support of topics in Digital Image Processing that are based on matrices and/or vectors.
Chapter 8 The Discrete Fourier Transform
Digital Image Procesing Unitary Transforms Discrete Fourier Trasform (DFT) in Image Processing DR TANIA STATHAKI READER (ASSOCIATE PROFFESOR) IN SIGNAL.
The Report of Monographic Study
Digital Image Procesing Unitary Transforms Discrete Fourier Trasform (DFT) in Image Processing DR TANIA STATHAKI READER (ASSOCIATE PROFFESOR) IN SIGNAL.
Digital Image Processing
Presentation transcript:

EE465: Introduction to Digital Image Processing 1 Data Compression: Advanced Topics  Huffman Coding Algorithm Motivation Procedure Examples  Unitary Transforms Definition Properties Applications

EE465: Introduction to Digital Image Processing 2 Recall: Recall: Variable Length Codes (VLC) Assign a long codeword to an event with small probability Assign a short codeword to an event with large probability Self-information It follows from the above formula that a small-probability event contains much information and therefore worth many bits to represent it. Conversely, if some event frequently occurs, it is probably a good idea to use as few bits as possible to represent it. Such observation leads to the idea of varying the code lengths based on the events’ probabilities.

EE465: Introduction to Digital Image Processing 3 Two Goals of VLC design  –log 2 p(x)  For an event x with probability of p(x), the optimal code-length is, where  x  denotes the smallest integer larger than x (e.g.,  3.4  =4 ) achieve optimal code length (i.e., minimal redundancy) satisfy uniquely decodable (prefix) condition code redundancy: Unless probabilities of events are all power of 2, we often have r>0

EE465: Introduction to Digital Image Processing 4 “Big Question” How can we simultaneously achieve minimum redundancy and uniquely decodable conditions? D. Huffman was the first one to think about this problem and come up with a systematic solution.

EE465: Introduction to Digital Image Processing 5 Huffman Coding (Huffman’1952)  Coding Procedures for an N-symbol source Source reduction  List all probabilities in a descending order  Merge the two symbols with smallest probabilities into a new compound symbol  Repeat the above two steps for N-2 steps Codeword assignment  Start from the smallest source and work back to the original source  Each merging point corresponds to a node in binary codeword tree

EE465: Introduction to Digital Image Processing 6 symbol x p(x) S W N E Example-I Step 1: Source reduction (EW) (NEW) compound symbols

EE465: Introduction to Digital Image Processing 7 p(x) codeword Example-I (Con’t) Step 2: Codeword assignment symbol x S W N E NEW 0 10EW 110 EW N S

EE465: Introduction to Digital Image Processing 8 Example-I (Con’t) NEW 0 10EW 110 EW N S NEW 1 01EW 000 EW N S The codeword assignment is not unique. In fact, at each merging point (node), we can arbitrarily assign “0” and “1” to the two branches (average code length is the same). or

EE465: Introduction to Digital Image Processing 9 symbol x p(x) e o a i Example-II Step 1: Source reduction (iou) (aiou) compound symbols u (ou)

EE465: Introduction to Digital Image Processing 10 symbol x p(x) e o a i Example-II (Con’t) (iou) (aiou) compound symbols u (ou) Step 2: Codeword assignment codeword

EE465: Introduction to Digital Image Processing 11 Example-II (Con’t) e ou (ou) i (iou)a (aiou) binary codeword tree representation

EE465: Introduction to Digital Image Processing 12 Example-II (Con’t) symbol x p(x) e o a i u codeword length If we use fixed-length codes, we have to spend three bits per sample, which gives code redundancy of =0.878bps

EE465: Introduction to Digital Image Processing 13 Example-III Step 1: Source reduction compound symbol

EE465: Introduction to Digital Image Processing 14 Example-III (Con’t) Step 2: Codeword assignment compound symbol

EE465: Introduction to Digital Image Processing 15 Summary of Huffman Coding Algorithm  Achieve minimal redundancy subject to the constraint that the source symbols be coded one at a time  Sorting symbols in descending probabilities is the key in the step of source reduction  The codeword assignment is not unique. Exchange the labeling of “0” and “1” at any node of binary codeword tree would produce another solution that equally works well  Only works for a source with finite number of symbols (otherwise, it does not know where to start)

EE465: Introduction to Digital Image Processing 16 Data Compression: Advanced Topics  Huffman Coding Algorithm Motivation Procedure Examples  Unitary Transforms Definition Properties Applications

EE465: Introduction to Digital Image Processing 17 An Example of 1D Transform with Two Variables x1x1 x2x2 y1y1 y2y2 Transform matrix (1,1) (1.414,0)

EE465: Introduction to Digital Image Processing 18 Decorrelating Property of Transform x1x1 x2x2 y1y1 y2y2 x 1 and x 2 are highly correlated p(x 1 x 2 )  p(x 1 )p(x 2 ) y 1 and y 2 are less correlated p(y 1 y 2 )  p(y 1 )p(y 2 ) Please use MATLAB demo program to help your understanding why it is desirable to have less correlation for image compression

EE465: Introduction to Digital Image Processing 19 Transform=Change of Coordinates  Intuitively speaking, transform plays the role of facilitating the source modeling Due to the decorrelating property of transform, it is easier to model transform coefficients (Y) instead of pixel values (X)  An appropriate choice of transform (transform matrix A) depends on the source statistics P(X) We will only consider the class of transforms corresponding to unitary matrices

EE465: Introduction to Digital Image Processing 20 A matrix A is called unitary if A -1 =A* T Unitary Matrix Definition conjugate transpose Example  For a real matrix A, it is unitary if A -1 =A T Notes:  transpose and conjugate can exchange, i.e., A *T =A T*

EE465: Introduction to Digital Image Processing 21 Example 1: Discrete Fourier Transform (DFT) Re Im DFT: DFT Matrix:

EE465: Introduction to Digital Image Processing 22 Discrete Fourier Transform (Con’t)  Properties of DFT matrix symmetry unitary Proof: If we denote then we have (identity matrix)

EE465: Introduction to Digital Image Processing 23 realYou can check it using MATLAB demo Example 2: Discrete Cosine Transform (DCT)

EE465: Introduction to Digital Image Processing 24 DCT Examples N=2: N=4: % generate DCT matrix with size of N-by-N Function C=DCT_matrix(N) for i=1:N; x=zeros(N,1);x(i)=1;y=dct(x);C(:,i)=y;end; end Here is a piece of MATLAB code to generate DCT matrix by yourself Haar Transform

EE465: Introduction to Digital Image Processing 25 % generate Hadamard matrix N=2^{n} function H=hadamard(n) H=[1 1;1 -1]/sqrt(2); i=1; while i<n H=[H H;H -H]/sqrt(2); i=i+1; end Here is a piece of MATLAB code to generate Hadamard matrix by yourself Example 3: Hadamard Transform

EE465: Introduction to Digital Image Processing 26 When the transform matrix A is unitary, the defined 1D transform is called unitary transform 1D Unitary Transform Inverse TransformForward Transform

EE465: Introduction to Digital Image Processing 27 Basis Vectors basis vectors corresponding to inverse transform basis vectors corresponding to forward transform (column vectors of transform matrix A) (column vectors of transform matrix A *T )

EE465: Introduction to Digital Image Processing 28 Do N 1D transforms in parallel From 1D to 2D

EE465: Introduction to Digital Image Processing 29 2D forward transform 1D column transform1D row transform Definition of 2D Transform

EE465: Introduction to Digital Image Processing 30 2D Transform=Two Sequential 1D Transforms Conclusion:  2D separable transform can be decomposed into two sequential  The ordering of 1D transforms does not matter row transform column transform row transform column transform (left matrix multiplication first) (right matrix multiplication first)

EE465: Introduction to Digital Image Processing 31 Basis Images T T Basis image B ij can be viewed as the response of the linear system (2D transform) to a delta-function input  ij T N1N1 1N1N

EE465: Introduction to Digital Image Processing 32 Example 1: 8-by-8 Hadamard Transform B ij i j DC In MATLAB demo, you can generate these 64 basis images and display them

EE465: Introduction to Digital Image Processing 33 Example 2: 8-by-8 DCT In MATLAB demo, you can generate these 64 basis images and display them i j DC

EE465: Introduction to Digital Image Processing 34 inverse transform Since A is a unitary matrix, we have Proof 2D Unitary Transform forward transform Suppose A is a unitary matrix,

EE465: Introduction to Digital Image Processing 35 Properties of Unitary Transforms  Energy compaction: only a small fraction of transform coefficients have large magnitude Such property is related to the decorrelating capability of unitary transforms  Energy conservation: unitary transform preserves the 2-norm of input vectors Such property essentially comes from the fact that rotating coordinates does not affect Euclidean distance

EE465: Introduction to Digital Image Processing 36 Energy Compaction Property  How does unitary transform compact the energy? Assumption: signal is correlated; no energy compaction can be done for white noise even with unitary transform Advanced mathematical analysis can show that DCT basis is an approximation of eigenvectors of AR(1) process (a good model for correlated signals such as an image)  A frequency-domain interpretation Most transform coefficients would be small except those around DC and those corresponding to edges (spatially high-frequency components) Images are mixture of smooth regions and edges

EE465: Introduction to Digital Image Processing 37 Energy Compaction Example in 1D Hadamard matrix significant A coefficient is called significant if its magnitude is above a pre-selected threshold th insignificant coefficients (th=64)

EE465: Introduction to Digital Image Processing 38 Energy Compaction Example in 2D  Example insignificant coefficients (th=64) A coefficient is called significant if its magnitude is above a pre-selected threshold th

EE465: Introduction to Digital Image Processing 39 Image Example Notice the excellent energy compaction property of DCT Original cameraman image X Its DCT coefficients Y (2451 significant coefficients, th=64) low-frequency high-frequency

EE465: Introduction to Digital Image Processing 40 Counter Example Original noise image XIts DCT coefficients Y No energy compaction can be achieved for white noise

EE465: Introduction to Digital Image Processing 41 Energy Conservation Property in 1D A is unitary Proof 1D case

EE465: Introduction to Digital Image Processing 42 Numerical Example Check:

EE465: Introduction to Digital Image Processing 43 Implication of Energy Conservation A is unitary Q TT -1 Linearity of Transform

EE465: Introduction to Digital Image Processing 44 Energy Conservation Property in 2D 2-norm of a matrix X Step 1: A unitary Proof: Using energy conservation property in 1D, we have

EE465: Introduction to Digital Image Processing 45 Energy Conservation Property in 2D (Con’t) Step 2: A unitary Hint: row transform column transform 2D transform can be decomposed into two sequential 1D transforms, e.g., Use the result you obtained in step 1 and note that

EE465: Introduction to Digital Image Processing 46 Numerical Example T Check:

EE465: Introduction to Digital Image Processing 47 Implication of Energy Conservation Q TT -1 Similar to 1D case, quantization noise in the transform domain has the same energy as that in the spatial domain Linearity of Transform

EE465: Introduction to Digital Image Processing 48 forward Transform entropy coding image X binary bit stream probability estimation Y Why Energy Conservation? f Y ^ super channel entropy decoding s inverse Transform image X f -1 s ^