ENI: Électronique Numérique Intégrée


---

Chapitre 2
Fonctions de base


 2.1 Introduction
 2.2 Variables et fonctions logiques, tables de vérité
 2.3 Représentations des fonctions logiques
  2.3.1 Formes algébriques
  2.3.2 Forme disjonctive
  2.3.3 Forme conjonctive
  2.3.4 Équivalence entre la table de vérité et les formes canoniques
  2.3.5 Forme canonique disjonctive
  2.3.6 Forme canonique conjonctive
 2.4 Description de méthodes de simplification
  2.4.1 Utilisation des propriétés de l’algèbre de Boole
  2.4.2 Simplification à partir de la forme algébrique
  2.4.3 Méthode des tables de Karnaugh
  2.4.4 Construction du tableau de Karnaugh
  2.4.5 Règles de simplification
  2.4.6 Fonctions non complètement définies
  2.4.7 Pertinence de la méthode
 2.5 Représentation schématique des fonctions logiques
 2.6 Quelques fonctions combinatoires importantes
  2.6.1 Fonctions d’aiguillage : multiplexeurs
  2.6.2 Opérateurs de comparaison
 2.7 Annexes
  2.7.1 Exercice de consolidation
  2.7.2 Bibliographie

2.1 Introduction

Nous évoquons, dans le chapitre 1, la possibilité de réaliser physiquement des fonctions de calcul utilisant une représentation binaire des données. Avant de poursuivre plus avant l’étude de la réalisation physique de ces fonctions, nous allons développer les bases mathématiques des fonctions logiques (Algèbre de Boole) ainsi que les méthodes de représentation et de manipulation associées.

Le choix d’une structure physique optimale pour construire une fonction logique est une opération complexe dépendant de nombreuses contraintes telles que l’optimisation de la vitesse de traitement, la minimisation de l’énergie dissipée par opération ou tout simplement le coût de fabrication.

Nous nous contenterons dans ce chapitre d’envisager le critère suivant qui pourra être remis en cause dans la suite du cours :

2.2 Variables et fonctions logiques, tables de vérité

Considérons l’ensemble E à 2 éléments (0,1).

  1. Une variable logique est un élément de E et ne possède ainsi que 2 états 0 et 1. Elle est représentée par des lettres (A,b,e,X,⋅⋅⋅).
  2. Une fonction logique de plusieurs variables applique E × E ×⋅⋅⋅E dans E. Elle associe à un n-uplet de variables booléennes (e0,e1,⋅⋅⋅,en-1) une valeur F(e0,e1,⋅⋅⋅,en-1).
  3. Il existe différentes manières d’exprimer une fonction booléenne. Une fonction de n variables est entièrement décrite par l’énoncé des valeurs de cette fonction pour l’ensemble (ou le sous-ensemble de définition) des combinaisons du n-uplet de variables :
    F(0,⋅⋅⋅ ,0,0),F(0,⋅⋅⋅ ,0,1),F (0,⋅⋅⋅ ,1,0),⋅⋅⋅ ,F(1,⋅⋅⋅ ,1,1)

    Cet énoncé prend généralement la forme d’un tableau à n + 1 colonnes et au plus 2n lignes, chaque ligne exposant une combinaison des variables et la valeur correspondante de la fonction. Les tableaux 2.1 et 2.2 suivants donnent la forme générale de tables de vérité de fonctions de trois variables totalement (fonction F) ou partiellement (fonction G) définies.

|------------|
ABCF (A,B, C)  |
|------------|
000 F (0,0,0)  |
|            |
001 F (0,0,1)  |
010 F (0,1,0)  |
|            |
011 F (0,1,1)  |
100 F (1,0,0)  |
|            |
101 F (1,0,1)  |
110 F (1,1,0)  |
|            |
111 F(1,1, 1)  |

Tab. 2.1: Table de vérité d’une fonction de 3 variables.

|------------|
ABCG(A, B, C)  |
|------------|
000     1      |
|            |
001     1      |
010     0      |
|            |
011non  définie |
100non  définie |
|            |
101     1      |
110     0      |
|            |
111     0      |

Tab. 2.2: Table de vérité d’une fonction partiellement définie.

2.3 Représentations des fonctions logiques

2.3.1 Formes algébriques

Nous associons, à l’ensemble E, l’algèbre de Boole basée sur trois opérateurs logiques :

Les tables de vérité de ces trois fonctions logiques sont données dans les tableaux 2.3, 2.4 et 2.5.

|
|
AA
01
|
10

Tab. 2.3: Opérateur NON.

|---|
ABA+B--|
|   |
000   |
011   |
|   |
101   |
111   |

Tab. 2.4: Opérateur OU.

|--|
ABA⋅B---
|--|
000  |
010  |
|  |
100  |
111  |

Tab. 2.5: Opérateur ET.

Une fonction logique booléenne se présente comme une association des opérations algébriques précédentes sur un ensemble de variables. Elle peut s’écrire de plusieurs façons.

2.3.2 Forme disjonctive

Elle correspond à une somme de produits logiques : F = Σ Π(ei)  , où ei représente une variable ou son complément. Exemple :

                      --  -- --
F1(X,Y,Z) = X ⋅Y + X ⋅Z + X ⋅Y ⋅Z

Si chacun des produits contient toutes les variables d’entrée sous une forme directe ou complémentée, alors la forme est appelée « première forme canonique » ou « forme canonique disjonctive ». Chacun des produits est alors appelé minterme. Exemple de forme canonique disjonctive :

            -- --     --           -- --
F2(X,Y, Z) = X ⋅Y ⋅Z + X ⋅Y ⋅Z + X ⋅Y ⋅Z

2.3.3 Forme conjonctive

Elle fait référence à un produit de sommes logiques : F = Π Σ(ei)  . Voici un exemple :

                     --      --      --
F3(X,Y,Z) = (X + Y)⋅(X + Z) ⋅(X  + Y + Z)

Si chacune des sommes contient toutes les variables d’entrée sous une forme directe ou complémentée, alors la forme est appelée « deuxième forme canonique » ou « forme canonique conjonctive ». Chacune des sommes est alors appelée maxterme. Exemple de forme canonique conjonctive :

                         --  --      --      --
F4(X,Y,Z) = (X + Y + Z)⋅(X + Y + Z) ⋅(X + Y + Z)

2.3.4 Équivalence entre la table de vérité et les formes canoniques

Nous avons défini la table de vérité d’une fonction comme la correspondance entre chaque combinaison des variables (du domaine de définition de la fonction) et la valeur (0 ou 1) associée de cette fonction.

Chacune des combinaisons des variables définit un état des entrées, on peut donc associer un état à chaque ligne d’une table de vérité.

2.3.5 Forme canonique disjonctive

Une fonction logique est représentée par l’ensemble des états pour lesquels la fonction est égale à « 1 ».

Considérons maintenant un état des entrées pour lequel une fonction booléenne vaut « 1 » : il existe un minterme unique prenant la valeur « 1 » dans cet état.

Il suffit donc d’effectuer la somme logique (ou réunion) des mintermes associés aux états pour lesquels la fonction vaut « 1 » pour établir l’expression canonique disjonctive de la fonction.

Exemple d’une fonction H à trois variables entièrement définie :

|------------||------|------------|
ABCH(A,  B, C) ||État  |Minterme    |
|------------||------|------------|
000     1      ||  0   |A  ⋅B ⋅C    |
|            ||      |--  --      |
001     1      ||  1   |A- ⋅B ⋅ C   |
010     0      ||  2   |A  ⋅ B ⋅C   |
|            ||      |--          |
011     1      ||  3   |A  ⋅ B-⋅ C  |
100     0      ||  4   |A  ⋅B ⋅C    |
|            ||      |    --      |
101     1      ||  5   |A  ⋅B ⋅ C   |
110     0      ||  6   |A  ⋅ B ⋅C   |
|            ||      |            |
111     0      ||  7   |A  ⋅ B ⋅ C  |

Tab. 2.6: Table de vérité de la fonction H : états associés et mintermes.

On remarque que H(A,B,C) = 1 pour les états 0, 1, 3, 5. On écrit la fonction ainsi spécifiée sous une forme dite numérique : H = R(0,1,3,5), Réunion des états 0, 1, 3, 5. La première forme canonique de la fonction H s’en déduit directement :

            -- ----  -- --     --          --
H(A, B,C) = A ⋅B ⋅C + A ⋅B ⋅C + A ⋅B ⋅C + A ⋅B ⋅C

2.3.6 Forme canonique conjonctive

Considérons maintenant un état des entrées pour lequel la fonction vaut « 0 ».

Il existe un maxterme unique prenant la valeur « 0 » en cet état. Ce maxterme prend donc la valeur « 1 » dans tous les autres états des entrées.

Il suffit donc d’effectuer le produit logique (ou intersection) des maxtermes associés aux états pour lesquels la fonction vaut « 0 » pour établir l’expression canonique conjonctive de la fonction.

Reprenons l’exemple de la fonction H :

|------------||------|-------------|
ABCH(A,  B, C) ||Etat  |Maxterme     |
|------------||------|-------------|
000     1      ||  0   |A  + B + C   |
|            ||      |         --  |
001     1      ||  1   |A  + B-+ C   |
010     0      ||  2   |A  + B + C   |
|            ||      |     --  --  |
011     1      ||  3   |A- + B + C   |
100     0      ||  4   |A  + B + C   |
|            ||      |--       --  |
101     1      ||  5   |A- + B-+ C   |
110     0      ||  6   |A  + B + C   |
|            ||      |--   --  --  |
111     0      ||  7   |A  + B + C   |

Tab. 2.7: Table de vérité de la fonction H : états associés et maxtermes.

On remarque que H(A,B,C) = 0 pour les états 2, 4, 6, 7. On écrit la fonction ainsi spécifiée sous une forme dite numérique : H = I(2,4,6,7) Intersection des états 2, 4, 6, 7.

La deuxième forme canonique de la fonction H s’en déduit directement :

H(A,B, C) = (A + B-+ C)⋅(A-+ B + C)⋅(A-+ B-+ C)⋅(A-+ B-+ C)

2.4 Description de méthodes de simplification

On cherche ici à obtenir une expression algébrique comportant un nombre minimal de termes, ainsi qu’un nombre minimal de variables dans chaque terme dans le but de simplifier la réalisation matérielle.

Attention : Comme nous l’avons indiqué en introduction, l’optimisation d’une fonction logique dépend de paramètres tels que la performance en vitesse désirée, la consommation maximale autorisée ou l’obligation d’utiliser des bibliothèques de fonctions élémentaires prédéfinies. La complexité de la représentation algébrique n’est donc qu’un critère d’optimisation parmi d’autres.

2.4.1 Utilisation des propriétés de l’algèbre de Boole

Les propriétés, lois et théorèmes fondamentaux de l’algèbre de Boole sont à notre disposition pour manipuler les équations :

Complémentarité :                      a+ a-= 1,    a⋅a-= 0,    a = a

Idempotence:                   a+ a +a + ⋅⋅⋅ = a,              a⋅a⋅a ⋅⋅⋅ = a
Élémentsneutres :                   a+ 0 = a,                     a ⋅1 = a
Élémentsabsorbants :                a+ 1 = 1,                     a ⋅0 = 0

Commutativité :                   a + b = b+ a,                  a ⋅b = b⋅a
Associativité:            (a + b)+ c = a+ (b+ c) = a + b+ c, (a ⋅b) ⋅c = a⋅(b⋅c) = a ⋅b⋅c
Distributivité:                (a + b)⋅c = (a⋅c)+ (b⋅c),     (a⋅b)+ c = (a + c) ⋅(b+ c)

Théorèmed’absorption (1) :        a+ (a⋅b) = a ,                a⋅(a+ b) = a
Théorèmed’absorption (2) :       a ⋅ˉb+ b = a+ b ,              (a + ˉb)⋅b = a ⋅b
Théorèmed’adjacence :          (a + ˉb) ⋅(a + b) = a,              a ⋅ˉb+ a⋅b = a

Remarque : Deux termes sont dits adjacents logiquement s’ils ne diffèrent que par une variable.

Théorème de De Morgan :

-----  ---     ----  -- -
a + b = a⋅b ,  a ⋅b = a+ b

Premier théorème d’expansion :

F(e0,e1,⋅⋅⋅,ei,⋅⋅⋅ ,en-1) = ei ⋅F (e0,e1,⋅⋅⋅ ,1,⋅⋅⋅ ,en-1)+ ei ⋅F(e0,e1,⋅⋅⋅ ,1,⋅⋅⋅ ,en- 1)

Second théorème d’expansion :

F(e,e,⋅⋅⋅,e,⋅⋅⋅ ,e  ) = [e +F (e,e ,⋅⋅⋅ ,0,⋅⋅⋅ ,e )]⋅[e-+ F(e ,e ,⋅⋅⋅ ,1,⋅⋅⋅ ,e )]
01i     n-1    i      0 1           n-1    i     0  1          n- 1

2.4.2 Simplification à partir de la forme algébrique

Les méthodes algébriques employées se rapportent aux relations fondamentales d’absorption, d’adjacence, de mise en facteur et aux théorèmes de De Morgan. On distingue plusieurs procédés permettant d’aboutir au but recherché :

Regroupement des termes et mises en facteur

       ---     --- -   --    -   ---      -   --    -
Z  =   a⋅c⋅d + a⋅c⋅d + a⋅b⋅c⋅d = a⋅c ⋅(d + d)+ a⋅b⋅c⋅d
   =   a⋅c+ a-⋅b⋅c⋅d = a⋅(c+ c⋅b⋅d) = a⋅(c+ b⋅d)

Nous avons successivement utilisé une mise en facteur, la complémentarité, une deuxième mise en facteur et enfin le théorème d’absorption.

Réplication de termes existants

                 -
Z   =  a⋅b ⋅c+ a⋅b⋅c + a⋅b⋅c+ a ⋅b⋅c
    =  a⋅b ⋅c+ a⋅b⋅c + a⋅b⋅c+ a ⋅b⋅c+ a⋅b ⋅c+ a⋅b⋅c
        --          -            -
    =  (a+ a)⋅b ⋅c + (b +b)⋅a ⋅c+ (c+ c)⋅a⋅b
    =  b⋅c +a ⋅c+ a⋅b

La réplication du terme abc permet de simplifier chacun des trois premiers termes en utilisant une mise en facteur et la complémentarité.

Suppression de termes superflus

Z  =  a-⋅b+ b⋅c+ a-⋅c = a-⋅b + b⋅c+ a⋅c ⋅(b +b)
      -- -  ---  -    -  --   -  ---      -     -     --
   =  a-⋅b+ a⋅b ⋅c+ b⋅c+ a ⋅b ⋅c = a⋅b ⋅(1 + c) + b⋅c⋅(1+ a)
   =  a ⋅b+ b⋅c

Nous avons ici réintroduit la variable b dans le troisième terme par l’intermédiaire de la propriété de complémentarité, nous avons ensuite utilisé la propriété d’absorption pour simplifier les produits.

Simplification par utilisation des formes canoniques

Si l’on dispose de la table de vérité de la fonction, on prend pour équation algébrique de départ la forme canonique comportant le minimum de termes. Cette équation sera ensuite simplifiée en utilisant les méthodes décrites précédemment. En effet, pour une fonction à N entrées, la forme canonique disjonctive comportera P mintermes (avec P 2N), alors que la forme conjonctive comportera 2N - P maxtermes.

2.4.3 Méthode des tables de Karnaugh

Les tables de Karnaugh sont des représentations sous forme d’un tableau à deux dimensions de la table de vérité. Elles sont construites de façon à ce que les termes logiquement adjacents soient géométriquement adjacents. Chaque ligne de la table de vérité est représentée par une case du tableau de Karnaugh dans laquelle on indique la valeur de la fonction.

La contrainte d’adjacence géométrique est réalisée par un ordonnancement des lignes (resp. colonnes) du tableau pour lequel le nombre de bits modifiés d’un code au suivant est constant et égal à un. Cette propriété est respectée entre le code de la dernière ligne (resp. colonne) et celui de la première ligne (resp. colonne). Prenons par exemple le cas d’une fonction F de trois variables, spécifiée dans le tableau 2.8.

|------------|------------|
ABCF (A,B, C)  |minterme    |
|------------|------------|
000     0      |A ⋅ B ⋅C    |
|            |--  --      |
001     1      |A-⋅ B ⋅ C   |
010     0      |A ⋅ B ⋅C    |
|            |--          |
011     1      |A ⋅ B-⋅ C   |
100     1      |A ⋅ B ⋅C    |
|            |    --      |
101     1      |A ⋅ B ⋅ C   |
110     1      |A ⋅ B ⋅C    |
|            |            |
111     1      |A ⋅ B ⋅ C   |

Tab. 2.8: Table de vérité de la fonction F : états associés et mintermes.

 

\\BC--|----|---|----|
\\00 |01  |11 |10  |
\\A--|----|---|----|
00  | 1  |1  | 0  |
|  |    |   |    |
11  | 1  |1  | 1  |

Tab. 2.9: Table de Karnaugh de la fonction F.
 
\-----|-------|-------|--------|
\\\BC00   |  01   |  11   |  10    |
\\A-----|-------|-------|--------|
----- |----   |--     | -- --  |
0A⋅B-⋅C- |A ⋅B-⋅C  |A ⋅B ⋅C  | A⋅B ⋅C-  |
1A⋅B ⋅C  |A ⋅B ⋅C  |A ⋅B ⋅C  |A ⋅B ⋅C   |

Tab. 2.10: Correspondance des mintermes.

Nous constatons que la fonction F est égale à « 1 » pour :

|-|----|----|---|
\\BC |    |    |   |
\\\A00 | 01 |11  |10 |
\-|----|----|---|
00#|#1####1###0##|
11#|#1####1###1##|

Tab. 2.11: Adjacence : a = 1

|-|----|----|---|
\\BC |    |    |   |
\\\A00 | 01 |11  |10 |
\-|#########|---|
00-|#1####1##|0--|
11 |#1####1##|1  |

Tab. 2.12: Adjacence : c = 1

Les deux zones déterminées « recouvrant » exactement les cases du tableau où la fonction F vaut 1, nous pouvons en déduire directement que : F = a + c.

Nous allons maintenant généraliser la méthode exposée dans l’exemple.

2.4.4 Construction du tableau de Karnaugh

2.4.5 Règles de simplification

Il s’agit de « paver » le tableau de Karnaugh en regroupant les « 1 » adjacents de telle manière que :

Chaque pavé ainsi constitué représente un terme produit de la fonction ne contenant que les variables « stables » (par rapport au codage des lignes et des colonnes du tableau).

Attention !

L’exemple suivant (Tab. 2.13) illustre ces deux principes :

|-|----|----|---|
\\BC |    |    |   |
\\\A00 | 01 |11  |10 |
\-|----|----|---|
01-|-1--|-1--|0--|
11 | 0  | 1  |1  |

Tab. 2.13: Table de Karnaugh

 

|-|----|----|---|
\\BC |    |    |   |
\\\A00 | 01 |11  |10 |
\###########|---|
01#|-1--##1###0##|
11#| 0  ##1###1##|

Tab. 2.14: Premier pavage
 
|-|----|----|---|
\\BC |    |    |   |
\\\A00 | 01 |11  |10 |
\###########|---|
01#|-1--##1###0##|
11#| 0  ##1###1##|

Tab. 2.15: Deuxième pavage

Selon le premier pavage (Tab. 2.14), l’expression obtenue est :

-
b⋅c+ a⋅c + a⋅b

Le second pavage (Tab. 2.15), qui utilise une adjacence entre deux cases extrêmes, donne :

---          -
a⋅b+ b⋅c + a⋅c

2.4.6 Fonctions non complètement définies

Certaines combinaisons peuvent ne pas se produire : elles n’ont pas d’effet sur la valeur de la fonction. Ces états indifférents, notés X ou -, peuvent être utilisés partiellement ou totalement pour simplifier la fonction, comme illustré dans l’exemple de la Fig. 2.16.

|--|----|---|----|----|
\\\\CD  |    |   |    |    |
\\\AB  |00  |01 | 11 |10  |
|\\-|----|---|----|----|
00--|-1--|-1-|-0--|-0--|
01  | 1  |X  | X  | X  |
|--|----|---|----|----|
11--|-0--|-1-|-1--|-0--|
10  | 0  | 0 | 0  |0   |

Tab. 2.16: Table de Karnaugh

 

|--|----|---|----|----|
\\\\CD  |    |   |    |    |
\\\AB  |00  |01 | 11 |10  |
|\\-#########|----|----|
00--##1####1#|-0--|-0--|
01  ##1####1#| X  | X  |
|--|----|---|----|----|
11--|-0--|-1-|-1--|-0--|
10  | 0  | 0 | 0  |0   |

Tab. 2.17: Premier pavage
 
|--|----|---|----|----|
\\\CD  |    |   |    |    |
\\\\AB  |00  |01 | 11 |10  |
|\\-|----|---|----|----|
00--|-1--##1###0##|-0--|
01  | 1  ##1###1##| X  |
|--|----#########|----|
11--|-0--|-1-|-1--|-0--|
10  | 0  | 0 | 0  |0   |

Tab. 2.18: Deuxième pavage

On profite du fait que les états indifférents peuvent être interprétés au choix comme des 1 ou des 0 pour réaliser les regroupements les plus pertinents permettant d’aboutir à une expression logique minimale. Ici, les deux regroupements en carrés retenus dans les tableaux 2.17 et 2.18 s’imposent naturellement.

L’expression obtenue finalement est :

a-⋅c+ b⋅d

2.4.7 Pertinence de la méthode

Dans une représentation à 2 dimensions, chaque case a au plus 4 cases géométriquement adjacentes. Pour une fonction logique de plus de 4 variables, le nombre d’adjacences logiques pour un minterme (égal au nombre de variables) devient supérieur aux possibilités dans le plan. Les groupements deviennent alors moins naturels, et la méthode n’est plus aussi utile.

2.5 Représentation schématique des fonctions logiques

Notre bibliothèque de fonctions ou portes logiques élémentaires n’est pour l’instant constituée que des trois opérateurs inversion (NOT), « et » logique (AND) et « ou » logique (OR). Nous allons compléter cette bibliothèque par quelques éléments supplémentaires dont l’objectif est de mettre en place une représentation schématique des fonctions logiques.

Nous distinguerons ainsi :

Ces deux fonctions sont la simple complémentation des fonctions AND et OR.

Nous associons maintenant à chacune des fonctions NOT, OR, AND, NAND et NOR un symbole graphique. La complémentation sera représentée systématiquement par un cercle :

AND   OR   NOT   NAND   NOR  
PIC
 
PIC
 
PIC
 
PIC
 
PIC
 
 

Fig. 2.1: Symboles des portes élémentaires.

Exemple de schéma et équation algébrique correspondante :

Y=((A+B)⋅C)+ C-    
PIC

Fig. 2.2: Un exemple de schéma.

2.6 Quelques fonctions combinatoires importantes

2.6.1 Fonctions d’aiguillage : multiplexeurs

La fonction « multiplexeur à N entrées » consiste à aiguiller vers la sortie de la fonction une entrée parmi N. Le multiplexeur à 2 entrées est le multiplexeur le plus simple à concevoir. Son équation algébrique est de la forme :

Y = A-⋅E0 +A ⋅E1 ,

(E0 , E1 ) sont les entrées à multiplexer et A est une entrée de sélection.

La fonction multiplexeur est une traduction directe d’une instruction de type « if ⋅⋅⋅ then ⋅⋅⋅ else ⋅⋅⋅» dans le cadre de langages informatiques. Elle permet aussi de décomposer une fonction booléenne complexe en utilisant les théorèmes d’expansion.

Le multiplexeur à deux entrées est souvent symbolisé de la façon suivante :

PIC

Fig. 2.3: Multiplexeur à deux entrées (Mux2).

Le multiplexeur à 2N entrées nécessite N entrées de sélection pour distinguer les 2N configurations des entrées.

Nous allons tenter maintenant de construire un multiplexeur à 4 entrées à partir des portes de base définies dans le chapitre précédent. L’expression algébrique de la sortie est de la forme :

    --- ---         ---     ---
S = A0 ⋅A1 ⋅E0 + A0 ⋅A1 ⋅E1 + A0 ⋅A1 ⋅E2 + A0 ⋅A1 ⋅E3

Cette formulation fait apparaître tous les mintermes possibles à partir des entrées de sélection (A0,A1). Le schéma de la Fig. 2.4 présente un multiplexeur à 4 entrées muni de plus une entrée supplémentaire V permettant de valider ou d’invalider (S = 0) la sortie de la fonction.

PIC

Fig. 2.4: Schéma interne d’un multiplexeur à 4 entrées avec entrée de validation.

Remarque : Il est possible de construire un multiplexeur à 4 entrées à partir de 3 multiplexeurs à 2 entrées. On se base pour cela sur la reformulation suivante, illustrée dans la Fig. 2.5.

    ---  ---                  ---
S = A1 ⋅(A0 ⋅E0 + A0 ⋅E1) + A1 ⋅(A0 ⋅E2 +A0 ⋅E3)

PIC

Fig. 2.5: Reformulation du multiplexeur à 4 entrées.

2.6.2 Opérateurs de comparaison

Les fonctions de comparaison les plus simples sont le test de l’égalité de deux variables booléennes ainsi que le test de complémentarité de deux variables booléennes. Ces deux fonctions ont pour équations algébriques respectives :

                       -- --
        Égalité : S  =   A ⋅B-+A-⋅B
Complémentarité : S  =   A ⋅B +A ⋅B

Ces fonctions étant très souvent utilisées, il a été jugé utile de définir un nouvel opérateur booléen pour les représenter. Il s’agit de l’opérateur « OU exclusif » que nous représenterons par le symbole suivant : .

Les relations précédentes deviennent :

                                      ----            ------
Égalité (NON -OU-exclusif ou XNOR) : S =   A⋅B + A ⋅B   =  A ⊕ B
Complémentarité (OU -exclusif ou XOR) : S =  A⋅B-+ A-⋅B   =  A ⊕ B

Les tables de vérité et symboles associés à ces fonctions sont donnés dans les tableaux 2.19 et  2.20.

|-----|---|---|--------|
|     |A  |B  | A-⊕-B--|
|     |   |   |        |
|     |---|---|--------|
|     |0  |0  |   1    |
|     |   |   |        |
|     |0  |1  |   0    |
|     |1  |0  |   0    |
|     |   |   |        |
       1   1      1

Tab. 2.19: Table de vérité et symbole des opérateurs XNOR

|-----|---|---|--------|
|     |A  |B  | A ⊕ B  |
|     |   |   |        |
|     |---|---|--------|
|     |0  |0  |   0    |
|     |   |   |        |
|     |0  |1  |   1    |
|     |1  |0  |   1    |
|     |   |   |        |
       1   1      0

Tab. 2.20: Table de vérité et symbole des opérateurs XOR

Disposant du comparateur d’égalité à deux entrées, il est possible de généraliser l’opérateur à la comparaison de deux mots de N bits. L’exemple suivant montre un comparateur opérant sur 2 mots de 4 bits.

Nous disposons de 2 nombres codés sur 4 bits : A = a3a2a1a0  et B = b3b2b1b0  .

Alors A = B si et seulement si (a3 = b3)  et (a2 = b2)  et (a1 = b1)  et (a0 = b0)  , ce qui justifie le montage de la Fig. 2.6.

PIC

Fig. 2.6: Test d’égalité de deux mots de 4 bits.

2.7 Annexes

2.7.1 Exercice de consolidation

L’expérience a montré que parmi les notions qui viennent d’être exposées, celle dans laquelle on se prend le plus fréquemment les « pieds dans le tapis » et qui par ailleurs sert le plus dans le cadre du module est la simplification des tables de Karnaugh. L’exercice suivant constitue en conséquence un petit entraînement qui pourrait s’avérer salutaire afin d’être au point sur ce sujet.

On désire réaliser un afficheur 7 segments (a,b,c,d,e,f,g, voir Fig. 2.7) traduisant un nombre binaire exprimé sur 4 bits A, B, C, D en un symbole hexadécimal (0,⋅⋅⋅,9,A,b,C,d,E,F).

PIC

Fig. 2.7: Afficheur 7 segments. Un segment = une diode électro-luminescente.

La transcription de cette réalisation en tables de vérité si l’on considère que l’on travaille en logique positive (segment allumé = « 1 ») donne une table par segment.

Pour vous aider, il vous est proposé de vous donner directement le tableau de Karnaugh correspondant au segment « a » ainsi que le résultat obtenu après simplification.

PIC

Fig. 2.8: Tableau de Karnaugh de a = F(A,B,C,D).

Le résultat à trouver est :

      --         --     -- --  --          -- --
a = A⋅D + B ⋅C + A ⋅C + B ⋅D + A⋅B ⋅D + A ⋅B ⋅C

Comment l’obtient-on ? Détaillons pour les sceptiques !

Regroupement : B ⋅C

PIC

Regroupement : --
A ⋅C

PIC

Regroupement : A ⋅D-

PIC

Regroupement : -- --
B ⋅D  .
Les extrémités sont logiquement adjacentes !

PIC

Regroupement : --
A ⋅B ⋅D

PIC

Enfin, Regroupement :    -- --
A ⋅B ⋅C  .

PIC

L’équation du premier segment a est ainsi obtenue à l’aide des 6 regroupements précédents. A vous de les effectuer pour les autres segments

Si vous arrivez au bout de cet exercice dans un temps raisonnable, vous pouvez considérer que vous ne rencontrerez pas beaucoup de problèmes dans le futur !

2.7.2 Bibliographie



Pour revenir au sommaire des supports du cours ENI.
---

Page maintenue par Jean Provost
Dernière modification:23 août 2006