INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Représentation et opérations.

Slides:



Advertisements
Présentations similaires
Architecture de machines Codage des informations
Advertisements

t(s) U(v) CAN temps ,4v
t(s) U(v) CAN temps ,4v
Le codage de l ’information
Architecture des Ordinateurs
Les types de codage Le complément à 2 : Nombres entiers
Présentation Unité de codage
Le binaire L’historique.
Ing Mohamed MASMOUDI Cours VHDL Ing Mohamed MASMOUDI
Exercices sur la conception de processeurs
Décrire un circuit numérique avec VHDL
Cours #9 Conception et réalisation de processeurs à usage général
TRAVAIL 3 : PRODUCTION MULTIMÉDIA
Cours #6 Conception d’unités de contrôle
Cours #12: Exercices de révision
Cours #8 Flot de conception d’un circuit numérique
Le codage des nombres en informatique
Cours #4 Éléments à mémoire et circuits séquentiels synchrones de base
Arithmétique des “computers”
Cours #7 Vérification d’un modèle VHDL
Cours #5 Conception de chemins des données
La logique binaire 1.
Modélisation VHDL d’un chemin des données
Codage de l’information
Décodeurs et encodeurs : sujets de ce thème
CORDIC Sujets de ce thème
Chapitre 2 : Représentation de l’information dans la machine
Représentation binaire de nombres entiers et opérations arithmétiques de base Sujets de ce thème
Représentation des informations
Cours de langage d'assemblage
Banc d’essai pour un circuit combinatoire
Le Système Binaire Introduction Les bases à connaitre Conversions
Codage des nombres réels avec la norme IEEE-754
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Synthèse d’un circuit.
Modélisation VHDL du chemin des données d’un processeur à usage général Sujets de ce thème
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois La technique du pipeline.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Analyse de machines.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Augmenter le débit d’un.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Description d’un circuit.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Bonnes pratiques de.
Synthèse et implémentation de circuits arithmétiques sur FPGA
Processeurs et chemins des données
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Entrées et sorties par.
Le codage des nombres binaires
INF8505: processeurs embarqués configurables Département de génie informatique et génie logiciel Langages de description architecturale.
Méthodologie de conception Outils de conception
Tests de boîte noire.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Vérification de circuits.
Chemin critique et fréquence maximale d’horloge
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Le problème du déphasage.
Cohen Julien Neville gabriel
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Encodage du jeu d’instructions.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Arithmétique entière.
Concepts intermédiaires de VHDL
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Modélisation VHDL de.
Synthèse et implémentation d’un circuit combinatoire
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Simulation d’un modèle.
Journées d'études Faible Tension Faible Consommation 14, 15, 16 mai Gwenolé CORRE, Nathalie JULIEN, Eric SENN, Eric MARTIN LESTER, Université de.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Banc d’essai pour un.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Objets des catégories.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Analyse détaillée du.
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Tests exhaustifs.
Implémentation de la division sur FPGA
VHDL pour circuits séquentiels
INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Flot de conception de.
150+2,6= Car 150 =150,0 Et 150,0 + 2,6 152,6 152,6.
26+2,9= Car 26 =26,0 Et 26,0 + 2,9 28,9 28, ,3 = Car si on pose 100 = 100,0 et 100,0 - 99,3 0,7 OU Dans la tête, on retranche 99 à 100 soit 1.
A. Lebrun. La base 2 Un nombre peut se représenter en base deux par une suite de 0 ou de 1. Chaque bit a un poids qui dépend de son rang Le format n impose.
Le codage des nombres en informatique
1 Objectifs Apprendre la structure de quelques circuits combinatoires souvent utilisés ( demi additionneur, additionneur complet,……..). Apprendre comment.
Transcription de la présentation:

INF3500 : Conception et implémentation de systèmes numériques Pierre Langlois Représentation et opérations sur les nombres décimaux à virgule fixe

INF3500 : Conception et implémentation de systèmes numériques Représentation de nombres décimaux à virgule fixe Sujets de ce thème Pourquoi utiliser la représentation décimale en binaire Comment représenter un nombre en format BCD L’addition BCD La soustraction BCD 2

INF3500 : Conception et implémentation de systèmes numériques Pourquoi BCD? L’encodage de nombres dans un format binaire décimal remonte au début de l’ère informatique. L’avantage principal est la facilité d’affichage des données pour les humains, sans besoin d’opérations de conversion. Un avantage reconnu plus récemment est la possibilité de faire des calculs exacts pour des transactions financières puisque la plupart des monnaies ont des divisions en centièmes. Les désavantages de l’encodage BCD en binaire sont une plus faible densité d’entreposage et le besoin de faire des opérations supplémentaires en arithmétique. 3

INF3500 : Conception et implémentation de systèmes numériques Représentation sur 4 bits En BCD, chaque chiffre d’un nombre peut prendre une valeur entre 0 et 9, inclusivement, et est encodé sur quatre bits : {0000, 0001, 0010, 0011, 0100, 0101, 0110, 0111, 1000, 1001}. La densité du code est donc de 10/16, soit 62.5%. Un nombre de plusieurs chiffres décimaux est formé en groupant des quartets: – 1234: – 991: Le format ‘Packed BCD’ groupe deux quartets par octet. Il existe des formats beaucoup plus efficaces, dont le format Densely Packed Decimal qui représente trois chiffres avec 10 bits. 4

INF3500 : Conception et implémentation de systèmes numériques Addition BCD Pour additionner correctement deux chiffres BCD, on utilise un additionneur binaire à 4 bits et une retenue. Il y a deux cas possible: – la somme est un chiffre BCD valide (0 à 9); ou, – la somme est égale ou supérieure à dix. Dans le premier cas, aucune action n’est requise. Dans le deuxième cas, il faut ajouter +6 à la somme obtenue. La combinaison de la retenue et de la somme finale produit alors un résultat correct. 5 Exemple : addition en BCD : | ← somme inférieure à dix, résultat correct (retenue 0, somme 7) Exemple : addition en BCD : | ← somme supérieure à 9, il faut ajouter | ← résultat correct, retenue de 1, somme de 5 Exemple : addition en BCD : | ← somme supérieure à 9, il faut ajouter | ← résultat correct, retenue de 1, somme de 7

INF3500 : Conception et implémentation de systèmes numériques Addition BCD: chemin des données et code VHDL 6 library IEEE; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity addBCD is port ( oper1, oper2 : in unsigned(3 downto 0); somme : out unsigned(3 downto 0); cout : out std_logic ); end addBCD; architecture arch1 of addBCD is begin process(oper1, oper2) variable t : unsigned(4 downto 0); begin t := ('0' & oper1) + ('0' & oper2); if (t > 9) then t := t + 6; end if; somme <= t(3 downto 0); cout <= t(4); end process; end arch1;

INF3500 : Conception et implémentation de systèmes numériques Soustraction BCD Comme dans le cas des nombres binaires signés, la soustraction BCD peut se faire sous la forme d’une addition. On doit prendre le complément à 10 du nombre à soustraire et l’ajouter. Le complément à 10 se trouve en prenant le complément à 9 de chaque chiffre et en ajoutant 1 au nombre résultant. On laisse tomber toute retenue. Le chiffre le plus significatif du nombre indique son signe: positif de 0 à 4, négatif de 5 à 9. Avec trois chiffres, on peut donc représenter les nombres de -500 à ChiffreComplément à

INF3500 : Conception et implémentation de systèmes numériques Vous devriez maintenant être capable de … Connaître et utiliser la représentation BCD sur 4 bits. (B2, B3) Décrire et utiliser l'addition et la soustraction pour ces nombres. (B2, B3) 8 CodeNiveau ( B1Connaissance - mémoriser de l’information. B2Compréhension – interpréter l’information. B3Application – confronter les connaissances à des cas pratiques simples. B4Analyse – décomposer un problème, cas pratiques plus complexes. B5Synthèse – expression personnelle, cas pratiques plus complexes.