## SEN1- Electronique Numérique

# Circuits séquentiels

L1 Portail IE Johanne Bézy

1

### Introduction / Plan

Définition : dans les schémas de « logique séquentielle », la sortie dépend non seulement des entrées mais aussi de l'histoire du système (états précédents). Il y a un effet mémoire.

- 1. Bascules
- 2. Compteurs
- 3. Registres

### 1.1. Définitions

- Les bascules sont des éléments bistables synchrones. Le terme "synchrone" indique que la sortie ne change d'état qu'à un endroit précis (front montant ou descendant) sur l'onde d'entrée appelée signal d'horloge H (signal carré).
- Les autres entrées de la bascule sont appelées entrées de commande (RS, JK, D).
- Les changements à la sortie sont synchronisés par l'horloge (la bascule ne répond à ses entrées que lors de ces transitions du signal d'horloge).

### 1.2. Bascules RS, D, JK

■ La bascule RS n'est pas disponible sous forme de CI mais elle constitue la base des bascules D et JK. C'est une fonction mémoire qui permet de stocker une information (1 bit).

#### a) Symboles logiques



- ► Entrées S, R synchrones (en sortie sur front de H)
- **►** Fonctionnement :
  - S au niveau HAUT, R au niveau BAS:
    - la sortie Q passe au niveau HAUT (lors du front déclencheur)
    - la bascule est dans l'état 1.
  - S BAS, R HAUT : Q passe à 0.
  - S et R au niveau BAS : la sortie conserve son état.
  - S et R au niveau HAUT: condition non valide

■ Table de vérité

Qn: état présent de la sortie

Qn+1 : état de la sortie après le front actif du signal d'horloge

| Entrées |   |          | Sortie | Remarque         |
|---------|---|----------|--------|------------------|
| S       | R | Н        | Qn+1   |                  |
| 0       | 0 | X        | Qn     | Aucun changement |
| 0       | 1 | <b>↑</b> | 0      | Etat 0           |
| 1       | 0 | <b>↑</b> | 1      | Etat 1           |
| 1       | 1 | <b>↑</b> | ?      | Non valide       |



#### c) Bascule D déclenchée par un signal d'horloge

- La bascule D est pratique lorsqu'il faut stocker un seul bit de données.
- Elle obtenue à partir d'un bascule RS pour laquelle :  $\bar{R} = S = D$
- Exemple : bascule D à déclenchement sur front montant :



- Si l'entrée est au niveau <u>haut</u> lorsqu'un signal d'horloge est appliqué, la bascule est mise à **l'état 1** et le niveau <u>haut</u> est stocké par la bascule (stockage du bit 1).
- Idem pour stockage du bit 0
- Table de vérité :

| Entrées |          | Sortie | Remarque |
|---------|----------|--------|----------|
| D       | Н        | Qn+1   |          |
| 0       | <b>↑</b> | 0      | Etat 0   |
| 1       | <b>↑</b> | 1      | Etat 1   |

Equation caractéristique de la bascule D : Qn + 1 = D (encore noté  $Q^+ = D$ )

#### d) Bascule JK déclenchée par un signal d'horloge

- Opération logique identique à celle de la bascule RS pour les conditions de la sortie à 1, à 0 et sans changement.
- La différence entre la bascule RS et la bascule JK : cette dernière ne possède aucun état non valide.

| 9 | Entrées |   |          | Sortie          | Remarque         |
|---|---------|---|----------|-----------------|------------------|
|   | J       | K | Н        | Qn+1            |                  |
|   | 0       | 0 | X        | Qn              | Aucun changement |
| / | 0       | 1 | <b>↑</b> | 0               | Etat 0           |
|   | 1       | 0 | <b>↑</b> | 1               | Etat 1           |
|   | 1       | 1 | <b>↑</b> | $\overline{Qn}$ | Basculement      |

#### Exemple de chronogramme :

Les formes d'onde suivantes sont appliquées aux entrées J, K et Horloge. Déterminer la sortie Q si la bascule est initialement à l'état 0. On suppose que la bascule déclenche sur front descendant.



| $Q_n \setminus J_n K_n$ | 00 | 01  | 11  | 10 |
|-------------------------|----|-----|-----|----|
| 0 _                     | Q  | 0 4 | 1_  |    |
| 1                       | 1) | 0   | 0 ( | 1  |

Equation caractéristique de la bascule JK:

$$Q_{n+1} = J_n \overline{Q_n} + \overline{K_n} Q_n$$
(encore noté :  $Q_+ = J \overline{Q} + \overline{K} Q$ )

### 1.3. Entrées asynchrones

- Les entrées présentées précédemment (*SR*, *D*, *J-K*) sont appelées <u>entrées synchrones</u> : les données présentes sur ces entrées ne sont transférées vers la sortie que lors du front déclencheur du signal d'horloge (transfert synchronisé par le signal d'horloge).
- La plupart des bascules possèdent aussi des entrées <u>asynchrones</u> qui agissent de manière indépendante par rapport aux entrées synchrones et au signal d'horloge. Elles permettent de "forcer" l'état de la bascule à 1 ou à 0 (entrées dite "prioritaires").
- Désignation :
  - *RAU*: Remise à Un (SET, PRESET)
  - RAZ : remise à Zéro (RESET, CLEAR)
- Symbole logique : exemple d'une *J-K valide au niveau HAUT* pour entrées asynchrones

| RAU | RAZ | Réponse de la bascule    |
|-----|-----|--------------------------|
| 0   | 0   | Fonctionnement synchrone |
| 1   | 0   | Mise à 1 : Q=1           |
| 0   | 1   | Mise à 0 : Q=0           |
| 1   | 1   | Inutilisé                |

Dans le cas RAU=1 RAZ=0, la sortie Q passe immédiatement à 1, quelque soit la valeur des entrées J, K, H (idem pour RAZ=1 RAU=0)

• Exercice : Les formes d'ondes J, K, H, /RAU, /RAZ (Attention : la remise à 1 et remise à 0 sont actives au niveau bas dans cet exemple) suivants sont appliqués aux entrées d'une bascule à déclenchement par front négatif (CI 74HC112).

Déterminer la forme d'onde de la sortie Q.



### 1.4. Caractéristiques des bascules

# a) Retards de propagation :

intervalle de temps entre l'application d'un signal d'entrée et la production d'un changement résultant en sortie.

- Le retard de propagation tpBH, mesuré entre le front déclencheur du signal de l'horloge et la transition résultante du niveau BAS au niveau HAUT à la sortie
- Le retard de propagation **tpHB**, mesuré entre le front déclencheur du signal de **l'horloge** et la transition résultante du niveau HAUT au niveau BAS à la **sortie**
- Le retard de propagation tpBH mesuré entre l'entrée asynchrone de remise à un (RAU) et la transition résultante de niveau BAS à niveau HAUT à la sortie.
- Le retard de propagation tpHB mesuré entre l'entrée asynchrone de remise à zéro (RAZ) et la transition résultante de niveau HAUT à niveau BAS à la sortie.

 $t_{PBH}$ 

Q





17



#### b) Temps de stabilisation :

Intervalle minimum pendant lequel les niveaux logiques des entrées doivent être maintenus de façon constante (*J* et *K*, ou *S* et *R*, ou *D*) avant le front déclencheur du signal d'horloge, de façon à garantir un déclenchement fiable de la bascule



#### c) Temps de maintien :

Intervalle minimum pendant lequel les niveaux logiques des entrées doivent être maintenus de façon constante après le front déclencheur du signal d'horloge, de façon à garantir un déclenchement fiable de la bascule

#### d) Fréquence maximale d'utilisation (fmax) :

vitesse la plus élevée du signal d'horloge, à laquelle une bascule peut être déclenchée de façon fiable.

| Exemples de                            | CMOS 74 MC | TTL          |
|----------------------------------------|------------|--------------|
| temps ( <u>ns</u> )                    |            | 74 <i>LS</i> |
| t <sub>pHB</sub> (Horloge à Q)         | 17         | 40           |
| t <sub>pHB</sub>                       | 17         | 25           |
| $t_{pHB}$ (de $\overline{RAZ}$ à $Q$ ) | 18         | 40           |
| $t_{pHB}$ (de $\overline{RAU}$ à $Q$ ) | 18         | 25           |
| $f \max(MH_z)$                         | 35         | 25           |

### 2.1. Compteurs synchrones

Synchrone : toutes les bascules du compteur sont synchronisées simultanément avec le même signal d'horloge.

#### a) Compteur binaire synchrone de 3 bits

■ Table des états

| Etat présent |     |      |         | Etat | suiv  | ant     |         |                        |
|--------------|-----|------|---------|------|-------|---------|---------|------------------------|
| Décimal      | Coc | lage | binaire | Cod  | age b | oinaire | Décimal | Etat suivant :         |
|              | Q2  | Q1   | Q0      | Q2+  | Q1+   | Q0+     |         | état occupé            |
| 0            | 0   | 0    | 0       | 0    | 0     | 1       | 1       | par le<br>compteur     |
| 1            | 0   | 0    | 1       | 0    | 1     | 0       | 2       | immédiatem             |
| 2            | 0   | 1    | 0       | 0    | 1     | 1       | 3       | ent après<br>l'état    |
| 3            | 0   | 1    | 1       | 1    | 0     | 0       | 4       | présent en             |
| 4            | 1   | 0    | 0       | 1    | 0     | 1       | 5       | réponse à              |
| 5            | 1   | 0    | 1       | 1    | 1     | 0       | 6       | l'application<br>d'une |
| 6            | 1   | 1    | 0       | 1    | 1     | 1       | 7       | impulsion de           |
| 7            | 1   | 1    | 1       | 0    | 0     | 0       | 0       | signal                 |
|              |     |      |         |      |       |         |         | d'horloge.             |



#### Synthèse du compteur avec des bascules D :

• il s'agit de trouver les expressions logiques des entrées des bascules.

#### ■ Méthode :

- Utiliser l'expression caractéristique des bascule D : Q+=D, vraie pour toute bascule D
- Exprimer Q+ pour chacune des bascules du compteur :
  - ✓ De manière générale, il y a n bascules dont les entrées sont D0, D1, .., Di, .., Dn-1, et les sorties Q0, Q1, .., Qi, .., Qn-1.
  - ✓ Dans notre compteur en particulier, il y a trois bascules, car trois bits (Q2, Q1, Q0) suffisent à coder en binaire les 8 états de la bascule.
- En déduire Di pour chacune des bascules du compteur.
- Pour trouver Qi+ pour chaque bascule : Tableau de Karnaugh de Qi+

#### Tableau de Karnaugh des $Q^+$ en fonction des Q (matrice de commande)

| 1            |     |      |         |      |                 |         |         |                        |
|--------------|-----|------|---------|------|-----------------|---------|---------|------------------------|
| Etat présent |     |      |         | Etat | sui             | vant    |         |                        |
| Décimal      | Coc | lage | binaire | Cod  | age l           | binaire | Décimal | Etat suivant :         |
|              | Q2  | Q1   | Q0      | Q2+  | Q1 <sup>+</sup> | + Q0+   |         | état occupé            |
| 0            | 0   | 0    | 0       | 0    | 0               | 1       | 1       | par le<br>compteur     |
| 1            | 0   | 0    | 1       | 0    | 1               | 0       | 2       | immédiatem             |
| 2            | 0   | 1    | 0       | 0    | 1               | 1       | 3       | ent après<br>l'état    |
| 3            | 0   | 1    | 1       | 1    | 0               | 0       | 4       | présent en             |
| 4            | 1   | 0    | 0       | 1    | 0               | 1       | 5       | réponse à              |
| 5            | 1   | 0    | 1       | 1    | 1               | 0       | 6       | l'application<br>d'une |
| 6            | 1   | 1    | 0       | 1    | 1               | 1       | 7       | impulsion de           |
| 7            | 1   | 1    | 1       | 0    | 0               | 0       | 0       | signal                 |
|              |     |      |         |      |                 |         |         | d'horloge.             |

| $Q_2^+$ : | $Q_2 \setminus Q_1 Q_0$ | 00 | 01 | 11 | 10 |
|-----------|-------------------------|----|----|----|----|
|           | 0                       | 0  | 0  | 1  | 0  |
|           | 1                       | 1  | 1  | 0  | 1  |
|           |                         |    |    |    |    |

 $Q_2^+ = Q_2 \overline{Q_1} + Q_2 \overline{Q_0} + \overline{Q_2} Q_1 Q_0$ , or pour une bascule D

on a: 
$$Q^+ = D$$
  $\Rightarrow D_2 = Q_2 \left(\overline{Q_1} + \overline{Q_0}\right) + \overline{Q_2}Q_1Q_0$   
 $= Q_2 \left(\overline{Q_1Q_0}\right) + \overline{Q_2}Q_1Q_0$   
 $D_2 = Q_2 \oplus \left(Q_1Q_0\right)$ 

$$\implies \underline{D_1 = Q_1 \oplus Q_0}$$

 $Q_1^+ = \overline{Q_1}Q_0 + Q_1\overline{Q_0}$ 

$$Q_0^+ = \overline{Q_0}$$

$$\underline{D_0} = \overline{Q_0}$$

#### **Synthèse du compteur avec des bascules JK** :

• il s'agit à nouveau de trouver les expressions logiques des entrées des bascules Ji, Ki.

| $Q_2^+$ : | $Q_{2} \setminus Q_{1}Q_{0}$ | 00 | 01 | 11 | 10 |
|-----------|------------------------------|----|----|----|----|
|           | 0                            | 0  | 0  | 1  | 0  |
|           | 1                            | 1  | 1  | 0  | 1  |

$$Q_2^+ = Q_2 \overline{Q_1} + Q_2 \overline{Q_0} + \overline{Q_2} Q_1 Q_0$$

$$Q_2^+ = J_2 \overline{Q_2} + \overline{K_2} Q_2$$

$$\Rightarrow \overline{J_2} = Q_1 \overline{Q_0}$$

$$K_2 = Q_1 Q_0$$

$$K_2 = Q_1 Q_0$$

 $Q_1^+$ 

| : | $Q_{_{2}} \setminus Q_{_{1}}Q_{_{0}}$ | 00  | 01 | 11 | 10 |
|---|---------------------------------------|-----|----|----|----|
|   | 0                                     | 0   | 1  | 0  | 1  |
|   | 1                                     | 0 ( | 1  | 0  | 1  |

$$\begin{aligned} Q_1^+ &= \overline{Q_1} Q_0 + Q_1 \overline{Q_0} \\ Q_1^+ &= J_1 \overline{Q_1} + \overline{K_1} Q_1 \\ \Longrightarrow & \boxed{J_1 = Q_0} \\ K_1 &= Q_0 \end{aligned}$$

| $Q_0^+$ : | $Q_{2} \setminus Q_{1}Q_{0}$ | 00 | 01 | 11 | 10 |
|-----------|------------------------------|----|----|----|----|
|           | 0                            | 1  | 0  | 0  | 1  |
|           | 1                            | 1  | 0  | 0  | 1  |

$$Q_0^+ = \overline{Q_0}$$

$$Q_0^+ = J_0 \overline{Q_0} + \overline{K_0} Q_0$$

$$\Longrightarrow \overline{J_0 = K_0 = 1}$$



#### b) Etude des états hors cycle



Il arrive que le nombre de bascules utilisées permettent de coder plus d'états que ceux du cycle de comptage : exemple d'un compteur synchrone bascules JK module 3 (module 3 = 3 états, compte de 0 à 2).

| Etat | $Q_1$ | $Q_0$ | $Q_1^+$ | $Q_0^+$ | $X_{1}$ | $X_{0}$ |
|------|-------|-------|---------|---------|---------|---------|
| 0    | 0     | 0     | 0       | 1       | 0       | 1       |
| 1    | 0     | 1     | 1       | 0       | 1       | 1       |
| 2    | 1     | 0     | 0       | 0       | 1       | 0       |
| 0    | 0     | 0     | 0       | 1       | 0       | 1       |

$$\begin{split} Q_1^+ &= \overline{Q_1} Q_0 &= J_1 \overline{Q_1} + \overline{K_1} Q_1 & \Rightarrow J_1 = Q_0, \ K_1 = 1 \\ Q_0^+ &= \overline{Q_1} \overline{Q_0} &= J_0 \overline{Q_0} + \overline{K_0} Q_0 & \Rightarrow J_0 = \overline{Q_1}, \ K_0 = 1 \end{split}$$

#### • Graphe des états



Que se passe t-il si le compteur démarre dans l'état 3?  $Q_1Q_0 \Rightarrow Q_1^+Q_0^+$ 

A l'instant suivant, on aura l'état 0 (on rentre à nouveau dans le cycle de comptage).



#### Exemple du composant 74 HC 163 (utilisé en TP)

• Symbole logique

Circuit Intégré **c**) compteur binaire synchrone de 4

du



• Initialisation : le compteur peut être initialisé de façon synchrone à n'importe quel nombre binaire de 4 bits (entrées données).

Sorties de données

Lorsqu'un 0 est appliqué sur l'entrée mir, le compteur est mis dans l'état correspondant aux entrées de données à la prochaine impulsion d'horloge.

- Remise à 0 : RAZ (niveau valide bas) : réinitialise les 4 bascules du compteur de façon synchrone.
- Fonctionnement du compteur : il faut que VAL1 et VAL2 soient actives.
- Fin de comptage : la sortie RCO passe à l'état HAUT quand le compteur atteint le compte final (15). Cette sortie est aussi utilisée pour cascader les compteurs (modulo plus élevé).

27

bits



- /RAZ=0 : met toutes les sorties à 0
- /INIT=0 : au prochain front de H, les entrées sont transférées à la sortie
- Comptage jusqu'à 15 puis recommence à 0, 1, 2
- Attention VAL1 passe à 0 : arrêt!

### 2.2. Compteurs asynchrones

Les bascules formant un compteur asynchrone ne changent pas d'état exactement au même moment, car elles ne sont pas reliées au même signal d'horloge.

#### a) Compteur binaire asynchrone de 3 bits

■ Table des états : idem compteur synchrone

| Etat présent |                |    |                | Etat suivant |     |         |                |                                                                                                                     |
|--------------|----------------|----|----------------|--------------|-----|---------|----------------|---------------------------------------------------------------------------------------------------------------------|
| Décimal      | Codage binaire |    | Codage binaire |              |     | Décimal | Etat suivant : |                                                                                                                     |
|              | Q2             | Q1 | Q0             | Q2+          | Q1+ | Q0+     |                | état occupé                                                                                                         |
| 0            | 0              | 0  | 0              | 0            | 0   | 1       | 1              | par le compteur immédiatem ent après l'état présent en réponse à l'application d'une impulsion de signal d'horloge. |
| 1            | 0              | 0  | 1              | 0            | 1   | 0       | 2              |                                                                                                                     |
| 2            | 0              | 1  | 0              | 0            | 1   | 1       | 3              |                                                                                                                     |
| 3            | 0              | 1  | 1              | 1            | 0   | 0       | 4              |                                                                                                                     |
| 4            | 1              | 0  | 0              | 1            | 0   | 1       | 5              |                                                                                                                     |
| 5            | 1              | 0  | 1              | 1            | 1   | 0       | 6              |                                                                                                                     |
| 6            | 1              | 1  | 0              | 1            | 1   | 1       | 7              |                                                                                                                     |
| 7            | 1              | 1  | 1              | 0            | 0   | 0       | 0              |                                                                                                                     |
|              |                |    |                |              |     |         |                |                                                                                                                     |





Avantage des compteurs asynchrones : schéma de câblage plus simple (pas de portes logiques).

#### Fonctionnement

Le signal d'horloge est appliqué uniquement à l'entrée C de la première bascule B0. La deuxième bascule utilise le signal de sortie comme signal d'horloge (front montant de front descendant des). Toutes les bascules sont connectées en mode de basculement (J=K=1) et sont initialement à 0.



#### Retard de propagation

L'inconvénient majeur des compteurs asynchrone vient des retards de propagation qui se cumulent et qui entraînent donc une limite de fréquence d'utilisation.

Exemple : cas où les 3 bascules du compteur précédent changent d'état lors du front montant (4). Les retards de propagation lors des quatre premières impulsions sont illustrés sur le chronogramme suivant :



⇒ Il faut compter 3 retards de propagation avant que l'effet de l'impulsion 4 de l'horloge n'ait traversé le compteur pour que Q₂ passe finalement de l'état BAS à l'état HAUT.

Il ne faut pas que le prochain front actif arrive sur H avant que Q<sub>2</sub> ait changé d'état, sinon Q0 changerait aussi et on n'aurait pas l'état 100.

⇒ Dans compteur asynchrone :

Retard cumulatif = désavantage majeur

Le retard cumulatif maximal d'un compteur doit toujours être inférieur à la période du signal d'horloge.

Les registres renferment un arrangement de bascules et sont des éléments importants dans les applications de stockage et de transfert de données.

### 3.1. Fonction stockage

- Le **stockage** est une fonction requise dans la plupart des systèmes numériques.
- Dijectif : conserver les données binaires pour une période de temps
  - Possibilité de stocker un bit ou un groupe de bits
  - Possibilité de retenir l'information aussi longtemps que nécessaire
- Unités de stockage les plus courantes : bascules, registres



- Registre : formé d'une combinaison de bascules utilisées pour stocker des groupes de bits (registre=élément de mémoire).
- Ex : on peut construire un registre 8 bits avec 8 bascules (La capacité de stockage = nombre total de bits)

### 3.2. Fonction décalage

- Registre permet:
  - stocker mais aussi
  - décaler les bits d'une position à une autre en interne ou vers un autre circuit extérieur
- ⇒ Appellation « registre à décalage »
- Différents types de déplacement des données dans les registres à décalage :



Sortie série

Entrée série Sortie parallèle



Décalage gauche Sortie série



Entrées parallèles Sorties parallèles



Sortie série

- Application : convertir des données parallèles en données série pour transmission (exemple téléphonie)
- Registre = élément synchrone car assemblage de bascules synchronisées sur le même signal d'horloge H :



$$q1 := d1$$
  
 $q0 := d0$   
Connexions  $\rightarrow d1 = d, d0 = q1$   
 $q1 := d$   
 $q0 := q1$ 

• Registre à chargement systématique (pure mémoire n bits) :



$$q_{3-0} := d_{3-0}$$

• Registre à chargement commandé (commande de chargement ch) :



D

<u>sinon</u> Q

• Registre à décalage systématique :



• Registre à décalage droite, gauche et chargement :



 $q_3q_2q_1q_0 := \underline{cas} s_1s_0$   $\underline{soit} \ 00 : q_3q_2q_1q_0 \qquad \text{état inchangé}$   $\underline{soit} \ 01 : R \ q_3q_2q_1 \qquad \text{décalage droite}$   $\underline{soit} \ 10 : q_2q_1q_0 \ L \qquad \text{décalage gauche}$ 

**<u>soit</u>**  $11: d_3d_2d_1d_0$  chargement

#### • Registre universel:

- ✓ Chargement Série ou parallèle (MODE, ESD, ESG, ou Ei)
- ✓ Décalage à droite et à gauche (SENS)
- ✓ Lecture série ou parallèle (SSG, SSD, ou Qi)
- ✓ Initialisation (INIT)



#### Application : générateur de retard

- Chronogramme d'un registre 74164 :
- L'entrée série sur l'entrée A est reçue et décalée dans le registre après l'application d'un niveau 1 sur B.
- On retrouve la forme d'onde entrée sur A successivement sur les sorties Q0, Q1, ..., Q7.
- Ce chronogramme illustre l'application possible des registres à décalage pour **générer un retard** entre 2 signaux (ici entre l'entrée A, et l'une ou l'autre des sorties même onde, mais retardée). Le retard peut être modifié grâce à la fréquence de l'horloge.

