

# Representação de informação

## Formatos e operações

João Canas Ferreira

Setembro de 2018



# Tópicos

1 Introdução à representação de informação

2 Representação em binário de números sem sinal

Representação binária

Conversão de base

O sistema de numeração hexadecimal

Operações aritméticas com operandos em binário

3 Representação de números inteiros com sinal

4 Representação de caracteres e símbolos gráficos

5 Representação de números em vírgula flutuante

Conceitos gerais

Formato IEEE-754 precisão simples

Operações aritméticas com operandos normalizados

## 1 Introdução à representação de informação

### 2 Representação em binário de números sem sinal

Representação binária

Conversão de base

O sistema de numeração hexadecimal

Operações aritméticas com operandos em binário

### 3 Representação de números inteiros com sinal

### 4 Representação de caracteres e símbolos gráficos

### 5 Representação de números em vírgula flutuante

Conceitos gerais

Formato IEEE-754 precisão simples

Operações aritméticas com operandos normalizados

# Representação física da informação

- O computador automático pode ser definido como uma máquina de uso geral que processa informação de acordo com uma sequência de instruções.

**Questão:** Como representar fisicamente a informação?

- As tecnologias atuais de implementação recorrem a elementos básicos que podem estar em um de dois estados (elementos bi-estáveis).

Os elementos ativos dos processadores atuais são dispositivos eletrónicos (transístores) que atuam como interruptores que podem estar **ligados** ou **desligados**.

Os dispositivos são feitos de silício, um material semicondutor, e vários compostos de silício. O óxido de silício é um dos materiais mais comuns (constituinte principal da areia).

- Os microprocessadores atuais são **circuitos integrados** que contém na ordem dos milhares de milhões ( $10^9$ ) de elementos ativos, que são capazes de mudar de estado em **algumas dezenas de picosegundos** ( $1\text{ ps} = 1 \times 10^{-12}\text{ s}$ ).

# Circuitos integrados

■ Circuitos miniaturizados em que os componentes estão todos integrados no mesmo substrato (de silício). Os circuitos **digitais** contém transistores (a funcionar como interruptores) e interligações de metal (alumínio ou cobre).



Fonte: [//learn.sparkfun.com/tutorials/integrated-circuits](http://learn.sparkfun.com/tutorials/integrated-circuits)

# Representação simbólica da informação

- Para obter uma **representação abstrata**, desligada dos detalhes da realização física, os estados são representados pelos símbolos **0 e 1**.
- A unidade fundamental de informação designa-se por **bit** (símbolo bit) e constitui a quantidade mínima de informação realizável fisicamente (pode assumir apenas dois valores diferentes, 0 ou 1).
- Para representar maior quantidade de informação pode-se usar um conjunto (ordenado) de bits. Um conjunto de N bits representa-se

$$a_{N-1}a_{N-2}\dots a_1a_0$$

- Um conjunto de 8 bits designa-se por **octeto**.
- O conjunto de bits mais pequeno tratado por um processador designa-se por **byte**, símbolo B.
- Para os computadores atuais,  $1\text{ B} = 8\text{ bit}$  (um byte é o mesmo que um octeto).

## 1 Introdução à representação de informação

## 2 Representação em binário de números sem sinal

Representação binária

Conversão de base

O sistema de numeração hexadecimal

Operações aritméticas com operandos em binário

## 3 Representação de números inteiros com sinal

## 4 Representação de caracteres e símbolos gráficos

## 5 Representação de números em vírgula flutuante

Conceitos gerais

Formato IEEE-754 precisão simples

Operações aritméticas com operandos normalizados

# Sistemas de numeração posicionais

- Um sistema numérico posicional de representação é determinado por:
  - ☞ **base  $b$ :** um número inteiro superior a 1;
  - ☞  **$b$  dígitos (símbolos individuais):**  $0, 1, \dots, b-1$ .
- Exemplo: O sistema decimal tem base  $b=10$  e dígitos  $0, 1, 2, \dots, 9$ .
- Uma sequência de  $N$  dígitos (número)  $d_{N-1}d_{N-2}\dots d_1d_0$  representa o valor dado pela expressão seguinte em que cada dígito aparece a multiplicar a potência da base correspondente. (Para qualquer base,  $b^0 = 1$ )

$$d_{N-1} \times b^{N-1} + d_{N-2} \times b^{N-2} + \dots + d_1 \times b^1 + d_0 \times b^0$$

- Por exemplo, para  $b = 10$ , o número **4542** representa o valor

$$4 \times 10^3 + 5 \times 10^2 + 4 \times 10^1 + 2$$

Por palavras: 4 milhares, 5 centenas, 4 dezenas e 2 unidades.

- **O peso de cada dígito depende da sua posição:** no número acima, as duas instâncias do símbolo '4' têm pesos diferentes ( $10^3$  e  $10$ , respetivamente).

## Sistema de numeração binário

- Num computador digital (binário) existem apenas dois símbolos que podem servir de dígitos (0 e 1). Logo, temos que usar base  $b = 2$ .
- Um conjunto de  $N$  bits pode ser interpretado como um número em base 2 em que  $d_i \in \{0, 1\}$  (i.e., uma soma de potências de 2):

$$d_{N-1} \times 2^{N-1} + d_{N-2} \times 2^{N-2} + \dots + d_1 \times 2^1 + d_0 \times 2^0$$

- Exemplo:  $10010_2 = 1 \times 2^4 + 0 \times 2^3 + 0 \times 2^2 + 1 \times 2^1 + 0 \times 2^0 = 16 + 2 = 18_{10}$
- Consequência: todos os números pares têm uma representação binária terminada por 0. [Porquê?]
- Consequência: as regras para as operações aritméticas em binário são análogas às regras usadas com o sistema decimal, porque dependem apenas das propriedades dos sistemas de numeração posicionais (com  $b \in \mathbb{N}, b > 1$ ).
- A conversão binário → decimal pode ser feita aplicando diretamente a definição e realizando os cálculos em decimal (como no exemplo acima).

## Parte fracionária

- O sistema posicional pode também representar facilmente números com parte fracionária usando potência inteiros **negativas** da base.
- A vírgula (ou o ponto, em inglês) é usado para separar as duas partes (inteira e fracionária). O número  $d_{N-1}d_{N-2}\dots d_1d_0.d_{-1}d_{-2}\dots$

$$d_{N-1} \times b^{N-1} + \dots + d_1 \times b^1 + d_0 \times b^0 + d_{-1} \times b^{-1} + d_{-2} \times b^{-2} + \dots$$

- Exemplo em decimal:  $17,83_{10} = 1 \times 10^1 + 7 + 8 \times \frac{1}{10} + 3 \times \frac{1}{10^2}$

Em palavras: 1 dezena, 7 unidades, 8 décimas e 3 centésimas.

- Exemplo em binário:

$$101,101_2 = 1 \times 2^2 + 1 + 1 \times \frac{1}{2} + 1 \times \frac{1}{2^3} = 4 + 1 + 0,5 + 0,125 = 5,625_{10}$$

- Em qualquer sistema posicional, pode-se considerar que existe um número infinito de zeros à esquerda e à direita da parte representada.

Exemplos:  $0076,1400_{10} = 76,14_{10}$      $00101,1100_2 = 101,11_2$ .

# Conversão binário → decimal

- Um número em binário corresponde a uma soma de potências de 2.
- Para converter um número binário em decimal basta executar as operações implícitas na representação posicional usando base 10.

## Exemplo de conversão base 2 → base 10

$$1101,011_2 = 2^3 + 2^2 + 2^0 + 2^{-2} + 2^{-3} = 8 + 4 + 1 + 0,25 + 0,125 = 13,375_{10}$$

- A posição imediatamente à *esquerda* da vírgula corresponde ao expoente 0.
- A posição imediatamente à *direita* da vírgula corresponde ao expoente -1.
- Expoentes crescem para a esquerda da vírgula, decrescem para a direita.

## Conversão decimal → binário: parte inteira

- Dividir o número sucessivamente por 2 até chegar a 0.
- Guardar o resto (0 ou 1) de cada divisão.
- Os valores sucessivos do resto constituem o número em binário, sendo que o primeiro resto corresponde ao bit *menos significativo* e o último ao *mais significativo*.

### Exemplo de conversão base 10 → base 2

$$19_{10} = ?_2$$

| N=19 | resto da divisão |
|------|------------------|
| 9    | 1                |
| 4    | 1                |
| 2    | 0                |
| 1    | 0                |
| 0    | 1                |

→

$$19_{10} = 10011_2$$

## Conversão decimal → binário: parte fracionária

- Multiplicar o número sucessivamente por 2.
- Guardar a parte inteira (0 ou 1) de cada multiplicação.
- Os valores da parte inteira constituem a parte fracionária do número em binário. O primeiro valor é o bit *mais significativo* e o último ao *menos significativo*.
- Terminar: número chega a 0 *ou* se repete *ou* atinge um número dado de bits.

Exemplo de conversão base 10 → base 2:      0,6<sub>10</sub>

| Número | ×2   | Parte inteira |                                                                           |
|--------|------|---------------|---------------------------------------------------------------------------|
| 0,6    | 1,2  | 1             | $0,6_{10} = 0,1001(1001)_2$<br>(parte fracionária infinita com repetição) |
| 0,2    | 0,4  | 0             |                                                                           |
| 0,4    | 0,8  | 0             | →                                                                         |
| 0,8    | 1,60 | 1             | com 8 casas binárias:                                                     |
| 0,6    | ...  | ...           | $0,10011001_2 = 2^{-1} + 2^{-4} + 2^{-5} + 2^{-8} = 0,59765625_{10}$      |

# Sistema de base 16

- O sistema *hexadecimal* use base  $b = 16$ .
- O conjunto de dígitos é  $0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F$ .
- Para os dígitos acima de 9, a correspondência com valores decimais é:

$$A \leftrightarrow 10 \quad B \leftrightarrow 11 \quad C \leftrightarrow 12 \quad D \leftrightarrow 13 \quad E \leftrightarrow 14 \quad F \leftrightarrow 15.$$

## Conversão de hexadecimal para decimal

$$6B7_{16} = 6B7_H = 6 \times 16^2 + 11 \times 16^1 + 7 = 1719_{10}$$

$$7F,5_{16} = 7 \times 16^1 + 15 \times 16^0 + 5 \times 16^{-1} = 127,3125_{10}$$

- A conversão de decimal para hexadecimal usa o mesmo procedimento que a conversão para binário, mas dividindo ou multiplicando por 16 (em vez de 2).
- O sistema hexadecimal permite uma representação mais compacta dos números (com menos dígitos).

## Relação entre sistema binário e sistema hexadecimal

► Existe uma relação direta entre as representações hexadecimal e binária!

Número binário com 8 bits:  $d_7d_6d_5d_4d_3d_2d_1d_0$  com  $d_i \in \{0, 1\}$  representa o valor

$$d_7 \cdot 2^7 + d_6 \cdot 2^6 + d_5 \cdot 2^5 + d_4 \cdot 2^4 + d_3 \cdot 2^3 + d_2 \cdot 2^2 + d_1 \cdot 2^1 + d_0 \cdot 2^0.$$

A expressão pode ser re-escrita como:

$$2^4 \cdot (d_7 \cdot 2^3 + d_6 \cdot 2^2 + d_5 \cdot 2^1 + d_4 \cdot 2^0) + 2^0 \cdot (d_3 \cdot 2^3 + d_2 \cdot 2^2 + d_1 \cdot 2^1 + d_0 \cdot 2^0).$$

► O valor das expressões a azul está entre 0 e 15. [Porquê?]

Portanto, a expressão pode ser escrita como

$$16^1 \cdot h_1 + 16^0 \cdot h_0 \quad \text{em que } h_i \in \{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E\}$$

que é representada em hexadecimal como  $h_1h_0$ .

► Um número em binário pode ser convertido para hexadecimal *formando grupos de 4 dígitos binários e substituindo-os pelo correspondente dígito hexadecimal.*

# Exemplos de conversão entre representações em base 2 e 16

## De binário para hexadecimal

$$\boxed{1} \boxed{10} \boxed{0101}_2 = D5_H$$

$$1011101001_2 = \boxed{0010} \boxed{1110} \boxed{1001}_2 = 2E9_H$$

$$111010,0101_2 = \boxed{0011} \boxed{1010} \boxed{0,0101}_2 = 3A,5_H$$

O processo também funciona no sentido inverso.

## De hexadecimal para binário

$$FF_H = \boxed{1111} \boxed{1111}_2 = 11111111_2$$

$$1AC_H = \boxed{0001} \boxed{1010} \boxed{1100}_2 = 110101100_2$$

$$5F,2A_H = \boxed{0101} \boxed{1111} \boxed{,0010} \boxed{1010}_2 = 1011111,00101010_2$$

# Adição de números sem sinal

■ Números sem sinal:  $\{0, 1, 2, 3, \dots\}$

■ Regras para as operações aritméticas são *análogas* às de aritmética decimal.

■ Adição:  $0 + 0 = 0$      $1 + 0 = 0 + 1 = 1$

■ Adição:  $1 + 1 = 10$

resultado igual a 0 e transporte de 1 unidade para a posição seguinte

■ Adição:  $1 + 1 + 1 = 11$

resultado igual a 1 e transporte de 1 unidade para a posição seguinte

## Adição em binário

$$\begin{array}{r} 1 & 1 & 1 & 1 & 1 \\ 0 & 1 & 0 & 1 & 1 & 1 & 0 & 1 \\ + & 1 & 1 & 0 & 1 & 0 & 1 & 0 & 0 \\ \hline 1 & 0 & 0 & 1 & 1 & 0 & 0 & 0 & 1 \end{array}$$

$$\begin{array}{r} 1 \\ + 2 & 1 & 2 \\ \hline 3 & 0 & 5 \end{array}$$

# Multiplicação de números sem sinal

► Regras:  $0 \times 0 = 1 \times 0 = 0 \times 1 = 0$        $1 \times 1 = 1$

## Multiplicação em binário

$$\begin{array}{r} & 1 & 0 & 1 & 0 & 0 \\ \times & 1 & 1 & 0 & 1 \\ \hline & 1 & 0 & 1 & 0 & 0 \\ 1 & 1 & 0 & 0 & 0 & 0 \\ 1 & 1 & 1 & 0 & 1 & 0 & 0 \\ + & 1 & 0 & 1 & 0 & 0 \\ \hline 1 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \end{array}$$

$$\begin{array}{r} & 2 & 0 \\ \times & 1 & 3 \\ \hline & 6 & 0 \\ \times & 2 & 0 \\ \hline 2 & 6 & 0 \end{array}$$

► Pode-se omitir as filas que têm apenas zeros, mas é preciso cuidado ao alinhar os produtos parciais.

# Subtração de números sem sinal

■ Subtrair apenas números menores a números maiores (diminuendo maior que o subtraendo).

■ Subtração:  $1 - 1 = 0 - 0 = 0 \quad 1 - 0 = 1$

■ Subtração:  $10 - 1 = 01$

resultado=1 e trocar o bit da posição seguinte (do diminuendo)

■ Subtração:  $100 - 1 = 011$

resultado=1 e trocar os bits das duas posições seguintes (do diminuendo)

■ As alterações do diminuendo (em binário) seguem a regra:

*da direita para a esquerda a partir da posição da subtração trocar zeros por uns até ao primeiro 1; trocar também este dígito.*

## Subtração em binário

$$\begin{array}{r} 0 \ 0 \ 1 \ 0 \ 1 \\ 1 \ 1 \ 0 \ 1 \ 0 \ 0 \ 1 \ 1 \\ - 0 \ 1 \ 0 \ 1 \ 1 \ 1 \ 1 \ 0 \\ \hline 0 \ 1 \ 1 \ 1 \ 0 \ 1 \ 0 \ 1 \end{array}$$

$$\begin{array}{r} 1 \ 0 \\ 2 \ 1 \ 1 \\ - 9 \ 4 \\ \hline 1 \ 1 \ 7 \end{array}$$

## 1 Introdução à representação de informação

## 2 Representação em binário de números sem sinal

Representação binária

Conversão de base

O sistema de numeração hexadecimal

Operações aritméticas com operandos em binário

## 3 Representação de números inteiros com sinal

## 4 Representação de caracteres e símbolos gráficos

## 5 Representação de números em vírgula flutuante

Conceitos gerais

Formato IEEE-754 precisão simples

Operações aritméticas com operandos normalizados

# Representações com número fixo de bits

■ Processadores usam um número fixo de bits para representar números.

Por exemplo, um processador de 32 bits tem esta designação por representar os números com 32 bit.

■ Muitos processadores suportam representações de vários tamanhos.

Ex.: microprocessadores Intel atuais suportam operandos de 8, 16, 32 ou 64 bit.

■ Apenas operações com operandos do mesmo tamanho (i.e., igual número de bits) são suportadas.

■ O uso de um tamanho fixo implica que *nem todos os resultados são representáveis*.

■ A gama de números sem sinal (binário puro) que pode ser representada com N bits é  $[0; 2^N - 1]$ . (Porquê?)

## Saída da gama de representação: erro de *overflow*

Com N = 8, a gama da representação binária é [0; 255].

O resultado da adição  $230_{10} + 72_{10}$  não pode ser representado, embora os operandos possam.

# Números sem sinal

■ A gama de números sem sinal (binário puro) que pode ser representada com N bits é  $[0; 2^N - 1]$ . (Porquê?)

## Saída da gama de representação: erro de *overflow*

Com N = 8, a gama da representação binária é [0; 255].

O resultado da adição  $230_{10} + 72_{10}$  não pode ser representado, embora os operandos possam.

## Adição em binário com *overflow*

Considerar N=8.

$$\begin{array}{r} 1 & 1 & 1 & 1 & 1 \\ 0 & 1 & 0 & 1 & 1 & 1 & 0 & 1 \\ + & 1 & 1 & 0 & 1 & 0 & 1 & 0 & 0 \\ \hline \text{X} & 0 & 0 & 1 & 1 & 0 & 0 & 0 & 1 \end{array} \qquad \begin{array}{r} & & 9 & 3 \\ & + & 2 & 1 & 2 \\ \hline & & 4 & 9 \end{array}$$

Erro!  
*Overflow*  
305 seria correto, mas tem-se  
 $305 - 256 = 49$

# Representação em sinal e grandeza

- A representação em sinal e grandeza com N bits usa o bit mais significativo para indicar o sinal e os N-1 bits para representar o valor absoluto (a grandeza).
- Bit de sinal: 0 positivo, 1 negativo.

## Representação em sinal e grandeza

Considerar N=6.

$$17_{10} = 010001_{SG} \quad -17_{10} = 110001_{SG}$$

A gama de valores representáveis é [−31; +31].

- A gama de valores representáveis em N bits é  $[-(2^{N-1} - 1); (2^{N-1} - 1)]$ .  
(Porquê?)
- Existem duas representações para 0. (Quais?)
- É uma representação muito pouco usada para representar números inteiros.

# Regras para operações aritméticas: Adição e subtração



Subtração:  $A - B = A + (-B)$  e usar as regras da adição

# Regras para operações aritméticas: Multiplicação



# Representação em complemento para 2: conceito

- Objetivo: encontrar uma representação com regras mais simples.
- O que acontece a um contador binário quando atinge o limite?

Volta a zero e continua a contar.



- Intervalo de valores da representação em complemento para 2: [-4; 3]

## Representação em complemento para 2: definição

- Representação em *complemento para 2* com **N** bits:  $[-2^{(N-1)}; 2^{(N-1)} - 1]$ .
- Números não-negativos são representados como habitualmente  $\rightarrow$  *bit mais significativo é zero*.
- Números negativos são representados de forma a satisfazer a fórmula:

$$-d_{N-1} \times 2^{N-1} + d_{N-2} \times 2^{N-2} + \dots + d_1 \times 2^1 + d_0 \times 2^0$$

$\rightarrow$  *bit mais significativo é um.* [Porquê?]

### Conversão de números com sinal (CPL2)

Usando  $N=5$ , o intervalo de valores representáveis é  $[-16;15]$ .

$$13_{10} = 01101_{\text{cpl2}}$$

$$-13_{10} = -16 + 3 = 10011_{\text{cpl2}}$$

## Representação em complemento para 2: operações

- Adição e subtração: procedimento é igual ao usado com números sem sinal, mas a deteção de *overflow* é diferente.
- Alternativa para subtração:  $A - B = A + (-B)$
- Ocorre *overflow* na adição de dois números em CPL2 **se e só se:**
  - ① os dois operandos tiverem o mesmo sinal      **e**
  - ② o sinal do resultado for diferente do sinal dos operandos
- Importante: ignora-se sempre o transporte para lá do dígito mais significativo.
- Determinar o simétrico (trocar o sinal) de  $x$ ;
  - ① calcular em binário  $(2^N - x)$  e ficar com os  $N$  bits menos significativos;
  - ② equivalente: trocar todos os bits de  $x$  e somar 1;
  - ③ regra prática: da direita para a esquerda, copiar os dígitos de  $x$  até ao 1º um; depois inverter os dígitos restantes.
- Multiplicação: tem regras próprias que não trataremos nesta UC.

## Representação em complemento para 2: exemplos

■ N = 6, intervalo [-32; 31].

### Cálculo do simétrico

Seja  $x = -21_{10}$ . Então,  $-x = 21_{10} = 010101_{\text{cpl2}}$ .

1. Como  $2^6 = 1000000_2$ ,

$$\begin{array}{r} 1 & 0 & 0 & 0 & 0 & 0 & 0 \\ - & 0 & 1 & 0 & 1 & 0 & 1 \\ \hline \cancel{X} & 1 & 0 & 1 & 0 & 1 & 1 \end{array}$$

2.  $010101 \rightarrow 101010 + 1 = 101011$

3.  $010101 \rightarrow 101011$

Logo  $x = -21_{10} = 101011_{\text{cpl2}}$

### Adição e subtração

Seja  $y = -13_{10}$ . Logo  $-y = 13_{10} = 001101_{\text{cpl2}} \rightarrow y = 110011_{\text{cpl2}}$ .

$x + y = 101011 + 110011 = \cancel{X}011110 \rightarrow \text{overflow!}$

$x - y = x + (-y) = 101011 + 001101 = 111000 \rightarrow \text{OK!}$

## Extensão do formato de representação

- Com dados representados em N bits, pode surgir a necessidade de obter a representação do mesmo valor em M bits.
- Em geral, é necessário ter  $M > N$  para não haver perda de informação.
- Em cada caso particular, depende da gama dos valores realmente processados.
- As regras são as seguintes:

| Formato            | Regra                                       | Exemplo ( $N=4, M=6$ )                                 |
|--------------------|---------------------------------------------|--------------------------------------------------------|
| sem sinal          | acrescentar zeros à esquerda                | $1010 \rightarrow 001010$                              |
| sinal e grandeza   | acrescentar zeros à direita do bit de sinal | $1010 \rightarrow 100010$                              |
| complemento para 2 | replicar o bit de sinal                     | $1010 \rightarrow 111010$<br>$0110 \rightarrow 000110$ |

## 1 Introdução à representação de informação

## 2 Representação em binário de números sem sinal

Representação binária

Conversão de base

O sistema de numeração hexadecimal

Operações aritméticas com operandos em binário

## 3 Representação de números inteiros com sinal

## 4 Representação de caracteres e símbolos gráficos

## 5 Representação de números em vírgula flutuante

Conceitos gerais

Formato IEEE-754 precisão simples

Operações aritméticas com operandos normalizados

# Código ASCII

## American Standard Code for Information Interchange

| Dec   | Hex | Oct   | Chr | Dec   | Hex | Oct    | HTML  | Chr | Dec   | Hex | Oct    | HTML | Chr | Dec    | Hex | Oct    | HTML   | Chr |
|-------|-----|-------|-----|-------|-----|--------|-------|-----|-------|-----|--------|------|-----|--------|-----|--------|--------|-----|
| 0 0   | 000 | NULL  |     | 32 20 | 040 | &#032; | Space |     | 64 40 | 100 | &#064; | @    |     | 96 60  | 140 | &#096; | `      |     |
| 1 1   | 001 | SoH   |     | 33 21 | 041 | &#033; | !     |     | 65 41 | 101 | &#065; | A    |     | 97 61  | 141 | &#097; | a      |     |
| 2 2   | 002 | SoTxt |     | 34 22 | 042 | &#034; | "     |     | 66 42 | 102 | &#066; | B    |     | 98 62  | 142 | &#098; | b      |     |
| 3 3   | 003 | EoTxt |     | 35 23 | 043 | &#035; | #     |     | 67 43 | 103 | &#067; | C    |     | 99 63  | 143 | &#099; | c      |     |
| 4 4   | 004 | EoT   |     | 36 24 | 044 | &#036; | \$    |     | 68 44 | 104 | &#068; | D    |     | 100 64 | 144 | &#100; | d      |     |
| 5 5   | 005 | Enq   |     | 37 25 | 045 | &#037; | %     |     | 69 45 | 105 | &#069; | E    |     | 101 65 | 145 | &#101; | e      |     |
| 6 6   | 006 | Ack   |     | 38 26 | 046 | &#038; | &     |     | 70 46 | 106 | &#070; | F    |     | 102 66 | 146 | &#102; | f      |     |
| 7 7   | 007 | Bell  |     | 39 27 | 047 | &#039; | '     |     | 71 47 | 107 | &#071; | G    |     | 103 67 | 147 | &#103; | g      |     |
| 8 8   | 010 | Bsp   |     | 40 28 | 050 | &#040; | (     |     | 72 48 | 110 | &#072; | H    |     | 104 68 | 150 | &#104; | h      |     |
| 9 9   | 011 | HTab  |     | 41 29 | 051 | &#041; | )     |     | 73 49 | 111 | &#073; | I    |     | 105 69 | 151 | &#105; | i      |     |
| 10 A  | 012 | LFeed |     | 42 2A | 052 | &#042; | *     |     | 74 4A | 112 | &#074; | J    |     | 106 6A | 152 | &#106; | j      |     |
| 11 B  | 013 | VTab  |     | 43 2B | 053 | &#043; | +     |     | 75 4B | 113 | &#075; | K    |     | 107 6B | 153 | &#107; | k      |     |
| 12 C  | 014 | FFeed |     | 44 2C | 054 | &#044; | ,     |     | 76 4C | 114 | &#076; | L    |     | 108 6C | 154 | &#108; | l      |     |
| 13 D  | 015 | CR    |     | 45 2D | 055 | &#045; | -     |     | 77 4D | 115 | &#077; | M    |     | 109 6D | 155 | &#109; | m      |     |
| 14 E  | 016 | SOut  |     | 46 2E | 056 | &#046; | .     |     | 78 4E | 116 | &#078; | N    |     | 110 6E | 156 | &#110; | n      |     |
| 15 F  | 017 | SIn   |     | 47 2F | 057 | &#047; | /     |     | 79 4F | 117 | &#079; | O    |     | 111 6F | 157 | &#111; | o      |     |
| 16 10 | 020 | DLE   |     | 48 30 | 060 | &#048; | 0     |     | 80 50 | 120 | &#080; | P    |     | 112 70 | 160 | &#112; | p      |     |
| 17 11 | 021 | DC1   |     | 49 31 | 061 | &#049; | 1     |     | 81 51 | 121 | &#081; | Q    |     | 113 71 | 161 | &#113; | q      |     |
| 18 12 | 022 | DC2   |     | 50 32 | 062 | &#050; | 2     |     | 82 52 | 122 | &#082; | R    |     | 114 72 | 162 | &#114; | r      |     |
| 19 13 | 023 | DC3   |     | 51 33 | 063 | &#051; | 3     |     | 83 53 | 123 | &#083; | S    |     | 115 73 | 163 | &#115; | s      |     |
| 20 14 | 024 | DC4   |     | 52 34 | 064 | &#052; | 4     |     | 84 54 | 124 | &#084; | T    |     | 116 74 | 164 | &#116; | t      |     |
| 21 15 | 025 | NAck  |     | 53 35 | 065 | &#053; | 5     |     | 85 55 | 125 | &#085; | U    |     | 117 75 | 165 | &#117; | u      |     |
| 22 16 | 026 | Syn   |     | 54 36 | 066 | &#054; | 6     |     | 86 56 | 126 | &#086; | V    |     | 118 76 | 166 | &#118; | v      |     |
| 23 17 | 027 | EoTB  |     | 55 37 | 067 | &#055; | 7     |     | 87 57 | 127 | &#087; | W    |     | 119 77 | 167 | &#119; | w      |     |
| 24 18 | 030 | Can   |     | 56 38 | 070 | &#056; | 8     |     | 88 58 | 130 | &#088; | X    |     | 120 78 | 170 | &#120; | x      |     |
| 25 19 | 031 | EoM   |     | 57 39 | 071 | &#057; | 9     |     | 89 59 | 131 | &#089; | Y    |     | 121 79 | 171 | &#121; | y      |     |
| 26 1A | 032 | Sub   |     | 58 3A | 072 | &#058; | :     |     | 90 5A | 132 | &#090; | Z    |     | 122 7A | 172 | &#122; | z      |     |
| 27 1B | 033 | Esc   |     | 59 3B | 073 | &#059; | ;     |     | 91 5B | 133 | &#091; | [    |     | 123 7B | 173 | &#123; | {      |     |
| 28 1C | 034 | FSep  |     | 60 3C | 074 | &#060; | <     |     | 92 5C | 134 | &#092; | \    |     | 124 7C | 174 | &#124; |        |     |
| 29 1D | 035 | GSep  |     | 61 3D | 075 | &#061; | =     |     | 93 5D | 135 | &#093; | ]    |     | 125 7D | 175 | &#125; | }      |     |
| 30 1E | 036 | RSep  |     | 62 3E | 076 | &#062; | >     |     | 94 5E | 136 | &#094; | ^    |     | 126 7E | 176 | &#126; | ~      |     |
| 31 1F | 037 | USep  |     | 63 3F | 077 | &#063; | ?     |     | 95 5F | 137 | &#095; | _    |     | 127 7F | 177 | &#127; | Delete |     |

charstable.com

# Máquina de escrever

Inicialmente, impressoras eram máquinas de escrever sem teclado (*typewriter*)



Fonte: [https://commons.wikimedia.org/wiki/File:Erika\\_9\\_typewriter.jpg](https://commons.wikimedia.org/wiki/File:Erika_9_typewriter.jpg)

# Código ISO-8859-1 (Latin-1)

ISO/IEC 8859-1:1998, Information technology—Part 1: Latin alphabet No. 1

| ISO-8859-1 |      |     |     |     |     |     |     |     |     |      |     |     |     |     |     |     |
|------------|------|-----|-----|-----|-----|-----|-----|-----|-----|------|-----|-----|-----|-----|-----|-----|
|            | x0   | x1  | x2  | x3  | x4  | x5  | x6  | x7  | x8  | x9   | xA  | xB  | xC  | xD  | xE  | xF  |
| 0x         | NUL  | SOH | STX | ETX | EOT | ENQ | ACK | BEL | BS  | HT   | LF  | VT  | FF  | CR  | SO  | SI  |
| 1x         | DLE  | DC1 | DC2 | DC3 | DC4 | NAK | SYN | ETB | CAN | EM   | SUB | ESC | FS  | GS  | RS  | US  |
| 2x         | SP   | !   | "   | #   | \$  | %   | &   | '   | (   | )    | *   | +   | ,   | -   | .   | /   |
| 3x         | 0    | 1   | 2   | 3   | 4   | 5   | 6   | 7   | 8   | 9    | :   | ;   | <   | =   | >   | ?   |
| 4x         | @    | A   | B   | C   | D   | E   | F   | G   | H   | I    | J   | K   | L   | M   | N   | O   |
| 5x         | P    | Q   | R   | S   | T   | U   | V   | W   | X   | Y    | Z   | [   | \   | ]   | ^   | _   |
| 6x         | `    | a   | b   | c   | d   | e   | f   | g   | h   | i    | j   | k   | l   | m   | n   | o   |
| 7x         | p    | q   | r   | s   | t   | u   | v   | w   | x   | y    | z   | {   |     | }   | ~   | DEL |
| 8x         | PAD  | HOP | BPH | NBH | IND | NEL | SSA | ESA | HTS | HTJ  | VTS | PLD | PLU | RI  | SS2 | SS3 |
| 9x         | DCS  | PU1 | PU2 | STS | CCH | MW  | SPA | EPA | SOS | SGCI | SCI | CSI | ST  | OSC | PM  | APC |
| Ax         | NBSP | í   | ¢   | £   | ¤   | ¥   | ƒ   | §   | “   | ©    | ™   | «   | »   | –   | ®   | –   |
| Bx         | °    | ±   | ²   | ³   | ‘   | µ   | ¶   | ·   | „   | ¹    | º   | »   | ¼   | ½   | ¾   | ܶ   |
| Cx         | À    | Á   | Â   | Ã   | Ä   | Å   | Æ   | Ç   | È   | É    | Ê   | Ï   | Í   | Ӯ   | ӻ   | Ӽ   |
| Dx         | Đ    | Ñ   | Ò   | Ó   | Ô   | Ö   | Ö   | ×   | Ø   | Ù    | Ú   | Û   | Ü   | Ý   | Þ   | Ծ   |
| Ex         | à    | á   | â   | ã   | ä   | å   | æ   | ç   | è   | é    | ê   | ë   | ì   | í   | î   | ĩ   |
| Fx         | ö    | ñ   | ò   | ó   | ô   | ö   | ö   | ÷   | ø   | ù    | ú   | û   | ü   | ý   | þ   | ÿ   |

Fonte: <https://www.alsacreations.com/>

## 1 Introdução à representação de informação

## 2 Representação em binário de números sem sinal

Representação binária

Conversão de base

O sistema de numeração hexadecimal

Operações aritméticas com operandos em binário

## 3 Representação de números inteiros com sinal

## 4 Representação de caracteres e símbolos gráficos

## 5 Representação de números em vírgula flutuante

Conceitos gerais

Formato IEEE-754 precisão simples

Operações aritméticas com operandos normalizados

# Notação científica

- Em muitas situações existe a necessidade de representar uma gama alargada de números, desde números muito próximos de zero até números de grande magnitude: cálculo científico, contabilidade, computação gráfica, etc.
- A chamada *notação científica* é o formato mais usado.
- Nesta notação em decimal, os números têm o formato  $d_0.d_1d_2d_3\dots \times 10^i$  em que  $i$  é um número inteiro qualquer.

## Exemplos

$$17,987 = 1,7987 \times 10^1$$

$$0,0004567 = 4,567 \times 10^{-4}$$

$$1,756 = 175,6 \times 10^{-2} = 0,001756 \times 10^3 = \dots$$

- Para se ter uma única representação, impõe-se uma condição de *normalização*. Exemplo: os números devem ter apenas 1 dígito ( $\neq 0$ ) à esquerda da vírgula.

$$4,567 \times 10^{-4} \checkmark \quad 0,0004567 \times 10^0 \text{ } \textcolor{red}{X} \quad 456,7 \times 10^{-6} \text{ } \textcolor{red}{X}$$

## Norma para representação em vírgula flutuante

- Notação científica é designada por representação em *vírgula flutuante* (“floating point”).
- A parte  $d_0.d_1d_2d_3\dots$  é designada por *mantissa*.
- Existem muitas variantes possíveis, mas os formatos usados atualmente são definidos pela norma IEEE-754 (versões em 1985 e 2008) e pela norma internacional ISO/IEC/IEEE 60559:2011 (conteúdo idêntico).
- A norma define várias representações de precisão diferente.
- O formato de precisão simples ocupa 32 bits; o de precisão dupla ocupa 64 bits.  
(Existem mais)
- Existe uma representação não normalizada para números próximos de zero.
- A norma define vários modos de arredondamento.
- A norma também define representações para infinito, erro, etc.  
(NaN = Not a Number)

# Definição do formato VF de precisão simples

→ O formato IEEE-754 codifica números representados em binário na seguinte forma *normalizada*:

$$\pm 1, F \times 2^K$$

- **F** parte fracionária da mantissa normalizada  $1, \dots$  (em binário)
- **K** expoente inteiro na gama  $[-126; +127]$

→ A organização do formato é a seguinte:

|          |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |                       |   |   |   |
|----------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------------------|---|---|---|
| 31       | 30        | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                     | 2 | 1 | 0 |
| <b>S</b> | <b>K*</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | parte fracionária (F) |   |   |   |
| 1        | 8 bits    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 23 bits               |   |   |   |

- **S** 0 se positivo, 1 se negativo (sinal)
- **K\***  $K^* = K + 127$  (em binário) — codificação excesso-127  
Portanto,  $K^* \in [1; 254]$

→ Generalização: Para um expoente de E bits usa-se a notação excesso  $2^{(E-1)} - 1$

# Conversão decimal ↔ VF

## Conversão decimal → VF

$X = -12,25$  em binário  $|X| = 1100,01_2 = 1,10001_2 \times 2^3$

$$K = 3 \rightarrow K^* = 127 + 3 = 130 = 10000010_2$$

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

|   |          |                                  |
|---|----------|----------------------------------|
| 1 | 10000010 | 10001000000000000000000000000000 |
|---|----------|----------------------------------|

1100 0001 0100 0100 0000 0000 0000 0000 → C1440000<sub>H</sub>

## Conversão VF → decimal

Y é representado em VF pelo padrão 41B90000<sub>H</sub>. Valor decimal?

41B90000<sub>H</sub> → 0100 0001 1011 1001 0000 0000 0000

|   |          |                                  |
|---|----------|----------------------------------|
| 0 | 10000011 | 01110010000000000000000000000000 |
|---|----------|----------------------------------|

$$K^* = 10000011_2 = 131 \rightarrow K = 131 - 127 = 4$$

$$|Y| = 1,0111001_2 \times 2^4 = 10111,001_2 = 23,125 \rightarrow Y = 23,125 \quad \text{porque } S = 0$$

## Casos especiais

➡ **K<sup>\*</sup> = 255** Situações excepcionais (erro, infinito, etc) NaN

➡ **K<sup>\*</sup> = 0** número não normalizado (*subnormal*).

Neste caso, o número representado é

$$\pm 0.F \times 2^{-126}$$

Exemplo:  $2^{-127} = 0,1 \times 2^{-126}$  é um número subnormal  
com F = 10000000000000000000000000000000<sub>2</sub> (são 22 zeros)

O bit da mantissa à esquerda da vírgula é (implicitamente) 0.

➡ O número zero também é subnormal: F = 0, K<sup>\*</sup> = 0.

➡ O uso de números subnormais permite uma aproximação mais gradual a zero, mas estes têm uma precisão inferior à dos números normalizados.

# Regras para adição / subtração

- O formato VF corresponde a uma representação em *sinal e grandeza*.
- Calcular  $C = A + B$  em VF

- ① Comparar  $|A|$  e  $|B|$ :  $X = \max(|A|, |B|)$  e  $Y = \min(|A|, |B|)$
- ② Alterar a mantissa de  $Y$  para este ter o mesmo expoente que  $X$ .
- ③ Se  $\text{sinal}(A) = \text{sinal}(B)$ 
  - ①  $|C| = X + Y$
  - ②  $\text{sinal}(C) = \text{sinal}(A)$
- ④ Se  $\text{sinal}(A) \neq B$ 
  - ①  $|C| = X - Y$
  - ②  $\text{sinal}(C) = \text{sinal}$  do operando de maior valor absoluto
- ⑤ Normalizar  $C$  (se necessário)

- Subtração é transformada em adição:  $C = A - B = A + (-B)$

# Regras para a multiplicação

■ Calcular  $C = A \times B$  em VF

- ① Se  $\text{sinal}(A)=\text{sinal}(B)$  então  $\text{sinal}(C)=0$  senão  $\text{sinal}(C)=1$
- ②  $\text{Expoente}(C)=\text{Expoente}(A)+\text{Expoente}(B)$
- ③  $\text{Mantissa}(C)=\text{Mantissa}(A) \times \text{Mantissa}(B)$
- ④ Normalizar C (se necessário)

■ Atenção: a soma de dois operandos codificados em excesso-127 faz-se somando os dois operandos normalmente e subtraindo 127. (Porquê?)

$$E_C = E_A + E_B - 127$$

em que  $E_A$ ,  $E_B$  e  $E_C$  são os expoentes *codificados* dos correspondentes operandos.

# Referências

- COD4** D. A. Patterson & J. L. Hennessey, Computer Organization and Design, 4 ed.
- COD3** D. A. Patterson & J. L. Hennessey, Computer Organization and Design, 3 ed.

Os tópicos tratados nesta apresentação são descritos na seguinte secção de [COD4]:

- apêndice C, secção C.9

Também são tratados na seguinte secção de [COD3]:

- apêndice B, secção B.9

# Circuitos combinatórios

João Canas Ferreira

Outubro de 2017



# Tópicos

## 1 Álgebra de Boole

- Representação abstrata do processamento binário
- Especificação algébrica
- Representações canónicas

## 2 Portas lógicas

- Portas elementares
- Descrição hierárquica de circuitos

## 3 Circuitos padrão

- Multiplexadores
- Descodificadores
- Codificadores

## 1 Álgebra de Boole

- Representação abstrata do processamento binário
- Especificação algébrica
- Representações canónicas

## 2 Portas lógicas

- Portas elementares
- Descrição hierárquica de circuitos

## 3 Circuitos padrão

- Multiplexadores
- Descodificadores
- Codificadores

# Tratamento de informação binária

- ➡ Como definir e representar o tratamento de informação binária?



- ➡ Modelo conceitual mais simples: “caixa negra” que tem  $n$  entradas e 1 saída. O valor binário da saída depende da **combinação** de valores binários presentes nas entradas.
- ➡ Como definir a função  $F$  das  $n$  entradas binárias?

## Definição exaustiva

■ Como as combinações de valores de entrada são finitas, podemos fazer uma lista (tabela) exaustiva do valor de saída correspondente a cada uma. Exemplo:

| $x_2$ | $x_1$ | $x_0$ | $F$ |
|-------|-------|-------|-----|
| 0     | 0     | 0     | 1   |
| 0     | 0     | 1     | 0   |
| 0     | 1     | 0     | 0   |
| 0     | 1     | 1     | 1   |
| 1     | 0     | 0     | 1   |
| 1     | 0     | 1     | 0   |
| 1     | 1     | 0     | 1   |
| 1     | 1     | 1     | 0   |

- Tabela de verdade (considerando 1 como verdadeiro e 0 como falso)
- Para uma função de  $n$  variáveis binárias, quantas linhas tem a tabela?
- Como calcular a **composição de funções**? (Quando um valor de entrada é, por sua vez, função de outros valores?)

# Expressão algébrica

- A especificação e composição das funções de variáveis binárias pode ser simplificada com a introdução de expressões algébricas.
- Em 1938, Claude Shannon propôs a utilização de um método de cálculo inventado no século XIX (1854) pelo Reverendo George Boole para expressar as “leis do raciocínio”.  
Nota: Esse método é equivalente ao cálculo da lógica proposicional.
- A formalização das operações associadas designa-se por **Álgebra de Boole** e pode ser feita sem requerer uma interpretação como “leis do raciocínio”.



George Boole



Claude Shannon

# Axiomas de Álgebra de Boole

- Uma **álgebra de Boole** é constituída por um conjunto  $A$ , dotado de duas operações binárias  $+$  e  $\bullet$ , uma operação unária  $\bar{\phantom{x}}$  (complemento) e tendo (pelo menos) dois elementos distintos 0 e 1.
- Para quaisquer  $x, y, z \in A$ , valem os seguintes axiomas (Huntington, 1904)

$$\begin{array}{lll} x + 0 = x & x \cdot 1 = x & \text{(identidade)} \\ x + y = y + x & x \cdot y = y \cdot x & \text{(comutatividade)} \\ x + (y \cdot z) = (x + y) \cdot (x + z) & x \cdot (y + z) = (x \cdot y) + (x \cdot z) & \text{(distributividade)} \\ x + \bar{x} = 1 & x \cdot \bar{x} = 0 & \text{(complemento)} \end{array}$$

- Notações alternativas:  $\vee$  para  $+$      $\wedge$  para  $\bullet$      $\neg x$  para  $\bar{x}$ .

- **Princípio da dualidade:** A uma igualdade verdadeira corresponde outra equação verdadeira obtida pelas trocas seguintes:

$$+ \leftrightarrow \bullet$$

$$0 \leftrightarrow 1$$

(Porquê?)

- Para circuito digitais:

álgebra de Boole com  $A = \{0, 1\}$  (apenas dois elementos: 0 e 1)

# Alguns teoremas úteis

■ Precedência decrescente: negação, e-lógico ( $\bullet$ ), ou-lógico ( $+$ ).

## 1 variável

$$x + x = x$$

$$x \cdot x = x$$

$$x + 1 = 1$$

$$x \cdot 0 = 0$$

$$\bar{\bar{x}} = x$$

## 2 variáveis

$$x + x \cdot y = x$$

$$x \cdot (x + y) = x$$

$$x + \bar{x} \cdot y = x + y$$

$$x \cdot (\bar{x} + y) = x \cdot y$$

$$(x + y) + (\bar{x} \cdot \bar{y}) = 1$$

$$(x \cdot y) \cdot (\bar{x} + \bar{y}) = 0$$

$$(x + y) \cdot (\bar{x} \cdot \bar{y}) = 0$$

$$(x \cdot y) + (\bar{x} + \bar{y}) = 1$$

$$\underline{x + y = \bar{x} \cdot \bar{y}}$$

$$\underline{x \cdot y = \bar{x} + \bar{y}}$$

## 3 variáveis

$$x \cdot (y \cdot z) = (x \cdot y) \cdot z$$

$$x + (y + z) = (x + y) + z$$

$$x \cdot y + \bar{x} \cdot z + y \cdot z = x \cdot y + \bar{x} \cdot z$$

$$(x + y) \cdot (\bar{x} + z) \cdot (y + z) = (x + y) \cdot (\bar{x} + z)$$

leis de de Morgan (não é gralha!)

■ Para a álgebra de Boole (de 2 elementos), os teoremas podem ser demonstrados construindo as tabelas de verdade das expressões de ambos os lados da igualdade e confirmando que as colunas dos resultados são iguais.

# Simplificação de expressões

■ Axiomas e teoremas podem ser usados na simplificação de expressões.

Exemplo (por convenção, pode omitir-se o operador  $\bullet$ ):

$$\begin{aligned}\overline{AB} (\overline{A} + B)(\overline{B} + B) &= \overline{AB} (\overline{A} + B) \\ &= (\overline{A} + \overline{B}) (\overline{A} + B) \quad \text{lei de Morgan} \\ &= \overline{A} + \overline{B}B \\ &= \overline{A}\end{aligned}$$

■ Alternativas:

- ☞ mapas de Karnaugh (método gráfico; até 6 variáveis)
- ☞ método Quine-McClusky (Karma3 em <http://bit.ly/boolmin>)  
expressões mínimas de dois níveis (pode demorar muito tempo)
- ☞ métodos heurísticos (Logic Friday em <http://www.sontrak.com/>)  
programa original: Espresso (<http://bit.ly/espresso-sources>)

## Teorema de expansão de Boole (Shannon)

■ Para qualquer função booleana vale sempre:

$$F(x_1, x_2, \dots, x_n) = x_1 \cdot F(1, x_2, \dots, x_n) + \overline{x_1} \cdot F(0, x_2, \dots, x_n)$$

■ A aplicação repetida da expansão permite escrever qualquer função na **forma canónica disjuntiva** (soma de produtos).

Exemplo para duas variáveis:

$$\begin{aligned} F(x_1, x_2) &= x_1 \cdot F(1, x_2) + \overline{x_1} \cdot F(0, x_2) \\ &= x_1 x_2 \cdot F(1, 1) + x_1 \overline{x_2} \cdot F(1, 0) + \overline{x_1} x_2 \cdot F(0, 1) + \overline{x_1} \overline{x_2} \cdot F(0, 0) \end{aligned}$$

A expressão corresponde à tabela de verdade:

| $x_1$ | $x_2$ | $F(x_1, x_2)$ |
|-------|-------|---------------|
| 0     | 0     | $F(0, 0)$     |
| 0     | 1     | $F(0, 1)$     |
| 1     | 0     | $F(1, 0)$     |
| 1     | 1     | $F(1, 1)$     |

## Forma canónica disjuntiva

- Uma função booleana de  $n$  variáveis pode ser expressa por uma soma de produtos (termos), em que cada produto inclui **uma só vez cada uma das variáveis ou o seu complemento**.

| $x_2$ | $x_1$ | $x_0$ | F |
|-------|-------|-------|---|
| 0     | 0     | 0     | 1 |
| 0     | 0     | 1     | 0 |
| 0     | 1     | 0     | 0 |
| 0     | 1     | 1     | 1 |
| 1     | 0     | 0     | 1 |
| 1     | 0     | 1     | 0 |
| 1     | 1     | 0     | 1 |
| 1     | 1     | 1     | 0 |

$F(x_2, x_1, x_0) = (\overline{x_2} \overline{x_1} \overline{x_0}) + (\overline{x_2} x_1 x_0) + (x_2 \overline{x_1} \overline{x_0}) + (x_2 x_1 \overline{x_0})$

- Cada um destes termos designa-se por **termo mínimo** ou *minterm*.
- Existe uma correspondência direta entre a forma canónica disjuntiva de uma função booleana e a sua tabela de verdade (considerando as variáveis pela mesma ordem).

## Somas de produtos mínimas

- A forma canónica disjuntiva mostra que é possível representar qualquer função booleana com **expressões de dois níveis**.
- A forma canónica disjuntiva é uma soma de produtos (SOP), mas não é, geralmente, a expressão desse tipo com o menor número de termos ou os termos mais simples (com menos variáveis).
- Mapas de Karnaugh ou o método de Quine-McCluskey permitem obter SOPs mínimas de forma sistemática.
- Também se pode usar simplificação algébrica.

$$\begin{aligned} F(x_2, x_1, x_0) &= (\overline{x_2} \overline{x_1} \overline{x_0}) + (\overline{x_2} x_1 x_0) + (x_2 \overline{x_1} \overline{x_0}) + (x_2 x_1 \overline{x_0}) \\ &= (\overline{x_2} \overline{x_1} \overline{x_0}) + (\overline{x_2} x_1 x_0) + x_2 \overline{x_0}(\overline{x_1} + x_1) \\ &= (\overline{x_2} \overline{x_1} \overline{x_0}) + (\overline{x_2} x_1 x_0) + x_2 \overline{x_0} \end{aligned}$$

## Forma canónica conjuntiva

- Devido ao princípio da dualidade, uma função booleana de  $n$  variáveis também pode ser expressa por um produto de somas (termos), em que cada soma inclui **uma só vez cada uma das variáveis ou o seu complemento.**

| $x_2$ | $x_1$ | $x_0$ | F |
|-------|-------|-------|---|
| 0     | 0     | 0     | 1 |
| 0     | 0     | 1     | 0 |
| 0     | 1     | 0     | 0 |
| 0     | 1     | 1     | 1 |
| 1     | 0     | 0     | 1 |
| 1     | 0     | 1     | 0 |
| 1     | 1     | 0     | 1 |
| 1     | 1     | 1     | 0 |

$$F(x_2, x_1, x_0) = (x_2 + x_1 + \bar{x}_0) \cdot (x_2 + \bar{x}_1 + x_0) \\ \cdot (\bar{x}_2 + x_1 + \bar{x}_0) \cdot (\bar{x}_2 + \bar{x}_1 + \bar{x}_0)$$

- Cada um destes termos designa-se por **termo máximo** ou *maxterm*.
- Fixada a ordem das variáveis, existe uma correspondência direta entre a forma canónica conjuntiva de uma função booleana e a sua tabela de verdade.
- A forma canónica conjuntiva é um **produto de somas** (POS), mas não é, geralmente, a expressão mais simples desse tipo.

## 1 Álgebra de Boole

Representação abstrata do processamento binário

Especificação algébrica

Representações canónicas

## 2 Portas lógicas

Portas elementares

Descrição hierárquica de circuitos

## 3 Circuitos padrão

Multiplexadores

Descodificadores

Codificadores

# Elementos para processamento lógico de informação

- Para realizar fisicamente o processamento da informação, são usados circuitos eletrónicos que realizam as funções lógicas elementares: **portas lógicas**.
- Quando não interessam os detalhes de implementação, usam-se símbolos para representar cada porta lógica.



- Também existem portas lógicas que combinam a negação com outras operações lógicas.



- Existem versões destas portas com mais entradas (3, 4, ... ) [exceto inversor].

# As portas lógicas XOR e XNOR

■■■ OU-exclusivo:  $F = A \oplus B = \bar{A}B + A\bar{B}$

OU-exclusivo negado:  $F = A \odot B = AB + \bar{A}\bar{B}$



| A | B | $A \oplus B$ | $A \odot B$ |
|---|---|--------------|-------------|
| 0 | 0 | 0            | 1           |
| 0 | 1 | 1            | 0           |
| 1 | 0 | 1            | 0           |
| 1 | 1 | 0            | 1           |

■■■ OU-exclusivo é igual a 1 quando as entradas são diferentes.

■■■ OU-exclusivo negado é igual a 1 quando as entradas são iguais.

■■■  $A \oplus (B \oplus C) = (A \oplus B) \oplus C$        $A \odot (B \odot C) = (A \odot B) \odot C$

■■■  $A \oplus 0 = A$        $A \oplus 1 = \bar{A}$        $A \oplus A = 0$        $A \oplus \bar{A} = 1$

■■■  $A \oplus \bar{B} = \bar{A} \oplus B = \overline{(A \oplus B)} = A \odot B$

# Circuitos com portas lógicas

- Existe uma correspondência direta entre uma função lógica e o circuito de portas lógicas elementares que a realiza.

Exemplo:



- Quanto mais simples for a expressão, mais pequeno é o circuito.
- Circuitos diferentes podem realizar a mesma função lógica (correspondem a expressões equivalentes).

# Complexidade e modularidade

- Circuitos lógicos podem ser muito complexos  $\Rightarrow$  como projetá-los?
- Dividir e conquistar: usar uma abordagem modular e hierárquica:
  - ☞ Portas lógicas são usadas para descrever funções lógicas mais complexas, implementadas por “módulos”.
  - ☞ Os módulos podem ser usados na definição de circuitos lógicos mais complexos.



- Função lógica  $M(I_2, I_1, I_0) = \overline{\overline{I_0} \overline{I_1}} I_2$

# Descrição hierárquica

■ Módulos podem ser combinados com outros módulos e portas lógicas.

Exemplo de módulo hierárquico  $Z(A, B, C) = ? :$



■ Este processo pode ser repetido um número arbitrário de vezes.

# Circuitos iterativos

➡ Circuitos **iterativos** são constituídos por repetições de um mesmo módulo.



- ① Identificar e projetar o módulo de base;
- ② Interligar uniformemente instâncias do módulo base  
(eventualmente com portas lógicas).

➡ Este tipo de circuito pode ser facilmente expandido.

# Somador do tipo ripple-carry

- ➡ O somador do tipo *ripple-carry* é um bom exemplo de um circuito iterativo.
- ➡ Exemplo: somar dois números de 4 bits  $a_3a_2a_1a_0$  e  $b_3b_2b_1b_0$  usando um módulo que calcula a soma de 2 bits (FA: *full adder*). Resultado:  $s_3s_2s_1s_0$  e  $c$



# Simplificar diagramas usando barramentos

- Um “barramento” é um grupo de sinais que interessa tratar como uma unidade. O seu uso simplifica muito os diagramas (comparar as duas figuras).



## 1 Álgebra de Boole

- Representação abstrata do processamento binário
- Especificação algébrica
- Representações canónicas

## 2 Portas lógicas

- Portas elementares
- Descrição hierárquica de circuitos

## 3 Circuitos padrão

- Multiplexadores
- Descodificadores
- Codificadores

## Funções lógicas comuns

- A experiência mostrou que existe um conjunto de funções lógicas que encontram utilização em muitos sistemas digitais.
- Essas funções são realizadas por **circuitos padrão** de “média complexidade” (i.e., mais complexos que simples portas lógicas).
- A sua utilização facilita o projeto de sistemas digitais

O circuito *full adder* estudado anteriormente pode ser considerado uma dessas funções.

- Outras funções incluem comparadores, des/codificadores de vários tipos, de/multiplexadores.
  - Circuitos padrão estão disponíveis no mercado
  - Existem normas para alguns símbolos “padrão” (ex.: IEEE Graphic Symbols for Logic Functions IEEE-91)
- Mais simples: usar um retângulo com entradas (à esquerda) e saídas (à direita).

# Multiplexador de 2 entradas

Um multiplexador (*multiplexer. mux*) 2:1 é um circuito que permite selecionar uma de duas entradas de dados.



| $S_0$ | $I_1$ | $I_0$ | $\text{mux}(I_0, I_1)$ |
|-------|-------|-------|------------------------|
| 0     | 0     | 0     | 0                      |
| 0     | 0     | 1     | 1                      |
| 0     | 1     | 0     | 0                      |
| 0     | 1     | 1     | 1                      |
| 1     | 0     | 0     | 0                      |
| 1     | 0     | 1     | 0                      |
| 1     | 1     | 0     | 1                      |
| 1     | 1     | 1     | 1                      |

- Existem multiplexadores 4:1, 8:1, ...,  $2^N$ :1
- Um multiplexador  $2^N$ :1 tem  $N$  entradas de controlo  $S_{N-1}, \dots, S_1, S_0$
- Todas as expressões lógicas podem ser implementadas com multiplexadores 2:1. (Porquê?)
- Expressões de  $n$  variáveis podem ser realizadas com um multiplexador de  $n$  entradas de dados.

# Combinar multiplexadores

➡ Como construir um multiplexador de 4:1?



# Descodificador binário

- Descodificador (*decoder*) de N-para-M (geralmente  $N < M$ ) transforma um código noutro com mais bits.
- Descodificador binário de N-para- $2^N$



■ Descodificador binário de 2:4

| EN | I1 | I0 | Y3 | Y2 | Y1 | Y0 |
|----|----|----|----|----|----|----|
| 0  | X  | X  | 0  | 0  | 0  | 0  |
| 1  | 0  | 0  | 1  | 0  | 0  | 0  |
| 1  | 0  | 1  | 0  | 1  | 0  | 0  |
| 1  | 1  | 0  | 0  | 0  | 1  | 0  |
| 1  | 1  | 1  | 0  | 0  | 0  | 1  |

■ Como fazer um descodificador binário 3:8 ?

- A entrada EN designa-se por **entrada de habilitação** (*enable*).
- Descodificador binário seguido de porta lógica OU permite realizar todas as funções de N variáveis. (Como?)

# Desmultiplexador

- Um desmultiplexador (*demultiplexer, demux*) de  $1:2^N$  tem 1 entrada de dados, N entradas de controlo (endereço) e  $2^N$  saídas.
- O valor da saída selecionada é igual ao da entrada de dados (entrada I).

Exemplo: desmultiplexador 1:2 (N=1)



| EN | $S_0$ | I | $Y_1$ | $Y_0$ |
|----|-------|---|-------|-------|
| 0  | X     | X | 0     | 0     |
| 1  | 0     | 0 | 0     | 0     |
| 1  | 0     | 1 | 0     | 1     |
| 1  | 1     | 0 | 0     | 0     |
| 1  | 1     | 1 | 1     | 0     |

- Um desmultiplexador pode ser considerado como um descodificador binário com uma entrada adicional que define o valor da saída selecionada.
- Como construir um desmultiplexador 1:4 usando circuitos padrão?

# Codificador binário

- Um codificador (*encoder*) transforma um código de X bits num código de Y bits, com  $X > Y$ .
- O codificador binário tem  $2^N$  entradas e N saídas (e sinais de controlo).



| EN | I <sub>3</sub> | I <sub>2</sub> | I <sub>1</sub> | I <sub>0</sub> | Y <sub>1</sub> | Y <sub>0</sub> | IDLE |
|----|----------------|----------------|----------------|----------------|----------------|----------------|------|
| 0  | X              | X              | X              | X              | 0              | 0              | 1    |
| 1  | 0              | 0              | 0              | 0              | 0              | 0              | 1    |
| 1  | 0              | 0              | 0              | 1              | 0              | 0              | 0    |
| 1  | 0              | 0              | 1              | 0              | 0              | 1              | 0    |
| 1  | 0              | 1              | 0              | 0              | 1              | 0              | 0    |
| 1  | 1              | 0              | 0              | 0              | 1              | 1              | 0    |

- Para as restantes combinações de valores de entrada, as saídas não estão definidas!

## Codificador de prioridade

■ A saída de um codificador de prioridade é definida pela entrada de maior prioridade que estiver a "1".

Exemplo: codificador de prioridade 4:2 (I<sub>3</sub> tem a maior prioridade; I<sub>0</sub> a menor)

| PPIOENC 4:1    | EI | I <sub>3</sub> | I <sub>2</sub> | I <sub>1</sub> | I <sub>0</sub> | Y <sub>1</sub> | Y <sub>0</sub> | GS | EO |
|----------------|----|----------------|----------------|----------------|----------------|----------------|----------------|----|----|
| I <sub>0</sub> | 0  | X              | X              | X              | X              | 0              | 0              | 0  | 0  |
| I <sub>1</sub> | 1  | 0              | 0              | 0              | 0              | 0              | 0              | 0  | 1  |
| I <sub>2</sub> |    | 1              | 0              | 0              | 0              | 1              | 0              | 0  | 1  |
| I <sub>3</sub> |    | 1              | 0              | 0              | 1              | X              | 0              | 1  | 0  |
| EI             |    | 1              | 0              | 1              | X              | X              | 1              | 0  | 1  |
|                |    | 1              | 1              | X              | X              | X              | 1              | 1  | 0  |

EI: (*enable input*) circuito habilitado;

EO: (*enable output*) para habilitar circuito de menor prioridade;

GS: (*got something*) está a "1" se EI=1 e alguma entrada de dados está a "1"

☞ Como fazer um codificador de prioridade 8:3 com dois codificadores 4:2 e portas lógicas?

# Referências

- COD4** D. A. Patterson & J. L. Hennessey, Computer Organization and Design, 4 ed.
- COD3** D. A. Patterson & J. L. Hennessey, Computer Organization and Design, 3 ed.

Alguns dos tópicos tratados nesta apresentação são descritos nas seguintes secções de [COD4]:

- apêndice C, secções C.1–C.3

Também são tratados nas seguintes secções de [COD3]:

- apêndice B, secções B.1–B.3

# Sistemas de Memória

## Conceitos básicos

João Canas Ferreira

Outubro de 2017



# Tópicos

## 1 Memórias

Aspetos gerais

Memórias Estáticas

Memórias Dinâmicas

## 2 Descodificação de endereços

Organização geral

Descodificação total

Descodificação parcial

Contém figuras de "Computer Organization and Design", D. Patterson & J. Hennessey, 3<sup>a</sup>. ed., MKP

# Taxonomia

- Registos e bancos de registos permitem guardar pequenas quantidades de dados. Para maiores quantidades, usam-se **memórias de acesso direto**.
- RAM = *random access memory* (memória de acesso direto): permitem leitura e escrita em qualquer posição.
- ROM = *read-only memory*: permitem apenas leitura.
- A maior parte das memórias RAM perde os dados quando é desligada a alimentação (memória volátil). Exceções:
  - (E)EPROM: (Electrically) erasable programmable ROM
  - memórias FLASH
- Dois tipos de memórias RAM voláteis:
  - SRAM: memória estática (cada célula de memória é um anel realimentado);
  - DRAM: memória dinâmica (cada célula deve ser atualizada periodicamente).

# Circuitos de memória: organização conceptual



- Para  $P$  linhas de endereço:  $N = 2^P$
- $2^{10}$  bytes = 1024 bytes = 1 KiB     $2^{20}$  bytes = 1048576 bytes = 1 MiB
- O porto de dados é bidirecional:  
é preciso especificar o tipo de acesso (leitura ou escrita).
- $M$  é a **largura** da memória (em número de bits).

# Memórias estáticas

As memórias estáticas aproximam-se do modelo conceptual de funcionamento.



Para aceder à memória:

- ativar o circuito: *chip select* (CS) ativo
- especificar o tipo de acesso:  
ativar *output enable* (leitura) **OU** *write enable* (escrita).

## Memórias estáticas: acessos

- Tempo de acesso para leitura: intervalo entre o instante em que *output enable* e endereço estão corretos e o aparecimento de dados na saída.
- Valores típicos para memórias estáticas:
  - rápidas: 2–4 ns
  - típicas: 8–20 ns (cerca de 32 milhões de bits)
  - de baixo consumo: 5–10 vezes mais lentas
- Durante esse tempo, um processador que execute uma instrução por ciclo e use um relógio de 2 GHz, executa:
  - 4–8 instruções
  - 16–40 instruções
- Tempo de acesso para escrita: endereços e dados devem estar estáveis antes e depois do flanco. O sinal de *write enable* é sensível ao nível (não ao flanco) e deve ter uma duração mínima para que a escrita se realize.
- O tempo de escrita é superior ao tempo de leitura.

# Memórias estáticas: circuito de saída

Buffer tristate

3 estados: 0, 1, desligado



Circuito de saída:



► Ao contrário de um banco de registos, o circuito de saída não pode ser baseado num multiplexador: uma SRAM 64K x 1 precisaria de ter um multiplexador 65536-para-1.

► Solução: utilizar *buffer tristate*, cuja saída pode ter 3 estados (0, 1 ou alta-impedância).

► No estado de alta-impedância, a saída do circuito está *desligada*.

► O estado da saída é determinado por uma entrada de controlo: *Sel*.

► Todas as saídas são ligadas em paralelo. **Não pode haver mais que uma saída ativa** (i.e., não em alta-impedância) a cada instante.

# Estrutura básica de uma memória estática



SRAM 4×2

Fonte: [COD3]

# Memória estática organizada por bancos

Para limitar o tamanho do descodificador de endereços:



Fonte: [COD3]

- Organização típica de uma memória 4 MiB como um agrupamento de 8 blocos de memória de capacidade  $(4 \times 2^{10}) \times 1024$  bits.
- Os blocos MUX são realizados por *buffers* de três estados.

# Memória dinâmica (DRAM)

- Valor guardado como *carga num condensador*.
- O acesso é feito através de um transístor a operar como interruptor.
- Consequência: maior densidade ( $\text{bit}/\text{mm}^2$ ), logo circuitos de maior capacidade e menor custo.
- Comparação: SRAM requer 4 a 6 transístores por bit armazenado.
- Acesso a DRAM é feito em duas etapas:
  - ① seleção de coluna (usando uma parte do endereço);
  - ② seleção de linha (usando os restantes bits do endereço).
- DRAM é mais lenta que SRAM. Exemplo:  
Capacidade: 2 Gbit ( $(512 \times 2^{20}) \times 4$  bits); tempo de acesso 55 ns.
- Condensador vai perdendo a carga e deve ser periodicamente “refrescado”, fazendo uma leitura seguida de escrita (circuito dinâmico). Acessos para refrescamento constituem 1 % to 2 % dos acessos.

# Acesso a uma memória dinâmica (exemplo)



- Endereço: 11+11 bits.
- DRAM  $(2 \times 2^{10}) \times 4$  bit: 11 bits selecionam uma linha, que é temporariamente armazenada em 2048 trincos.
- Multiplexador seleciona uma de 2048 entradas.

# Módulos de memória: DIMM

Cl's individuais podem ser agrupados em módulos.

Ex: módulo  $(32 \times 2^{20}) \times 64$ , i.e, de capacidade 256 MiB, pode usar 16 componentes  $(32 \times 2^{20}) \times 4$ .



## 1 Memórias

Aspetos gerais

Memórias Estáticas

Memórias Dinâmicas

## 2 Descodificação de endereços

Organização geral

Descodificação total

Descodificação parcial

# Organização da memória de um computador

- A memória física de um computador é geralmente composta por vários módulos (circuitos integrados, DIMM, etc.) por forma a ser possível obter maiores capacidades de armazenamento.
- Para além dos módulos de memória é necessário ter um circuito de descodificação de endereços que seleciona quais os módulos ativos durante um dado acesso (com base no endereço apresentado pelo CPU).
- Organização típica:
  - os bits menos significativos são ligados diretamente aos módulos individuais;
  - os bits mais significativos são usados para definir a ativação dos módulos.
- Linhas de dados podem ligadas a mais que um módulo (usando *buffers tristate*).

# Organização da memória: diagrama de blocos



Nota: Para memórias DRAM, a descodificação de endereços é mais complicada; apenas abordaremos o caso das memórias SRAM e ROM (que é análogo).

# Regras para descodificação de endereços

- Para que esta organização funcione bem, a descodificação de endereços deve garantir que:

Para o conjunto de todos os módulos que partilham uma mesma linha de dados: **apenas um** deve ser ativado durante um acesso.

Se esta condição não for respeitada, os componentes podem ser definitivamente danificados.

☞ O que acontece se nenhum módulo ser selecionado?

- O mapeamento de endereços para componentes pode ser classificado de acordo com o número de endereços que é mapeado na mesma posição física:
  - **total:** 1 endereço → 1 posição
  - **parcial:** N endereços → 1 posição
- Na descodificação total, todos os bits do endereço são usados: ligados diretamente aos componentes ou utilizados na seleção dos componentes.

# Descodificação total: exemplo



RAM1: 4Kx8      RAM2: 8Kx8  
Espaço de endereçamento do CPU:  
64 K, 1 byte por endereço

RAM 1:  
1011 XXXX XXXX XXXX  
Gama: B000H a BFFFH

RAM2:  
001X XXXX XXXX XXXX  
Gama: 2000H a 3FFFF

- Endereço B712H (46866) → RAM1
- Endereço C1E0H (49632) → nenhum circuito!

# Descodificação parcial: exemplo



RAM1: 4Kx8      RAM2: 8Kx8  
Espaço de endereçamento do CPU:  
64 K, 1 byte por endereço

RAM 1:  
10?? XXXX XXXX XXXX  
Gamas:

8000H a 8FFFH  
9000H a 9FFFH  
A000H a AFFFH  
B000H a BFFFH

RAM2:  
0?1X XXXX XXXX XXXX  
Gamas:

2000H a 3FFFH  
6000H a 7FFFH

- O byte 10 de RAM1 pode ser acedido através de que endereços?
- 800AH, 900AH, A00AH e B00AH

# Referências

- COD4** D. A. Patterson & J. L. Hennessey, Computer Organization and Design, 4 ed.
- COD3** D. A. Patterson & J. L. Hennessey, Computer Organization and Design, 3 ed.

Os tópicos tratados nesta apresentação são descritos na seguinte secção de [COD4]:

- apêndice C, secção C.9

Também são tratados na seguinte secção de [COD3]:

- apêndice B, secção B.9

# Circuitos digitais síncronos

João Canas Ferreira

Outubro de 2017



# Tópicos

- 1 Sistemas sequenciais síncronos
- 2 Elementos de memória
- 3 Registos e contadores

Contém figuras de "Computer Organization and Design", D. Patterson & J. Hennessey, 3<sup>a</sup>. ed., MKP

# Definição de circuito sequencial

- Circuito *combinatório*: o valor da saída depende *apenas* dos valores actuais das entradas.
- Circuito *sequencial*: o valor da saída depende dos valores actuais **e** de todos os valores anteriores das entradas.
- Estado de um circuito: conjunto de *variáveis de estado* que, em cada momento, contêm informação suficiente sobre o passado para permitirem a determinação do comportamento futuro (em conjunto com os valores da entrada).
- Em circuitos digitais, as variáveis de estado são binárias: um circuito com  $N$  variáveis de estado pode ter até  $2^N$  estados.
- O valor de uma variável de estado é preservado num *elemento de memória*.
- Nos circuitos digitais *síncronos*, as mudanças de estado ocorrem em instantes de tempo determinados por um sinal periódico: o sinal de relógio.

# Sinal de relógio

Sinal de relógio típico:



- Período  $T$ : intervalo de repetição
- Frequência  $F$ :  $F = 1/T$  (Hz)

# Organização geral de um sistema sequencial síncrono



- O flanco de relógio determina quando é que os elementos de memória são modificados.
- O período de relógio deve ser longo o suficiente para a saída da lógica combinacional atingir o seu valor final (estabilizar).



- Num sistema sensível ao flanco (como todos os que usaremos) um elemento de memória pode ser “lido” e alterado no mesmo ciclo de relógio.

# Regulação do sinal de relógio

- tempo de *setup*: período de tempo, *anterior* ao flanco activo do sinal de relógio, em que a entrada de um elemento de memória deve permanecer inalterada [preparação].
- tempo de *hold*: período de tempo, *posterior* ao flanco activo do sinal de relógio, em que a entrada de um elemento de memória deve permanecer inalterada [permanência].
- tempo de propagação  $t_{pm}$ : tempo (máximo) que o elemento de memória demora a reagir ao flanco activo do relógio.
- tempo de propagação  $t_{pc}$ : tempo (máximo) que a saída do circuito combinacional leva a atingir o valor final.

O valor mínimo para o período do sinal de relógio é:

$$T \geq t_{\text{setup}} + t_{pm} + t_{pc}$$

# Regulação do sinal de relógio: gráficos



1 Sistemas sequenciais síncronos

2 Elementos de memória

3 Registros e contadores

## Realimentação positiva

- Uma forma de “preservar” valores lógicos baseia-se na utilização de “realimentação positiva” (i. e., que reforça o estado atual).
- O elemento de memória tem dois estados: elemento *bi-estável*.

O elemento bi-estável mais simples:



Mas não tem entradas ...

## O trinco tipo D



| Clk | D | Q          | /Q          |
|-----|---|------------|-------------|
| 1   | 0 | 0          | 1           |
| 1   | 1 | 1          | 0           |
| 0   | x | Q anterior | /Q anterior |

Clk=1: modo transparente  
Clk=0: modo de retenção

## O trinco tipo D: formas de onda



## O flip-flop tipo D



| D | Clk | Q          | /Q          |
|---|-----|------------|-------------|
| 0 | ↑   | 0          | 1           |
| 1 | ↑   | 1          | 0           |
| x | 0   | Q anterior | /Q anterior |
| x | 1   | Q anterior | /Q anterior |

## O flip-flop tipo D: formas de onda



# O flip-flop tipo T

- O flip-flop tipo T troca de estado a cada ciclo de relógio.



- Por vezes, é útil ter uma entrada de *habilitação* (*enable*). O circuito só funciona quando essa entrada está activa.



# O flip-flop tipo T: formas de onda

- Flip-flop T sem entrada de *enable*



- Flip-flop T com entrada de *enable*



1 Sistemas sequenciais síncronos

2 Elementos de memória

3 Registros e contadores

# Registros e bancos de registros

- *registro*: grupo de  $n$  elementos de memória, que são acedidos como uma única entidade.
- *banco de registos*: conjunto de registos (de capacidade idêntica), em que cada registo individual pode ser selecionado pelo seu número de ordem ( $0, 1, \dots$ ).



## Banco de registos multi-porto

Modelo conceptual de um banco de registos com 2 portos de leitura e 1 porto de escrita (sinal de relógio omitido)



# Banco de registos: secção de leitura



# Banco de registos: secção de escrita



## Contador do tipo *ripple counter*



- Saída: número de quatro bits:  $Q_3Q_2Q_1Q_0$ .
- Contador muito lento: na pior situação (mudança do bit mais significativo) um contador de  $n$  bits demora  $n \times T_{pTQ}$  a reagir ao flanco activo.  
[ $T_{pTQ}$  é o tempo de propagação da entrada T para a saída Q.]

# Formas de onda para *ripple counter*—situação ideal



# Formas de onda para ripple counter—situação real



# Contador binário síncrono



- Nesta versão, todos os flip-flops comutam simultaneamente (em  $T_{pTQ}$  segundos).
- Entre flancos sucessivos, o sinal de habilitação deve propagar-se ao longo da cadeia de portas AND.

# Formas de onda do contador binário



# Referências

**COD4** D. A. Patterson & J. L. Hennessey, Computer Organization and Design, 4 ed.

**COD3** D. A. Patterson & J. L. Hennessey, Computer Organization and Design, 3 ed.

Os tópicos tratados nesta apresentação são descritos nas seguintes secções de [COD4]:

- apêndice C, secções C.7–C.8

Também são tratados nas seguintes secções de [COD3]:

- apêndice B, secções B.7–B.8