Tema3 Secuenciales
Tema3 Secuenciales
Tema3 Secuenciales
TEMA - 3
LÓGICA SECUENCIAL.
REGISTROS DE DESPLAZAMIENTO Y CONTADORES.
1.- Introducción.
Hemos visto que en la lógica combinacional las salidas están determinadas sólo por los
estados existentes en las entradas. En la lógica secuencial sin embargo, las salidas están
determinadas no sólo por las entradas sino también por la secuencia de entradas que
condujeron al estado existente, las que precedieron. En otras palabras el circuito posee
memoria.
Elementos
de
memoria
biestable con dos salidas Q Q (una la complementaria de la otra), compuesto de dos puertas
NOR acopladas tal y como muestra la Figura 3-2. Se puede observar que la salida de cada
puerta NOR se conecta a la entrada de la puerta opuesta.
NOR S Qn
R R Qn
Q A B S
Q 0 0 1 0 0 Qn −1 Qn −1 Sin cambio
0 1 0 0 1 0 1 RESET
1 0 0 1 0 1 0 SET
Q 1 1 0 1 1 0 0 Ambiguo
Q
S Qn-1 estado anterior
Qn salida
Figura 3-2. Latch R-S con entrada activa a nivel alto.
1
La diferencia básica entre latches y flip-flops es la manera en que cambian de un estado a otro.
T-3 “Lógica Secuencial. Registros de Desplazamiento y Contadores” 3
El funcionamiento del latch R-S con entrada activa a nivel alto se deriva del
comportamiento de la puerta NOR (ver tabla de verdad de la figura 3-2). Si una de las entradas
de una puerta NOR (de dos entradas) se mantiene a ‘0’ la salida será la inversa de la otra
entrada. En consecuencia si en el latch R y S son ‘0’, la salida del circuito se mantendrá en el
estado en el estuviera (ver tabla de verdad del latch en la figura 3-2). Si la entrada R del latch
se pone a ‘1’ mientras que la entrada S permanece a ‘0’, la salida Q se pondrá a ‘0’ sin importar
su estado previo (en una puerta NOR en cuanto hay una entrada a ‘1’ la salida es ‘0‘) y a su
vez la salida negada, Q se pondrá a ‘1‘, el latch pasará al estado de Reset. Si ahora R vuelve
a ‘0’ el circuito entrará de nuevo en su modo de memoria. De manera similar si S se lleva a ‘1’
mientras R permanece a ‘0’, entonces la salida negada Q se pondrá a ‘0’, con lo que la salida Q
se colocará a ‘1’. En resumen el funcionamiento del latch es el siguiente:
• La entrada R activa (‘1’) realiza un RESET del latch (pone la salida a ‘0’).
S Q
• La entrada S activa (‘1’) realiza un SET del latch (pone la salida a ‘1’ ).
R Q
• Si las entradas están desactivadas (R=0 y S=0) la salida del latch no
cambia (Qn=Qn-1). Figura 3-3.Latch R-S.
• Si se activan las dos entradas (R=1 y S=1) el circuito no funciona correctamente (Q=0 y
Q =0).
El símbolo lógico del latch R-S con entrada activa se muestra en la Figura 3-3.
S NAND
Q
Q A B S S R Qn Qn
0 0 1 0 0 1 1 Ambiguo
0 1 1 0 1 1 0 SET
1 0 1 1 0 0 1 RESET
Q
Q 1 1 0 1 1 Qn −1 Sin cambio
R Qn −1
Al comparar el funcionamiento de una puerta NAND con otra NOR podemos ver que si
bien una puerta NOR se asemeja a un inversor cuando una de sus entradas está conectada a
‘0’, la puerta NAND se asemeja a un inversor cuando una de sus entradas está conectada a ‘1’
(ver tabla de verdad de una puerta NAND en la figura 3-4). Por tanto el modo de memoria del
latch (Qn=Qn-1) corresponde en este caso con las dos entradas a ‘1’. Si la entrada S se lleva a
nivel bajo ‘0’ la salida Q se pone a ‘1’ (SET) y si la entrada R se lleva a nivel bajo ‘0’ la salida
Q será ‘0’ (RESET). De ahí que a este latch se le dé el nombre de latch con entrada activa a
nivel bajo.
S S
Q
S Q
E
E Q
R
Q
R R
E S R Qn Qn
1 0 0 Qn −1 Qn −1 Sin cambio
1 0 1 0 1 RESET
1 1 0 1 0 SET
0 X X Qn −1 Qn −1 Sin cambio
Cuando la señal de habilitación E esté a nivel bajo, las señales S y R estarán a nivel
alto sin importar el valor de las entradas R y S. Esto coloca al latch en su modo de memoria,
evitando que la salida cambie de estado. Cuando se activa la entrada de habilitación, las
señales R y S se invierten y se aplican al latch S - R , es decir, el circuito actúa como un latch
R-S con entrada activa a nivel alto. La tabla de verdad se puede apreciar en la Figura 3-6.
D S Qn Qn
E D
Q D Q
1 0 0 1 RESET
E
Q 1 1 1 0 SET
E Qn −1
0 X Qn −1 Sin cambio
Q
R
Al igual que antes, cuando la entrada de habilitación E está a nivel bajo las señales S y
R estarán a nivel alto y la salida del circuito no variará (modo memoria). Si la habilitación está
activa, la entrada D determina el valor de las señales S y R . Si D es ‘1’ S será ‘0’ y R ‘1’, lo
que realizará el SET del circuito (Q=’1’) . Si D es ‘0’ S será ‘1’ y R ‘0’, lo que pondrá el circuito
a RESET (Q=’0’).
En resumen cuando la habilitación (E) está activa la salida Q toma el valor de la entrada
D, y cuando está desactiva, la salida permanece en su estado anterior. Este dispositivo
también es conocido como báscula D transparente y se emplea para almacenar un bit de
información como veremos en el capítulo 5.
Algunos biestables están construidos de manera que sólo cambian de estado ante la
aplicación de una señal de disparo, en concreto ante el flanco de bajada o de subida de una
señal de entrada llamada reloj (CLK). Estos biestables reciben el nombre de biestables
disparados por flanco, o más comúnmente flip-flops.
Los flip-flops son dispositivos síncronos. El término síncrono significa que la salida
cambia de estado únicamente en un instante específico de una entrada de disparo (reloj), es
decir, los cambios en la salida se producen sincronizadamente con el reloj.
(a) (b)
S Q S Q
CLK CLK
Q Q
R R
Figura 3-7. Flip-flop R-S (a) disparado por flanco de subida. (b) disparado por flanco de bajada.
S
S R CLK Qn Qn
0 0 ↑ Qn −1 Qn −1 Sin cambio
R 0 1 ↑ 0 1 RESET
1 0 ↑ 1 0 SET
1 1 ↑ 0 0 Ambiguo
CLK X X X Sin cambio
Qn −1 Qn −1
Figura 3-8. Ejemplo de formas de onda en las entradas y en la salida de un flip-flop disparado por flanco
ascendente.
El funcionamiento de un flip-flop R-S activado por flanco descendente es, por supuesto,
idéntico, excepto que el disparo tiene lugar en el flanco de bajada de la señal de reloj (cuando
cambia de ‘1’ a ‘0’).
D CLK Qn Qn
D Q
CLK 0 ↑ 0 1 RESET
Q 1 ↑ 1 0 SET
X X Qn −1 Qn −1 Sin cambio
Figura 3-9. Flip-flop D disparado por flanco ascendente.
CLK
Q
D=1 D=0 D=0 D=1 D=1
Q=1 Q=0 Q=0 Q=1 Q=1
Figura 3-10. Ejemplo de formas de onda en las entradas y en la salida de un flip-flop D disparado por
flanco ascendente.
T-3 “Lógica Secuencial. Registros de Desplazamiento y Contadores” 7
La tabla de transición muestra las características de un flip-flop J-K disparado por flanco
ascendente.
J K CLK Qn Qn
0 0 ↑ Qn −1 Qn −1 Sin cambio
0 1 ↑ 0 1 RESET
1 0 ↑ 1 0 SET
1 1 ↑ Qn −1 Qn −1 Báscula
La Figura 3-11 ilustra el funcionamiento del flip-flop J-K disparado por flanco ascendente
y su símbolo lógico.
J Q
K CLK
Q
K
CLK
3.4.- Flip-flop T.
Existe otro tipo de flip-flop con una única entrada (T). El comportamiento de un flip-flop
tipo T es equivalente al de un flip-flop tipo J-K con sus entradas J y K unidas. De este modo, si
la entrada T presenta un nivel bajo ‘0’ el dispositivo está en su modo de memoria, y si al
entrada T se encuentra a nivel alto ‘1’ el dispositivo cambia de estado, es decir la salida
bascula. En la Figura 3-12 se aprecia este comportamiento y el símbolo lógico.
8 T-3 “Lógica Secuencial. Registros de Desplazamiento y Contadores”
T CLK Qn Qn
0 ↑ Qn −1 Qn −1 Sin cambio
1 ↑ Qn −1 Qn −1 Báscula
T Q
T CLK
Q
CLK
Q
T= 0 T= 0 T= 1 T= 1 T=0
Sin cambio Sin cambio Báscula Báscula Sin cambio
1 J1 Q1 J2 Q2 CLK
CLK CLK
0 Q 0 Q
K1 K2
Reloj Q1
Q2
Maestro Esclavo
S S’ S
S Q'
Q
CLK CLK
Q
R R Q' R
R’
La tabla de verdad de un flip-flop R-S maestro esclavo es la misma que la de los flip-
flops R-S disparado por flanco, excepto en la manera en que se sincroniza con la señal de
reloj. El dispositivo responde a sus entradas mientras el reloj está alto, pero las salidas no se
actualizan hasta que el reloj se hace bajo (Figura 3-15), es decir, el dispositivo maestro/esclavo
responde al final del pulso de entrada de reloj, en lugar de hacerlo en el flanco ascendente o
descendente . La tabla de verdad y el símbolo lógico se muestran en al Figura 3-15.
Respuesta
S R CLK Qn Qn
del maestro Se deshabilita el maestro y
las salidas se transfieren al 0 0 П Qn −1 Qn −1 Sin cambio
Reloj esclavo 0 1 П 0 1 RESET
1 0 П 1 0 SET
M/S
S Q
CLK
Q
R
M/S M/S
S1 Q1 S2 Q2 CLK
1
CLK CLK
Q R2
Q
0 R1 0
Q1
Reloj
Q2
Al igual que antes el primer flip-flop responde al pulso de reloj que entra, pero esta vez la
salida cambia en el flanco descendente del pulso. La entrada S2 del segundo flip-flop es ‘0’
mientras el reloj está a nivel alto, y por lo tanto el circuito permanece en su estado de memoria.
Después del primer pulso de reloj la salida Q1 se pone a nivel alto ‘1’ y con ella la entrada S2.
Entonces cuando termine el segundo pulso de reloj la salida del segundo flip-flop se pondrá a
nivel alto.
Entre ellas se encuentran la entrada PRESENT (PRE), que cuando se active colocará la
salida a nivel alto (Q=’1’) y la entrada CLEAR (CLR) que cuando se active llevará a la salida a
nivel bajo(Q= ‘0’). Como ocurre con el resto de entradas éstas pueden ser activas a nivel alto o
a nivel bajo (lo normal). Las entradas PRESET y CLEAR pueden anular las otras entradas al
circuito. Es necesario asegurarse de que ambas entradas asíncronas no están activas
simultáneamente.
J PRE
S Q
J Q
CLK
CLK Q
K
Q CLR
R
K
CLR
Los dos tipos de registros de desplazamiento son serie y paralelo. En un registro paralelo
los bits se almacenan simultáneamente a partir de líneas paralelas, mientras que en un registro
de desplazamiento serie, los bits se almacenan de uno a uno.
Estos dos tipos se emplean, entre otras cosas, para transformar (Figura 3-18) palabras
de información en paralelo a una sucesión de bits sobre una línea, es decir, datos serie
(registro de desplazamiento paralelo-serie), o una sucesión de datos en serie en una palabra
de datos en paralelo (registro de desplazamiento serie- paralelo).
1 0 0 1 1 1 0 1
Registro de desplazamiento
1 0 0 1 1 1 0 1
a) Conversión de paralelo a serie
1 0 0 1 1 1 0 1
Registro de desplazamiento
1 0 0 1 1 1 0 1
b) Conversión de serie a paralelo
Salidas paralelo
Q0 Q1 Q2 Q3
D
D0 Q0 D1 Q1 D2 Q2 D3 Q3
(entrada serie)
CLK CLK CLK CLK
Q0 Q1 Q2 Q3
Reloj (CLK)
CLK
D CLK Q3 Q2 Q1 Q0
D 1 0 1 1
1 ↓ 0 0 0 1
0 ↓ 0 0 1 0
Q0 1 ↓ 0 1 0 1
1
1 ↓ 1 0 1 1
Q1 1
Q2 0
Q3 1
CLK
D0 D1 D2 D3
1 0 1 1
Obsérvese que el circuito tiene cuatro líneas de entrada de datos, D0, D1, D2 y D3 y una
entrada SHIFT/LOAD (desplazamiento/carga), que permite cargar en paralelo los cuatro bits de
datos en el registro. Cuando esta entrada esté a nivel bajo, las puertas G1, G2 y G3 se activan,
permitiendo que cada bit sea aplicado a la entrada D de su respectivo flip-flop. Cuando se
aplica un pulso de reloj, los flip-flops con D=1 pasan a SET (Q=1), y los flip-flops con D=0
pasan a RESET (Q=0),almacenándose de este modo los cuatro bits simultáneamente.
Cuando la entrada SHIFT/LOAD está a nivel alto, las puertas G1, G2 y G3 se inhiben y las
puertas G4, G5 y G6 se activan, permitiendo que los bits de datos se desplacen hacia la
derecha, pasando de una etapa a la siguiente. Las puertas OR permiten el desplazamiento
normal o la introducción de datos en paralelo, dependiendo de qué puerta AND se haya
activado, es decir, del valor de la entrada SHIFT/LOAD.
CLK
SHIFT/LOAD
Q0 1
Q1 0
Q2
1
Q3 1 1 0 1
6. Contadores.
La función de recuento es muy importante en los sistemas digitales. Existen muchos
tipos de contadores digitales, pero su objetivo básico es contar sucesos representados por
cambios de nivel o impulsos, o generar una secuencia de códigos particular. Para contar, el
contador debe recordar el número actual, con el fin de poder pasar correctamente al siguiente
valor de la secuencia. Por tanto la capacidad de almacenamiento es una característica
importante en todos los contadores, por lo que generalmente se utilizan flip-flops para su
implementación.
Q0 Q1 Q2 Q3
1 1 1 1
J0 Q0 J1 Q1 J2 Q2 J3 Q3
CLK
CLK CLK CLK CLK
K0 Q0 K1 Q1 K2 Q2 K3 Q3
El contador de cuatro bits dispone de dieciséis estados diferentes (24 =16).Hay que tener
en cuenta que Q0 representa el bit menos significativo (LSB) y Q3 el bit más significativo (MSB).
La secuencia de estados del contador se muestra en la Tabla 3-1.
El tercer flanco negativo de CLK hace que Q0 pase a nivel alto de nuevo, mientras que
Q1 , Q2 y Q3 no se ven afectados (Q1 = 1, Q2 = 0, Q3 = 0).
En el cronograma (figura 3-25), las formas de onda de las salidas de los flip-flops se
muestran en función de los impulsos de reloj. Para simplificar, se muestran las transiciones
simultáneas, aunque existe, por supuesto, un ligero retardo entre las transiciones de la señal
de reloj de cada flip-flop y su salida.
CLK
Q0
Q1
Q2
Q3
Q0 Q1 Q2 Q3
1 1 1 1
J0 Q0 J1 Q1 J2 Q2 J3 Q3
CLK
CLK CLK CLK CLK
K0 Q0 K1 Q1 K2 Q2 K3 Q3
Tabla 3-2.
Q3 Q2 Q1 Q0
La tabla de verdad correspondiente al contador mostrado
1 1 1 1 15
en la Figura 3-2 es la que aparece en la Tabla 3-2. 1 1 1 0 14
1 1 0 1 13
1 1 0 0 12
1 0 1 1 11
1 0 1 0 10
1 0 0 1 9
1 0 0 0 8
0 1 1 1 7
0 1 1 0 6
0 1 0 1 5
0 1 0 0 4
0 0 1 1 3
0 0 1 0 2
0 0 0 1 1
0 0 0 0 0
16 T-3 “Lógica Secuencial. Registros de Desplazamiento y Contadores”
También se puede diseñar contadores con módulo menor de 2n, truncando la secuencia.
Q0 Q1 Q2 Q3
1 1 1 1
J0 Q0 J1 Q1 J2 Q2 J3 Q3
CLK
CLK CLK CLK CLK
K0 Q0 K1 Q1 K2 Q2 K3 Q3
Un circuito secuencial está formado por una etapa de lógica combinacional y una etapa
de memoria (flip-flops). Para el funcionamiento del circuito se requiere la información
almacenada en la etapa de memoria (estado), así como las entradas de la lógica
T-3 “Lógica Secuencial. Registros de Desplazamiento y Contadores” 17
Para diseñar un sistema a partir de esta tabla, necesitamos decidir sobre la naturaleza
de los biestables que se usarán y determinar cuál debe ser la entrada de cada biestable para
producir la transición al estado siguiente.
La Tabla 3-5 es una tabla de transiciones del flip-flop J-K. Se enumeran todas las
posibles transiciones de salida, mostrando cómo evoluciona la salida Q del flip-flop. Para cada
transición de salida, se indican las entradas J y K que dan lugar a esa transición. Las ‘X’
indican condiciones indiferentes (la entrada puede ser ‘1’ o ‘0’).
Estado Estado
Entradas
presente siguiente
Qn Qn+1 J K
0 0 0 X
0 1 1 X
1 0 X 1
1 1 X 0
Al diseñar el contador, se aplica la tabla de transiciones a cada flip-flop del contador. Por
ejemplo, para el estado actual 000, Q0 pasa del estado ‘0’ a ‘1’. Para que esto ocurra, J0 tiene
que ser ‘1’ y es indiferente el valor que tome K0, como se indica en la tabla de transiciones 3-5.
2
En sistemas sencillos los estados pueden deducirse directamente de la definición del problema, pero en los
casos más complejos puede ser necesario modelar el sistema mediante un diagrama de estados.
18 T-3 “Lógica Secuencial. Registros de Desplazamiento y Contadores”
La etapa final del diseño consiste en crear circuitos que produzcan estas señales. Los
mapas de Karnaugh se utilizan para determinar la lógica requerida para las entradas J y K de
cada flip-flop del contador. Se debe utilizar un mapa de Karnaugh para la entrada J y otro para
la entrada K de cada flip-flop. Cada celda del mapa de Karnaugh representa uno de los estados
actuales de la secuencia del contador de módulo 5 (Figura 3-28).
J2 K1
Q2Q1 Q2Q1
Q0 00 01 11 10 Q0 00 01 11 10
0 0 0 X X 0 X 0 X X
1 0 1 X X 1 X 1 X X
J2= Q1·Q0 K1= Q0
K2 J0
Q2Q1 Q2Q1
Q0 00 01 11 10 Q0 00 01 10 11
0 X X X 1 0 1 1 X 0
1 X X X X 1 X X X X
K2= 1 J0= Q 2
J1 K0
Q2Q1 Q2Q1
Q0 00 01 11 10 Q0 00 01 10 11
0 0 X X 0 0 X X X X
1 1 X X X 1 1 1 X X
J1= Q0 K0= 1
El paso final consiste en implementar la lógica a partir de las expresiones de las entradas
J y K, y conectar los flip-flops para conseguir un contador de módulo 5, como muestra la Figura
3-29.
Q0 Q1 Q2
J0 Q0 J1 Q1 J2 Q2