Support

Transcription

Support
Communications numériques
FIP 2e année (option informatique)
2014–2015
Syllabus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Bibliographie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2
4
Modulation et démodulation
Filtres de mise en forme d’impulsions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Travaux dirigés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Travaux pratiques. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5
6
8
Codage source
Travaux dirigés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Travaux pratiques. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Codage canal
Travaux dirigés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
Travaux pratiques. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Ce document est mis à disposition selon les termes de la licence
Creative Commons Attribution 4.0 International.
Version du 26 mars 2015.
1
Syllabus
Description du cours
Ce cours a pour objectif de présenter les principes de base d’un système de communications numériques.
Nous y aborderons les principaux blocs de la chaîne de communication, à savoir le codage source, le
codage canal et la modulation du signal numérique. Ce cours sera centré sur les concepts mathématiques
des différents blocs.
Pré-requis
Pour comprendre ce cours, il est nécessaire d’avoir de solides connaissances en mathématiques (calcul matriciel, algèbre de Boole, systèmes binaire et hexadécimal, code de Gray, probabilités) et en
traitement du signal (transformée de Fourier, analyse fréquentielle, numérisation, théorème de l’échantillonnage, démodulation cohérente, filtrage adapté).
Contenu du cours
• Introduction : définition, historique et intérêt du numérique, présentation rapide de la chaîne de
communication et de ses différents blocs ;
• Modulation : modulation en bande de base et sur porteuse, présentation de quelques codes en
ligne (NRZ, Manchester, AMI), principe des modulations sur porteuse (ASK, FSK, PSK, QAM),
constellation, réception dans le cas d’un canal bruité (réception en bande de base, filtre adapté),
réception dans le cas d’un canal à bande limitée (interférences entre symboles, critère de Nyquist,
diagramme de l’œil) ;
• Codage source : définition de l’information propre et de l’entropie d’une source, de la capacité
du canal, premier et deuxième théorèmes de Shannon, propriétés des codes sources (longueur
moyenne, réversibilité, etc.), codage de Huffman, illustration des compressions sans perte et avec
perte ;
• Codage canal : codes en blocs linéaire et codes convolutifs (avec quelques exemples), rendement
de codage, code systématique, distance de Hamming, matrices génératrice et de contrôle de
parité, pouvoirs de détection et de correction, représentation d’un code convolutif à l’aide des
diagrammes d’état, en arbre ou en treillis, évocation de l’algorithme de Viterbi.
Enseignant
Vincent Mazet (bureau C219, [email protected]). N’hésitez pas à communiquer numériquement
avec moi ! J’accepte également les communications analogiques.
Calendrier des séances
jeudi 26 février 2015
vendredi 27 février 2015
mercredi 18 mars 2015
lundi 23 mars 2015
mercredi 25 mars 2015
vendredi 27 mars 2015
vendredi 27 mars 2015
lundi 13 avril 2015
vendredi 17 avril 2015
10h30
10h30
10h30
8h30
16h00
10h30
14h00
8h30
10h30
Introduction
Modulation
Modulation
TP 1
Codage source
Codage canal
TP 2
TP 3
Examen
C416
C416
C413
A202
C410
C413
A402
A202
C429
2
Évaluation
L’évaluation est un contrôle continu : il n’y a donc pas de rattrapage ! La note finale est calculée à
partir de trois contrôles et un examen théorique :
• les contrôles durent dix minutes et ont lieu au début de chaque séance de TP. Ils sont individuels.
Ils contiennent des questions de cours, de TD et de TP. Aucun document ni appareil électronique
n’est autorisé. La moyenne des notes de contrôle a pour coefficient 0,5 ;
• L’examen théorique dure 1h45. Il est individuel. Il s’agit de questions de cours et d’exercices
similaires à ceux des TD. Seules la calculatrice personnelle et une feuille A4 recto-verso sont
autorisées. Il a pour coefficient 0,5.
Déroulement des TP
Les TP consistent principalement en des simulations sous Matlab. Les fonctions principales à utiliser
sont données dans les énoncés, reportez-vous à l’aide (help ou doc) pour plus d’informations. Certaines
de ces fonctions sont intégrées dans Matlab, d’autres (identifiées par un astérisque) sont à télécharger
à l’adresse http://miv.u-strasbg.fr/mazet/communications/. Certains programmes sont à compléter :
les emplacements correspondants sont indiqués dans le code. Par ailleurs, conservez vos programmes
d’un TP au suivant car ils seront souvent réutilisés.
Site internet
Les documents présentés en cours et l’examen de l’année précédente
sont disponibles à cette adresse :
http://miv.u-strasbg.fr/mazet/communications/
3
Bibliographie
Ouvrages
[1] F. Auger : Introduction à la théorie du signal et de l’information. Éditions Technip, 1999.
[2] J.R. Barry, E.A. Lee et D.G. Messerschmitt : Digital Communication. Springer, 3e édition,
2004.
[3] M. Joindot et A. Glavieux : Introduction aux communications numériques. Dunod, 2007.
[4] U. Madhow : Fundamentals of Digital Communication. Cambridge University Press, 2008.
[5] J.G. Proakis et M. Salehi : Digital Communications. McGraw-Hill, 5e édition, 2008.
[6] H. Sari : Transmission des signaux numériques. Techniques de l’ingénieur, 1995.
[7] B. Sklar : Digital Communications, Fundamentals and Applications. Prentice Hall PTR, 2e
édition, 2001.
[8] S.G. Wilson : Digital Modulation and Coding. Prentice-Hall, 1996.
Culture générale
[9] M. Beaugeois, D. Deltombe et D. Hennequin : Comment un téléphone portable téléphone-til ?, 2013. Unisciel/Université Lille 1.
http://www.universcience.tv/video-comment-un-telephone-portable-telephone-t-il-5820.html.
[10] Espace des sciences : La théorie de l’information, une science qui s’émancipe, 2008. Conférence
de Claude Berrou. http://www.youtube.com/watch?v=_N55Bde6k7Q.
[11] C. Douillard : la technique des constellations tournées, 2012. La minute du chercheur (Télécom
Bretagne). http://vimeo.com/21291291.
[12] J. Gómez : Codage et cryptographie, 2013. Images des Mathématiques, CNRS.
http://images.math.cnrs.fr/Codage-et-cryptographie.html.
[13] C. Laot : Les communications acoustiques sous-marines, 2014. La minute du chercheur (Télécom
Bretagne). http://vimeo.com/85234793.
[14] C.E. Shannon : A Mathematical Theory of Communication. The Bell System Technical Journal,
27(3):379–423, juillet 1948.
Autres sources
Les citations issues de Wikipédia sont publiées sous licence CC-BY-SA 3.0.
[15] Wikipedia : On-off keying, 2014. (Accédé le 12 février 2015).
[16] Wikipedia : List of ITU-T V-series recommendations, 2015. (Accédé le 12 février 2015).
Ce cours est fondé également sur les documents suivants :
[17] C. Collet : Communications numériques. Cours de Télécom Physique Strasbourg, 2013.
[18] F. Salzenstein : Communications numériques. Cours de Télécom Physique Strasbourg, 2013.
4
Filtres de mise en forme d’impulsions
Réponse impulsionnelle
− T2
Réponse fréquentielle (module)
−T
T
2
T
Filtre rectangulaire
−T
T
− T2
T
2
Filtre en sinus cardinal
α = 0,2
α = 0,8
−T
α = 0,2
α = 0,8
T
−T
T
Filtre en cosinus surélevé
α = 0,2
α = 0,8
−T
α = 0,2
α = 0,8
T
−T
Filtre en racine de cosinus surélevé
5
T
TD 1 : Modulation et démodulation
Exercice 1
L’article Wikipédia sur les recommandations de transfert de données sur le réseau téléphonique présente
la norme V.32 (utilisée par les modems dans les années 1980 et 1990) ainsi :
« V.32 is an ITU-T recommendation for a modem operating as full-duplex on a 4-wire
circuit, or half-duplex on a two-wire circuit, allowing bidirectional data transfer at either
9.6 kbit/s or 4.8 kbit/s at a symbol rate of 2,400 baud. » [16]
1. Quelle est la rapidité de modulation ?
2. Quel est le débit binaire ?
3. Quelle est la taille en bits des symboles émis ?
Exercice 2
Représentez les constellations des modulations suivantes :
— OOK (on-off keying) définie dans Wikipédia par :
« OOK denotes the simplest form of amplitude-shift keying (ASK) modulation that represents digital data as the presence or absence of a carrier wave. The presence of a carrier
for a specific duration represents a binary one, while its absence for the same duration
represents a binary zero. » [15]
— 4-ASK (modulation ASK 4-aire) ;
— 2-PSK (appelée aussi BPSK pour binary PSK) ;
— 8-QAM.
Exercice 3
1. Quelle est le type de modulation dont la constellation est représentée ci-dessous ?
2. En utilisant dans la mesure du possible un code de Gray, donnez les symboles associés à chaque
point de la constellation.
Exercice 4
La transmission d’un message binaire à un débit D = 600 Mbits/s est effectuée en utilisant huit signaux
{±s(t), ± 3s(t), ± 5s(t), ± 7s(t)} où s(t) est un signal de durée T .
1. Quelle est la rapidité de la modulation ?
2. Est-ce une modulation en bande de base ou sur porteuse ?
6
Exercice 5
Les quatre modulations linéaires ci-dessous représentent la séquence binaire 0 1 1 0 0 1 1 1 1 1 0 0.
1. Identifiez les modulations en bande de base et les modulations sur porteuse.
2. Déterminez les valeurs des symboles et les formes d’onde de ces modulations.
0
1
1
0
0
1
1
1
1
1
0
0
RZ
OOK
BPSK
NRZI
Exercice 6
On considère les deux formes d’onde ci-dessous :
(
1 si t ∈ [0, T [
et
h1 (t) =
0 sinon
(
1 si t ∈ [0, T /2[
h2 (t) =
0 sinon.
1. Représentez h1 (t) et h2 (t).
2. Quelles sont les réponses impulsionnelles des filtres de réception associés à ces formes d’onde ?
3. Calculez le signal en sortie des filtres de réception.
Exercice 7
Un message binaire est transmis avec une rapidité de modulation R = 300 bits/s.
1. Y a-t-il des interférences entre symboles si le canal a une fréquence de coupure de 100 Hz ?
2. Y a-t-il des interférences entre symboles si le canal a une fréquence de coupure de 200 Hz ?
Exercice 8
Déterminez, à partir des diagrammes de l’œil ci-dessous :
— le nombre de symboles du message ;
— le meilleur instant d’échantillonnage ;
— la meilleure valeur de seuil ;
— s’il y a des IES ;
— s’il y a du bruit.
2
2
2
1
1
0
0
−1
−1
7
1
5
0
3
−1
1
−2
−0.5
−0.25
0
(a)
0.25
0.5
−0.5
−0.25
0
0.25
−2
−0.5
0.5
(b)
−0.25
0
(c)
7
0.25
0.5
−2
−0.5
−0.25
0
(d)
0.25
0.5
TP 1 : Modulation et démodulation
Exercice 9 : Étude de quelques modulations numériques
L’objectif de cet exercice est d’implémenter et de comparer quelques modulations numériques :
— NRZ (non-return-to-zero) binaire ;
— AMI (bipolar alternate mark inversion) ;
— Manchester ;
— BPSK (binary phase-shift keying) ;
— 16-QAM (quadrature amplitude modulation).
1. Créez une séquence binaire aléatoire x2 de N bits (randmary*) et convertissez-la en séquence
hexadécimale x16 (bin2mary*) : vous disposez donc du même message disponible sous deux
représentations différentes. Affichez-les (disp).
2. Représentez les signaux analogiques associés au message pour les modulations étudiées. Utilisez
pour cela les fonctions modnrz*, modami*, modmanchester*, modbpsk* et modqam16*. Pour coder
une fonction porte, vous pouvez utiliser la syntaxe :
h = V * (t>t1) .* (t<t2);
3. L’analyse spectrale des modulations peut être effectuée à l’aide de la densité spectrale de puissance, qui est le carré du module de la transformée de Fourier. En choisissant un message suffisamment long (N grand), représentez la densité spectrale de puissance de chaque modulation
en échelle décimale (periodogram 1 ).
4. Identifiez les modulations en bande de base et les modulations sur porteuse.
5. Comparez les codes en termes de simplicité de mise en œuvre, de largeur de bande, de téléalimentation possible, de robustesse au bruit et de détection d’interruption de la transmission.
6. D’après vos conclusions, quel type de modulation est le plus adapté aux communications suivantes ?
(a) périphérique USB et ordinateur ;
(b) téléphone mobile et antenne relais ;
(c) sonde spatiale et Terre ;
(d) communication par laser à l’air libre entre deux bâtiments ;
(e) bus informatique ou de terrain (I2 C, SATA, ASI, Modbus, . . .) ;
(f) liaison Wi-Fi.
Exercice 10 : Transmission en bande de base sur un canal idéal
Le principe d’une transmission en bande de base est représenté figure 5.1 (page 9).
Un canal est dit idéal si sa largeur de bande est infinie (Inf) : sa réponse impulsionnelle est alors
g(t) = A δ(t − τ ) où A et τ sont l’atténuation et le retard du signal reçu (sans perdre en généralité, on
pourra prendre A = 1 et τ = 0).
La détection des formes d’onde h(t) dans le signal bruité y(t), est effectuée à l’aide d’un filtre adapté
de réponse impulsionnelle r(t) = h(−t).
1. Donnez l’expression du signal reçu y(t) en fonction du signal émis x(t) et des caractéristiques
du canal.
2. Simulez l’émission d’un message codé en NRZ binaire (randmary*, modnrz*, channel*). Observez le signal en entrée du détecteur pour différents niveaux de bruit.
1. Les deuxième et troisième arguments de la fonction peuvent être laissé libres ([]), le quatrième sera égal à 100/T
où T étant la durée d’un bit.
8
Message à émettre
Canal b(t)
Émetteur
mapper
α
h(t)
forme d’onde
x(t)
g(t)
y(t)
+
filtre passe-bas
r(t)
Récepteur
z(t)
filtre de réception
Tb
échantillonnage
S
seuillage
Message reçu
Figure 5.1 – Principe d’une transmission en bande de base.
3. Dans un premier temps, on ne tient pas compte du filtre de réception : r(t) = δ(t). Appliquez
un seuil (sampling*) sur le signal z(t) = y(t) pour retrouver, tous les T , les symboles αk émis.
4. Dans un deuxième temps, appliquez le filtre de détection (convolution avec conv 2 ), puis effectuez
le seuillage et l’échantillonnage comme dans la question précédente.
5. Calculez les taux d’erreurs obtenus avec et sans filtre de détection (la fonction hamdist* permet
de compter le nombre de bits différents entre deux séquences binaires). Comment varie la qualité
de la détection en fonction du niveau de bruit ?
Exercice 11 : Transmission en bande de base sur un canal à bande limitée
Cette fois, on suppose le canal sans bruit mais à bande limitée. On peut alors être en présence d’IES (interférences entre symboles) si les valeurs du signal z(t) aux instants T dépendent de plusieurs symboles
αk . La détection est alors perturbée même s’il n’y a pas de bruit.
1. Simulez l’émission d’un message codé en NRZ binaire. Observez le signal en entrée du détecteur
pour différentes fréquences de coupure du canal.
2. Le diagramme de l’œil correspond aux différentes traces d’un signal affichées sur une période.
Tracez le diagramme de l’œil (eyediag*) de y(t) : que se passe-t-il lorsque la bande passante du
canal varie ?
3. Quelle est la condition sur le signal temporel y(t) pour éviter les IES ? Comment se traduit-elle
sur la transformée de Fourier de y(t) ?
4. En déduire pourquoi une forme d’onde rectangulaire n’est pas adaptée lorsque la bande passante
du canal est trop faible.
5. Simulez la transmission du message avec une forme d’onde en racine de cosinus surélevé
(modnrzrrc*).
6. Concluez sur cette forme d’onde en observant le diagramme de l’œil pour plusieurs valeurs de α.
7. Simulez l’opération de détection en comparant les deux formes d’onde.
2. Précisez le troisième argument ’same’ pour conserver des signaux de même taille.
9
TD 2 : Codage source
Exercice 1
On considère l’alphabet défini ci-dessous :
Symbole
Probabilité
1.
2.
3.
4.
5.
A
B
C
D
E
F
G
0,35
0,30
0,20
0,10
0,04
0,005
0,005
Calculez l’auto-information pour chaque symbole.
Calculez l’entropie de la source
Déterminez le code de Huffman associé à la source.
Donnez la longueur moyenne du code obtenu.
Calculez l’efficacité du code.
Exercice 2
Mêmes questions que l’exercice 1 avec l’alphabet défini ci-dessous :
Symbole
Probabilité
A
B
C
D
E
F
G
H
0,36
0,14
0,13
0,12
0,10
0,09
0,04
0,02
Exercice 3
1. Le code binaire { 0 0 , 1 1 , 0 1 0 1 , 1 1 1 , 1 0 1 0 , 1 0 0 1 0 0 , 0 1 1 0 } est-il à décodage unique ?
2. Le code ternaire { 0 0 , 0 1 2 , 0 1 1 0 , 0 1 1 2 , 1 0 0 , 2 0 1 , 2 1 2 , 2 2 } est-il à décodage unique ?
Exercice 4
Une source utilise un alphabet de trois symboles {A,B,C} dont les probabilités respectives sont égales
à 0,5, 0,3 et 0,2.
1. Calculez l’entropie de la source.
2. Combien de bits sont nécessaires pour réaliser un code de longueur fixe à décodage unique ?
On décide alors de transmettre ces symboles en les regroupant par groupe de deux : cela revient à
considérer une nouvelle source Y .
3. Combien y a-t-il de symboles dans l’alphabet de la source Y ?
4. Calculez l’entropie de la source Y .
5. Combien de bits sont nécessaires pour réaliser un code de longueur fixe à décodage unique ?
6. Cette manière de procéder est-elle plus intéressante pour la transmission de la source X ?
Exercice 5
Une source émet 100 symboles par seconde parmi un alphabet de trois symboles {A,B,C} dont les
probabilités respectives sont égales à 0,8, 0,15 et 0,05. On souhaite savoir si les messages de cette source
peuvent être transmis sur un canal binaire pouvant transmettre sans erreur 100 bits par seconde.
1. Calculez l’entropie de la source.
2. Quel est le débit de la source ?
3. Quel est le débit du canal ?
4. Calculez le taux d’émission de la source.
5. Quelle est la capacité du canal ?
6. La transmission est-elle possible sans erreur ? Si oui, proposez un code de Huffman pour réaliser
la transmission.
10
TP 2 : Codage source
Exercice 6 : Application de la théorie de l’information à la transmission d’un texte
Un texte en français est transmis sur un canal binaire. Le texte contient K = 1000 caractères parmi
les vingt-six lettres de l’alphabet (majuscules non accentuées) et quatre signes de ponctuation (point,
virgule, espace, apostrophe).
1. Quelle est la taille de l’alphabet de la source ?
2. Quelle est la taille de l’alphabet du canal ?
3. Les symboles de la source peuvent-ils être considérés comme équiprobables ?
4. Calculez l’entropie de la source. Le fichier french.mat contient un vecteur codant les probabilités
d’occurrence des caractères, la fonction load permet de le charger et le logarithme à base 2 se
calcule avec la fonction log2. Est-il possible de compresser les données avant transmission ?
5. La transmission du texte se fait à une vitesse maximale de 10 bits/s avec un taux d’erreur nul.
À quel débit canal cela correspond-il ? En déduire la capacité du canal.
6. D’après le second théorème de Shannon (théorème du codage canal), quel est le taux d’émission
maximal pour pouvoir transmettre les données sans erreur ?
7. En déduire le débit de la source puis le temps minimal théorique nécessaire pour transmettre le
texte sans erreur (aucun codage source sans perte ne permet donc de diminuer cette durée).
8. Que devient ce temps dans le cas d’un canal 8-aire (transmission 8-QAM par exemple), dans le
cas d’un canal émettant 10 symboles par seconde ?
Pour réaliser la transmission, on propose de tester trois codes :
— le code ASCII classique qui code chaque symbole sur 8 bits ;
— un code de Huffman binaire de première extention ;
— un code de Huffman binaire de deuxième extention.
9. Calculez la longueur moyenne et l’efficacité de chaque code. La fonction huffman* permet de
créer le dictionnaire dict associé au codage de Huffman. Ce dictionnaire est stocké par Matlab
dans une variable de type cell array : la syntaxe dict{i} permet d’accéder à l’élément i du
dictionnaire dict. Pour calculer le dictionnaire associé au codage de Huffman de deuxième
extention, il faut calculer les probabilités des nouveaux symboles avec kron.
10. Déterminez alors la durée de transmission nécessaire pour chaque code.
Exercice 7 : Compression d’une image numérique
Nous allons étudier deux codages source sur des images à niveaux de gris (sur 8 bits), non compressées
et de taille 128 × 128 :
smiley.pgm,
schtroumpf.pgm,
lena.pgm,
boat.pgm.
1. Quelle est l’entropie de la source ?
2. En déduire la longueur moyenne minimale d’un code dans le cas d’une compression sans perte,
puis la taille d’une image en bits.
3. Chargez (imread) l’une des images précédentes puis convertissez-la en double (double) avant
de l’afficher (imshow 1 ).
1. N’oubliez pas le deuxième argument qui permet de régler l’échelle des intensités !
11
Codage sans perte Le codage par plage (RLE : run length encoding, utilisé par exemple pour le
format BMP) est une technique de compression sans perte. Le principe est de remplacer toute séquence
consécutive d’un même symbole par la taille de cette séquence suivi du symbole. Par exemple, le message
VVVVVMVV sera codé 5V1M2V.
4. Appliquez la compression RLE à l’image (rleenc*).
5. On définit le taux de compression par :
Taux de compression = 1 −
taille de l’image compressée
.
taille de l’image non compressée
Quel taux de compression obtenez-vous ?
Codage avec perte On peut autoriser la compression d’une image avec perte tout en conservant
une qualité visuelle correcte. Ainsi, le principe fondamental de la compression JPEG est de calculer la
transformée en cosinus discrète (DCT : discrete cosine transform) de l’image pour obtenir des coefficients qui seront quantifiés afin de réduire la taille de l’image. Ce sont ces coefficients qui sont stockés
ou transmis. La transformation en cosinus discrète inverse permet de décoder l’image compressée.
6. Appliquez la transformée en cosinus discrète (dct2) sur l’image. La transformée obtenue est
une image de même taille que l’originale, les basses fréquences se situent dans le coin en haut à
gauche.
7. Visuellement, ce sont les basses fréquences qui sont les plus importantes dans l’image : les hautes
fréquences peuvent donc être fortement quantifiés voire carrément annulées. Pour annuler ces
hautes fréquences, on peut procéder de la sorte :
C = length(I);
T = 0.5;
[X,Y] = meshgrid(1:C,1:C);
M = ( (X+Y) <= 2*C*T );
imshow(M,[]);
J = I.*M;
%
%
%
%
%
%
Taille de l’image DCT I
Taux de compression (entre 0 et 1)
Matrices des coordonnées
Définit un masque triangulaire
Affichage du masque
Masquage de l’image
Ces valeurs nulles n’étant pas transmises, quel taux de compression obtenez-vous ?
8. Appliquez la transformée inverse (idct2) sur l’image masquée des coefficient puis affichez l’image
compressée.
9. Discutez la qualité de l’image compressée. On distingue la qualité visuelle de l’image (critère
qualitatif et subjectif) et la qualité quantitative qui est généralement mesurée à l’aide du rapport
signal-à-bruit en crête (PSNR : peak signal-to-noise ratio). Le PSNR quantifie l’erreur pixel par
pixel entre l’image originale I et l’image compressée J (de taille M × N ) :
D2
PSNR = 10 log10
EQM
où D est la dynamique du signal (sur 8 bits, D = 28 − 1) et
EQM =
M N
1 XX
[I(m,n) − J(m,n)]2 .
MN
m=1 n=1
10. Concluez sur les deux méthodes de compression d’image étudiées.
12
TD 3 : Codage canal
Exercice 1
Calculez les distances de Hamming entre les mots suivants :
a = 0 0 0 0,
b = 1 1 1 1,
c = 1 1 0 1.
Exercice 2
Le principe du code à parité (3, 2) est de rajouter à chaque bloc du message un « bit de parité » de
sorte que le nombre de bit à 1 dans les mots du code soient pair.
1. Donnez le rendement de ce code.
2. Donnez l’ensemble des mots du code. Est-ce un code systématique ?
3. Donnez les matrices génératrice et de contrôle de parité.
4. Représentez géométriquement dans F32 les mots du code.
5. Calculez la distance minimale. En déduire les pouvoirs de détection et de correction du code.
Exercice 3
Les codes de Hamming sont définis dans [5, p. 420] ainsi :
« Hamming codes are one of the earliest codes studied in coding theory. Hamming codes
are linear block codes with parameters n = 2m − 1 and k = 2m − m − 1, for m ≥ 3.
Hamming codes are best described in terms of their parity check matrix H which is an
(n − k) × n = m × (2m − 1) matrix. The 2m − 1 columns of H consist of all possible binary
vectors of length m excluding the all-zero vector. »
Dans cet exercice, on considère le code de Hamming (7, 4).
1. Donnez le rendement de ce code.
2. Donnez les matrices génératrice et de contrôle de parité.
3. Donnez l’ensemble des mots du code.
4. Calculez la distance minimale. En déduire les pouvoirs de détection et de correction du code.
Exercice 4
On reçoit la séquence binaire 1 0 0 0 1 1 1 1 1 1 0 0 1 0 0 1 0 1 0 0 0 1 1 0 1 0 1 1 1 0 1 1 1 1 1. Trouvez le message
émis sachant qu’un code de Hamming (7,4) a été utilisé.
Exercice 5
On suppose un canal binaire où les erreurs de transmissions se traduisent par une suppression de
certains bits (et non une modification de leur état). Le récepteur sait quels sont les bits manquants
mais ne connaît pas leurs valeurs. Expliquez comment un code de Hamming (7,4) peut trouver les bits
manquants lorsque un ou deux bits consécutifs ont été supprimés.
Exercice 6
Les mots du message à coder sont de longueur k = 3 bits. On utilise un code à parité qui assure que
le nombre de bits à 1 dans chaque mot du code est pair.
1. Donnez la taille n d’un mot du code.
2. Donnez la matrice génératrice.
3. Calculez la distance minimale du code.
13
On remplace maintenant le code par un code à parité croisée, c’est-à-dire qu’en arrangeant les mots du
message sous forme d’un tableau k × k, des bits de parité sont calculés sur chaque ligne et sur chaque
colonne. L’exemple ci-dessous donne les bits de parité pour le message 1 1 1 0 1 0 0 1 1 :
message
1
1
1
1
0
1
0
1
0
1
1
0
1
1
0
parité ligne
parité colonne
Répondez aux questions précédentes en considérant le code à parité croisée. Concluez sur l’intérêt d’un
code de parité croisé par rapport à un code de parité simple.
Exercice 7
On considère le code convolutif ci-dessous :
u1
m
+
u2
1. Déterminez k, n, K. En déduire le rendement R.
2. Est-ce un code systématique ?
3. Donnez les polynômes générateurs.
4. Calculez la sortie du codeur lorsque l’entrée est 0 1 1 1 0 1 1 0.
5. Représentez les diagrammes d’état, en arbre et en treillis.
Exercice 8
Même questions que dans l’exercice 7 pour le code convolutif ci-dessous :
+
u1
m
+
u2
+
u3
Exercice 9
Le meilleur code en treillis de rendement 1/2 et de longueur de contrainte 4 a comme polynômes
générateurs 158 et 178 . Représentez son schéma bloc.
Exercice 10
À partir du treillis du codeur de l’exercice 7, décodez la séquence reçue 1 1 0 0 1 0 1 0 à l’aide de l’algorithme de Viterbi.
14
TP 3 : Codage canal
Exercice 11 : codes à parité
On considère dans cet exercice le code à parité (4, 5).
1. Déterminez k, n, K. En déduire le rendement R.
2. Déterminez la matrice génératrice G et la matrice de contrôle de parité H. En Matlab, une
matrice identité se crée avec l’instruction eye.
3. Quelle est la distance minimale du code à parité ? Pour cela, il peut être utile d’écrire tous les
mots du code. La fonction dec2binary* permet d’obtenir la valeur binaire d’un nombre décimal.
4. Complétez les fonctions encparity* et decparity* qui effectuent respectivement le codage et
le décodage. Utilisez le modulo 2 pour effectuer une multiplication dans le corps de Galois F2
(mod). Testez le bon fonctionnement de vos fonctions sur un exemple à partir d’une séquence
binaire aléatoire (randmary*).
Exercice 12 : code de Hamming (7, 4)
Le code de Hamming (7,4) a été défini exercice 3.
1. Répondez aux questions de l’exercice 3.
2. Complétez les fonctions enchamming* et dechamming* qui effectuent respectivement le codage
et le décodage. Testez le bon fonctionnement de vos fonctions sur un exemple.
Exercice 13 : codes convolutif
On considère le code convolutif dont le schéma-bloc est représenté ci-dessous :
u1
+
m
+
u2
1. Déterminez k, n, K. En déduire le rendement R.
2. Complétez la fonction encconv* qui effectue le codage. Le décodage sera effectué avec l’algorithme de Viterbi (decconv*). Testez le bon fonctionnement de votre code sur un exemple.
Exercice 14 : performances des codes
Les performances de trois codes précédents seront mesurées en considérant un canal binaire symétrique
de probabilité d’erreur α. La transmission est dite « simplex » c’est-à-dire qu’elle s’effectue dans un
seul sens (il n’est pas possible pour le récepteur de demander à l’émetteur de transmettre une nouvelle
fois le message si une erreur a été détectée sans avoir pu être corrigée).
1. Complétez la fonction bsc* qui simule un canal binaire symétrique.
2. Simulez la transmission via ce canal d’une séquence binaire aléatoire sans codage canal et avec
les codes des exercices 11, 12 et 13.
3. Tracez la probabilité d’erreur par élément du message en fonction de la probabilité d’erreur sur
le canal de transmission (faites plusieurs simulations avec des messages suffisamment longs).
15