Coding for the Network: Scalable and Multiple description coding Marco Cagnazzo

Similar documents
Recommended Readings

Scalable Video Coding

ECE 634: Digital Video Systems Scalable coding: 3/23/17

Unit-level Optimization for SVC Extractor

Network-Adaptive Video Coding and Transmission

A LOW-COMPLEXITY MULTIPLE DESCRIPTION VIDEO CODER BASED ON 3D-TRANSFORMS

ESTIMATION OF THE UTILITIES OF THE NAL UNITS IN H.264/AVC SCALABLE VIDEO BITSTREAMS. Bin Zhang, Mathias Wien and Jens-Rainer Ohm

Multiple Description Coding for Video Using Motion Compensated Prediction *

Adaptation of Scalable Video Coding to Packet Loss and its Performance Analysis

FOR compressed video, due to motion prediction and

Performance Comparison between DWT-based and DCT-based Encoders

Optimum Quantization Parameters for Mode Decision in Scalable Extension of H.264/AVC Video Codec

A Review of Multiple Description Coding Techniques for Error-Resilient Video Delivery

4G WIRELESS VIDEO COMMUNICATIONS

One-pass bitrate control for MPEG-4 Scalable Video Coding using ρ-domain

Module 6 STILL IMAGE COMPRESSION STANDARDS

SIGNAL COMPRESSION. 9. Lossy image compression: SPIHT and S+P

QUANTIZER DESIGN FOR EXPLOITING COMMON INFORMATION IN LAYERED CODING. Mehdi Salehifar, Tejaswi Nanjundaswamy, and Kenneth Rose

Video Coding with Multiple Descriptors and Spatial Scalability for Device Diversity in Wireless Multi-hop Networks

Effective Relay Communication for Scalable Video Transmission

A 3-D Virtual SPIHT for Scalable Very Low Bit-Rate Embedded Video Compression

Lecture 5: Error Resilience & Scalability

Channel-Adaptive Error Protection for Scalable Audio Streaming over Wireless Internet

Rate-distortion Optimized Streaming of Compressed Light Fields with Multiple Representations

Optimal Estimation for Error Concealment in Scalable Video Coding

SINGLE PASS DEPENDENT BIT ALLOCATION FOR SPATIAL SCALABILITY CODING OF H.264/SVC

Cross-Layer Optimization for Efficient Delivery of Scalable Video over WiMAX Lung-Jen Wang 1, a *, Chiung-Yun Chang 2,b and Jen-Yi Huang 3,c

Overview: motion-compensated coding

Review and Implementation of DWT based Scalable Video Coding with Scalable Motion Coding.

FAST SPATIAL LAYER MODE DECISION BASED ON TEMPORAL LEVELS IN H.264/AVC SCALABLE EXTENSION

Video Coding with Multiple Descriptors and Spatial Scalability for Device Diversity in Wireless Multi-hop Networks

THE H.264 ADVANCED VIDEO COMPRESSION STANDARD

Context based optimal shape coding

Unbalanced Multiple Description Video Communication Using Path Diversity

Robust Wireless Delivery of Scalable Videos using Inter-layer Network Coding

Streaming Video over the Internet. Dr. Dapeng Wu University of Florida Department of Electrical and Computer Engineering

Optimizing Joint Erasure- and Error-Correction Coding for Wireless Packet Transmissions

Rate-distortion Optimized Streaming of Compressed Light Fields with Multiple Representations

CONTENT ADAPTIVE COMPLEXITY REDUCTION SCHEME FOR QUALITY/FIDELITY SCALABLE HEVC

Wireless Video Transmission: A Single Layer Distortion Optimal Approach

Scalable Video Coding

Professor, CSE Department, Nirma University, Ahmedabad, India

Scalable Extension of HEVC 한종기

SCALABLE HYBRID VIDEO CODERS WITH DOUBLE MOTION COMPENSATION

Energy-Aware MPEG-4 4 FGS Streaming

JPEG 2000 vs. JPEG in MPEG Encoding

In the name of Allah. the compassionate, the merciful

Fast Mode Decision for H.264/AVC Using Mode Prediction

2014 Summer School on MPEG/VCEG Video. Video Coding Concept

Advances of MPEG Scalable Video Coding Standard

MULTI-BUFFER BASED CONGESTION CONTROL FOR MULTICAST STREAMING OF SCALABLE VIDEO

ARCHITECTURES OF INCORPORATING MPEG-4 AVC INTO THREE-DIMENSIONAL WAVELET VIDEO CODING

The Performance of MANET Routing Protocols for Scalable Video Communication

Comparison of Shaping and Buffering for Video Transmission

FPGA IMPLEMENTATION OF BIT PLANE ENTROPY ENCODER FOR 3 D DWT BASED VIDEO COMPRESSION

International Journal of Emerging Technology and Advanced Engineering Website: (ISSN , Volume 2, Issue 4, April 2012)

Upcoming Video Standards. Madhukar Budagavi, Ph.D. DSPS R&D Center, Dallas Texas Instruments Inc.

Audio-coding standards

Low-complexity video compression based on 3-D DWT and fast entropy coding

Complexity Reduced Mode Selection of H.264/AVC Intra Coding

VIDEO COMPRESSION STANDARDS

Optimized Progressive Coding of Stereo Images Using Discrete Wavelet Transform

Layered Network Architecture. CSC358 - Introduction to Computer Networks

Xiaoqing Zhu, Sangeun Han and Bernd Girod Information Systems Laboratory Department of Electrical Engineering Stanford University

Chapter 11.3 MPEG-2. MPEG-2: For higher quality video at a bit-rate of more than 4 Mbps Defined seven profiles aimed at different applications:

ELL 788 Computational Perception & Cognition July November 2015

BANDWIDTH-EFFICIENT ENCODER FRAMEWORK FOR H.264/AVC SCALABLE EXTENSION. Yi-Hau Chen, Tzu-Der Chuang, Yu-Jen Chen, and Liang-Gee Chen

DIGITAL TELEVISION 1. DIGITAL VIDEO FUNDAMENTALS

The Frozen Mountain irtc White Paper Series

Department of Electrical Engineering, IIT Bombay.

Pyramid Coding and Subband Coding

DCT Based, Lossy Still Image Compression

Increase-Decrease Congestion Control for Real-time Streaming: Scalability

3. Quality of Service

Distributed Source Coding for Image and Video Applications. Acknowledgements

Video Redundancy Coding in H.263+ Stephan Wenger Technische Universität Berlin

Multimedia networked applications: standards, protocols and research trends

Multi-path Forward Error Correction Control Scheme with Path Interleaving

Wavelet Transform (WT) & JPEG-2000

Bit Allocation for Spatial Scalability in H.264/SVC

For layered video encoding, video sequence is encoded into a base layer bitstream and one (or more) enhancement layer bit-stream(s).

Scalable Video Transport over IP Networks

Perceptual Coding. Lossless vs. lossy compression Perceptual models Selecting info to eliminate Quantization and entropy encoding

Convention Paper Presented at the 121st Convention 2006 October 5 8 San Francisco, CA, USA

Fast Mode Assignment for Quality Scalable Extension of the High Efficiency Video Coding (HEVC) Standard: A Bayesian Approach

Video Transcoding Architectures and Techniques: An Overview. IEEE Signal Processing Magazine March 2003 Present by Chen-hsiu Huang

MODELING AND SIMULATION OF MPEG-2 VIDEO TRANSPORT OVER ATM NETWOR.KS CONSIDERING THE JITTER EFFECT

Differential Compression and Optimal Caching Methods for Content-Based Image Search Systems

Audio-coding standards

ADVANCES IN VIDEO COMPRESSION

signal-to-noise ratio (PSNR), 2

MCTF and Scalability Extension of H.264/AVC and its Application to Video Transmission, Storage, and Surveillance

Optimized Strategies for Real-Time Multimedia Communications from Mobile Devices

Multimedia Applications over Packet Networks

Multi-path Transport of FGS Video

A DISTRIBUTED VIDEO STREAMING PLATFORM SUPPORTING MULTIPLE DESCRIPTION CODING

Error Control Techniques for Interactive Low-bit Rate Video Transmission over the Internet.

System Modeling and Implementation of MPEG-4. Encoder under Fine-Granular-Scalability Framework

Multiple description coding for SNR scalable video transmission over unreliable networks

Fraunhofer Institute for Telecommunications - Heinrich Hertz Institute (HHI)

Transcription:

Coding for the Network: Scalable and Multiple description coding Marco Cagnazzo

Overview Examples and motivations Scalable coding for network transmission Techniques for multiple description coding 2 27/05/2013

Coding for the Network Traditional compression techniques: Minimum size for a given quality Assumptions: Known bandwidth Known decoding parameters (resolution, frame-rate) No errors Network video delivery Different links and users Unreliable links 3 27/05/2013

Coding for the Network Basic idea: from a monolithic representation to a structured representation Layered (i.e. hierarchical) sub-streams: scalable video coding (SVC) Equal importance sub-streams: multiple description coding (MDC) 4 27/05/2013

Image transmission 1. Sequential coding 2. Progressive coding (scalable) 3. Multiple description (MDC) 5 packets 2 cases: no error packet 2/5 not received 5 27/05/2013

Examples: transmission without errors Packet 1 Non-scalable Scalable Multiple descriptions 6 27/05/2013

Examples: transmission without errors Packet 2 Non-scalable Scalable Multiple descriptions 7 27/05/2013

Examples: transmission without errors Packet 3 Non-scalable Scalable Multiple descriptions 8 27/05/2013

Examples: transmission without errors Packet 4 Non-scalable Scalable Multiple descriptions 9 27/05/2013

Examples: transmission without errors Packet 5 Non-scalable Scalable Multiple descriptions 10 27/05/2013

Examples: transmission with errors Packet 1 Non-scalable Scalable Multiple descriptions 11 27/05/2013

Examples: transmission with errors Packet 2: LOSS Non-scalable Scalable Multiple descriptions 12 27/05/2013

Examples: transmission with errors Packet 3 Non-scalable Scalable Multiple descriptions 13 27/05/2013

Examples: transmission with errors Packet 4 Non-scalable Scalable Multiple descriptions 14 27/05/2013

Examples: transmission with errors Packet 5 Non-scalable Scalable Multiple descriptions 15 27/05/2013

Examples: heterogeneous users and networks Server Router Client 1 Client 3 Router Client 2 Non-scalable 16 27/05/2013

Examples: efficient network use Server Router Client 1 Client 3 Router Client 2 Scalable 17 27/05/2013

Multiple Description Coding 18 27/05/2013

Multiple Description Coding + P2P 19 27/05/2013

Overview Examples and motivations Scalable coding for network transmission Principles and applications Techniques for multiple description coding 20 27/05/2013

SVC approach Encode once Different versions obtained by combining sub-streams Intelligent network (multiple multicast groups) Packet replication only where needed Efficient network use 21 27/05/2013

Scalability in video coding Resolution Definition: A scalable video stream is a compressed representation of a video such that: The representation is made up of layers Layers provide incremental refinement of the sequence The representation is efficient in term of reconstructed image quality for a given rate Quality 22 27/05/2013

Kinds of scalability SNR scalability aka quality, bit-rate scalability Space scalability aka resolution scalability Time scalability aka frame-rate scalability Other (object scalability, ) 23 27/05/2013

Scalability: pros Encode once, decode many! Optimal use of the network Space saving on the server Each user is provided exactly with the demanded information Error resilience (but what if base layer is lost?) Dynamic decoding rate 24 27/05/2013

Scalability: cons Complexity increases Rate-distortion performances are degraded This goes worse and worse when more layers are added Is it better to degrade base layer or details? Fully useful only if the infrastructure is changed Multicast routers are needed 25 27/05/2013

Scalability: issues How can we obtain quality, space and time scalability? How can we achieve scalability with low impact on rate-distortion performance? How can we achieve scalability with low complexity increase? How can we trade-off between base layer and details degradation? 26 27/05/2013

Overview Examples and motivations Scalable coding for network transmission Techniques for multiple description coding Principles MDC techniques 27 27/05/2013

MDC vs. SVC Scalable coding: base + enhancement If base is lost, enhancements are useless TCP-based transmission: all packets arrive but retransmission delay is usually much higher than packet interarrival In conclusion, SVC relies too much on transport layer, which could fail for several reasons A different transmission model could help when transmission is not reliable and delay is a constraint 28 27/05/2013

Multiple description coding: principles The encoder creates 2 description of the same importance Trivial example: odd and even frames Descriptions sent over different (logical) channels One description is enough for acceptable quality Receiving 2 descriptions provides the best quality Generalization: N descriptions 29 27/05/2013

MDC: pros and cons Pros Good quality without retransmission Real-time and interactive applications Simplification of network design: no feedback channel needed Traffic dispersion Cons Better than scalable coding since all streams have the same importance Application to P2P distribution using multiple paths Excess rate: for the same quality, MDC demands more bits wrt single description coding 30 27/05/2013

MDC: conceptual scheme Usually a balanced scheme is considered: R 1 =R 2 =R/2 D 1,1 =D 1,2 =D 1 Video input Multiple Description Encoder Channel 1 Channel 2 R 1 R 2 Multiple Description Decoder D 1,1 D 0 D 1,2 31 27/05/2013

MDC: conceptual scheme Usually a balanced scheme is considered: R 1 =R 2 =R/2 D 1,1 =D 1,2 =D 1 MD decoder Side Decoder 1 D 1,1 Video input Multiple Description Encoder Channel 1 R 1 Central Decoder D 0 Channel 2 R 2 MDC Dilemma: Two good descriptions at rate R 1 tend to be similar: how can their combination be much better than simply one of them? Side Decoder 2 D 1,2 32 27/05/2013

MDC problems For SDC, one has to minimize D 0 for a given R For MDC, we consider the redundancy ρ(d 0, D 1 ) ρ D 0, D 1 = R R R = R 1 + R 2 : rate for MDC to assure distortion D 0 for the central decoder and D 1 for the side decoders R : rate for the SDC to assure distortion D 0 33 27/05/2013

MDC problems Distortion bounds 0 If, then D 1 If the distortion bound is achieved for central decoder, use the additional rate for side decoder Another approach uses the error probability p: J = 1 p 2 D 0 + 2p 1 p D 1 + λr 34 27/05/2013

Overview Examples and motivations Techniques for scalable coding Techniques for multiple description coding Principles MDC techniques 35 27/05/2013

MDC techniques: Channel splitting Video data are split into 2 (or more channels) and processed separately Channel splitting relies only on channel redundancy The splitting can be performed in space, time, frequency 2 Coding z -1 2 Coding 36 27/05/2013

Temporal Channel splitting: An example 37 27/05/2013

Spatial channel splitting: FMO in H.264 Images divided into slices Slices coded independently FMO allows to define arbitrarily shaped slices Slices correspond to descriptions Description 0 Description 1 38 27/05/2013

Channel splitting: example AR model for vocal signal X n = ax n 1 + Y n Y n = N 0, σ i. i. d., a ]0, 1[ Filter characterization? 39 27/05/2013

Channel splitting: example AR model for vocal signal X n = ax n 1 + Y n Y n = N 0, σ i. i. d., a ]0, 1[ Filter characterization? X z = az 1 X z + Y z X n = + a m Y n m m=0 Statistical characterization of X n? 40 27/05/2013

Channel splitting: example AR model for vocal signal X n = ax n 1 + Y n Y n = N 0, σ i. i. d., a ]0, 1[ Filter characterization? X z = az 1 X z + Y z X n = + a m Y n m m=0 Statistical characterization of X n? Zero-mean gaussian r xx n = σ2 a k 1 a 2 For simplicity, we set σ 2 = 1 a 2 r xx k = a k 41 27/05/2013

Channel splitting: example AR model for vocal signal X n = ax n 1 + Y n Y n = N 0, σ i. i. d., a ]0, 1[ X n = N 0, 1, r xx k = a k The larger a, the more correlated the samples of X Now we want to encode X Single description : DPCM coding Multiple description: Channel splitting with DPCM on each channel and linear interpolation at side decoders 42 27/05/2013

Channel splitting: example DPCM coding for AR Gaussian signal with correlation a x n = ax n 1 E n = Y n D PCM = σ 2 2 2R = (1 a 2 )2 2R For simplicity, we suppose a perfectly known, and we ignore the quantization error of the predictor (high-rate hypothesis) The formula for the distortion holds for the single description case, but also for the encoding of any AR Gaussian signal with correlation a 43 27/05/2013

Channel splitting: example Channel splitting X e n = X 2n X o n = X 2n + 1 r xe x e k =? E X 2n X 2n + 2k = r xx 2k = a 2 k 44 27/05/2013

Channel splitting: example Channel splitting X e n = X 2n X o n = X 2n + 1 r xe x e k = E X 2n X 2n + 2k = r xx 2k = a 2 k On each channel we have an AR Gaussian signal with correlation a 2 We can use the previous formula for distortion 45 27/05/2013

Channel splitting: example Central decoder On both channel we receive an AR Gaussian signal D o = D e = 1 a 4 2 2R The distortion (called full-rate distortion) is the average of the distortions on the two channels D F = 1 2 D o + 1 2 D e = 1 a 4 2 2R The central decoder has a constant factor increase in distortion (at high rate): D F D PCM = 1 + a 2 > 1 The more correlated are the samples, the larger lossses will be caused by channel splitting 46 27/05/2013

Channel splitting: example Side decoder (half-rate decoder) We only receive even samples, therefore: D e = (1 a 4 )2 2R For odd samples: the quantization distortion (modulated by a term depending on quantization noise correlation, ω ]0, 1[ ) plus the interpolation error D o = ωd e + 1 a 2 + 1 2 1 a2 D H = 1 2 D o + 1 2 D e = 1 2 1 a 2 + 1 2 1 a2 + 1+ω 2 D F In the worst case (ω = 1), D H = D F + k a Actually at low bit rate we can have D H < D F 47 27/05/2013

Channel splitting: example Summary: Central decoder: constant loss ( in db) wrt single description coding The side decoder performance saturates since it cannot get rid of interpolation error, no matter how high the rate is At low bit-rate, the side decoder can outperform the central one: our approximation do not hold longer; it could be better to use the few bits we have to encode pretty one only the even samples and interpolate the odd ones Results are coherent with experimentation in audio coding (see figure) 48 27/05/2013

Channel splitting: an example for video coding 49 27/05/2013

MDC techniques: Unequal Error Protection Produce a two-layers progressive representation of data Insert the base layer in both descriptions Split the enhancement layer in the two descriptions Base Stream Formation Descript 1 Scalable Coding Enhanc. Descript 2 50 27/05/2013

MDC techniques: Correlating transforms Keep some correlation among coefficients Statistical dependencies are used to estimate transform coefficients that are in a lost description x 1,x 2 (x 1 +x 2, x 1 -x 2 ) X 1, X 2 : Independent Gaussian variables Y 1, Y 2 : Correlated Gaussian variables 51 27/05/2013

MDC techniques: Redundant transforms Project the input vector into a redundant set Use subsets of coefficients to form descriptions x 1 x 2 x 3 x 1 x 2 Description 1 x 1 x 3 Description 2 52 27/05/2013

Other MDC approaches Shifted intervals Non-convex quantizers One index corresponds to disjoint intervals Oversampled filter banks Related to wavelets Scalability+MDC 53 27/05/2013

Mismatch for video MDC Mismatch (i.e. drift) if prediction is made with information not available at the decoder Mismatch is probable because of packet loss No mismatch: improves side decoders Mismatch: improves central decoder 54 27/05/2013

Conclusions Traditional approaches unfit to video delivery over networks Basic idea: split the stream into substreams Scalable coding: good RD performances, good use of resources (memory, complexity, bandwidth), some error resilience MDC: acceptable RD performances, quite good use of resources, good error resilience Cons: Compression capability Complexity 55 27/05/2013

Bibliography Scalable video coding [1] W. Li, Overview of Fine Granularity Scalability in MPEG-4 Video Standard. IEEE Trans. Circ. and Syst. for Video Tech., 11(3) Mar. 2001. [2] J.-R. Ohm, Advances in Scalable Video Coding. Proceedings of the IEEE, 93(1), Jan. 2005. [3] H. Schwarz, D. Marpe, T. Wiegand, Overview of the Scalable Video Coding Extension of the H.264/AVC Standard. IEEE Trans. Circ. and Syst. for Video Tech., 17(9), Sept. 2007 Multiple Description Coding [4] V. Goyal, Multiple Description Coding: Compression Meets the Network. IEEE Sign. Proc. Magazine, Sept. 2001 [5] Y. Wang, A. R. Reibman, S. Lin, Multiple Description Coding for Video Delivery. Proceedings of the IEEE, 93(1), Jan. 2005. 56 27/05/2013