Free Lossless Audio Codec
Free Lossless Audio Codec (FLAC) est un codec libre de compression audio sans perte développé par Xiph.org. Il obtient un taux de compression d'environ 50 % par rapport à des données PCM non-compressées[2]. Son caractère sans perte le rend adapté pour l'archivage de données audio.
Développé par | Xiph.org |
---|---|
Dernière version | 1.4.3 ()[1] |
Dépôt | gitlab.xiph.org/xiph/flac |
Écrit en | C |
Système d'exploitation | Multiplateforme |
Formats lus | Free Lossless Audio Codec (d), RF64, Audio Interchange File Format, Ogg et Sony Wave64 (d) |
Formats écrits | Free Lossless Audio Codec (d), Waveform Audio File Format, Sony Wave64 (d), RF64 et Audio Interchange File Format |
Type | Codec audio (en) |
Licence | BSD 3-clauses, licence publique générale GNU version 2 et licence publique générale limitée GNU version 2.0 (d) |
Documentation | xiph.org/flac/documentation_tools_flac.html |
Site web | xiph.org/flac |
Free Lossless Audio Codec
Développé par | |
---|---|
Version initiale | |
Type de format | |
Spécification | |
Site web |
(en) xiph.org/flac |
Historique
modifierLe développement de FLAC a commencé en 2000 en tant que projet indépendant par Josh Coalson[3]. La version 1.0 est publiée le 20 juillet 2001[4].
Le , FLAC rejoint Xiph.org, rejoignant ainsi la collection de formats audio libres soutenus par la fondation, comprenant notamment le conteneur Ogg et les codecs Vorbis, Theora et Speex.
L'Union européenne de radio-télévision (UER) a choisi le format FLAC pour son réseau Euroradio, pour la distribution audio de haute qualité[5].
Android supporte nativement le FLAC depuis sa version 3.1[6].
Sous Windows 10, le lecteur Windows Media supporte le FLAC[7].
En janvier 2017, les navigateurs web Firefox 51 et Google Chrome 46 gèrent nativement le FLAC[8].
Depuis juin 2017, la version 11 de iOS supporte nativement le FLAC[9].
Projet
modifierLe projet FLAC est constitué de plusieurs éléments :
- le format de flux ;
- un format conteneur appelé Native FLAC ;
- libFLAC, une bibliothèque de codage et décodage ainsi qu’une interface aux métadonnées ;
- libFLAC++, un accès objet à libFLAC ;
- flac, un accès en ligne de commande à libFLAC pour coder et décoder des fichiers .flac ;
- metaflac, un éditeur en ligne de commande pour les fichiers .flac ;
- des plugins d’entrée pour plusieurs lecteurs musicaux populaires (Winamp, XMMS…) ;
- avec l’inclusion dans le projet Xiph.org, le conteneur Ogg, adapté pour le streaming (l’ensemble est appelé Ogg FLAC).
Les spécifications du format de flux sont dans le domaine public (le projet FLAC se réserve les droits quant aux spécifications et à la certification de compatibilité). Le projet s’attache aussi à ce qu’aucun brevet ne couvre le format ou les méthodes de codage/décodage. Les bibliothèques libFLAC et libFLAC++ sont disponibles sous licence BSD, les sources de flac, metaflac et des plugins sont sous licence GPL.
Comparaisons
modifierEn tant que format sans perte, il conserve l'intégralité des informations contenues dans le flux audio et est comparable à des formats tels que ALAC ou Shorten.
FLAC obtient des taux de compression des données PCM de 30 à 70 %[10] pour un fichier audio de qualité CD. C'est en général un meilleur taux que celui atteint par un algorithme généraliste comme ZIP, qui atteint 20 à 40 %. Les codecs avec perte tels que MP3 ou Vorbis peuvent atteindre 80 à 90% de compression au prix d'une perte d'une partie des données originelles.
Le FLAC utilise la prédiction linéaire pour convertir les échantillons en une série de blocs non-corrélés d’environ 100 ms (connus sous le nom de résidus), qui sont stockés efficacement en utilisant le codage de Golomb-Rice. Il utilise aussi le codage par plages pour les blocs d’échantillons identiques, tels les passages blancs. Ceci lui permet d’être décompressé à la volée durant la lecture, y compris par un système autonome équipé de peu de mémoire (platine CD, lecteur portable à disque dur ou mémoire Flash, lecteur autonome à disque dur pour chaîne hi-fi ou voiture).
Usages
modifierFLAC est approprié pour tous les archivages de données audio, avec le support des métadonnées, image de couverture, ainsi que pour la recherche rapide. FLAC est un format ouvert ; ne nécessitant pas le paiement de redevances, il est bien supporté par de nombreux logiciels.
Étant un codec sans perte, le FLAC est très utilisé comme format d’archivage[11] : si le support original est perdu, endommagé ou usé, une copie en FLAC des pistes audio garantit qu’une copie exacte des données originales peut être récupérée à tout moment. Un fichier Cue sheet (CUE) peut éventuellement être créé quand on "rippe" un CD. Si le CD est lu et "rippé" parfaitement en fichier FLAC, le fichier CUE permet de graver plus tard un CD audio qui est la réplique exacte de celui d’origine, en incluant l’ordre des pistes, prégaps, et CD-Text. Pourtant certaines données seront tout de même perdues, comme les informations de paroles ou encore les graphiques d’un CD+G, ces données n'étant pas incluses dans le fichier CUE, elles ne seront pas archivées.
Le support de la restitution de FLAC sur les appareils audio portables, et les systèmes audio dédiés est limité mais en progrès[12].
FLAC est disponible pour pratiquement tous les systèmes d’exploitation.
Description technique
modifierStructure d'un flux FLAC
modifierUn flux FLAC commence toujours par la séquence magique fLaC
, suivie de blocs de métadonnées décrivant le flux à la suite desquels s'ajoutent des trames contenant les données audio en tant que telles[13].
Le premier bloc de métadonnées est obligatoire et donne des informations utiles au décodage du flux : la taille des blocs audio, la taille des trames audio, la fréquence d'échantillonnage, le nombre de canaux, le nombre total d'échantillons dans le fichier, ainsi que des informations permettant la détection d'erreur[14]. Les autres blocs de métadonnées sont optionnels et permettent de stocker des informations supplémentaires telles qu'une image, une description de la piste sous forme de commentaires Vorbis, ou des indications de positions facilitant la navigation rapide au sein du flux[15].
Chaque trame audio commence par un en-tête décrivant la trame en donnant sa taille, la fréquence d’échantillonnage, le nombre de canaux, la taille d'un échantillon en bits, ainsi que des informations permettant la détection d'erreur[16]. L'en-tête est suivi par des sous-trames, une par canal, chacune contenant les paramètres utilisés pour la compression, suivis des données compressées[16].
Méthode d'encodage
modifierFLAC utilise une méthode d'encodage sans perte combinant un codage prédictif linéaire (en) et un codage de Rice[17].
Le codage prédictif linéaire est une méthode de compression avec perte. Il consiste à prédire la valeur approximative du signal à l'aide d'une suite récurrente linéaire utilisant seulement un petit nombre de paramètres pour être définie et initialisée. FLAC permet l'utilisation de cinq prédicteurs prédéfinis d'ordre 0 à 4, ou bien l'utilisation d'un prédicteur spécifique défini par au plus 32 coefficients[18].
Le codage de Rice complète l'encodage prédictif linéaire en permettant l'encodage sans perte du résidu, c'est-à-dire de la différence entre le signal à compresser et la prédiction, de sorte que l'encodage de FLAC est globalement sans perte. FLAC admet un paramètre pour le codage de Rice compris entre 0 et 30[19].
Gestion de multiples canaux
modifierUn flux FLAC est capable de gérer de 1 à 8 canaux distincts[19], ce qui permet de stocker des flux mono, stéréo ou plus complexes, par exemple 2.1 ou 5.1.
Pour les flux stéréo, FLAC offre la possibilité de décorréler les deux canaux en stockant une combinaison des canaux plutôt que les canaux bruts, ce qui peut améliorer la compression de certains flux[19]. Le choix du mode de combinaison des deux canaux est fait trame par trame[19].
Échantillonnage
modifierFLAC permet d'utiliser une large gamme de fréquences d’échantillonnage. La fréquence d'échantillonnage peut être stockée dans l'en-tête STREAMINFO, ce qui permet de spécifier n’importe quelle fréquence de 1 Hz à 1 048 570 Hz avec des incréments de 1 Hz[19]. Pour une utilisation en streaming, il faut nécessairement spécifier la fréquence d'échantillonnage dans les en-têtes de trame et la plage de fréquences utilisables est alors réduite[19]. Notamment, la fréquence maximale est alors de 655 360 Hz[19].
FLAC peut encoder les données avec une profondeur d’échantillonnage de 4 à 32 bits par échantillon. Lorsque cette valeur est précisée dans l'en-tête STREAMINFO, la totalité de la plage est utilisable. Pour une utilisation en streaming, la profondeur d'échantillonnage est spécifiée dans l'en-tête de trame et les possibilités sont alors réduites[19] à 8, 12, 16, 20 ou 24 bits.
Le FLAC ne supporte que des échantillons entiers, ce qui facilite l'implémentation sur des plateformes sans gestion native des nombres en virgule flottante[20].
Détection d'erreur
modifierFLAC incorpore différentes mesures permettant la détection d'erreur dans le flux audio.
L'en-tête STREAMINFO contient une empreinte MD5 des données PCM brutes permettant de vérifier au décodage l'intégrité des données, même si l'introduction d'une erreur n'a pas rendu le flux invalide[19].
Chaque trame audio utilise des CRC pour la détection d'erreur. Un CRC-8 permet la vérification de l'intégrité de l'en-tête de la trame, tandis qu'un CRC-16 est utilisé pour vérifier l'intégrité de la trame dans son ensemble, en-tête et données audio compris[19]. Ces CRC permettent des vérifications d'intégrité dans le cas d'une utilisation en streaming.
Métadonnées
modifierLe format FLAC permet de stocker des métadonnées de différents types en plus des métadonnées obligatoires contenues dans l'en-tête STREAMINFO.
Afin de permettre la navigation rapide au sein du fichier par les lecteurs, FLAC permet de stocker des indications de positions dans les en-têtes, qui permettent au décodeur de sauter rapidement à un emplacement du flux sans avoir besoin de le décoder dans son intégralité[19].
FLAC permet de stocker des métadonnées Vorbis[19], ce qui donne la possibilité de stocker les informations générales sur le morceau telles que le nom d'artiste, le nom de la piste ou le ReplayGain (en). Les tags ID3 ne sont pas supportés même si le décodeur de référence sait les reconnaître pour les ignorer[21].
FLAC permet de stocker directement une cuesheet au sein du fichier, ce qui permet éventuellement de reproduire un CD audio à l'identique à partir du fichier FLAC[19].
Il est également possible de stocker des images telles qu'une jaquette de CD dans les métadonnées. Le format utilisé par FLAC pour les images est proche du champ APIC de ID3v2[19].
Le format autorise des blocs de métadonnées arbitraires à l'usage d'applications tierces, dont le type est spécifié par un identifiant sur 32 bits[19]. Les identifiants peuvent être enregistrés auprès des développeurs de FLAC[22].
Sous-ensemble dédié au streaming
modifierFLAC définit un sous-ensemble du format pour garantir qu'un flux puisse être lu en streaming[19]. Ces options font qu'un décodeur peut commencer à décoder le flux au milieu de celui-ci[19]. Les contraintes rajoutées par ce sous-ensemble concernent notamment les fréquences et la profondeur d'échantillonnage, qui doivent pouvoir être stockées dans les trames et non pas uniquement dans l'en-tête[19].
L'implémentation de référence flac utilise ce sous-ensemble par défaut[19].
Intégration dans d'autres formats de conteneurs
modifierBien que le format FLAC définisse son propre format de conteneur, il est également possible d'intégrer un flux FLAC dans d'autres conteneurs, notamment Ogg[23], MP4[24] et Matroska[25].
Implémentation
modifierImplémentation de référence
modifierFLAC est mis en œuvre dans libFLAC, la bibliothèque de référence pour coder et décoder des flux FLAC. Le programme flac (utilisable en ligne de commande), est le programme de référence qui utilise l’API libFLAC. Une version C++ est aussi disponible sous le nom de libFLAC++.
L’implémentation de référence de FLAC peut être compilée sur de nombreuses plates-formes, incluant la plupart des systèmes d’exploitation Unix (tels que Linux, * BSD, Solaris et Mac OS X), ReactOS, Windows, HaikuOS.
L'API de libFLAC est organisée autour de flux, flux séparables et fichiers pour permettre d’améliorer l’abstraction du flux binaire de base de FLAC. La plupart des applications FLAC se limiteront à l’utilisation du codage/décodage en utilisant libFLAC à leur niveau.
Autres implémentations
modifierFLAC est également implémenté dans libavcodec de manière totalement indépendante de libFLAC[20].
Notes et références
modifier- « FLAC 1.4.3 Released With More Optimizations, Drops PowerPC-Specific Code », (consulté le )
- (en) FLAC Website : codec comparison
- (en) « Flac · GitLab », sur GitLab (consulté le ).
- (en) « Changelog », sur xiph.org (consulté le ).
- Marc, « Le MP3HD : la nouveauté MP3 de Thomson et Fraunhofer », sur www.homecinema-hifi.com, (consulté le )
- « Android Supported Media Formats », sur developer.android.com (consulté le )
- « Codecs pris en charge », sur msdn.microsoft.com (consulté le )
- « Janvier 2017 : support natif du FLAC par Firefox 51 et Chrome 46 », (consulté le )
- « iOS 11 intègre nativement le décodage des fichiers audio Flac », sur www.lesnumeriques.com (consulté le )
- http://math.univ-lyon1.fr/~caldero/Potiron.pdf TIPE
- « ADONIS/SIAF/CINES-GM - 0.4 », sur Archives de France (consulté le ) : « FLAC est très utilisé comme format d'archivage (compression sans perte) », p. 68.
- (en) FLAC Website.
- (en) Martijn van Beurden et Andrew Weaver, « Free Lossless Audio Codec » (Internet-Draft) (consulté le ), p. 11
- (en) Martijn van Beurden et Andrew Weaver, « Free Lossless Audio Codec » (Internet-Draft) (consulté le ), p. 14
- (en) Martijn van Beurden et Andrew Weaver, « Free Lossless Audio Codec » (Internet-Draft) (consulté le ), p. 13-14
- (en) Martijn van Beurden et Andrew Weaver, « Free Lossless Audio Codec » (Internet-Draft) (consulté le ), p. 12
- (en) Martijn van Beurden et Andrew Weaver, « Free Lossless Audio Codec » (Internet-Draft) (consulté le ), p. 6-7
- (en) Martijn van Beurden et Andrew Weaver, « Free Lossless Audio Codec » (Internet-Draft) (consulté le ), p. 39-42
- (en) « Format », sur xiph.org (consulté le ).
- (en) Martijn van Beurden et Andrew Weaver, « Free Lossless Audio Codec » (Internet-Draft) (consulté le ), p. 40
- (en) « FAQ », sur xiph.org (consulté le ).
- (en) « ID registry », sur xiph.org (consulté le ).
- « ogg mapping »
- « Encapsulation of FLAC in ISO Base Media File Format »
- « Matroska Media Container Codec Specifications »
Annexes
modifierArticles connexes
modifierLiens externes
modifier- (en) Site officiel
- (en) « Accueil du projet FLAC », sur SourceForge.net.