Flux rss

Le codage binaire


Présentation du binaire

Vers la fin des années 30, Claude Shannon démontra qu'à l'aide de « contacteurs » (interrupteurs) fermés pour « vrai » et ouverts pour « faux » il était possible d'effectuer des opérations logiques en associant le nombre 1 pour « vrai » et 0 pour « faux ».

Ce codage de l'information est nommé base binaire. C'est avec ce codage que fonctionnent les ordinateurs. Il consiste à utiliser deux états (représentés par les chiffres 0 et 1) pour coder les informations.

L'homme calcule depuis 2000 ans avant Jésus-Christ avec 10 chiffres (0, 1, 2, 3, 4, 5, 6, 7, 8, 9), on parle alors de base décimale (ou base 10). Toutefois dans des civilisations plus anciennes ou pour certaines applications actuelles d'autres bases de calcul ont et sont toujours utilisées :

  • base sexagésimale (60), utilisée par les Sumériens. Cette base est également utilisée dans le système horaire actuel, pour les minutes et les secondes ;
  • base vicésimale (20), utilisée par les Mayas ;
  • base duodécimale (12), utilisée par les anglo-saxons dans leur système monétaire jusqu'en 1960 : un « pound » représentait vingt « shilling » et un « shilling » représentait douze « pences ». Le système d'heure actuel fonctionne également sur douze heures (notamment dans la notation anglo-saxonne) ;
  • base quinaire (5), utilisée par les Mayas ;
  • base binaire (2), utilisée par l'ensemble des technologies numériques.

Le bit

Le terme bit (b avec une minuscule dans les notations) signifie « binary digit », c'est-à-dire 0 ou 1 en numérotation binaire. Il s'agit de la plus petite unité d'information manipulable par une machine numérique. Il est possible de représenter physiquement cette information binaire :

  • par un signal électrique ou magnétique, qui, au-delà d'un certain seuil, correspond à la valeur 1 ;
  • par des aspérités géométriques dans une surface ;
  • grâce à des bistables, c'est-à-dire des composants électroniques qui ont deux états d'équilibre (l'un correspond à l'état 1, l'autre à 0).

Avec un bit il est ainsi possible d'obtenir deux états : soit 1, soit 0. Grâce à 2 bits, il est possible d'obtenir quatre états différents (2*2) :

0 0
0 1
1 0
1 1

Avec 3 bits, il est possible d'obtenir huit états différents (2*2*2) :

Valeur binaire sur 3 bits Valeur décimale
000 0
001 1
010 2
011 3
100 4
101 5
110 6
111 7

Pour un groupe de n bits, il est possible de représenter 2n valeurs.

Poids des bits

Dans un nombre binaire, la valeur d'un bit, appelée poids, dépend de la position du bit en partant de la droite. A la manière des dizaines, des centaines et des milliers pour un nombre décimal, le poids d'un bit croît d'une puissance de deux en allant de la droite vers la gauche comme le montre le tableau suivant :

Nombre binaire11111111
Poids27 = 12826 = 6425 = 3224 = 1623 = 822 = 421 = 220 = 1

Conversions

Pour convertir un mot binaire en nombre décimal, il suffit de multiplier la valeur de chaque bit par son poids, puis d'additionner chaque résultat. Ainsi, le mot binaire 0101 vaut en décimal :

23x0 + 22x1 + 21x0 + 20x1
= 8x0 + 4x1 + 2x0 + 1x1
= 5

L'octet

L'octet (en anglais byte ou B avec une majuscule dans les notations) est une unité d'information composée de 8 bits. Il permet par exemple de stocker un caractère, tel qu'une lettre ou un chiffre.

Ce regroupement de nombres par série de 8 permet une lisibilité plus grande, au même titre que l'on apprécie, en base décimale, de regrouper les nombres par trois pour pouvoir distinguer les milliers. Le nombre « 1 256 245 » est par exemple plus lisible que « 1256245 ».

Une unité d'information composée de 16 bits est généralement appelée mot (en anglais word).

Une unité d'information de 32 bits de longueur est appelée mot double (en anglais double word, d'où l'appellation dword).

Pour un octet, le plus petit nombre est 0 (représenté par huit zéros 00000000), et le plus grand est 255 (représenté par huit chiffres « un » 11111111), ce qui représente 256 possibilités de valeurs différentes.

27 =128 26 =64 25 =32 24 =16 23 =8 22 =4 21 =2 20 =1
0 0 0 0 0 0 0 0
1 1 1 1 1 1 1 1

KiloOctets, MégaOctets

Longtemps l'informatique s'est singularisée par l'utilisation de différentes valeurs pour les unités du système international. Ainsi beaucoup d'informaticiens ont appris que 1 kilooctet valait 1024 octets. Or, depuis décembre 1998, l'organisme international IEC a statué sur la question (http://physics.nist.gov/cuu/Units/binary.html). Voici donc les unités standardisées :

  • Un kilooctet (ko ou kB) = 1000 octets
  • Un Mégaoctet (Mo ou MB) = 1000 ko = 1 000 000 octets
  • Un Gigaoctet (Go ou GB) = 1000 Mo = 1 000 000 000 octets
  • Un Téraoctet (To) = 1000 Go = 1 000 000 000 000 octets

Nota Attention ! De nombreux logiciels (parfois même certains systèmes d'exploitation) utilisent toujours la notation antérieure à 1998 pour laquelle :
  • Un kilooctet (ko) = 210 octets = 1024 octets
  • Un Mégaoctet (Mo) = 220 octets = 1024 ko = 1 048 576 octets
  • Un Gigaoctet (Go) = 230 octets = 1024 Mo = 1 073 741 824 octets
  • Un Téraoctet (To) = 240 octets = 1024 Go = 1 099 511 627 776 octets

L'IEC a également défini le kilo binaire (kibi), le méga binaire (Mébi), le giga binaire (Gibi), le tera binaire (Tebi).
Voici leurs définitions :

  • Un kibioctet (kio ou kiB) vaut 210 = 1024 octets
  • Un Mébioctet (Mio ou MiB) vaut 220 = 1 048 576 octets
  • Un Gibioctet (Gio ou GiB) vaut 230 = 1 073 741 824 octets
  • Un Tébioctet (Tio ou TiB) vaut 240 = 1 099 511 627 776 octets

Il est également utile de noter que la communauté internationale dans son ensemble utilise préférentiellement le nom de « byte » plutôt que le terme « octet » purement francophone. Cela donne les notations suivantes pour kilobyte, mégabyte, gigabyte et terabyte :

kB, MB, GB, TB
Nota Notez l'utilisation d'un B majuscule pour différencier Byte et bit.

Voici une capture d'écran du logiciel HTTrack, l'aspirateur de sites le plus populaire, montrant l'utilisation de cette notation :

Capture d'écran du logiciel HTTrack

Les opérations en binaire

Les opérations arithmétiques simples telles que l'addition, la soustraction et la multiplication sont faciles à effectuer en binaire.

L'addition en binaire

L'addition en binaire se fait avec les mêmes règles qu'en décimale :
On commence à additionner les bits de poids faible (les bits de droite) puis on a des retenues lorsque la somme de deux bits de même poids dépasse la valeur de l'unité la plus grande (dans le cas du binaire : 1), cette retenue est reportée sur le bit de poids plus fort suivant...

Par exemple :

  0 1 1 0 1
+ 0 1 1 1 0
- - - - - -
  1 1 0 1 1

La multiplication en binaire

La table de multiplication en binaire est très simple :

  • 0x0=0
  • 0x1=0
  • 1x0=0
  • 1x1=1

La multiplication se fait en formant un produit partiel pour chaque digit du multiplicateur (seuls les bits non nuls donneront un résultat non nul). Lorsque le bit du multiplicateur est nul, le produit partiel est nul, lorsqu'il vaut un, le produit partiel est constitué du multiplicande décalé du nombre de positions égal au poids du bit du multiplicateur.

Par exemple :

    0 1 0 1 multiplicande
x   0 0 1 0 multiplicateur
- - - - - -
    0 0 0 0
  0 1 0 1  
0 0 0 0    
- - - - - -
  0 1 0 1 0

Ce document intitulé « Le codage binaire » issu de Comment Ça Marche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
 
[Shell] Affichage d'un fichier binaire: Terminal illisibleLorsque vous affichez par mégarde le contenu d'un fichier binaire (par exemple cat /bin/mount | more), il peut arrivé que le terminal affiche des caractères non imprimables, ce qui provoque un affichage totalement illisible avec des caractères... www.commentcamarche.net/faq/sujet-972-shell-affichage-d-un-fichier-binaire-terminal-illisible
Binaire et hexa (Résolu)bonjour, je cherche quelqu'un qui pourait m'aider a comprendre le binaire et l'hexa et surtout le calcul pour passer de l'un a l'autre merci www.commentcamarche.net/forum/affich-2618081-binaire-et-hexa
Division binaire (Résolu)Bonjour, ...salut!!! vous pouvez m'aidez?? .... comment peut on faire la division binaire suivante -->111110101100011 par le generateur 10011 que peut-on dire du message?? www.commentcamarche.net/forum/affich-4710361-division-binaire
Parser un fichier binaire en PHPSupposons que vous ayez enregistré des données binaires dans un fichier, c'est-à-dire un enregistrement brut qui n'est pas traduit en texte. C'est une chose que l'on fait couramment avec certains langages de bas niveau comme le C ou le... www.commentcamarche.net/faq/sujet-13092-parser-un-fichier-binaire-en-php
[Gravure] Graver ou lire un fichier .NRGUn fichier .NRG est une image de CD, c'est-à-dire une copie binaire d'un CD ou d'un DVD sous forme d'un fichier Les fichiers .NRG sont utilisables par des programmes de gravure ou bien des lecteurs de disques virtuels (tels que Daemon... www.commentcamarche.net/faq/sujet-3350-gravure-graver-ou-lire-un-fichier-nrg
[Gravure] Graver ou lire un fichier .BIN / .CUELes fichiers .bin et .cue sont respectivement : .BIN : une image de CD, c'est-à-dire une copie binaire d'un CD ou d'un DVD sous forme d'un fichier .CUE : informations sur les pistes du disque. Les fichiers .BIN / .CUE sont utilisables par... www.commentcamarche.net/faq/sujet-2963-gravure-graver-ou-lire-un-fichier-bin-cue
Explication sur la soustraction binaire en co (Résolu)Bonjour, Je suis un etudiant et j aimerai que l on m aide a comprendre la soustraction binaire en complement a deux. www.commentcamarche.net/forum/affich-3739098-explication-sur-la-soustraction-binaire-en-co
Multiplication binaire (Résolu)Pourriez-vous m'aider à comprendre la multiplication des binaires. Je ne comprends pas les retenus. Si quelqu'un peut me donner l'exemple de 1111 X 1111 en m'expliquant comment il s'y prend pour les retenus, je suis certain... www.commentcamarche.net/forum/affich-3583071-multiplication-binaire
Afficher un entier sous forme binaire en C (Résolu)bonjour, j'ai besoin d'un programme en C qui affiche un entier saisie, en binaire , en utilisant des operateurs de bits. merci. www.commentcamarche.net/forum/affich-2848053-afficher-un-entier-sous-forme-binaire-en-c
Télécharger Binary Clock Screensaver Le langage binaire est encore mal connu de tous. Cet éditeur a trouvé le moyen d'allier ce langage avec un écran de veille. Binary Clock Screensaver est un écran de veille basé sur une horloge binaire. L'interface repose sur un fond noir et des leds... www.commentcamarche.net/telecharger/telecharger-34055954-binary-clock-screensaver
Télécharger I Doser i-Doser est une application qui permet de synchroniser votre cerveau avec une humeur spécifique afin de vous détendre. L'ambiance de détente est obtenue à partir de doses de battement binaural qui modifie le comportement de votre cerveau pour vous... www.commentcamarche.net/telecharger/telecharger-34056126-i-doser
Télécharger Hex WorkshopHex Workshop est un ensemble d'outils de développement hexadécimaux pour Microsoft Windows. Il combine à la fois l'édition binaire avancée avec la facilité et la flexibilité d'une unité de traitement de texte. Avec Hex Workshop, vous pouvez éditer,... www.commentcamarche.net/telecharger/telecharger-34055425-hex-workshop
NATIVE INSTRUMENTS FM8 DNATIVE INSTRUMENTS FM8 D,FM 8 ,Native Instruments FM8 - award winning FM synthesizer with extended sound architecture. Compatible with Windows XP (Pentium or Athlon 1.4GHz, 512Mb RAM) and Mac OSX (10.4, G4 1.4GHz, 512Mb RAM), Universal Binary compatible. www.commentcamarche.net/guide-achat/native-instruments-fm8-d-188761282-fiche-technique
Fujitsu Fi-60F60 F ,USB 2.0,Divers:Scanning Speed:1.0 sec (200 dpi) Binary 1 bit/pixel, 1.0 sec (200 dpi) 8 bit/pixel Grayscale, 1.7 sec (200 dpi) 24 bit/pixel Color,Plateforme:PC,Profondeur Couleur :24 bit,Résolution optique Vertical: ,Système... www.commentcamarche.net/guide-achat/fujitsu-fi-60f-325844-fiche-technique
Montres binairesVoici les première montres à affichage binaire. Il y a fort à parier que les modèles suivants se rechargeront sur port USB. Seuls les vrais geeks (informaniaques) seront capables de dire l'heure. Pour les autres, les couleurs des leds représentant... www.commentcamarche.net/actualites/montres-binaires-2158743-actualite.php3
Le code ASCII Le morse a été le premier codage à permettre une communication longue distance. C'est Samuel F.B.Morse qui l'a mis au point en 1844. Ce code est composé de points et de tirets (un codage binaire en quelque sorte...). Il permit d'effectuer des... www.commentcamarche.net/base/ascii.php3
Fichier BIN Les fichiers BIN et CUE sont respectivement : .BIN : une image de CD, c'est-à-dire une copie binaire d'un CD ou d'un DVD sous forme d'un fichier .CUE : informations sur les pistes du disque. Les fichiers .BIN / .CUE sont utilisables par des... www.commentcamarche.net/fichier/bin.php3
La base hexadécimale Les nombres binaires étant de plus en plus longs, il a fallu introduire une nouvelle base : la base hexadécimale. La base hexadécimale consiste à compter sur une base 16, c'est pourquoi au-delà des 10 premiers chiffres on a décidé d'ajouter les 6... www.commentcamarche.net/base/hexa.php3
Toutes les réponses pour « Binaire »