Context-adaptive binary arithmetic coding ou CABAC que l'on peut traduire par codage arithmétique binaire adaptable au contexte est un type de codeur entropique utilisé dans la norme de compression vidéo H.264/AVC ainsi que dans la norme H.265/HEVC. Il s'agit d'un codeur arithmétique dont la compression est dite sans perte.

Algorithme

modifier

Le CABAC possède de nombreux modes de probabilités pour différents contextes. Tout d'abord, il convertit tous les symboles non-binaires en symboles binaires. Puis, pour chaque bit, le codeur sélectionne le modèle de probabilité le plus adapté et utilise les informations des éléments voisins pour optimiser l'estimation de la probabilité. Le codage arithmétique est ensuite appliqué pour compresser les données résultantes.

Application dans la norme H.264

modifier

Dans la norme H.264, il existe deux codeurs entropiques qui se distinguent des autres normes vidéo : CAVLC ( (en)Context-adaptive variable-length coding) et CABAC ((en) Context-adaptive binary arithmetic coding). Ce dernier n'est pas utilisé dans tous les profils de codage définis par la norme : il est seulement supporté dans le profil Main et des profils supérieurs, c'est-à-dire supérieurs par le débit qu'ils autorisent. La raison est due à la complexité du CABAC qui nécessite une grande quantité de ressources pour traiter et décoder les données, en comparaison avec des algorithmes similaires. En comparaison, le CAVLC est moins exigeant au niveau des ressources, c'est pourquoi il est présent sur tous les profils et les plus petites plateformes (par exemple les mobiles).

Il est également difficile de paralléliser les différents traitements à cause de leur dépendance avec les autres contextes précédemment calculés.

Mais malgré sa complexité, CABAC fournit de meilleurs résultats de compression que la plupart des algorithmes d'encodage utilisés dans l'encodage vidéo ce qui fait de lui l'un des premiers avantages du schéma d'encodage de la norme H.264. En effet, son gain par rapport à CAVLC est d'environ 10 % dans des conditions similaires.

Références

modifier
  • (en) E. G. Richardson, H.264 and MPEG-4 Video Compression : Video Coding for Next-generation Multimedia, Chichester, John Wiley & Sons Ltd., septembre 2003, 281 p. (ISBN 978-0-470-84837-1)
  • (en) Introduction au CABAC

Annexes

modifier

Articles connexes

modifier

Liens externes

modifier

📚 Artikel Terkait di Wikipedia

H.264

(Advanced Video Coding), ou MPEG-4 Part 10, est une norme de codage vidéo développée conjointement par l'UIT-T Q.6/SG16 Video Coding Experts Group (VCEG)

Context-adaptive variable-length coding

entropique mais de type arithmétique CABAC (Context-based adaptive binary arithmetic coding) qui est plus efficace d'un point de compression par rapport au CAVLC

X264

CABAC (Context-based Adaptive Binary Arithmetic Coding) et CAVLC (Context-based Adaptive Variable Length Coding) MRF (Multiple Reference Frames) Tous

Free Lossless Image Format

fmt/872 Signature 46 4C 49 46 (hexa) Version initiale 3 octobre 2015 Basé sur Meta-Adaptive Near-zero Integer Arithmetic Coding (d) Site web flif.info

Théorème d'Ax-Grothendieck

Lachaud, Christophe Ritzenthaler et Michael A. Tsfasman, Arithmetic, Geometry, Cryptography and Coding Theory, Providence, R.I., AMS, coll. « Contemp. Math

Gary Urton

Social Life of Numbers: A Quechua Ontology of Numbers and Philosophy of Arithmetic. University of Texas Press, Austin. Spanish edition: La Vida Social de

Svetlana Katok

87–132. Coding of closed geodescis after Gauss and Morse. Geometria Dedicata, vol. 63, 1996, p. 123. Closed geodesics, periods and arithmetic of modular

Stephen Wolfram

want to read the silly books they gave us. And I never was able to do arithmetic. It was when he got into higher mathematics, such as calculus, he says