04 - Binaire Cours Hexadecimal Representation Donnees

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 17

Cours - NSI

Représentation des données


Types et valeurs de base

1 Un peu d’histoire
Voir le site : https ://www.math93.com/histoire-des-maths/histoire-des-nombres/154-histoire-des-nombres.html

1.1 Règles de construction des numérotations


Les règles de construction des numérotation écrite sont simples :
1. il faut permettre une lecture sans ambiguïté, une même écriture ne devant pas représenter deux
nombres différents.
2. Il faut représenter un maximum de nombres avec un minimum de symboles.

1.2 Les bases


C’est l’usage d’une base qui permettra de répondre au mieux aux contraintes posées.
Au lieu de compter uniquement par unités, on compte "par paquets". La plus fréquente est la base décimale
(10), mais on trouve également :
— la base sexagésimale (60), utilisée par les Sumériens et parfois au moyen âge en France,
— la base vicésimale (20), utilisée par les Mayas ou duodécimale (12),
— la base 16 (système hexadécimal), en informatique, facilitant les conversions en base 2 en regroupant
des chiffres binaires, 16 étant une puissance de 2 ;
— la quinaire (5), utilisée aussi par les Mayas
— et la binaire (2) utilisé en électronique numérique et informatique .
Chez les Mayas, le moyen le plus simple pour représenter les nombres était un système utilisant, le point
valait 1, la barre 5 et un zéro. On les trouve sur le codex de Dresde.

1.3 La numération indienne de position

Remarque historique
L’invention de cette numération dans l’Inde au 5e siècle.
Les chiffres de "un" à "neuf" ont été inventés en Inde avant notre ère. Ils apparaissent dans des ins-
criptions de Nana Ghât au 3e siècle av.J.-C. , mais le principe de position n’y est pas appliqué.

La numération de position avec un zéro (qui était un point à l’origine), a été inventé au cours du
5e siècle. Dans un traité de cosmologie écrit en sanscrit en 458, le "LOKAVIBHAGA", "les parties de
l’univers", on voit apparaître le nombre 14 236 713 écrit en toute lettres ( "un" "quatre" ...). dans ce
texte, on trouve aussi le mot "sunya", "le vide", qui représente le zéro. C’est à ce jour le document le
plus ancien faisant référence de cette numération.

Propagation de cette numération.


En 773, arriva à Bagdad une ambassade indienne avec un présent pour le calife MANSOUR et les
savants arabes qui l’entouraient : le calcul et les chiffres.
Muhammad ibn Musa al-Khuwârizmi a écrit le premier ouvrage en langue arabe présentant la nu-
mération indienne de position au 9e siècle, "livre de l’addition et de la soustraction d’après le calcul
des Indiens".
C’est par cet ouvrage que le calcul indien pénétra dans l’Occident chrétien.
Cours - NSI - Représentation des données
Types et valeurs de base

Maintes fois traduit en latin à partir du 12e siècle, sa célébrité fût telle que ce calcul fut nommé
algorisme, d’Algorismus latinisation d’al-Khuwârizmi.
Au Xe siècle, le moine français Gerbert d’AURILLAC apprit la nouvelle numération chez les Maures
d’Espagne et, grâce aux chaires qu’il occupa dans les établissement religieux d’Europe, il put intro-
duire le nouveau système en occident.

2 Représentation des entiers naturels

2.1 La notion de base


— Une base (de numération) désigne la valeur dont les puissances successives interviennent dans l’écri-
ture des nombres dans la numération positionnelle.
— En base N , on a donc besoin de N chiffres (digits), de 0 à N − 1.
Par exemple, en base 10, on a besoin de 10 chiffres, de 0 à 9, en base 2, on a besoin de 2 chiffres de 0
et 1, etc.

— Pour les bases supérieures à 10, il faut d’autres chiffres. On aurait pu inventer des symboles nouveaux.
On convient plutôt d’utiliser les premières lettres de l’alphabet.
Pour la base 16, on utilise les chiffres de 0 à 9 puis A (pour 10), B (pour 11), C (pour 12) ... , F (pour 15)

Exemple
— BASE 2 :
10112 = 1 × 23 + 0 × 22 + 1 × 21 + 1 × 20

— BASE 10
204810 = 2 × 103 + 0 × 102 + 4 × 101 + 8 × 100

— BASE 16
204C 16 = 2 × 163 + 0 × 162 + 4 × 161 + 12 × 160

2.2 Bases et notations


— En mathématiques : base en index
Pour n’importe quelle base, on a l’habitude de l’indiquer en indice du nombre.
Par exemple (100111)2 pour le nombre dont le développement en base 2 est 100111, ou encore (172)8
pour le nombre dont le développement en base 8 est 172.
— En informatique : base en préfixe
En plus de cette notation, il en existe d’autres, notamment employées en informatique.
Par exemple sous Python (ou en C, C++, Java) pour indiquer qu’on est en base 2 on ajoute le préfixe
0b et le préfixe 0x pour la base 16 :

# CODE PYTHON
>>> bin(45) # la fonction bin permet de convertir un décimal en base 2
'0b101101'
# Remarquez l'utilisation des guillemets pour le résultat,
# il est de type chaîne de caractères
>>> hex(45) # la fonction hex permet de convertir un décimal en base 16
'0x2d'

www.math93.com / M. Duffaud 2/17


Cours - NSI - Représentation des données
Types et valeurs de base

2.3 Le binaire
2.3.1 Vocabulaire

Tout information manipulée par un ordinateur est représentée par des mots composés uniquement de 0 et
1 (les bits). Un octet (byte) est un mot binaire de 8 bits et un quartet = un mot binaire de 4 octets ou 32 bits.

2.3.2 Méthode de conversion : de base 10 en base 2

En binaire chaque rang ne peut prendre que deux valeurs (il pouvait en prendre dix en décimal). Donc, dès
que le rang atteint sa deuxième - la plus haute - valeur on change de rang. En binaire, un rang commence à
0 et se termine à 1.
base 10 0 1 2 3 4 5 6 7 8 9 10 11 12
base 2 02 12 102 112 1002 1012 1102 1112 10002 10012 10102 10112 11002

Exercice 2.1 : Compléter le tableau


base 10 13 14 15 16 17 18 19 20 21
base 2

Méthode : De la base 10 à la base 2


On procède par divisions successives par 2 des quotients, et on récupère les restes :
— On considère un entier en base 10.
— On le divise par 2 et on note le reste de la division (c’est soit un 1 soit un 0).
— On refait la même chose avec le quotient précédent, et on met de nouveau le reste
de coté.
— On re-itère la division, et ce jusqu’à ce que le quotient est 0.
— Le nombre en binaire apparaît : le premier à placer est le dernier reste non nul.
Ensuite, on remonte en plaçant les restes que l’on avait. On les place à droite du
premier 1.

Exemple
Écrivons 77 en base 2. Il s’agit de faire une suite de divisions euclidiennes par 2. Le résultat sera
la juxtaposition des restes. Le schéma ci-dessous explique la méthode :

7710 = 10011012

# On peut vérifier avec la fonction bin de Python :


>>> bin(77)
'0b1001101'
# Ou pour passer de la base 2 à la base 10
>>> int('1001101',2)
77

www.math93.com / M. Duffaud 3/17


Cours - NSI - Représentation des données
Types et valeurs de base

2.3.3 Méthode de conversion : de base 2 en base 10

Méthode : De la base 2 à la base 10


On utilise le fait qu’en base 2, le chiffre le plus à droite représente les unités, celui d’avant
les paquets de 2, puis les paquets de 22 ...

10112 = 1 × 23 + 0 × 22 + 1 × 21 + 1 × 20 = 1110

# Sur Python, il suffit d'écrire le préfixe 0b devant le nombre :


>>> 0b1011
11

2.3.4 Exercices

Exercice 2.2
Trouver la représentation en base 10 du nombre 1111 11112 .

Corrigé
— Méthode 1.

1111 11112 = 1 × 27 + 1 × 26 + · · · + 1 × 21 + 1 × 20 = 25510

— Méthode 2 : On peut aussi plus simplement considérer que c’est l’entier qui précède

10000 00002 = 2810 = 25610

on retrouve bien 255

Exercice 2.3
En base 10, une série de 2 caractères peuvent représenter 100 nombres entiers différents (de 0 à 99).
Sur le même principe combien de nombres entiers naturels peut on représenter avec un nombre n de
caractères en binaire.

Corrigé
Avec un nombre n de caractères en binaire ou un mot de n bits, on peut représenter les
nombres entiers de 0 à 2n − 1 soit 2n entiers.

www.math93.com / M. Duffaud 4/17


Cours - NSI - Représentation des données
Types et valeurs de base

2.4 Représentation hexadécimale


Comme les représentations décimale et binaire, la représentation hexadécimale est un système de numé-
ration positionnel en base 16. Tout entier naturel non nul n dans ce système peut s’écrire sous la forme :

n = (h p ...h 0 )16

avec,
h i ∈ {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B,C , D, E , F }
Le tableau suivant présente les conversions des premiers entiers naturels entre les trois représentations
précédentes.

2.4.1 Conversion décimal/Hexadécimal

Là encore, convertir un entier du système hexadécimal au système décimal et réciproquement peut aisé-
ment se faire.
(B 7)16 ↔ 11 × 161 + 7 × 160 = 183
On procède par divisions successives par 16 pour convertir en entier base 10 en base 16.
Par exemple ici :

Reste base 10 Base 16


183 = 16 × 11 + 7 =⇒ reste 7 ←→ 7
11 = 16 × 0 + 11 =⇒ reste 11 ←→ B

Puis on lit les restes de bas en haut :


(B 7)16 ↔ (183)10

2.4.2 Conversion Binaire/Hexadécimal

La conversion hexadécimal ↔ binaire peut également se faire rapidement : chaque chiffre hexadécimal
équivaut à exactement quatre chiffres binaires.

www.math93.com / M. Duffaud 5/17


Cours - NSI - Représentation des données
Types et valeurs de base

— Reprenant l’exemple du nombre B7, le tableau précédent indique que 7 peut être converti en 0111 et
B en 1011. Ce qui donne la représentation binaire 01111011 ou 1111011 si on omet le premier zéro.
{
(7)16 = 710 = (0111)2
=⇒ (B 7)16 = (1011 0111)2
(B )16 = 1110 = (1011)2

— À la représentation binaire 110 1110 peut être associée deux blocs de quatre chiffres : 0110 (on ajoute
1 zéro) et 1110. Le premier bloc se convertit en 6 et le second en E de sorte que la représentation
hexadécimale de l’entier est 6E.
{
(0110)2 = (6)16
=⇒ (0110 1110)2 = (6E )16
(1110)2 = (E )16

Particulièrement pratique pour représenter de grands entiers sous forme compacte, la représentation
hexadécimale est fréquemment utilisée en électronique numérique et dans le monde des réseaux
pour décrire des adresses.

Exercice 2.4
Donner la représentation binaire de (ABC 1)16 et la représentation en hexadécimale de (1011 0110 1101)2

Corrigé
— (ABC 1)16 = (1010 1010 1100 0001)2
— (1011 0110 1101)2 = (B 6D)16

www.math93.com / M. Duffaud 6/17


Cours - NSI - Représentation des données
Types et valeurs de base

2.5 Codage binaire


2.5.1 Des bits

D’un point de vue matériel, un ordinateur est un ensemble de composants électroniques parcourus par des
courants électriques. Par convention, le passage d’un courant dans un composant est codé par le chiffre
1, l’absence de courant étant codé par un 0. Ainsi, toute information stockée dans un ordinateur peut être
codée par une suite finie de 0 et de 1 appelée suite de bits (binary digits). Une convention fixe la taille de ces
suites finies de bits.

Par exemple, un codage sur 4 bits signifie qu’une information est représentée en machine à l’aide de quatre
0 ou 1. L’ordre de ces bits importe de sorte que 0111 ne code pas la même information que 1110. En outre,
les zéros présents en début de codage sont indispensables. Ainsi, sur 4 bits, 24 = 16 entiers naturels peuvent
être codés ; par exemple, les entiers de 0 à 15.

0 ↔ 0000 ; 1 ↔ 0001 ; 2 ↔ 0010 ; 3 ↔ 0011 ; 4 ↔ 0100 ; 5 ↔ 0101 ; 6 ↔ 0110 ; 7 ↔ 0111 ; 8 ↔ 1000 ; 9 ↔ 1001

10 ↔ 1010 ; 11 ↔ 1011 ; 12 ↔ 1100 ; 13 ↔ 1101 ; 14 ↔ 1110 ; 15 ↔ 1111

Nombre d’entiers codés sur n bits


Si n est un entier naturel non nul, 2n entiers peuvent être codés en binaire sur n bits :
( )
0 −→ · · · −→ 2n − 1

— Pour n = 4 bits : on a 24 = 16 entiers possibles de 0 à 24 − 1 = 15

— Pour n = 8 bits : on a 28 = 256 entiers possibles de 0 à 28 − 1 = 255

— Pour n = 16 bits : on a 216 = 65 536 entiers possibles de 0 à 216 − 1 = 65 535

2.5.2 Arithmétique élémentaire

Cela signifie que les entiers plus grands que 2n ne peuvent pas être codés sur n bits. La capacité de codage
sur n bits est dépassée. Soit on ajoute des bits pour coder de plus grands entiers, soit on se contente de
coder les entiers sur n bits. Alors attention aux additions ...

Exemple
Illustrons notre propos avec n = 4 bits et deux entiers n 1 = 3 et n 2 = 4. L’addition de ces entiers
est l’entier n 3 = 7. En binaire, les additions sont effectuées suivant les règles suivantes.
— 0 + 0 donne 0 avec une retenue égale à 0 ;
— 0 + 1 donne 1 avec une retenue égale à 0 ;
— 1 + 0 donne 1 avec une retenue égale à 0 ;
— 1 + 1 donne 0 avec une retenue égale à 1 ;
Le codage de n 1 et n 2 sur 4 bits donne respectivement 0011 et 0100. L’addition de ces codages
peut être posée et s’écrit :

Retenue 0 0 0 0
0 0 1 1
+ 0 1 0 0
0 0 1 1 1

Le résultat obtenu, à savoir 0111 sur 4 bits, correspond au codage binaire de 7.

www.math93.com / M. Duffaud 7/17


Cours - NSI - Représentation des données
Types et valeurs de base

Choisissons à présent n 1 = 11 et n 2 = 13 dont les codages binaires sur 4 bits sont respectivement
1011 et 1101. L’addition de ces codages donne alors :

Retenue 1 1 1 1
1 0 1 1
+ 1 1 0 1
1 1 0 0 0

Le résultat obtenu est 11000. En codant sur 4 bits, seuls les 4 bits de plus faibles poids sont
conservés, à savoir 1000. Ce codage est celui de l’entier 8 et non celui de la somme 11 + 23 = 24.
On peut remarquer 8 = 24 − 16 ; le résultat est la somme modulo 16 (c’est à dire à une nombre
de fois 16 près).

L’addition des codages réalise la somme modulo 2n .


Par exemple 255 + 1 renvoie 0 plutôt que 256 sur certaines machines, en l’occurrence les ma-
chines codant les entiers naturels sur 8 bits ou moins !

2.5.3 Overflow

Remarque historique
Le vol inaugural 501 du lanceur européen Ariane 5 du 4 juin 1996 s’est soldé par un échec, causé
par un dysfonctionnement informatique, qui vit la fusée se briser et exploser en vol seulement 36,7
secondes après le décollage.
Tout tenait à une seule petite variable : celle allouée à l’accélération horizontale. En effet, l’accélé-
ration horizontale maximum produite par Ariane 4 donnait une valeur décimale d’environ 64. La
valeur d’accélération horizontale de la fusée étant traitée dans un registre mémoire à 8 bits, cela
donne en base binaire 28 = 256 valeurs disponibles, un nombre suffisant pour coder la valeur 64, qui
donne en binaire (100 0000)2 et ne nécessite que 7 bits.
Mais Ariane 5 était bien plus puissante et brutale : son accélération pouvait atteindre la valeur 300,
qui donne (100101100)2 en binaire et nécessite un registre à 9 bits.
Ainsi, la variable codée sur 8 bits a connu un dépassement de capacité. Il aurait fallu la coder sur
un bit de plus, donc 9 bits, ce qui aurait permis de stocker une valeur limite de 29 − 1 = 511, alors
suffisante pour coder la valeur 300. De ce dépassement de capacité a résulté une valeur absurde dans
la variable, ne correspondant pas à la réalité. Par effet domino, le logiciel décida de l’autodestruction
de la fusée à partir de cette donnée erronée.

www.math93.com / M. Duffaud 8/17


Cours - NSI - Représentation des données
Types et valeurs de base

3 Représentation des entiers relatifs

3.1 Faire le TD d’introduction


▷ TD NSI : représentation binaire d’un entier relatif
Disponible sur votre page : https ://www.math93.com/lycee/nsi-1ere/nsi-1ere.html

3.2 Écriture d’un entier relatif en binaire sur N bits

Méthode : complément à 2
On considère un nombre relatif n en base 10.
1. Si n ≥ 0, on utilise la méthode classique de conversion en base 2 (cf. 2.3.2).
2. Si n est négatif, on code |n| en binaire puis :
— Étape 1 : On prend le complément à 1 (NON logique) de l’écriture binaire, c’est
à dire qu’on remplace les 1 par des 0 et les 0 par des 1.
— Étape 2 : On ajoute 1 au résultat, plus exactement (0000 0001)2 si on est sur 8
bits.
— On remarque que l’écriture binaire de l’entier négatif n correspond à celle n +
2N .

Exemple
Représentation binaire de (−8)10 sur 8 bits.
— Étape 1 : On prend le non logique ou complément à 1.
Par exemple (sur 8 bits) :

(8)10 = (0000 1000)2 =⇒ (1111 0111)2


Par complément à 1

— Étape 2 : On ajoute 1 (d’où le nom, complément à 2)

(1111 0111)2 + (0000 0001)2 = (1111 1000)2

— Donc
(8)10 = (0000 1000)2 =⇒ (−8)10 = (1111 1000)2
Par complément à 2

— On remarque que l’écriture binaire de l’entier négatif n correspond à celle n + 28 car en


binaire
(1111 1000)2 = 24810 =⇒ 248 − 28 = −8

3.3 Astuce

Astuce
Il suffit en fait en lisant le nombre binaire de droite à gauche :
— Étape 1 : de conserver tous les 0 et le premier 1 ;
— Étape 2 : de changer tous les autres digits à gauche du premier 1.
Une petite vidéo : https ://www.youtube.com/watch ?v=bNTyHfTnqEU
Juste une petite confusion entre droite et gauche mais cela ne gène pas la compréhension.

www.math93.com / M. Duffaud 9/17


Cours - NSI - Représentation des données
Types et valeurs de base

3.4 Définition et exemple

Définition 1

Soit la représentation binaire d’un entier naturel sur n bits :


( )
x n x n−1 · · · x 1
2

— x 0 est le bit de poids faible ;


— x n est le bit de poids fort (et indique le signe).
S’il vaut 1, le nombre en base 10 est négatif, s’il vaut 0, le nombre en base 10 est positif.

On a vu dans le TD d’approche que sur 4 bits on a les résultats suivants. Notez que le bit de poids fort donne
bien le signe :
−8 −7 −6 −5 −4 −3 −2 −1 0 1 2 3 4 5 6 7
1 000 1 001 1 010 1 011 1 100 1 101 1 110 1 111 0000 0001 0010 0011 0100 0101 0110 0111

3.5 Plus grand et plus petit relatifs sur n bits


Soit une machine programmée sur n bits. Il y a donc 2n nombres relatifs possibles.
2n
On garde le (000 · · · 00)2 pour le 0. On va donc en prendre la moitié soit = 2n−1 pour les négatifs et l’autre
2
moitié pour les positifs ou nul.

−2n−1 ... −1 0 1 ... 2n−1 − 1


100 · · · 00 ... 111 · · · 11 00 · · · 00 00 · · · 001 ... 011 · · · 11

Plus grand et plus petit relatifs sur n bits (n > 0)


1. Sur n bits on peut représenter 2n entiers relatifs.
2. La moitié soit 2n−1 sont des entiers positifs ou nuls : de 0 à 2n−1 − 1 .

3. La moitié soit 2n−1 sont des entiers strictement négatifs : de −2n−1 à (−1).

4. Les 2n entiers relatifs sont donc compris entre −2n−1 et 2n−1 − 1 :

−2n−1 ... −→ −1 −→ 0... −→ 2n−1 − 1

Plus grand et plus petit relatifs sur n bits


— Sur 4 bits : on a 24 = 16 relatifs possibles de −8 à 7 :

−23 = −8 −→ · · · −→ · · · −→ 23 − 1 = 7

— Sur 8 bits : on a 28 = 256 relatifs possibles de −128 à 127 :

−27 = −128 −→ · · · −→ · · · −→ 27 − 1 = 127

— Sur 16 bits : on a 216 = 65 536 relatifs possibles de −32 768 à 32 767 :

−215 = −32 768 −→ · · · −→ · · · −→ 215 − 1 = 32 767

— Sur 32 bits : on a 232 = 4 294 967 296 relatifs possibles de −2 147 483 648 à 2 147 483 647 :

−231 = −2 147 483 648 −→ · · · −→ · · · −→ 231 − 1 = 2 147 483 647

www.math93.com / M. Duffaud 10/17


Cours - NSI - Représentation des données
Types et valeurs de base

4 Représentation approximative des réels (flottants)

4.1 Nombres décimaux : rappels

Définition 2

a
Un nombre décimal est un nombre qui peut s’écrire sous la forme , où a est un entier relatifs
10n
et n un entier.

Par exemple :
1235
= 12, 35 = 1 × 101 + 2 × 100 + 3 10−1} + 5
| ×{z 10−2}
| ×{z
102
3 dixièmes 5 centièmes

4.2 Nombres dyadiques (par analogie)

Définition 3

a
Un nombre dyadique est un nombre qui peut s’écrire sous la forme , où a est un entier relatifs
2n
et n un entier.

Par exemple :
13 13
= 3, 25 = 2 = 1 × 21 + 1 × 20 + 0 × 2−1 + 1 × 2−2
4 2

Méthode
a
Pour obtenir le développement dyadique d’un nombre dyadique on prend le binaire
2n
correspondant à a et on insère une virgule avant le n-ième bit en partant de la fin.

13
Par exemple : pour
22
— Étape 1 : a = 13 = (1101)2 ;
13
— Étape 2 : Le développement dyadique de est donc (11, 01)2
22

13 13
= 3, 25 = (11, 01)2 ⇐⇒ 3, 25 = 2 = 1 × 21 + 1 × 20 + 0 × 2−1 + 1 × 2−2
22 2

On peut faire une analogie avec les décimaux, par exemple :

13 13 = (1101)2

13 13
= 1, 3 = (110, 1)2
10 2
13 13
= 0, 13 = (11, 01)2
102 22
13 13
= 0, 013 = (1, 101)2
103 23

www.math93.com / M. Duffaud 11/17


Cours - NSI - Représentation des données
Types et valeurs de base

4.3 Conversion d’un nombre décimal en base 2


Comment passer d’un décimal à son écriture en binaire :

Méthode
Pour obtenir le développement dyadique d’un nombre décimal quelconque .
— Étape 1 : on convertit sa partie entière en base 2 ;
— Étape 2 : on multiplie la partie fractionnaire par 2 puis on note sa partie entière .
— Étape 3 : on recommence cette opération avec la partie fractionnaire du résultat et
ainsi de suite
— Test d’arrêt : On s’arrête quand la partie fractionnaire est nulle ou quand la préci-
sion souhaitée est atteinte.
— Conclusion : la partie fractionnaire dans la base 2 est alors la concaténation des
parties entières obtenues dans l’ordre de leur calcul.
Par exemple : pour 3, 25

• 3 = (11)2
• 0, 25 × 2 = 0, 5 = 0 + 0, 5
• 0, 5 × 2 = 1 = 1 + 0
On retrouve bien :
3, 25 = (11, 01)2

Exemple
Conversion de 12,6875 en binaire
La partie entière : 12 = (1100)2

0,6875 ×2 = 1, 375 = 1 + 0, 375


0,375 ×2 = 0, 75 = 0 + 0, 75
0,75 ×2 = 1, 5 = 1 + 0, 5
0,5 ×2 = 1 = 1 +0

12, 6875 = (1100, 1011)2

4.4 Nombre décimaux non dyadiques


Il existe des décimaux qui ne sont pas dyadiques, qui n’admettent pas de développement dyadique fini.
Par exemple on obtient :
0, 1 = (0, 00011001100110011001100110011 · · ·)2
Par conséquent, leur représentation en machine sera nécessairement tronquée et engendrera des erreurs
dans les opérations.

# Dans la console PYTHON


>>>0.1+0.1+0.1
0.30000000000000004

www.math93.com / M. Duffaud 12/17


Cours - NSI - Représentation des données
Types et valeurs de base

4.5 Représentation des réels : première approche


De façon analogue aux nombres décimaux, un nombre réel x sera codé en binaire à l’aide de son écriture
décimale approchée.

Exemple
1
Conversion de en binaire
3
1
On pose x = ≈ 0, 33333 · · · , la partie entière : 0 = (0)2 et :
3

0, 33333 · · · ×2 = 0, 66666 · · · = 0 + 0, 66666 · · ·


0, 66666 · · · ×2 = 1, 333333 · · · = 1 + 0, 333333 · · ·
0, 333333 · · · ×2 = 0, 666666 · · · = 0 + 0, 666666 · · ·

Le processus se répète ... donc :

1
= (0, 0101010101 · · · · · ·)2
3

4.6 Représentation des réels : Norme IEEE-754 (Complément) et nombre flottant


Pour un espace mémoire donné, on souhaite obtenir la représentation qui maximise à la fois l’effectif des
nombres codés sur cet espace et la précision.
Représenter des réels en informatique consiste à l’approcher par un nombre décimal (un flottant). Une
infinité de réels voisins auront donc la même représentation.

4.6.1 Principe de la méthode de la virgule flottante

L’utilisation de la virgule flottante est la plus répandue. Son principe consiste à séparer les chiffres signifi-
catifs et la position de la virgule dans le but d’avoir un maximum de chiffres significatifs.
Ce type de représentation est implémentées directement dans le micro-processeur.
On distingue trois parties :
— le signe s ,
— la mantisse m ,
— l’exposant e ,

Exemple

Exemple en base 10. Exemple en base 2.

−1234, 56489 = −1, 23456789 × 103 (10001, 11001)2 = (1, 000111001)2 × 24


{
{ m = 1, 000111001
m = 1, 23456789
e =4
e =3
En base 2, le premier bit de la mantisse (le bit
avant la virgule) sera toujours 1. On ajuste en-
suite l’exposant.

www.math93.com / M. Duffaud 13/17


Cours - NSI - Représentation des données
Types et valeurs de base

4.6.2 Norme IEEE-754

La norme IEEE-754 utilisée depuis 1995 et révisée en 2008 est la plus utilisée pour représenter les nombres
à virgule flottante en base 2 sur les ordinateurs.
Elle propose deux formats (nombres de bits pour représenter les nombres) : simple précision (32 bits) et
double précision (64 bits). Le premier bit de la mantisse étant toujours 1, on ne le représente pas (le cas 0 se
traite à part). Sans entrer dans les détails on a :
— Simple précision : 32 bits
— le signe s : 1 bit de signe (0 pour positif et 1 négatif)
— l’exposant e : 8 bits pour l’exposant (décalé de 127).
— la mantisse m : 23 bits pour la mantisse.
— Les flottants positifs en simple précision peuvent représenter des nombres décimaux compris
(approximativement) entre 10−38 et 1038 .
— Double précision : 64 bits
— le signe s : 1 bit de signe (0 pour positif et 1 négatif)
— l’exposant e : 11 bits pour l’exposant (décalé de 1023).
— la mantisse m : 52 bits pour la mantisse.
— Les flottants positifs en double précision peuvent représenter des nombres décimaux compris
(approximativement) entre 10−308 et 10308 .

Exemple
Par exemple le mot de 32 bits suivant :

1 10000110 10101101100000000000000

représente le décimal calculé ainsi :


— le signe s = −1 : car le bit de signe est 1
— l’exposant e = 100001102 : 8 bits pour l’exposant (décalé de 127).

e 10 = 27 + 23 + 22 − 127 = 7

— la mantisse m = 101011011000000000000002 : 23 bits pour la mantisse donc

m 10 = 1 + 1 × 2−1 + 1 × 2−3 + 1 × 2−5 + 1 × 2−6 + 1 × 2−8 + 1 × 2−9 = 1, 677734375

— Soit au final le nombre :


−1, 677734375 × 27 = −214, 75

www.math93.com / M. Duffaud 14/17


Cours - NSI - Représentation des données
Types et valeurs de base

5 Représentation des chaînes de caractères


Les caractères sont des données non numériques, ce sont des symboles alphanumériques :
— Les lettres majuscules et minuscules,
— Les symboles de ponctuation (, ? . ; : !),
— Les caractères dit spéciaux ($,@, %, ...)
— Les chiffres.
— Les contrôles.
Un texte, ou chaîne de caractères, sera représenté comme une suite de caractères.
À chaque caractère correspond un nombre qui sera codé en binaire. On doit pour cela faire un choix arbi-
traire.

5.1 Le codage ASCCII

Remarque historique
Historiquement l’ASCII (American Standart Code for Information Interchange) a été définie pour
écrire des textes en anglais. Il n’y a donc pas de lettre accentuées

C’est le codage de base en informatiques pour les caractères.

La construction de la table ASCII


— Le code ASCII est un code sur 7 bits, il y a donc 27 = 128 codages possibles.
— Il y a 33 caractères de contrôle, retenons surtout l’espace ou fin de ligne.
— Les lettres se suivent dans l’ordre alphabétique.
* Les majuscules codée de 65 à 90
* Les minuscules codée de 97 à 122
* Pour passer de majuscule à minuscule à on ajoute 32 = 25 . Cela revient alors
à modifier le 6ème bit.
G codé 71 = 0100 01112 devient g codé 103 = 0110 01112
— Les chiffres sont rangés dans l’ordre croissant codé entre 48 et 57. Les quatre pre-
miers bits définissent la valeur en binaire du chiffre.
— Même si 7 bits sont suffisants pour représenter les 128 caractères, en pratique
chaque caractère occupe 1 octet (8 bits) en mémoire. Le bit de poids fort est utilisé
pour un somme de contrôle afin de vérifier des erreurs de transmission.

www.math93.com / M. Duffaud 15/17


Cours - NSI - Représentation des données
Types et valeurs de base

En python, on peut manipuler le code ASCII avec chr et ord :

# Dans la console PYTHON


>>>chr(65)
'A'
>>>ord('a')
92

Retenez deux caractères de contrôle classiques (le passage à la ligne et la tabulation) :

# Dans la console PYTHON


>>>chr(10)
'\n'
>>>chr(9)
'\t'

Exercice 5.5
1. A l’aide de la table ASCII, coder la phrase suivante "L’an qui vient !"
2. Retrouver l’expression codée en binaire :
0100 0010 0111 0010 0110 0001 0111 0110 0110 1111 0010 1100
3. Peut on coder la phrase "Un âne est passé par là ?" à l’aide de la table ASCII.

www.math93.com / M. Duffaud 16/17


Cours - NSI - Représentation des données
Types et valeurs de base

5.2 Norme ISO 8859


Pour pouvoir écrire en français, on a besoin d’accent comme é, è, à, ù etc... et aussi de ç.
Pour cela l’ISO (Organisation Internationale de Normalisation) a proposé la norme ISO 8859, une extension
de l’ASCII mais qui utilise 8 bits au lieu de 7. Au total 256 caractères peuvent alors être encodés.

Malgré un nombre de caractères doublé, cela reste insuffisant pour représenter tous les caractères, on dé-
finit alors plusieurs tables de correspondances (on parle aussi de pages) notées I SO − 8859 − n, où n est le
numéro de la table. Bien d’indépendantes, ces tables sont conçues pour qu’elles soient compatibles entre
elles. Les 128 premiers caractères sont ceux de la norme ASCII et les autres sont spécifiques.

Par exemple le code ISO 8859-1 (latin-1) correspond à la zone Europe occidentale

5.3 Codage Unicode : norme ISO-10646


Ce standard est lié à la norme ISO/CEI 10646 qui décrit une table de caractères équivalente. La dernière
version, Unicode 12.0, a été publiée en mars 2019 (et couvre 137 929 caractères).

Cette norme associe à chaque caractère (lettre, nombre, idéogramme, etc.) un nom unique (en anglais et en
français) ainsi qu’un numéro (entier positif en base 10 appelé point de code).

Cette norme Unicode : ISO-10646 a une capacité maximale de 232 caractères soit plus de 4 milliards (puisque
l’on code sur 4 octets, 32 bits au maximum).

On utilise la notation U+xxx pour désigner les points de code du jeu universel de caractères.
La norme unicode définit plusieurs techniques d’encodage pour représenter les points de code. Ces enco-
dages, appelés formats de transformation universelle ou Universal Transformation Format (UTF) portent
les noms UTF-n, où n désigne le nombre minimal de bits pour représenter un point de code.

5.4 Norme UTF-8


Le format UTF-8 est le format le plus utilisé (-8 donc 8 bits ou 1 octet au minimum). Il permet un encodage
de 1 à 4 octets au maximum.
Comme son nom l’indique, il faut seulement 8 bits pour coder les premiers caractères. L’UTF-8 est compa-
tible avec le standard ASCII, les 127 premiers caractères sont représentés sur 1 octet, comme en ASCII.
Vous n’aurez normalement pas de problème d’accent si vous commencez l’en tête de vos programmes en
python avec :

# -*- coding: utf-8 -*-

Bilan encodage
— ASCII : table sur 7 bits codant 128 caractères.
— Norme Unicode : ISO-10646 a une capacité maximale de 232 caractères soit plus
de 4 milliards.
— Le format UTF-8 est le format d’encodage le plus utilisé. Il permet un encodage
sur 1 à 4 octets au maximum

www.math93.com / M. Duffaud 17/17

Vous aimerez peut-être aussi