



## Detecção de Erros

Cálculo do CRC



## Nível de Enlace



- **Transmite e Recebe de quadros**
  - **Quadro = PDU do Nível de Enlace**
  - **Delimitação de Quadros (Enquadramento)**
- **Detecta erros**
- **Endereça**
- **Controla o Acesso ao Meio (MAC)**
- **Opcionalmente**
  - **Corrige erros ou perdas**
  - **Controla o fluxo**



## Detecção de Erros: Operações



- Paridade
- CheckSum
- CRC

## CRC (Cyclic Redundancy Check)

- Código de Redundância Cíclica.
- É comum recorrer-se a uma *representação polinomial* para as sequências de bits
  - utiliza-se polinômios de uma variável arbitrária  $X$  para de tal forma que a sequência de bits  $c_{n-1}, \dots, c_1, c_0$  é representada pelo polinômio

$$c(X) = c_{n-1}X^{n-1} + c_{n-2}X^{n-2} + \dots + c_1X + c_0$$

- Exemplo: A palavra 10110001 é representada pelo polinômio  $X^7 + X^5 + X^4 + 1$ .

• Polinômios de grau  $n$  representam sequências de  $n + 1$  bits

- Transmissor e receptor têm, previamente acordado, um padrão de bits cuja representação polinomial é conhecida pelo nome de **polinômio gerador**.



- Alguns polinômios geradores são largamente utilizados e padronizados. Como exemplos, temos os seguintes:

$$CRC - 12 = X^{12} + X^{11} + X^3 + X^2 + X + 1$$

$$CRC - 16 = X^{16} + X^{15} + X^2 + 1$$

$$CRC - CCITT = X^{16} + X^{12} + X^5 + 1$$

$$CRC - 32 = X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} +$$

$$X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 +$$

$$X^2 + X + 1$$

- Para gerar uma sequencia de **r bits**, o grau do polinômio gerador deve ser **r**,

- o tamanho da sequência de bits referente ao polinômio gerador será **r + 1**.

- O CRC-32, por exemplo,

- escolhido pelo IEEE 802 para ser utilizado em protocolos de redes locais,

### -Polinômio de grau 32

- Sequência de 33 bits
    - Gera FCS de 32 bits.

$$X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + \\ X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + \\ X^2 + X + 1$$

CRC-32

- Utiliza Aritmética em módulo 2.

## Aritmética em Módulo 2

- Adição bit a bit (representada pelo símbolo  $\oplus$ ) é realizada sem se considerar o “vai um”, como representado a seguir:

$$0 \oplus 0 = 0$$

$$0 \oplus 1 = 1$$

$$1 \oplus 0 = 1$$

$$1 \oplus 1 = 0$$

- **Operação XOR**

- Como  $1 \oplus 1 = 0$ , tem-se que, nessa aritmética,  $1 = -1$ .

- Logo, a subtração módulo-2 é igual à soma.



## Aritmética em Módulo 2

- As regras para a multiplicação em aritmética módulo-2 são as mesmas da multiplicação tradicional:

$$0 \times 0 = 0$$

$$0 \times 1 = 0$$

$$1 \times 0 = 0$$

$$1 \times 1 = 1$$

- **Operação AND**

- Tomando-se a divisão como a operação inversa da multiplicação e excluindo os casos de divisão por zero, obtém-se as seguintes operações possíveis:

$$0 \div 1 = 0$$

$$1 \div 1 = 1$$



## Aritmética em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 110110 \\ \times 1101 \\ \hline 110110 \\ 000000 \\ \hline \end{array}$$
$$\begin{array}{r} 1010 \\ + 0110 \\ \hline 1100 \\ \end{array}$$
$$\begin{array}{r} 1010 \\ - 0110 \\ \hline 1100 \\ \end{array}$$
$$\begin{array}{r} 110110 \\ 110110 \\ \hline 101011110 \\ \end{array}$$



## Divisão em Módulo 2 com Vários Algarismos

Dividendo                          Divisor

$$101011000 \quad | \quad 1101$$



## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r|l} 101011000 & 1101 \\ \hline & \end{array}$$

## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r|l} 101011000 & 1101 \\ \hline & 1 \\ \hline & \end{array}$$

## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 101011000 \\ \underline{1101} \downarrow \\ 1111 \end{array} \quad \left| \begin{array}{r} 1101 \\ 1 \end{array} \right.$$

## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 101011000 \\ \underline{1101} \downarrow \\ 1111 \end{array} \quad \left| \begin{array}{r} 1101 \\ 11 \end{array} \right.$$

## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 101011000 \\ \underline{1101} \downarrow \\ 1111 \\ \underline{1101} \downarrow \\ 0101 \end{array} \quad \left| \begin{array}{r} 1101 \\ 11 \end{array} \right.$$

## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 101011000 \\ \underline{1101} \downarrow \\ 1111 \\ \underline{1101} \downarrow \\ 0101 \end{array} \quad \left| \begin{array}{r} 1101 \\ 110 \end{array} \right.$$

## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 101011000 \\ \underline{1101} \downarrow \\ 1111 \\ \underline{1101} \downarrow \\ 0101 \\ \underline{0000} \downarrow \\ 1010 \end{array} \quad \left| \begin{array}{r} 1101 \\ 110 \end{array} \right.$$

## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 101011000 \\ \underline{1101} \downarrow \\ 1111 \\ \underline{1101} \downarrow \\ 0101 \\ \underline{0000} \downarrow \\ 1010 \end{array} \quad \left| \begin{array}{r} 1101 \\ 1101 \end{array} \right.$$

## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 101011000 \\ \underline{1101} \\ 1111 \\ \underline{1101} \\ 0101 \\ \underline{0000} \\ 1010 \\ \underline{1101} \\ 1110 \end{array} \quad \left| \begin{array}{r} 1101 \\ \underline{1101} \end{array} \right.$$



## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r} 101011000 \\ \underline{1101} \\ 1111 \\ \underline{1101} \\ 0101 \\ \underline{0000} \\ 1010 \\ \underline{1101} \\ 1110 \end{array} \quad \left| \begin{array}{r} 1101 \\ \underline{11011} \end{array} \right.$$



## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r}
 101011000 \\
 1101 \downarrow \\
 1111 \\
 1101 \downarrow \\
 0101 \\
 0000 \downarrow \\
 1010 \\
 1101 \downarrow \\
 1110 \\
 1101 \downarrow \\
 0110
 \end{array}
 \quad
 \left| \begin{array}{l} 1101 \\ 11011 \end{array} \right.$$



## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r}
 101011000 \\
 1101 \downarrow \\
 1111 \\
 1101 \downarrow \\
 0101 \\
 0000 \downarrow \\
 1010 \\
 1101 \downarrow \\
 1110 \\
 1101 \downarrow \\
 0110
 \end{array}
 \quad
 \left| \begin{array}{l} 1101 \\ 110110 \end{array} \right.$$



## Divisão em Módulo 2 com Vários Algarismos

$$\begin{array}{r}
 \text{Dividendo} \\
 \begin{array}{r}
 101011000 \\
 1101 \downarrow \\
 1111 \\
 1101 \downarrow \\
 0101 \\
 0000 \downarrow \\
 1010 \\
 1101 \downarrow \\
 1110 \\
 1101 \downarrow \\
 0110 \\
 0000 \\
 \hline
 110
 \end{array}
 \end{array}
 \quad
 \begin{array}{r}
 \text{Divisor} \\
 \begin{array}{r}
 1101 \\
 110110 \\
 \hline
 \text{Quociente}
 \end{array}
 \end{array}$$



## Propriedade da Divisão

$$\begin{array}{r}
 \text{Dividendo} \quad \boxed{\text{Divisor}} \\
 \hline
 \text{Resto} \quad \text{Quociente}
 \end{array}$$

$$\text{Dividendo} = \text{Quociente} \times \text{Divisor} + \text{Resto}$$



## Divisão em Módulo 2 com Vários Algarismos



$$\text{Dividendo} = \text{Quociente} \times \text{Divisor} + \text{Resto}$$

$$\begin{array}{r}
 110110 \\
 \times \underline{1101} \\
 \hline
 110110 \\
 000000 \\
 \hline
 110110 \\
 110110 \\
 \hline
 101011110 \\
 + \underline{110} \\
 \hline
 101011000
 \end{array}$$



## Colocação de zeros à direita

- Em qualquer Base Numérica (B), acrescentar zero à direita significa multiplicar pela base
  - Exemplo na base B = 10
    - 3 acrescido de zero à direita = 30 (multiplica por 10)
  - Exemplo na base B = 2
    - 11 acrescido de zero à direita = 110
      - 3 vira 6 (multiplica por 2)
- Logo, colocar n zeros à direita corresponde a multiplicar por B<sup>n</sup>
  - Na Base B = 2
    - 1101 acrescido de 00 à direita = 110100
      - 13 vira 52 (13 x 2<sup>2</sup>)



## Cálculo para Geração do CRC

1. Toma-se a sequencia original (com  $k$  bits) do quadro e acrescenta-se  $r$  zeros à direita.
  - corresponde à multiplicação do bloco original por  $2^r$ ,
  - $r$  é o número de bits previsto para o CRC.
  - Gera uma nova sequencia de  $n = (k + r)$  bits
2. A nova sequencia de  $n$  bits é então dividida, utilizando-se aritmética módulo-2, pela seqüência correspondente ao polinômio gerador.
  - O resto dessa divisão, que conterá no máximo  $r$  bits, é a seqüência de verificação (FCS).
  - O FCS é então somado (em aritmética módulo-2) ao bloco de  $n$  bits anterior,
    - Ou seja: os  $r$  zeros introduzidos são substituídos pelo FCS calculado.



## Geração do CRC

Polinômio Gerador:  $x^3 + x^2 + 1$

Bits do Quadro  
 $\overbrace{101011}$



## Geração do CRC



## CRC na Recepção



■ Sabemos que o  $FCS$  é o resto da divisão de  $2^rD$  por  $P$

- $2^rD$  é o dividendo
- $P$  é o divisor
- Chamaremos o quociente de  $Q$ ,
- $FCS$  é o resto

■ Então:  $2^r D = P \cdot Q + FCS$



$$2^r D = P \cdot Q + FCS$$



$$T = 2^r D + FCS \quad \Rightarrow \quad T = P \cdot Q + FCS + FCS$$

$$2^r D = P \cdot Q + FCS$$

$T = P \cdot Q$

A soma é um XOR bit a bit

Isso significa que a mensagem transmitida é divisível por  $P$ .

Ou seja: uma transmissão sem erros tem que ser divisível por  $P$ .

Logo, na recepção, basta que se efetue a divisão do quadro inteiro recebido (incluindo o FCS) pela seqüência  $P$ . Um erro será detectado toda vez que o resto dessa divisão for diferente de zero.



## Verificação do CRC na Recepção



$$+ \begin{array}{r} 101011000 \\ 1101 \\ \hline 101011110 \end{array}$$

Mensagem a ser transmitida

### Na Recepção

Mensagem FCS

|           |      |        |
|-----------|------|--------|
| 101011110 | 1101 | 110110 |
| 1101      | 1101 |        |
| 1111      | 1101 |        |
| 1101      | 1101 |        |
| 0101      | 1101 |        |
| 0000      | 1101 |        |
| 1011      | 1101 |        |
| 1101      | 1101 |        |
| 1101      | 1101 |        |
| 0000      | 1101 |        |
| 0000      | 1101 |        |
| 000       |      |        |



- Códigos cílicos apresentam algumas características interessantes.

- Uma delas é decorrência de uma propriedade que permite circuitos simples como método de obtenção do resto da divisão em aritmética módulo-2
  - Registros de Deslocamento com Realimentação Linear (Linear Feedback Shift Registers — LFSRs).



## Registro de Deslocamento com 4 bits

**Registros de Deslocamento** : a cada período de relógio completado, cada flip-flop torna disponível na sua saída o valor que estava previamente armazenado e armazena o novo valor disponível na sua entrada.



## Registro de Deslocamento com 4 bits

**Registros de Deslocamento** : a cada período de relógio completado, cada flip-flop torna disponível na sua saída o valor que estava previamente armazenado e armazena o novo valor disponível na sua entrada.



## Registro de Deslocamento com 4 bits

**Registros de Deslocamento** : a cada período de relógio completado, cada flip-flop torna disponível na sua saída o valor que estava previamente armazenado e armazena o novo valor disponível na sua entrada.



## Registro de Deslocamento com 4 bits

**Registros de Deslocamento** : a cada período de relógio completado, cada flip-flop torna disponível na sua saída o valor que estava previamente armazenado e armazena o novo valor disponível na sua entrada.



## Registro de Deslocamento com 4 bits

**Registros de Deslocamento** : a cada período de relógio completado, cada flip-flop torna disponível na sua saída o valor que estava previamente armazenado e armazena o novo valor disponível na sua entrada.



## Registro de Deslocamento com 4 bits

**Registros de Deslocamento**: a cada período de relógio completado, cada flip-flop torna disponível na sua saída o valor que estava previamente armazenado e armazena o novo valor disponível na sua entrada.



## LFSR



- Inicialmente, antes do cálculo, todos os flip-flops são colocados em 0.
- Os elementos circulares da figura correspondem a operadores bit a bit para as operações de XOR e de AND conforme o símbolo indicado.
- A cada período de relógio, um bit da sequência de bits de entrada ( $I$ ) é “empurrado” para dentro do circuito.
  - Enquanto houver bits de  $I$  a serem processados, as duas chaves indicadas na figura permanecem na posição “A”;
    - permitindo a entrada de novos bits e simultaneamente colocando na saída os próprios bits da mensagem original.
- Depois de todos os bits de  $I$  terem entrado no circuito, essas chaves mudam para a posição “B”,
  - Fazendo com que não sejam mais lidos novos bits na entrada e que os bits armazenados nos registros  $R_{m-1}$  a  $R_0$  sejam colocados, um a um, para fora do circuito.
    - Esses serão os bits que corresponderão ao resto da divisão dos bits de entrada pela sequência geradora ( $A_m, A_{m-1}, \dots, A_1, A_0$ ) e serão colocados na saída logo após toda a sequência de entrada.

## LFSR



## LFSR



## LFSR



- Inicialmente, antes do cálculo, todos os flip-flops são colocados em 0.
- Os elementos circulares da figura correspondem a operadores bit a bit para as operações de XOR e de AND conforme o símbolo indicado.
- A cada período de relógio, um bit da sequência de bits de entrada ( $I$ ) é “empurrado” para dentro do circuito.
  - Enquanto houver bits de  $I$  a serem processados, as duas chaves indicadas na figura permanecem na posição “A”,
    - permitindo a entrada de novos bits e simultaneamente colocando na saída os próprios bits da mensagem original.
- Depois de todos os bits de  $I$  terem entrado no circuito, essas chaves mudam para a posição “B”,
  - Fazendo com que não sejam mais lidos novos bits na entrada e que os bits armazenados nos registros  $R_{m-1}$ ,  $R_0$  sejam colocados, um a um, para fora do circuito.
    - Esses serão os bits que corresponderão ao resto da divisão dos bits de entrada pela sequência geradora ( $A_m, A_{m-1}, \dots, A_1, A_0$ ) e serão colocados na saída logo após toda a sequência de entrada.

## LFSR



- Inicialmente, antes do cálculo, todos os flip-flops são colocados em 0.
- Os elementos circulares da figura correspondem a operadores bit a bit para as operações de XOR e de AND conforme o símbolo indicado.
- A cada período de relógio, um bit da sequência de bits de entrada ( $I$ ) é “empurrado” para dentro do circuito.
  - Enquanto houver bits de  $I$  a serem processados, as duas chaves indicadas na figura permanecem na posição “A”,
    - permitindo a entrada de novos bits e simultaneamente colocando na saída os próprios bits da mensagem original.
- Depois de todos os bits de  $I$  terem entrado no circuito, essas chaves mudam para a posição “B”,
  - Fazendo com que não sejam mais lidos novos bits na entrada e que os bits armazenados nos registros  $R_{m-1}$ ,  $R_0$  sejam colocados, um a um, para fora do circuito.
    - Esses serão os bits que corresponderão ao resto da divisão dos bits de entrada pela sequência geradora ( $A_m, A_{m-1}, \dots, A_1, A_0$ ) e serão colocados na saída logo após toda a sequência de entrada.

## LFSR



## Exemplo



## Simplificação do Circuito



- Uma simplificação pode ser feita considerando que  $A_1=0$  (fazendo com que o XOR posicionado entre  $R_0$  e  $R_1$  seja desnecessário) e  $A_0=A_2=1$  (fazendo com que os multiplicadores por  $A_0$  e  $A_2$  sejam desnecessários).



## Funcionamento



- $R_0(t+1) = R_2(t) \oplus I(t)$
- $R_1(t+1) = R_0(t)$
- $R_2(t+1) = R_2(t) \oplus R_1(t) \oplus I(t)$

| $t$ | $R_2$ | $R_1$ | $R_0$ | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|-----|-------|-------|-------|---------------------------|----------------|-----|
|     |       |       |       |                           |                |     |

Resto



## Funcionamento



- $R_0(t+1) = R_2(t) \oplus I(t)$
- $R_1(t+1) = R_0(t)$
- $R_2(t+1) = R_2(t) \oplus R_1(t) \oplus I(t)$

| $t$ | $R_2$ | $R_1$ | $R_0$ | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|-----|-------|-------|-------|---------------------------|----------------|-----|
| 0   | 0     | 0     | 0     |                           |                | 1   |
| 1   |       |       |       |                           |                | 0   |
| 2   |       |       |       |                           |                | 1   |
| 3   |       |       |       |                           |                | 0   |
| 4   |       |       |       |                           |                | 1   |
| 5   |       |       |       |                           |                | 1   |
| 6   |       |       |       |                           |                | 1   |

Resto



## Funcionamento



- $R_0(t+1) = R_2(t) \oplus I(t)$
- $R_1(t+1) = R_0(t)$
- $R_2(t+1) = R_2(t) \oplus R_1(t) \oplus I(t)$

| $t$ | $R_2$ | $R_1$ | $R_0$ | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|-----|-------|-------|-------|---------------------------|----------------|-----|
| 0   | 0     | 0     | 0     | 1                         | 1              | 1   |
| 1   |       |       |       |                           |                | 0   |
| 2   |       |       |       |                           |                | 1   |
| 3   |       |       |       |                           |                | 0   |
| 4   |       |       |       |                           |                | 1   |
| 5   |       |       |       |                           |                | 1   |
| 6   |       |       |       |                           |                | 1   |

Resto



## Funcionamento



- $R_0(t+1) = R_2(t) \oplus I(t)$
- $R_1(t+1) = R_0(t)$
- $R_2(t+1) = R_2(t) \oplus R_1(t) \oplus I(t)$

| $t$ | $R_2$ | $R_1$ | $R_0$ | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|-----|-------|-------|-------|---------------------------|----------------|-----|
| 0   | 0     | 0     | 0     | 1                         | 1              | 1   |
| 1   | 1     | 0     | 1     | 0                         | 0              | 0   |
| 2   |       |       |       |                           |                | 1   |
| 3   |       |       |       |                           |                | 0   |
| 4   |       |       |       |                           |                | 1   |
| 5   |       |       |       |                           |                | 1   |
| 6   |       |       |       |                           |                |     |

↑ Resto



## Funcionamento



- $R_0(t+1) = R_2(t) \oplus I(t)$
- $R_1(t+1) = R_0(t)$
- $R_2(t+1) = R_2(t) \oplus R_1(t) \oplus I(t)$

| $t$ | $R_2$ | $R_1$ | $R_0$ | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|-----|-------|-------|-------|---------------------------|----------------|-----|
| 0   | 0     | 0     | 0     | 1                         | 1              | 1   |
| 1   | 1     | 0     | 1     | 1                         | 1              | 0   |
| 2   |       |       |       |                           |                | 1   |
| 3   |       |       |       |                           |                | 0   |
| 4   |       |       |       |                           |                | 1   |
| 5   |       |       |       |                           |                | 1   |
| 6   |       |       |       |                           |                |     |

↑ Resto



## Funcionamento



- $R_0(t+1) = R_2(t) \oplus I(t)$
- $R_1(t+1) = R_0(t)$
- $R_2(t+1) = R_2(t) \oplus R_1(t) \oplus I(t)$

| $t$ | $R_2$ | $R_1$ | $R_0$ | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|-----|-------|-------|-------|---------------------------|----------------|-----|
| 0   | 0     | 0     | 0     | 1                         | 1              | 1   |
| 1   | 1     | 0     | 1     | 1                         | 1              | 0   |
| 2   | 1     | 1     | 1     | 1                         | 0              | 1   |
| 3   |       |       |       |                           |                | 0   |
| 4   |       |       |       |                           |                | 1   |
| 5   |       |       |       |                           |                | 1   |
| 6   |       |       |       |                           |                |     |

↑ Resto



## Funcionamento



- $R_0(t+1) = R_2(t) \oplus I(t)$
- $R_1(t+1) = R_0(t)$
- $R_2(t+1) = R_2(t) \oplus R_1(t) \oplus I(t)$

| $t$ | $R_2$ | $R_1$ | $R_0$ | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|-----|-------|-------|-------|---------------------------|----------------|-----|
| 0   | 0     | 0     | 0     | 1                         | 1              | 1   |
| 1   | 1     | 0     | 1     | 1                         | 1              | 0   |
| 2   | 1     | 1     | 1     | 1                         | 0              | 1   |
| 3   | 1     | 1     | 0     | 0                         | 1              | 0   |
| 4   | 0     | 0     | 1     | 1                         | 1              | 1   |
| 5   | 1     | 1     | 1     | 1                         | 0              | 1   |
| 6   | 1     | 1     | 0     |                           |                |     |

↑ Resto



## Funcionamento

59  
DEPARTAMENTO  
DE INFORMÁTICA  
PUC-RIO



| $R_2$    | $R_1$    | $R_0$    | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|----------|----------|----------|---------------------------|----------------|-----|
| 0        | 0        | 0        | 1                         | 1              | 1   |
| 1        | 0        | 1        | 1                         | 1              | 0   |
| 1        | 1        | 1        | 1                         | 0              | 1   |
| 1        | 1        | 0        | 0                         | 1              | 0   |
| 0        | 0        | 1        | 1                         | 1              | 1   |
| 1        | 1        | 1        | 1                         | 0              | 1   |
| <b>1</b> | <b>1</b> | <b>0</b> |                           |                |     |



TeleMidia

## Verificação do CRC na Recepção

60  
DEPARTAMENTO  
DE INFORMÁTICA  
PUC-RIO

### Na Recepção

Mensagem FCS

|             |      |
|-------------|------|
| 101011110   | 1101 |
| <u>1101</u> |      |
| 1111        |      |
| <u>1101</u> |      |
| 0101        |      |
| <u>0000</u> |      |
| 1011        |      |
| <u>1101</u> |      |
| 1101        |      |
| <u>1101</u> |      |
| 0000        |      |
| <u>0000</u> |      |
| 0000        |      |
| <u>000</u>  |      |



| $t$ | $R_2$ | $R_1$ | $R_0$ | $R_2 \oplus R_1 \oplus I$ | $R_2 \oplus I$ | $I$ |
|-----|-------|-------|-------|---------------------------|----------------|-----|
| 0   | 0     | 0     | 0     | 0                         | 0              | 1   |
| 1   | 0     | 0     | 0     | 0                         | 0              | 0   |
| 2   | 0     | 0     | 1     | 0                         | 0              | 1   |
| 3   | 0     | 0     | 0     | 0                         | 0              | 0   |
| 4   | 0     | 0     | 1     | 0                         | 0              | 1   |
| 5   | 0     | 0     | 0     | 0                         | 0              | 1   |
| 6   | 0     | 0     | 1     | 0                         | 0              | 1   |
| 7   | 0     | 0     | 0     | 0                         | 0              | 0   |
| 8   | 0     | 0     | 1     | 0                         | 0              | 1   |
| 9   | 0     | 0     | 0     | 0                         | 0              | 0   |



TeleMidia



**Obrigado**

