Code de Hadamard

Si ce bandeau n'est plus pertinent, retirez-le. Cliquez ici pour en savoir plus.
Si ce bandeau n'est plus pertinent, retirez-le. Cliquez ici pour en savoir plus.

Cet article ne cite pas suffisamment ses sources ().

Si vous disposez d'ouvrages ou d'articles de référence ou si vous connaissez des sites web de qualité traitant du thème abordé ici, merci de compléter l'article en donnant les références utiles à sa vérifiabilité et en les liant à la section « Notes et références ».

En pratique : Quelles sources sont attendues ? Comment ajouter mes sources ?

Matrice du code de Hadamard augmenté [32, 6, 16] pour le code de Reed-Muller (1, 5) de la sonde spatiale Mariner 9 de la NASA

Le code de Hadamard est un code correcteur, nommé d'après Jacques Hadamard, à taux de transfert extrêmement faible mais à grande distance, couramment utilisé pour la détection et la correction d'erreurs lors de la transmission de messages sur des canaux très bruyants ou peu fiables.

Dans la notation standard de la théorie du codage pour les codes en bloc, le code de Hadamard est un code [ 2 k , k , 2 k 1 ] 2 {\displaystyle [2^{k},k,2^{k-1}]_{2}} , c'est-à-dire un code linéaire sur un alphabet binaire, a une longueur de bloc de 2 k {\displaystyle 2^{k}} , la longueur (ou la dimension) du message k {\displaystyle k} , et une distance minimale 2 k / 2 {\displaystyle 2^{k}/2} . Bien que la longueur du bloc soit très grande par rapport à la longueur du message, les erreurs peuvent être corrigées même dans des conditions extrêmement bruyantes.

Ce code étant localement déchiffrable, c'est-à-dire qu'il est possible de récupérer des parties du message original avec une forte probabilité, tout en ne disposant que d'une petite fraction du message reçu, il possède de nombreuses applications dans la théorie de la complexité des calculs et en particulier dans la conception de preuves vérifiables par probabilité. De plus, comme la distance relative du code de Hadamard est de 1/2, il est en théorie possible de récupérer des messages avec au maximum 1/4 de bits erronés. Cependant, en utilisant le décodage par liste, il est possible de calculer une courte liste de messages candidats possibles tant que moins de 1 2 ϵ {\displaystyle {\tfrac {1}{2}}-\epsilon } des bits du message reçu ont été corrompus.

Grâce à ses propriétés mathématiques uniques, les codes Hadamard sont intensément étudiés dans des domaines tels que la théorie du codage, les mathématiques et l'informatique théorique, outre ses applications dans de nombreuses technologies et industries.

Histoire

Bien que Jacques Hadamard n'ait pas inventé le code lui-même, il a défini la matrice de Hadamard vers 1893, bien avant que le premier code correcteur, le code de Hamming, ne soit développé dans les années 1940.

Le code de Hadamard est basé sur des matrices de Hadamard, et bien qu'il y ait beaucoup de matrices de Hadamard différentes qui pourraient être utilisées, normalement seulement la construction de Sylvester des matrices de Hadamard est utilisée pour obtenir les mots de code du code de Hadamard.

James Joseph Sylvester a développé sa construction, similaire aux matrices d'Hadamard, en 1867, ce qui est de fait antérieur aux travaux d'Hadamard sur les matrices d'Hadamard. Le nom de code de Hadamard est donc contesté et parfois le code est appelé code Walsh, en l'honneur du mathématicien américain Joseph Leonard Walsh.

Constructions

Normalement, les codes Hadamard sont basés sur la construction de matrices Hadamard par Sylvester, mais le terme " code de Hadamard " est également utilisé pour désigner les codes construits à partir de matrices Hadamard arbitraires, qui ne sont pas nécessairement de type Sylvester. Le lien entre les matrices Hadamard et la théorie de la construction du code a été trouvé pour la première fois par R. C. Bose et S. S. Shrikhande en 1959[1].

Si n {\displaystyle n} est la taille de la matrice Hadamard, le code a les paramètres ( n , l o g ( n ) , n / 2 ) 2 {\displaystyle (n,log(n),n/2)_{2}} , ce qui signifie que c'est un code binaire pas nécessairement linéaire avec des mots de code l o g ( n ) {\displaystyle log(n)} de longueur de bloc n {\displaystyle n} et de distance minimale n / 2 {\displaystyle n/2} .

Les constructions et schémas de décodage décrits ci-dessous s'appliquent pour le n {\displaystyle n} général, mais la propriété de linéarité et l'identification avec les codes Reed-Muller exigent que n {\displaystyle n} soit une puissance de 2 et que la matrice Hadamard soit équivalente à la matrice construite par la méthode

Construction utilisant des produits scalaires

Lorsqu'il reçoit un message binaire x { 0 , 1 } k {\displaystyle x\in \{0,1\}^{k}} de longueur k {\displaystyle k} , le code de Hadamard encode le message en un mot de code C Had ( x ) {\displaystyle C_{\text{Had}}(x)} à l'aide d'une fonction d'encodage Had : { 0 , 1 } k { 0 , 1 } 2 k . {\displaystyle {\text{Had}}:\{0,1\}^{k}\to \{0,1\}^{2^{k}}.} Cette fonction utilise le produit scalaire x , y {\displaystyle \langle x,y\rangle } de deux vecteurs x , y { 0 , 1 } k {\displaystyle x,y\in \{0,1\}^{k}} , qui est défini comme suit:

x , y = i = 1 k x i y i   mod   2 . {\displaystyle \langle x,y\rangle =\sum _{i=1}^{k}x_{i}y_{i}\ {\bmod {\ }}2\,.}

Ensuite, l'encodage Hadamard de x {\displaystyle x} est défini comme la séquence de produits scalaires tous avec x {\displaystyle x}  :

C Had ( x ) = ( x , y ) y { 0 , 1 } k {\displaystyle C_{\text{Had}}(x)={\Big (}\langle x,y\rangle {\Big )}_{y\in \{0,1\}^{k}}}

Construction utilisant une matrice de générateur

Le code de Hadamard est un code linéaire, et tous les codes linéaires peuvent être générés par une matrice de générateur G {\displaystyle G} . Cette matrice est telle que C Had ( x ) = x G {\displaystyle C_{\text{Had}}(x)=x\cdot G} est valable pour tous les x { 0 , 1 } k {\displaystyle x\in \{0,1\}^{k}} , où le message x {\displaystyle x} est vu comme un vecteur ligne et le produit vecteur-matrice est compris dans le espace vectoriel sur le champ fini. F 2 {\displaystyle \mathbb {F} _{2}} . En particulier, une manière équivalente d'écrire la définition interne du produit pour le code de Hadamard consiste à utiliser la matrice du générateur dont les colonnes sont constituées de chaînes de caractères " toutes " y {\displaystyle y} de longueur k {\displaystyle k} , c'est-à-dire,

G = ( y 1 y 2 y 2 k ) {\displaystyle G={\begin{pmatrix}\uparrow &\uparrow &&\uparrow \\y_{1}&y_{2}&\dots &y_{2^{k}}\\\downarrow &\downarrow &&\downarrow \end{pmatrix}}\,}

y i { 0 , 1 } k {\displaystyle y_{i}\in \{0,1\}^{k}} est le i {\displaystyle i} -ième vecteur binaire dans ordre lexicographique. Par exemple, la matrice génératrice pour le code de Hadamard de dimension k = 3 {\displaystyle k=3} est:

G = [ 0 0 0 0 1 1 1 1 0 0 1 1 0 0 1 1 0 1 0 1 0 1 0 1 ] {\displaystyle G={\begin{bmatrix}0&0&0&0&1&1&1&1\\0&0&1&1&0&0&1&1\\0&1&0&1&0&1&0&1\end{bmatrix}}}

La matrice G {\displaystyle G} est une matrice ( k × 2 k ) {\displaystyle (k\times 2^{k})} et donne lieu à l'opérateur linéaire Had : { 0 , 1 } k { 0 , 1 } 2 k {\displaystyle {\text{Had}}:\{0,1\}^{k}\to \{0,1\}^{2^{k}}} .

Une autre façon de définir le code de Hadamard est en termes de matrice de contrôle de parité : la matrice de contrôle de parité du code de Hadamard est égale à la matrice de génération du code de Hamming.

Construction utilisant des matrices Hadamard générales

Les codes Hadamard généralisés sont obtenus à partir d'un n × n {\displaystyle {\text{n}}\times {\text{n}}} matrice de Hadamard H {\displaystyle {\text{H}}} . En particulier, les mots de code 2 n {\displaystyle 2n} du code sont les lignes de H {\displaystyle {\text{H}}} et les lignes de -H {\displaystyle {\text{-H}}} . Pour obtenir un code sur l'alphabet { 0 , 1 } {\displaystyle \{0,1\}} , le mapping -1 1 {\displaystyle {\text{-1}}\rightarrow 1} , 1 0 {\displaystyle 1\rightarrow 0} , ou, de manière équivalente, x ( 1 x ) / 2 {\displaystyle x\rightarrow (1-x)/2} , est appliqué aux éléments de la matrice. Le fait que la distance minimale du code soit n / 2 {\displaystyle n/2} découle de la propriété de définition des matrices de Hadamard, à savoir que leurs lignes sont mutuellement orthogonales. Cela implique que deux lignes distinctes d'une matrice Hadamard diffèrent exactement par leurs positions n / 2 {\displaystyle n/2} , et, comme la négation d'une ligne n'affecte pas l'orthogonalité, que toute ligne de H {\displaystyle {\text{H}}} diffère de toute ligne de -H {\displaystyle {\text{-H}}} par ses positions n / 2 {\displaystyle n/2} également, sauf lorsque les lignes correspondent, auquel cas elles diffèrent par leurs positions n {\displaystyle n} .

Distance

La distance d'un code est le minimum distance de Hamming entre deux mots de code distincts, c'est-à-dire le nombre minimum de positions auxquelles deux mots de code distincts diffèrent. Comme le code de Hadamard est un code linéaire, la distance est égale au minimum poids de Hamming entre tous ses mots-codes non nuls.

Dans les lignes qui suivent, nous allons demonstrer que C Had, r {\displaystyle C_{\text{Had, r}}} a un poids égal à 2 r 1 {\displaystyle 2^{r-1}} . Considérons un message x 0 {\displaystyle x\neq 0} . Soit sa ième entrée x i = 1. x {\displaystyle x_{i}=1.x} est codé comme c = ( x 1 , x 2 , . . . , x r ) ( H r 0 , H r 1 , . . . . H r 2 r 1 ) {\displaystyle c=(x_{1},x_{2},...,x_{r})(H_{r}^{0},H_{r}^{1},....H_{r}^{2^{r}-1})} , où H r j {\displaystyle H_{r}^{j}} est la représentation binaire de 0 j 2 r 1 {\displaystyle 0\leq j\leq 2^{r}-1} , c'est-à-dire qu'il contient tous les vecteurs de { 0 , 1 } 2 {\displaystyle \{0,1\}^{2}} . Notez également que le j {\displaystyle j} -ième bit des mots de code c est x , H r j {\displaystyle \langle x,H_{r}^{j}\rangle } . Regrouper toutes les colonnes de la matrice du générateur en paires ( u , v ) {\displaystyle (u,v)} de sorte que v = u + e i {\displaystyle v=u+e_{i}} (c'est-à-dire que v et u sont les mêmes sauf en position ième). Notez que cela partitionne toutes les colonnes en paires disjointes 2 r 1 {\displaystyle 2^{r-1}} . Ensuite,

x , v = x , u + e i = x , u + x , e i = x , u + x i = x , u + 1 {\displaystyle \langle x,v\rangle =\langle x,u+e_{i}\rangle =\langle x,u\rangle +\langle x,e_{i}\rangle =\langle x,u\rangle +x_{i}=\langle x,u\rangle +1}

Ainsi, nous avons exactement celui de x , v {\displaystyle \langle x,v\rangle } et x , u {\displaystyle \langle x,u\rangle } est 1. Comme le choix de la paire ( u , v ) {\displaystyle (u,v)} était arbitraire, nous avons prouvé que pour tout mot de code c non nul tel que c C Had , w t ( c ) = 2 r 1 {\displaystyle c\in C_{\text{Had}},wt(c)=2^{r-1}} .

Localement déchiffrable

Un code localement déchiffrable est un code qui permet de récupérer un seul bit du message original avec une forte probabilité en ne regardant qu'une petite partie du mot reçu. Plus formellement, le problème de déchiffrement local peut être décrit comme :

Déchiffrement local : Soit C { 0 , 1 } n {\displaystyle C\subseteq \{0,1\}^{n}} un code et la carte de codage soit E : 0 , 1 k C {\displaystyle E:{0,1}^{k}\rightarrow C} . Étant donné r 0 , 1 n {\displaystyle r\in {0,1}^{n}} et i [ k ] {\displaystyle i\in [k]} tel que ( r , E ( m ) ) < ρ {\displaystyle \triangle (r,E(m))<\rho } pour quelques m 0 , 1 k {\displaystyle m\in {0,1}^{k}} . Trouve m i {\displaystyle m_{i}} .

Une question naturelle à se poser serait si on doit le faire tourner pendant le temps Ω ( k ) {\displaystyle \Omega (k)}  ? Et la réponse à cette question est non. Pour pouvoir répondre à cette question, nous allons mesurer la complexité d'un algorithme de déchiffrement basé sur le nombre d'emplacements interrogés par l'algorithme à partir du mot entré/reçu.

Selon le modèle d'accès aléatoire, c'est-à-dire que l'accès à un emplacement donné dans un mot reçu est compté comme une opération. Nous définirons une classe de codes décodables basée sur le nombre d'emplacements auxquels un algorithme doit accéder afin de récupérer un emplacement donné d'un message et une fraction des erreurs qu'il peut tolérer.

Définition (( t , ϵ {\displaystyle t,\epsilon } )-code déchiffrement localement). C n {\displaystyle C\subset \textstyle \sum ^{n}} , avec une carte de codage E : k n {\displaystyle E:\textstyle \sum ^{k}\rightarrow \textstyle \sum ^{n}} , est (t, ϵ {\displaystyle \epsilon } )-code localement déchiffrable s'il existe un algorithme A {\displaystyle A} tel que pour tous les messages x k {\displaystyle x\in \textstyle \sum ^{k}} , r n {\displaystyle r\in \textstyle \sum ^{n}} et i [ k ] {\displaystyle i\in [k]} tel que ( r , E ( x ) ) ϵ {\displaystyle \triangle (r,E(x))\leq -\epsilon } ,

P r [ A ( i , r ) x i ] 0.1 {\displaystyle Pr[A(i,r)\neq x_{i}]\leq 0.1}

et A {\displaystyle A} accède au maximum aux coordonnées de t {\displaystyle t} à partir de r {\displaystyle r} .

Algorithme

  1. Choisissez u F 2 k {\displaystyle u\in \mathbb {F} _{2}^{k}} uniformément au hasard
  2. Requête y {\displaystyle y} à la position marquée par u {\displaystyle u} et u + e i {\displaystyle u+e_{i}}
  3. Sortie y , u + y , u + e i {\displaystyle \langle y,u\rangle +\langle y,u+e_{i}\rangle }

Analyse

Une fois reçue la sortie de l'algorithme ci-dessus, nous pouvons obtenir :

= y , u + y , u + e i {\displaystyle =\langle y,u\rangle +\langle y,u+e_{i}\rangle } mod 2 {\displaystyle 2}

= y , u + y , u + y , e i {\displaystyle =\langle y,u\rangle +\langle y,u\rangle +\langle y,e_{i}\rangle } mod 2 {\displaystyle 2}

= y , e i {\displaystyle =\langle y,e_{i}\rangle } mod 2 {\displaystyle 2}

= y i {\displaystyle =y_{i}}

S'il n'y a pas d'erreur aux positions u {\displaystyle u} et u + e i {\displaystyle u+e_{i}} , alors il est possible de récupérer le i e m e {\displaystyle ieme} bit de x {\displaystyle x} . Puisque Δ ( C H a d ( x ) , y ) 2 r 10 {\displaystyle \Delta (C_{Had}(x),y)\leq {\tfrac {2^{r}}{10}}} , la probabilité d'erreur à une seule position est 1 10 {\displaystyle \leq {\tfrac {1}{10}}} . Par l'Inégalité de Boole, la probabilité d'obtenir une erreur à u {\displaystyle u} et u + e i {\displaystyle u+e_{i}} n'est pas supérieure à la somme des probabilités des deux événements, dans ce cas particulier étant 1 5 {\displaystyle {\tfrac {1}{5}}} . Au total, la probabilité de déterminer le i e m e {\displaystyle ieme} bit par x i {\displaystyle x_{i}} du message x {\displaystyle x} est supérieure au complément d'obtention d'une erreur, c'est-à-dire 1 1 5 = 4 5 {\displaystyle \geq 1-{\tfrac {1}{5}}={\tfrac {4}{5}}} .

Optimalité

Pour k 7 {\displaystyle k\leq 7} les codes Hadamard linéaires se sont avérés optimaux dans le sens de la distance minimale[2].

Applications réelles

Le 14 novembre 1971, le vaisseau spatial Mariner 9 est entré en orbite autour de Mars et a commencé à prendre des photos. Un code de Hadamard amélioré a été utilisé pendant la mission pour corriger les erreurs de transmission des images. Les mots de données utilisés au cours de cette mission étaient de 6 bits, ce qui représentait 64 valeurs de niveaux de gris. En raison des limites de la qualité de l'alignement de l'émetteur à ce moment-là (à cause des problèmes de la boucle de poursuite du Doppler), la longueur maximale des données utiles était d'environ 30 bits. Au lieu d'utiliser un code de répétition, une code de Hadamard [ 32 , 6 , 16 ] {\displaystyle [32,6,16]} a été utilisé.

Notes et références

  1. Richard Hamming error-detecting and error-correcting codes Bell System Technical Journal 29(2):147-160, 1950
  2. Iliya Bouyukliev et David B. Jaffe, « Optimal binary linear codes of dimension at most seven », Discrete Mathematics, vol. 226, no 1,‎ , p. 51–70 (ISSN 0012-365X, DOI 10.1016/S0012-365X(00)00125-4, lire en ligne, consulté le )

Liens externes

  • Essential Coding Theory par Guruswami V., Rudra A. et Sudan M., 2019
  • Algorithmic Introduction to Coding Theory (Lecture 14) par Sudan M., 2002
  • List decoding of binary codes par Guruswami V., 2009
  • Folded RS Codes, Local Decoding par Kopparty S., 2016

Bibliographie

  • (en) Amadei M., Manzoli U. et Merani, M.L. On the assignment of Walsh and quasi-orthogonal codes in a multicarrier DS-CDMA system with multiple classes of users, IEEE, 2002, (ISBN 0-7803-7632-3)
  • (en) Arora S. et Barak B., Computational Complexity: A Modern Approach, Cambridge University Press, 2009, (ISBN 9780521424264)
  • icône décorative Portail des télécommunications
  • icône décorative Portail de l'informatique théorique