Complément à 2

Complément à 2

Complément à deux

Le complément à deux est une représentation binaire des entiers relatifs qui permet d'effectuer les opérations arithmétiques usuelles naturellement.

bit de signe
0 1 1 1 1 1 1 1 = 127
0 0 0 0 0 0 1 0 = 2
0 0 0 0 0 0 0 1 = 1
0 0 0 0 0 0 0 0 = 0
1 1 1 1 1 1 1 1 = −1
1 1 1 1 1 1 1 0 = −2
1 0 0 0 0 0 0 1 = −127
1 0 0 0 0 0 0 0 = −128

Entier de 8 bits en complément à deux


Explication

La notation est utilisée sur des écritures de nombres de longueur donnée (nombres écrits couramment sur 8, 16, 32 ou 64 bits). Dans une telle écriture on utilise le bit de poids fort (bit le plus à gauche) du nombre pour contenir la représentation de son signe (positif ou négatif, le zéro étant considéré comme positif).

La première idée est de marquer le signe du nombre de façon simple : le signe puis la représentation de sa valeur absolue. Ainsi :

v
00000010 = +2 en décimal
v
10000010 = −2 en décimal

Malheureusement cette représentation possède deux inconvénients. Le premier (mineur) est que le nombre zéro (0) possède deux représentations: 00000000 et 10000000 sont respectivement égaux à 0 et −0. L'autre inconvénient (majeur) est que cette représentation n'est pas compatible avec l'addition ; l'addition usuelle d'un nombre négatif et d'un nombre positif ne fonctionne pas. Ainsi:

00000011 + 10000100 = 10000111

Soit 3 + (−4) = (−7) au lieu de (−1)

C'est pour remédier à ces problèmes que l'on utilise la notation en complément à deux. Les nombres positifs sont représentés comme attendu, en revanche les nombres négatifs sont obtenus de la manière suivante :

  • On inverse les bits de l'écriture binaire de sa valeur absolue (opération binaire NOT), on fait ce qu'on appelle le complément à un,
  • On ajoute 1 au résultat (les dépassements sont ignorés).

Cette opération correspond au calcul de 2n−|X|, où n est la longueur de la représentation. Ainsi −1 s'écrit comme 256-1=255=111111112, pour les nombres sur 8 bits.

Les deux inconvénients précédents disparaissent alors. En effet, l'opération précédente effectuée sur 00000000 permet d'obtenir 00000000 (−0 = +0 = 0) et l'addition usuelle des nombres binaires fonctionne.

La même opération effectuée sur un nombre négatif donne le nombre positif de départ: 2n − (2n−x) = x.

Pour coder (−4) :

  • On prend le nombre positif 4 : 00000100
  • On inverse les bits : 11111011
  • On ajoute 1 : 11111100

Le bit de signe est automatiquement mis à 1 par l'opération d'inversion. On peut vérifier que cette fois l'opération 3 + (−4) se fait sans erreur :

00000011 + 11111100 = 11111111

Le complément à deux de 11111111 est 00000001 soit 1 en décimal, donc 11111111 = (−1) en décimal.


Le résultat de l'addition usuelle de nombres représentés en complément à deux est le codage en complément à deux du résultat de l'addition des nombres. Ainsi les calculs peuvent-ils s'enchaîner naturellement.


Si l'on doit transformer un nombre en son complément à deux "de tête", un bon moyen est de garder tous les chiffres depuis la droite jusqu'au premier 1 (compris) puis d'inverser tous les suivants.

  • Prenons par exemple le nombre 20 : 00010100
  • On garde la partie à droite telle quelle : (00010100)
  • On inverse la partie de gauche après le premier un : 11101100
  • Et voici −20 : 11101100

Explications plus détaillées

D'un point de vue plus technique, cette écriture est simplement la troncature de l'écriture infinie à gauche. Pour la base 10, on sait qu'il est sans effet de compléter un nombre par des zéros à sa gauche, i.e. 123 peut s'écrire 0000123 et même avec une infinité de 0, comme ...0123. Mais il est bien moins connu que si l'on permet de compléter à gauche avec une infinité de 9 on obtient une réprésentation des nombres négatifs! Par exemple :


  ...99 (infinité de 9 à gauche)
+ ...01 (infinité de 0 à gauche)
-------
  ...00 (infinité de 0 à gauche)

On peut alors interpréter ...99 comme étant −1, puisque −1+1=0.

Cette notation est le complément à 10. Pour obtenir la représentation d'un nombre négatif il faut complémenter à 9 chaque chiffre puis ajouter 1 au résultat. Ainsi pour obtenir la représentation de -123 on fait : ...0123 transformé en ...9876 puis en ...9877.

Un exemple plus complet. Essayons de calculer dans une telle représentation 12 + (−7) 12 s'écrit ...012, −7 s'écrit (...07 complémenté en ...92 puis additionné de 1 donne ...93) ...93. Additionnons:


  ...012
+ ....93
--------
  ....05

Et chacun sait que 12 + (−7) = 12 − 7 = 5

Une telle écriture mais de taille fixe fonctionne car le chiffre le plus à gauche (le signe 0 pour le + et 9 pour le −) représente alors simplement l'infinité des chiffres à gauche (l'opération consistant à allonger à volonté l'écriture du nombre à gauche s'appelle l'extension du signe et est bien connue des informaticiens).

Le complément à deux est alors la même technique employée avec la base 2.

Voir aussi

Ce document provient de « Compl%C3%A9ment %C3%A0 deux ».

Wikimedia Foundation. 2010.

Contenu soumis à la licence CC-BY-SA. Source : Article Complément à 2 de Wikipédia en français (auteurs)

Игры ⚽ Нужна курсовая?

Regardez d'autres dictionnaires:

  • complément — [ kɔ̃plemɑ̃ ] n. m. • 1308; de l a. fr. complir « remplir »; repris 1690; lat. complementum, de complere « remplir » 1 ♦ Ce qui s ajoute ou doit s ajouter à une chose pour qu elle soit complète. ⇒ achèvement, couronnement. Le complément est… …   Encyclopédie Universelle

  • complement — COMPLEMÉNT, complemente, s.n. 1. Ceea ce se adaugă la ceva spre a l întregi; complinire. 2. Parte secundară a propoziţiei care determină un verb, un adjectiv sau un adverb. 3. Substanţă de natură proteică prezentă în serul normal şi care… …   Dicționar Român

  • Complement — Complément Cette page d’homonymie répertorie les différents sujets et articles partageant un même nom …   Wikipédia en Français

  • complement — COMPLEMENT. s. m. Ce qui s ajoute à une chose pour lui donner sa perfection. On dit en Théologie, Complément de béatitude, pour exprimer Le comble de la beatitude. La résurrection des corps sera le complément de la béatitude des Saints.Complément …   Dictionnaire de l'Académie Française 1798

  • complement — n Complement, supplement are comparable both as nouns meaning one thing that makes up for a want or deficiency in another thing and as verbs meaning to supply what is needed to make up for such a want or deficiency. Complement implies a… …   New Dictionary of Synonyms

  • Complement — Com ple*ment, n. [L. complementun: cf. F. compl[ e]ment. See {Complete}, v. t., and cf. {Compliment}.] 1. That which fills up or completes; the quantity or number required to fill a thing or make it complete. [1913 Webster] 2. That which is… …   The Collaborative International Dictionary of English

  • complement — complement, compliment, complementary, complimentary 1. Complement and compliment each function as noun and verb; in pronunciation they are largely indistinguishable except that in the verbal function compliment has a fuller i sound in its second …   Modern English usage

  • Complement — (v. lat. Complementum), 1) Ergänzung; 2) (Math.), C. einer Größe ist im Allgemeinen das, was zu dieser addirt werden muß, um ein gewisses Ganze zu erhalten. Complement eines Winkels od. Kreisbogens ist beziehungsweise derjenige Winkel od. Bogen,… …   Pierer's Universal-Lexikon

  • complement — ► NOUN 1) a thing that contributes extra features to something else so as to enhance or improve it. 2) the number or quantity that makes something complete. 3) a word or words used with a verb to complete the meaning of the predicate (e.g. happy… …   English terms dictionary

  • Complement a un — Complément à un Le complément à un est l opération qui inverse la valeur de chacun des bits d un nombre binaire. Il est la première étape du complément à deux. Exemple Ce document provient de « Compl%C3%A9ment %C3%A0 un ». Catégorie :… …   Wikipédia en Français

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”