**TP 9 ELECTRONIQUE : VHDL (Composants Imbriqués)**

Réalisé par :

* PENDU Louis
* PELTIER Alexandre

**SOMMAIRE**

PAGE 1 : Sommaire

PAGE 2 : Exercice 1 : Demi-Additionneur

PAGE 3 : Exercice 2 : Additionneur Complet

Dans ces exercices à chaque fois nous avons réalisé différents fichiers portant l’extension .vhdl. Les fichiers sont donnés en annexe. Voici les différentes sources VHDL utilisées :

* Ou.vhdl
* Xor.vhdl
* Et.vhdl
* Test\_demi\_add.vhdl
* Test\_full\_add.vhdl

Dans ce compte-rendu nous ne mettrons que les chronogrammes obtenus que nous commenterons. Désolé pour la lisibilité de notre chronogramme mais faire des impressions écran sur linux et l’importer vers Windows endommage la qualité !! Et nous ne maitrisons pas Latex.

***Exercice 1 : Demi-Additionneur***

Nous avons à présent réalisé un composant demi-additionneur 1 bit (HalfAdder). Ce demi-additionneur a pour caractéristique un temps de propagation de 1 ns à chaque porte logique de base. Pour réaliser ce composant nous avons besoin des portes XOR et ET. En effet la sortie sera construite à l’aide de la porte XOR et la retenue sera faite avec la porte ET. Ce travail correspond aux sources VHDL suivantes : xor.vhdl, et.vhdl et test\_demi\_add.vhdl.

**Chronogramme :**

![](data:image/png;base64,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)

Sur ce chronogramme nous avons en entrée A (1° Ligne) et B (2° Ligne). En sortie nous avons S (3° Ligne) et R (4° Ligne). Lorsque A et B valent 0 alors S vaut 0 et R vaut 0. Ensuite lorsque A vaut 0 et B vaut 1 alors on a S à 1 et R à 0. Après on fait passer A à 1 et B à 0 ce qui donne 1 pour S et 0 pour R. Enfin lorsque A et B valent 1 alors S est à 0 et R à 1. Nous avons donc bien les caractéristiques d’un demi-additionneur 1 bit.

***Exercice 2 : Additionneur Complet***

Dans ce dernier exercice nous avons réalisé un composant additionneur complet 1 bit (FullAdder). Pour cela on réutilise le demi-additionneur élaboré ci-dessus. Cet additionneur complet a comme caractéristique un temps de propagation de 1 ns à chaque porte logique de base. Donc les sources VHDL liées à cet exercice sont : xor.vhdl, et.vhdl, ou.vhdl et test\_full\_add.vhdl. De plus comme vous pouvez le voir nous avons ajouté une porte OU dans notre réalisation : elle nous servira à relier les deux retenues sortantes des deux demi-additionneurs en faisant R1+R2. On se sert du OU créé dans le TP8.

**Chronogramme :**

![](data:image/png;base64,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)

Sur ce chronogramme en entrée nous avons Rin (1° Ligne), B (2° Ligne) et A (3° Ligne) puis en sortie nous avons S (4° Ligne) et Rout (5° Ligne). Quand nos entrées sont initialisées à 0 alors nos sorites valent 0. Ensuite lorsque l’on passe A à 1 on a S à 1 et Rout à 0. Ensuite on a A à 0, B à 1 et Rin à 0 on obtient toujours S à 1 et Rout à 0 et cela ainsi de suite pour arriver au cas où toutes nos entrées sont à 1 et alors nos sorties sont à 1. Par conséquent on constate bien que l’on obtient un additionneur complet 1 bit à l’aide de deux demi-additionneurs 1 bit réalisé dans l’exercice précédent.