TD1 Inf1021 2021-2022
TD1 Inf1021 2021-2022
TD1 Inf1021 2021-2022
Département d’Informatique
1.3.1 (89)10 + (93)10 ; 1.3.2 (89)10 − (28)10 ; 1.3.3 (13)10 × (5)10 ; 1.3.4 (13)10 /(2)10
2.1 Déterminez sur le même nombre de bits utilisés, la représentation en compléments logiques et arithmé-
tiques des codes binaires suivants :
Complément restreint (à 1) Complément vrai (à 2) Nombre en base 10
A = 1100 1001
B = 0011 1111
C = 0111 0011 0001 0000
D = 0111 1111 1111 1111
2.2 Effectuer les opérations suivantes d’abord en complément à 1 puis en complément vrai en précisant si la
réponse est correcte ou pas (sur 8 bits pour les deux premières et 16 bits pour les deux dernières) :
2.3 Etant donné n bits, quelle est la configuration du plus petit nombre représentable
2.4 Effectuer les opérations suivantes comme indiqué puis commenter les résultats obtenus :
2.4.1 En complément à 1 sur 10 bits : -500-11 2.4.2 En complément à 2 sur 9 bits : 240+18
4.1 On considère une représentation binaire normalisée, en virgule flottante sur 8 bits, d’un nombre réel.
Dans cette représentation, le bit de poids fort est réservé au signe (0 quand il est positif, 1 quand il est
négatif), les 3 bits suivants représentent l’exposant codé en notation biaisée (Biais = 2n−1 , où n est le
nombre de bits réservés à l’exposant), les 4 derniers bits sont consacrés à la mantisse. On suppose que la
technique du bit caché n’est pas utilisée. Dans cette représentation, donner :
4.1.1 La valeur décimale du flottant x ayant pour représentation 0 010 1111
4.1.2 La représentation et la valeur décimale du flottant suivant immédiatement x
4.1.3 Les valeurs décimales du plus petit flottant et du plus petit flottant strictement positif
Dans toute la suite, on considère la norme IEEE 754 simple précision
4.2 Effectuer les opérations suivantes pour chaque op de l’ensemble {+, −}
4.3 Soient les nombres N1 = (C0400000)16 et N2 = 0.00625. A quelle valeur décimale correspondent-ils si le
motif utilisé pour leur représentation est la virgule flottante simple précision ?
4.4 Quelle est la précision de cette représentation ?
4.5 Donner la représentation du plus petit réel strictement positif et du plus petit nombre représentable sur
cette machine.
4.6 Donner la représentation du plus petit réel >1 et en déduire la plus petite valeur qui puisse être addi-
tionné à 1 avec exactitude.
4.7 Soit le motif binaire suivant pour l’exposant : 01111111. quelle est la valeur représentée si on a seulement
des 0 pour la mantisse ?
4.8 Soit le motif binaire suivant pour l’exposant : 10000000. quelle est la valeur représentée si on a seulement
des 0 pour la mantisse ?
4.9 Soit le motif binaire suivant pour l’exposant : 10000000. quelle est la valeur représentée si on a un 1 pour
le poids fort de la mantisse et des 0 pour le reste ?
E XERCICE 5 [Divers]
5.1 Représenter les nombres suivants en virgule flottante (Mantisse Normalisée, Exposant en Complément
à 2) dans le format : S Exposant Mantisse sachant qu’om utilise pour cela 1 bit de signe, 5 bits pour
l’exposant et 10 bits pour la mantisse.
5.2 On dispose d’une machine où les valeurs numériques réelles sont représentées sur 16 bits (numérotés de
0 à 15) avec :
— une quantité fractionnaire sur 10 bits (0 à 9) correspondant à la mantisse M normalisée (0.5 ≤ M <1) ;
— un exposant en complément à 2, codé sur 5 bits (10 à 14) ;
6.1 Décoder la séquence de caractères ASCII sur 8 bits suivante : 01001001 00100000 01001100 01001111
01010110 01000101 00100000 01011001 01001111 01010101
6.2 Comment transformer le code ASCII sur 8 bits d’une minuscule en son équivalent majuscule ?
6.3 Quelle opération faut-il faire sur l’octet de codage pour passer d’une lettre en minuscule à la même lettre
en majuscule ?
6.4 Dans le tableau de la figure 1, le a a pour code 61 : pourquoi ?
6.5 On donne le texte suivant en hexadécimal : 4d 50 53 69 20 21 21. Que signifie-t-il ?
6.6 e code Unicode du symbole euro est le 8364. Donner son codage UTF8
6.7 On a le texte suivant en hexadécimal sous la norme ISO-8859-1 : 6c 61 20 70 72 e9 70 61 20 63 27 65 7374
20 65 78 74 72 61. Que signifie-t-il ?
6.8 On reprend la phrase de la question [6.6]. Sachant que le numéro Unicode du é est le 233, donner sa
représentation hexadécimale UTF8. Donner le texte complet sous forme hexadécimale.
6.9 Décoder alors ce texte en supposant qu’il est écrit sous la norme ISO-8859-1. Que remarque-t-on ?
6.10 est codée en UTF8 par ce b5. Quel est son code Unicode ? Comment se décode-t-il en ISO-8859-1 ?
7.1 Un registre de 32 bits contient un nombre BCD. De gauche à droite, 1e bit contient le signe les bits 1 à 7
contiennent l’exposant représenté sous forme biaisée, le 8e bit représente le signe de la mantisse (1 pour
le – et 0 pour le +), les 9 à 32 représentent la mantisse, normalisée.
Dans ce contexte, donner la représentation, puis la valeur décimale du
7.1.1 plus grand nombre positif, 7.1.3 plus grand nombre négatif,
7.1.2 plus petit nombre positif, 7.1.4 plus petit nombre négatif.
7.2 Un registre de 38 bits contient un nombre représenté en excédant-3 comme suit de gauche à droite :
les bits 1 à 9 contiennent l’exposant représenté en complément à 2 ; le 10e bit représente le signe de la
mantisse (0 pour le positif, 1 pour le négatif), les bits 11 à 38 représentent la mantisse (normalisée).
7.2.1 Donner la représentation du plus petit nombre positif et du plus grand nombre négatif et exprimer
chacun en décimal
7.2.2 Donner la représentation des nombres décimaux suivants : 215.75, -0.025
7.3 Soit une représentation flottante normalisée en base β, mantisse de t chiffres et exposant e tel que −N ≤
e ≤ M , où M et N sont des entiers donnés.
Exprimer en fonction de M, N, β et t le plus petit et le plus grand nombre sans signe représentable.
E XERCICE 8 [Précision ?]
La fonction cosinus peut s’exprimer sous forme de série de Taylor comme suit :
cos(X) = ∞ k X 2k X2 X4 X6 k X 2k
P P∞
i=0 (−1) (2k)! = 1 − 2! + 4! − 6! + . . . = i=0 ak , où ak = (−1) (2k)!
8.1 montrer que l’on peut évaluer cette série sans faire usage du factoriel. (indications : établir une relation
entre ak+1 et ak qui ne fait intervenir que x et k)
8.2 Pour un x donné on voudrait calculer une approximation de cos(x) avec une précision , par la série
tronquée Z = M
P
k=0 ak où M est choisi tel |aM +1 | ≤ que on démontre que pour Pune série convergente
dont les termes alternent en signe, l’erreur de l’approximation vérifie |cos(X) − M k=0 ak | ≤ dès que
|aM +1 | ≤ . Donner un algorithme itératif pour le calcul de l’approximation pour un x et donnés.
E XERCICE 9 [Codage]
9.1 Vous voulez envoyer le mot 1011. Quels bits de contrôle devez-vous lui adjoindre et quelle séquence
transmettrez-vous alors si vous vous servez du code de Hamming 7-4 ?
9.2 Y a-t-il une erreur dans le mot suivant (Hamming 7-4) : 1101101 ?
9.3 Soit un mot de Hamming 15-11 suivant : 101101111011011
9.3.1 Quels sont les bits de contrôle de parité ? 9.3.3 Quel est le message reçu ?
9.3.2 Quelles positions contrôle chacun de ces bits ? 9.3.4 Le message reçu est-il celui transmis ?