Registros de desplazamiento.

Introducción

"0" y "1", nuestros personajes.
"0" y "1", nuestros personajes.

Un "registro de desplazamiento" es una configuración circuítal muy utilizada, generalmente para convertir un flujo de datos en forma serial a uno del tipo paralelo, motivo por el cual a menudo los chips encargados de esta tarea son llamados "conversores serie-paralelo".

Funcionamiento

Por supuesto, es posible construir un registro de este tipo a partir de componentes discretos, aunque en la practica resulta no solo inapropiado por cuestiones de tamaño y velocidad, si no también económicas, ya que un chip como los que mencionaremos en este texto rara vez superan el valor de 1 u$s.
La mejor manera de entender conceptos nuevos es apoyándose en analogías con temas que nos son familiares. En este caso no vamos a hacer una excepción, por lo que utilizaremos como ejemplo el funcionamiento de una cola, como la de un banco o supermercado.
Supongamos que dos tipos de personas pueden formar parte de una cola. Estos dos tipos de personas son las que se ven en la figura siguiente, y es imposible confundir una con otra. Es decir, siempre estaremos seguros que en una posición determinada de la fila esta una u otra persona. Las llamaremos "0" (el "gordito) y "1" (al mas flaco). Aclaro que la elección de los personajes solo tiene que ver con el parecido (?) con el 0 y el 1.
RDDImage1.gif
"0" y "1", nuestros personajes.

La cola que usaremos como ejemplo tiene 8 lugares, que hemos numerado del 0 al 7, pero nada impide trabaja con colas más largas, por lo que todo lo que se vea aquí, puede ser generalizado para colas de la longitud que se desee.

RDDImage2.gif
La cola utilizada como ejemplo tiene 8 posiciones.

Otra particularidad de nuestra hipotética cola es que nunca puede estar vacía. Todas sus posiciones tienen que estar ocupadas, ya sea por "gorditos" o "flacos". En el estado inicial, la cola se encuentra completamente llena de "gorditos", como se a continuación:

RDDImage3.gif
El estado inicial de la cola es este: completa de "gorditos".

Nuestra cola funciona como cualquier cola de la vida real: cuando alguien nuevo llega a la fila, se coloca en el lugar de mas atrás, que en este caso corresponde a la "posición 0". Como la cola tiene una longitud máxima (en nuestro ejemplo) de 8 posiciones, para hacer lugar al recién llegado, es necesario que todos los que estaban en la fila "avancen" una posición. El que estaba en la posición 0 pasa la 1, el que estaba en la 1 pasa a la 2, y así hasta llegar al que estaba en la posición 7, que "sale" por el extremo opuesto.

RDDImage4.gif
Llega un nuevo integrante a la cola....

RDDImage5.gif
...y ocupa el ultimo lugar, desplazando a todos los demás una posición. El primero "sale" de la fila.

RDDImage6.gif
Este es el estado final de nuestra fila, con el nuevo integrante en el último lugar.

Si continuaran ingresando personas en la fila, el proceso se repetiría con cada nuevo integrante que llegue. Como el que entra primero es el primero en salir, a este tipo de colas se las llama "FIFO", por First Input, First Output (Primero que entra, primero que sale).
Con todas estas cuestiones en mente podemos seguir avanzando en la comprensión del funcionamiento de los registros de desplazamiento. Supongamos que queremos que en la cola haya dos flacos en los primeros lugares, luego un gordo, otra vez dos flacos, luego otro gordo por ultimo dos flacos más (como siempre, 8 personas en total). Sabiendo que cada personaje que ingresa en la cola "empuja" a todos una posición a la derecha, si queremos que el que termine ocupando el extremo derecho de la cola sea un flaco, ese será el que primero debe entrar. Siguiendo el razonamiento anterior, los personajes deberían entrar en la fila en el orden siguiente:

RDDImage7.gif
Los nuevos integrantes de la fila, esperando para ocupar su lugar.

RDDImage8.gif
Este es el estado final de nuestra fila, con los integrantes originales desplazados hacia la derecha.

Poniendo fin a nuestra analogía, tendríamos que los integrantes de esta hipotética cola son los "0"s y "1"s (o estados altos y bajos) de nuestros circuitos, es decir, nuestros datos. La cola en si es el registro de desplazamiento. Cuando decíamos que el estado inicial de la cola eran 8 gordos, estábamos queriendo decir que al alimentar nuestro circuito, todas las salidas estarán en "0" o estado bajo.

El reloj

Hay una salvedad, y es la existencia del "reloj". Efectivamente, en un circuito real, los datos pasan al registro de desplazamiento con cada pulso de reloj. Podemos pensar en este reloj como si se tratase de un "maestro de ceremonias", que da una palmada cada vez que alguien debe ingresar en la cola.
Muchos circuitos de registros de desplazamiento "reales" también incluyen un sistema de RESET, que permite poner simultáneamente todas las salidas en "0" o estado bajo, sin necesidad de ingresar 8 ceros seguidos. Esto permite limpiar rápidamente el registro de desplazamiento.
Cuando decimos "rápidamente" nos referimos a que como la velocidad de los pulsos del reloj (CLOCK) no puede ser infinita (típicamente el máximo ronda los 10 o 20 MHz) y cada dato demora el tiempo de un pulso de reloj en desplazarse por el registro, introducir 8 "0"s llevaría 800 ns (100 ns * 8 bits), contra los 100 ns que demora en aplicarse el RESET. No obstante, para obtener los tiempos exactos implicados se debe consultar la hoja de datos del integrado que estemos utilizando, ya que los limites varían incluso con la tensión de alimentación y la temperatura.

El 74HC164N

Existen varios circuitos integrados que implementan un registro de desplazamiento en su interior, por ejemplo, el 74HC164N

El CD4094

Aunque similar al 74HC164N, este integrado disponde de algunas caracteristicas que lo hacen más interesantes en muchos casos. Consulta el tutorial correspondiente:Usando el CD4094 para manejar displays 7 segmentos.