## Codificadores e decodificadores

Sequências de *bits* podem ser usadas para codificar valores numéricos. Dois códigos binários têm aplicações especiais: o BCD (Binary-Coded Decimal) e o de Gray.

# Código BCD

O código BCD é basicamente uma forma de codificar valores numéricos na base 10 em seus equivalentes binários.

| Decimal | BCD  |
|---------|------|
| 0       | 0000 |
| 1       | 0001 |
| 2       | 0010 |
| 3       | 0011 |
| 4       | 0100 |
| 5       | 0101 |
| 6       | 0110 |
| 7       | 0111 |
| 8       | 1000 |
| 9       | 1001 |

## Exemplo:

Codificar o valor decimal 369 em código BCD: 369 = (0011) (0110) (1001)

Um circuito codificador "decimal-para-BCD" é aquele capaz de mapear um conjunto de entradas (0-9) em um outro conjunto de quatro valores binários (s<sub>3</sub>s<sub>2</sub>s<sub>1</sub>s<sub>0</sub>), se apenas uma das entradas for acionada.



# Código de Gray

O código de Gray serve para expressar sequências binárias nas quais dois valores sucessivos tenham apenas um *bit* de diferença (distância de Hamming = 1).

| Decimal | Binário | Gray |
|---------|---------|------|
| Decimal |         |      |
| 0       | 000     | 000  |
| 1       | 001     | 001  |
| 2       | 010     | 011  |
| 3       | 011     | 010  |
| 4       | 100     | 110  |
| 5       | 101     | 111  |
| 6       | 110     | 101  |
| 7       | 111     | 100  |

Esse código também é conhecido com "código binário refletido", por causa da característica abaixo:

eixo de reflexão

|   |            | 000         |
|---|------------|-------------|
|   |            | <b>0</b> 01 |
|   | <b>0</b> 0 | <b>0</b> 11 |
| 0 | <b>0</b> 1 | <b>0</b> 10 |
| 1 | <b>1</b> 1 | <b>1</b> 10 |
|   | <b>1</b> 0 | <b>1</b> 11 |
|   |            | <b>1</b> 01 |
|   |            | <b>1</b> 00 |

Decodificadores em geral são circuitos lógicos capazes de ativar uma saída de acordo com uma seleção de sinais de entrada.

Um decodificador de nível alto ativa uma saída quando uma das entradas estiver em nível 1 e as outras em nível 0.

## Exemplo:

Montar um decodificador em nível alto para a tabela abaixo:

| e <sub>1</sub> | $e_0$ | S <sub>3</sub> S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> |
|----------------|-------|-------------------------------------------------------------|
| 0              | 0     | 1000                                                        |
| 0              | 1     | 0100                                                        |
| 1              | 0     | 0010                                                        |
| 1              | 1     | 0001                                                        |



Um decodificador de nível baixo ativa uma saída quando uma das entradas estiver em nível 0 e as outras em nível 1.

## Exemplo:

Montar um decodificador em nível baixo para a tabela abaixo:

| <b>e</b> <sub>1</sub> | <b>e</b> <sub>0</sub> | S <sub>3</sub> S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> |
|-----------------------|-----------------------|-------------------------------------------------------------|
| 0                     | 0                     | 0111                                                        |
| 0                     | 1                     | 1011                                                        |
| 1                     | 0                     | 1 1 0 1                                                     |
| 1                     | 1                     | 1110                                                        |



# Multiplexadores (MUX) e demultiplexadores (DEMUX)

Multiplexadores (ou seletores de dados) são circuitos lógicos capazes de atuar como chaves digitais: recebem várias entradas e selecionam uma delas, em certo instante, e realizam sua transferência para a saída, mediante um código de seleção. Podem ser usados para rotear dados, sequenciar operações, realizar conversões do tipo paralelo-série e gerar tabelas ou formas de ondas.

## Exemplo:

Dados os sinais de entrada ( x ) e ( y ), escolher a saída mediante um sinal de seleção.



Multiplexadores podem selecionar mais sinais dependendo do número de bits (tamanho) da chave de seleção.

## Exemplo:

Dados os sinais de entrada (x,y,v,w), escolher a saída mediante um sinal de seleção.



| <b>e</b> 1 | <b>e</b> 0 | $s = x \cdot e_1' \cdot e_0' + y \cdot e_1' \cdot e_0 + v \cdot e_1 \cdot e_0' + w \cdot e_1 \cdot e_0$ |
|------------|------------|---------------------------------------------------------------------------------------------------------|
| 0          | 0          | X                                                                                                       |
| 0          | 1          | у                                                                                                       |
| 1          | 0          | V                                                                                                       |
| 1          | 1          | W                                                                                                       |

Demultiplexadores (ou distribuidores de dados) são circuitos capazes de receber um sinal de entrada e distribuí-lo em uma dentre várias saídas, segundo um código de seleção. Podem ser usados para distribuir um mesmo sinal de ativação ou sequenciamento (*clock*) para vários circuitos.

## Exemplo:

Dados um sinal de entrada ( x ) e dois sinais de ativação e<sub>0</sub> e e<sub>1</sub>, distribuí-lo à saída.



| e <sub>1</sub> | $\mathbf{e}_0$ | e <sub>1</sub> e <sub>0</sub> x | S <sub>3</sub> S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> |
|----------------|----------------|---------------------------------|-------------------------------------------------------------|
| 0              | 0              | $s_3 = 0 \ 0 \ X$               | X 0 0 0                                                     |
| 0              | 1              | $s_2 = 0 \ 1 \ X$               | 0 X 0 0                                                     |
| 1              | 0              | $s_1 = 1 \ 0 \ X$               | 0 0 X 0                                                     |
| 1              | 1              | $s_0 = 1 1 X$                   | 0 0 0 X                                                     |

## Dispositivos lógicos programáveis

PLDs (*Programmable Logic Devices* ou FPGAs – *Field Programmable Gate Arrays*) são arranjos de portas lógicas que servem para uma rápida implementação de circuitos razoavelmente complexos. A figura abaixo ilustra uma organização de um arranjo de portas AND e OR.



Há três tipos comuns de arranjos lógicos combinacionais:

- PLA (Programmable Logic Array) AND's e OR's programáveis
- ROM (Read-Only Memory)
- AND's fixas e OR's programáveis
- PAL (*Programmable Array Logic*) AND's programáveis e OR's fixas





## Circuitos com chaveamento

As portas lógicas básicas podem ser usadas para controlar a passagem (chavear) de um sinal de entrada ( p ) para a saída, se a outra entrada ( q ) for usada como o controle (chave).



## Exemplo:

Montar um *circuito direcionador de pulsos*: envia um pulso de entrada ( p ) para uma saída ou outra, dependendo de uma chave de controle ( q ).

