

# Resumo - Teste 1

## Bloco 1 - Representação da informação nos computadores

### • 5, Princípios básicos da arquitetura de computadores

- Abstracção - Esconder os detalhes sempre que não são necessários
- Disciplina - Restringir intencionalmente as liberdades
- Hierarquia - Dividir um sistema em módulos e sub-módulos
- Modularidade - Cada um dos módulos tem interfaces bem definidas
- Regularidade - Sempre que possível reutilizar os módulos já disponíveis

- Abstracção Digital: Considerar apenas um subconjunto discreto de todos os valores possíveis

- Quantidade de informação: A quantidade de informação numa variável descreta com N níveis:

ex.: Semaforo com R, G, Y

$$\begin{array}{l} z^1 = 1 \\ z^2 = 2 \\ z^3 = 4 \xrightarrow{\text{menor inteiro superior}} 3 \\ z^4 = 8 \end{array}$$
$$D = \lceil \log_2 3 \rceil = 2$$

$$D = \log_2 N \xrightarrow{\substack{\text{número de bits} \\ \text{Nível}}} (\text{bits})$$

⚠ Se não considerarmos a abstracção digital

$D = \log_2(+\infty) = +\infty$ , o que seria impossível

para guardar em memória (+∞ bits)

- Gama de representação: Conjunto de números que podemos utilizar com N algarismos

→ Decimal:  $[0, 10^N - 1]$

→ Binário:  $[0, 2^N - 1]$

• Sinal e Módulo:  $[-(2^{N-1} - 1), 2^{N-1} - 1] = [-2^{N-1} + 1, 2^{N-1} - 1]$

• Complemento para 2:  $[-2^{N-1}, 2^{N-1} - 1]$

## • Binário:

- Com  $N$  bits, tem a forma:  $b_{N-1}, b_{N-2} \dots b_2, b_1, b_0$
- Cada bit tem o valor 1 ou 0
- Em decimal o seu valor é a soma:  $2^{N-1}b_{N-1} + \dots + 2^1b_1 + 2^0b_0$
- Gama de representação:  $[0, 2^N - 1]$

## • Potências de 2:

$$2^0 = 1$$

$$2^1 = 2$$

$$2^2 = 4$$

$$2^3 = 8$$

$$2^4 = 16$$

$$2^5 = 32$$

$$2^6 = 64$$

$$2^7 = 128$$

$$2^8 = 256$$

$$2^9 = 512$$

$$2^{10} = 1024$$

$$2^{11} = 2048$$

## • Com 3 bits:

Binário → Decimal

$$\begin{array}{ccc} 000 & 0 & @ \end{array}$$

$$\begin{array}{ccc} 001 & 1 & \\ \hline \end{array}$$

$$\begin{array}{ccc} 010 & 2 & \\ \hline \end{array}$$

$$\begin{array}{ccc} 011 & 3 & \\ \hline \end{array}$$

$$\begin{array}{ccc} 100 & 4 & \\ \hline \end{array}$$

$$\begin{array}{ccc} 101 & 5 & \\ \hline \end{array}$$

$$\begin{array}{ccc} 110 & 6 & \\ \hline \end{array}$$

$$\begin{array}{ccc} 111 & 7 & @ \end{array}$$

④ Gama de representação  $[0, 2^3 - 1] = [0, 7]$  ✓

## • Hexadecimal:

→ Um algoritmo hexadecimal pode ser: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F

→ A base 16 funciona agrupando bits em grupos de 4 ( $2^4 = 16$ )

→ Em decimal o seu valor é a soma: ex.:  $A4F_{16} = \underline{10} \times 16^2 + \underline{4} \times 16^1 + \underline{15} \times 16^0_{10}$

$$\text{ex.: } \underbrace{10}_{A_{16}} \underbrace{10}_{4_{16}} \underbrace{00}_{0_{16}} \underbrace{11}_{1_{16}} = A3_{16}$$

$$10_{10} \quad 4_{10} \quad 15_{10}$$

## • Octal:

→ Um algoritmo hexadecimal pode ser: 0, 1, 2, 3, 4, 5, 6, 7

→ A base 8 funciona agrupando bits em grupos de 3 ( $2^3 = 8$ )

→ Em decimal o seu valor é a soma: ex.:  $741_{16} = \underline{7} \times 8^2 + \underline{4} \times 8^1 + \underline{1} \times 8^0_{10}$

$$\text{ex.: } \underbrace{10}_{A_{16}} \underbrace{10}_{4_{16}} \underbrace{00}_{0_{16}} \underbrace{11}_{1_{16}} = A3_{16}$$

$$7_{10} \quad 4_{10} \quad 1_{10}$$

• Sistema de numeração (Tabela): (4 bits)

| Decimal | Binário | Octal | Hexadecimal |
|---------|---------|-------|-------------|
| 0       | 0000    | 0     | 0           |
| 1       | 0001    | 1     | 1           |
| 2       | 0010    | 2     | 2           |
| 3       | 0011    | 3     | 3           |
| 4       | 0100    | 4     | 4           |
| 5       | 0101    | 5     | 5           |
| 6       | 0110    | 6     | 6           |
| 7       | 0111    | 7     | 7           |
| 8       | 1000    | 10    | 8           |
| 9       | 1001    | 11    | 9           |
| 10      | 1010    | 12    | A           |
| 11      | 1011    | 13    | B           |
| 12      | 1100    | 14    | C           |
| 13      | 1101    | 15    | D           |
| 14      | 1110    | 16    | E           |
| 15      | 1111    | 17    | F           |

→ Byte: conjunto de 8 bits (pode representar  $2^8 = 256$  valores distintos, [0, 255])

→ Nibble: meio byte, conjunto de 4 bits [0, 15]

→ Palavra: conjunto de bits sobre o qual o processador opera (ex.: 64 bits)

→ lsb: bit menos significativo (1001<sup>lsb</sup>)

→ msb: bit mais significativo (1001<sup>msb</sup>)

→ LSB / MSB: byte menos e mais significativo

$$1 \text{ kilo byte} \approx 10^3 = 1000$$

- Kilo byte :  $2^{10} = 1024$  bytes
  - Mega byte :  $2^{20} = 1048576$  bytes
  - Giga byte :  $2^{30} = 1073741824$  bytes
- (...)

### • Número com sinal e módulo:

- O bit menos significativo representa o sinal e os restantes o módulo
- Gama de representação:  $[-2^{N-1} + 1, 2^{N-1} - 1]$

- Desvantagens: dupla representação do zero (+0 e -0)  
operações aritméticas não são imediatas

$\begin{array}{r} 1000 \\ 0000 \end{array}$  (-0)      (+0)

### • Vantagem: intuitiva

### • Complemento para 2:

→ 0 que realmente é utilizado no computador?

- Igual à representação sem sinal, exceto que o bit mais significativo vale  $-2^{N-1}$
- Gama de representação:  $[-2^{N-1}, 2^{N-1} - 1]$
- Calcular o complemento para 2 de um número consiste em inverter todos os bits e somar 1
- Extender os números:  $\begin{array}{r} 0000 \\ 1111 \end{array} \boxed{0} 111 = 7$   
 $\begin{array}{r} 1111 \\ 0000 \end{array} \boxed{1} 000 = -8$

- Vantagem: somos funcionam da mesma forma que os números sem sinal

↳ Não esquecer:

Temos overflow na soma se: → 2 positivos a soma é negativa

→ 2 negativos a soma é positiva

Mas nunca ocorre com números de sinal diferente?

### Vírgula Fixa:

- Erro de representação (precisão) é em função dos algorismos da parte fracionária
- Tem a forma:  $b_{n-1} \dots b_1 b_0, \underbrace{b_{-1} b_{-2} b_{-3} \dots}_{\text{Parte fracionária}}$
- Somas e subtrações são iguais em complemento para 2 e em número sem sinal, desde que, os vírgulas estejam alinhados

- O erro máximo é sempre metade do valor do último dígito representado

Ex.: 123,45 ou  $b_2 b_1 b_0, b_{-1} b_{-2}$

$$10^{-2} = 0,01 \quad 2^{-2} = 0,25$$

$$\frac{10^{-2}}{2} = 0,005 \quad \frac{2^{-2}}{2} = 0,125$$

- Problema: Valores muito grandes (ou muito pequenos) em vírgula fixa requer uma enorme quantidade de algorismos

$$m_2 = \lceil m_1 \times \log_2 r_1 \rceil$$

em binário ↗ Solução em decimal:  $6,02 \times 10^{23}$

### Vírgula Flutuante:

$$x = \pm \underbrace{1}_{\neq 0, \text{ logo tem de ser } 1}, m \times 2^{\text{exp}} \rightarrow \text{Exponente}$$

Compromisso entre a precisão e a gama de representação

- Montissa: conjunto de números finitos que determinam a precisão (distância entre 2 pontos consecutivos)
- Exponente: determina a gama de representação

### Formato IEEE 754 (formato global para utilizar vírgula flutuante)

$$x = (-1)^s \times 1, \text{Montissa} \times 2^{(\text{Exp} - \text{Bias})}$$

|   |     |          |
|---|-----|----------|
| S | Exp | Montissa |
|---|-----|----------|

|  
| Bias  
|

→ Precisão simples: 1 bit      8 bits      23 bits = 32 bits      |      127

→ Precisão dupla: 1 bit      11 bits      52 bits = 64 bits      |      1023

→ Cosas especiais:

|                                   |          |            |                 |
|-----------------------------------|----------|------------|-----------------|
| Número representado<br>em decimal | <b>S</b> | <b>Exp</b> | <b>Mantissa</b> |
|-----------------------------------|----------|------------|-----------------|

|     |   |           |                              |
|-----|---|-----------|------------------------------|
| O   | X | 0000 0000 | 000 0000 0000 0000 0000 0000 |
| +00 | O | 1111 1111 | 000 0000 0000 0000 0000 0000 |
| -00 | 1 | 1111 1111 | 000 0000 0000 0000 0000 0000 |
| aN  | X | 1111 1111 | Non - Zero                   |

$\sqrt{2}x:$

II Que número está representado em formato IEEE 754 precisão simples como:

The diagram shows a 32-bit IEEE 754 floating-point number. The bits are grouped into three main fields: Sign (1 bit), Exponent (8 bits), and Mantissa (23 bits). The sign bit is highlighted in red. The exponent field is labeled "Exponent: 8 bits". The mantissa field is labeled "Mantissa: 23 bits". A red box highlights the entire 32-bit sequence. An arrow points from the sign bit to the text "Sign: 1 bit". Another arrow points from the exponent field to the text "Exponent: 8 bits". A third arrow points from the mantissa field to the text "Mantissa: 23 bits".

2 Determine a representação em formato IEEE 754 precisão simples do número:

$$5,5_{10} = 101,10$$

$$= 1,0110 \times 2^2$$

$$= (-1) \times 1,0110 \times 2^{(129 - 127)} \text{ Biob}$$

1 bit → Simbol : 0

$$8 \text{ bits} \rightarrow \text{Exponent: } 129_{10} = 1000 \ 0001 \quad 129_{10} = 128 + 1 = 1000 \ 0001$$

23 bits → Mantissa: 0110 0000 0000 0000 0000 0000 000

$$X = (-1)^5 \times 1, \text{Montissa} \times 2^{(\text{Exponente - Bias})} = (-1)^0 \times 1, 0110 \times 2^{(129 - 127)}$$

Sint Montissa  
0 100 0 000 1 0 11 0 000 0 000 0 000 0 000 0 000 → (0x40B0 0000)  
Exponente

③ Somar os números seguintes representados na norma IEEE 756:

$\downarrow \quad 0x3FC00000 + 0x40500000$

$$0\ 0\ 1\ 1\ 1\ 1\ 1\ 1 + 0\ 1\ 0\ 0\ 0\ 0\ 0\ 0 = 0\ 1\ 0\ 1\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0\ 0$$

$$(-1)^0 \times 1, 1_2 \times 2^{\underline{(127-127)}} + (-1)^0 \times 1, 101 \times 2^{\underline{(128-127)}}$$

$$= 1,1_2 \times 2^0 + 1,101_2 \times 2^1 = 0,11_2 \times 2^1 + 1,101_2 \times 2^1$$

$$= \frac{0,110}{1,00111} \times z^1 = 1,00111 \times z^1 = 1,00111 \times z^{\underline{(129-127)}}$$

$0\ 100\ 0000\ 1001\ 0000\ 0000\ 0000\ 0000 = 0x40980000$

## • Overflow:

- Overflow significa que o valor não é representável com o nº de bits disponível
- As máquinas digitais operam com um nº fixo de bits
- Se o resultado de uma soma exceder o nº de bits disponível
  - (ex: em complemento para 2 ocorre frequentemente pois temos de especificar antes o número de bits disponíveis)

## • ASCII:

- American Standard Code for Information Interchange
- É um código binário que codifica 128 símbolos (1 byte cada)
  - 95 gráficos (letras, caracteres, símbolos matemáticos, ...)
  - 33 controlo (Esc, Del, mudanças de linha, ...)
- O código ASCII permite representar o alfabeto latino

Nota: O standard UNICODE representa os caracteres em 8, 16 e 32 bits.

Sendo a representação de 8 bits (UTF-8) compatível com código ASCII

## • Outro tipo de dados:

- Imagens: tratadas como array de pixels
  - Monocromados: 1 bit  $\Rightarrow$  branco ou preto
  - Cor: RGB  $\Rightarrow$  8 bits para intensidade de cada cor
    - 
    - Para cada cor gama de representação = [0, 255]
- Som: sequência de números armazenados que representam a amplitude sonora ao longo do tempo

## Bloco 2 - Lógica Binária e Álgebra de Boole

- Operações lógicas:

| A | NOT A |
|---|-------|
| 0 | 1     |
| 1 | 0     |



| A | B | A AND B |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 0       |
| 1 | 0 | 0       |
| 1 | 1 | 1       |



| A | B | A NAND B |
|---|---|----------|
| 0 | 0 | 1        |
| 0 | 1 | 1        |
| 1 | 0 | 1        |
| 1 | 1 | 0        |



| A | B | A OR B |
|---|---|--------|
| 0 | 0 | 0      |
| 0 | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | 1      |



| A | B | A NOR B |
|---|---|---------|
| 0 | 0 | 1       |
| 0 | 1 | 0       |
| 1 | 0 | 0       |
| 1 | 1 | 0       |



| A | B | A XOR B |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 1       |
| 1 | 0 | 1       |
| 1 | 1 | 0       |



| A | B | A XNOR B |
|---|---|----------|
| 0 | 0 | 1        |
| 0 | 1 | 0        |
| 1 | 0 | 0        |
| 1 | 1 | 1        |



## • Níveis lógicos:

→ Os valores existem no circuito como tensões:

- 0 corresponde a ground ou 0V → GND
  - 1 corresponde à tensão de alimentação → VCC  
 $\approx 1,3V$
  - Para resolver o problema dos tensões intermédias há uma gama de tensões que correspondem ao nível lógico 0 e uma gama de representação que corresponde ao 1
- $0.1V \rightsquigarrow$  nível 0  
 $1,1V \rightsquigarrow$  nível 1



## • Ruído:

- O que é?
- Tudo o que degrada a qualidade do sinal
- Pode ser uma resistência, imperfeições de fonte...

→ Para resolver definimos uma margem de ruído

Margem de Ruído:



$$NM_H = V_{OH} - V_{IH}$$

$$NM_L = V_{IL} - V_{OL}$$

## • Circuitos lógicos:

→ Lógica combinatoria: Sem memória, os saídos são determinados apenas pelos entradas

→ Lógica sequencial: Com memória, os saídos são determinados pelos entradas atuais e passados  
 ↗ importante considerar

## • Considerações sobre o tempo:

→ A propagação não é instantânea:



• Logo, temos de ter alguma considerações:



$t_{pD}$ : tempo de propagação (tempo máximo

que demora a propagar-se da entrada para a saída)

$t_{cD}$ : tempo de contaminação (tempo mínimo

que demora a propagar-se da entrada para a saída)

Glitch: Quando apenas uma mudança na entrada produz "metaestabilidade" mais do que uma variação na saída (variações rápidas não previstas)

## • Algebra de Boole:

Definições:

→ Complemento:  $\bar{A}, \bar{B}, \bar{C}$

→ Literal:  $A, \bar{B}, C$

→ Implicantes:  $AB, \bar{A}B, A\bar{B}\bar{C}$  (produto de literais)

→ Mintermos:  $A\bar{B}C, \bar{A}BC, \bar{A}\bar{B}\bar{C}$  (produto que inclui todos os variáveis)

→ Maxtermos:  $A+\bar{B}+C, \bar{A}+B+C, \bar{A}+\bar{B}+\bar{C}$  (soma que inclui todos os variáveis)

Por definição a prioridade dos operadores é: NOT > AND > OR

→ Tabela de verdade pode sempre ser descrita como SoP e PoS:

SoP  $\Rightarrow$  1.º FC: Soma de produtos (mintermos)

PoS  $\Rightarrow$  2.º FC: Produto de somas (maxtermos)

| ex: |   |   |
|-----|---|---|
| A   | B | Y |
| 0   | 0 | 1 |
| 0   | 1 | 0 |
| 1   | 0 | 0 |
| 1   | 1 | 1 |

$\Rightarrow$  SoP       $\Rightarrow$  PoS

$Y = \bar{A}\bar{B} + AB$        $Y = (A+\bar{B}) \cdot (\bar{A}+B)$

Mais exemplos à frente!

## • Axiomas:

Valor binário  $\rightarrow B=0$  se  $B \neq 1$

NOT  $\rightarrow \bar{0} = 1$

AND  $\rightarrow 0 \cdot 0 = 0$

$$1 \cdot 1 = 0$$

$$0 \cdot 1 = 1 \cdot 0 = 0$$

## • Teoremas:

1 variável:

Teorema dual

Identidade  $\rightarrow x \cdot 1 = x$  ou  $x + 0 = x$

Elemento Absorvente  $\rightarrow x \cdot 0 = 0$  ou  $x + 1 = 1$

Idempotência  $\rightarrow x \cdot x = x$  ou  $x + x = x$

Involução  $\rightarrow \bar{\bar{x}} = x$

Complementariedade  $\rightarrow x \cdot \bar{x} = 0$  ou  $x + \bar{x} = 1$

2 variáveis:

Comutatividade  $\rightarrow x \cdot y = y \cdot x$  ou  $x + y = y + x$

Associatividade  $\rightarrow (x \cdot y) \cdot z = x \cdot (y \cdot z)$  ou  $(x + y) + z = x + (y + z)$

Diferente da álgebra convencional  $\Rightarrow$  Distributividade  $\rightarrow (x + y) \cdot (x + z) = x + (y \cdot z)$  ou  $(x \cdot y) + (x \cdot z) = x \cdot (y + z)$

Absorção  $\rightarrow x \cdot (x + y) = x$  ou  $x + (x \cdot y) = x$

Adjacência  $\rightarrow (x \cdot y) + (x \bar{y}) = x$  ou  $(x + y) \cdot (x + \bar{y}) = x$

Simplificação  $\rightarrow (x + \bar{y}) \cdot y = x y$  ou  $x \bar{y} + y = x + y$

De Morgan  $\rightarrow \overline{x \cdot y} = \overline{x} + \overline{y}$  ou  $\overline{x + y} = \overline{x} \cdot \overline{y}$

Nota: Uma forma de provar os teoremas é por indução perfeita

— //

• "Bubble Pushing":

Empurram-se os bolhas:



Ex:



//



? Dous megalos seguidos

## • Conjunto completo de operadores:

→ Conjunto de operadores que permite a implementação de qualquer função booleana:

- { AND, OR, NOT }

- { AND, NOT }

- { OR, NOT }

- { NAND }

- { NOR }

Podemos reescrever  
as formas canónicas  
só com um tipo de portos  
lógicos

Conjunto completo com apenas  
um tipo de portos facilita o trabalho  
de quem projeta os circuitos

Regularidade favorece facilidade !

## • Todos os formas canónicas:

→ 1<sup>ª</sup> forma canónica SOP (AND-OR)

→ 2<sup>ª</sup> forma canónica POS (OR-AND)

→ 3<sup>ª</sup> forma canónica SOP (NAND-NAND)

→ 4<sup>ª</sup> forma canónica POS (NOR-NOR)

ex:

$$f(x, y, z) = \underset{1}{x} \underset{1}{y} + \underset{0}{\bar{z}}$$

| x | y | z | f |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

1<sup>ª</sup> FC →  $\bar{x}\bar{y}\bar{z} + \bar{x}y\bar{z} + x\bar{y}\bar{z} + xy\bar{z} + xyz$  (AND-OR)

3<sup>ª</sup> FC →  $\overline{\bar{x}\bar{y}\bar{z} \cdot \bar{x}y\bar{z} \cdot x\bar{y}\bar{z} \cdot xy\bar{z} + xyz}$  (NAND-NAND)

2<sup>ª</sup> FC →  $(x+y+\bar{z}) \cdot (x+\bar{y}+\bar{z}) \cdot (\bar{x}+y+\bar{z})$  (OR-AND)

4<sup>ª</sup> FC →  $\overline{(x+y+\bar{z}) + (x+\bar{y}+\bar{z}) + (\bar{x}+y+\bar{z})}$  (NOR-NOR)

Como todo o processo de simplificação é chato e demorado, para uma simplificação mais fácil utilizaremos...

## • Mapos de Karnaugh: (bastante fácil, basta exemplificar)

Ex:

|     | A | B | C | Y |
|-----|---|---|---|---|
| 0 - | 0 | 0 | 0 | 0 |
| 1 - | 0 | 0 | 1 | 0 |
| 2 - | 0 | 1 | 0 | 1 |
| 3 - | 0 | 1 | 1 | 1 |
| 4 - | 1 | 0 | 0 | 0 |
| 5 - | 1 | 0 | 1 | 0 |
| 6 - | 1 | 1 | 0 | 0 |
| 7 - | 1 | 1 | 1 | 1 |



$$Y = \bar{A}B + BC$$

Ex:

|      | A | B | C | D | Y |
|------|---|---|---|---|---|
| 0 -  | 0 | 0 | 0 | 0 | 1 |
| 1 -  | 0 | 0 | 0 | 1 | 0 |
| 2 -  | 0 | 0 | 1 | 0 | 1 |
| 3 -  | 0 | 0 | 1 | 1 | 1 |
| 4 -  | 0 | 1 | 0 | 0 | 0 |
| 5 -  | 0 | 1 | 0 | 1 | 1 |
| 6 -  | 0 | 1 | 1 | 0 | 1 |
| 7 -  | 0 | 1 | 1 | 1 | 1 |
| 8 -  | 1 | 0 | 0 | 0 | 1 |
| 9 -  | 1 | 0 | 0 | 1 | 0 |
| 10 - | 1 | 0 | 1 | 0 | 1 |
| 11 - | 1 | 0 | 1 | 1 | 0 |
| 12 - | 1 | 1 | 0 | 0 | 0 |
| 13 - | 1 | 1 | 0 | 1 | 0 |
| 14 - | 1 | 1 | 1 | 0 | 0 |
| 15 - | 1 | 1 | 1 | 1 | 0 |



$$Y = \bar{B}\bar{D} + \bar{A}C + \bar{A}BD + A\bar{B}\bar{C}$$

## Bloco 3 - Blocos Combinatórios básicos / Circuitos Sequenciais / Móquinos de Estado

Mux 4:1



### Multiplexer:



| S | Y              |
|---|----------------|
| 0 | D <sub>0</sub> |
| 1 | D <sub>1</sub> |



→ Ponta tristate:



## Decodificador:

→ O decodificador ativa a saída correspondente ao número que está representado na entrada



| A <sub>1</sub> , A <sub>0</sub> | Y <sub>3</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Y <sub>0</sub> |
|---------------------------------|----------------|----------------|----------------|----------------|
| 00                              | 0              | 0              | 0              | 1              |
| 01                              | 0              | 0              | 1              | 0              |
| 10                              | 0              | 1              | 0              | 0              |
| 11                              | 1              | 0              | 0              | 0              |

## Somador completo de um bit:

| Cim | A | B | S | cout |
|-----|---|---|---|------|
| 0 - | 0 | 0 | 0 | 0    |
| 1 - | 0 | 0 | 1 | 0    |
| 2 - | 0 | 1 | 1 | 0    |
| 3 - | 0 | 1 | 0 | 1    |
| 4 - | 1 | 0 | 1 | 0    |
| 5 - | 1 | 0 | 0 | 1    |
| 6 - | 1 | 1 | 0 | 1    |
| 7 - | 1 | 1 | 1 | 1    |

| Cim A |   | 00 | 01 | 11 | 10 |
|-------|---|----|----|----|----|
| Cim   | A | 0  | 1  | 0  | 1  |
| 0     | 0 | 0  | 1  | 0  | 1  |
| 1     | 1 | 1  | 0  | 1  | 0  |

$$S = \overline{\text{cim}} A \overline{B} + \overline{\text{cim}} \overline{A} B + \text{cim} A B + \text{cim} \overline{A} \overline{B} = \text{cim} \oplus A \oplus B$$

| Cim A |   | 00 | 01 | 11 | 10 |
|-------|---|----|----|----|----|
| Cim   | A | 0  | 0  | 1  | 0  |
| 0     | 0 | 0  | 1  | 0  | 1  |
| 1     | 1 | 1  | 0  | 1  | 1  |

$$\text{Cout} = \text{cim} B + \text{cim} A + AB$$

ex: Somador/subtraidor de 3 bits com detecção de overflow



| Add/Sub | B | R |
|---------|---|---|
| 0       | 0 | 0 |
| 0       | 0 | 1 |
| 1       | 0 | 1 |
| 1       | 1 | 0 |

$$R = \text{Add/Sub} \oplus B$$

| C <sub>2</sub> | C <sub>1</sub> | Overflow |
|----------------|----------------|----------|
| 0              | 0              | 0        |
| 0              | 1              | 1        |
| 1              | 0              | 1        |
| 1              | 1              | 0        |

$$\text{Overflow} = C_2 \oplus C_1$$

↓ Esta solução tem um tempo de atraso muito grande porque a soma do último bit depende do primeiro (os tempos de atraso de cada somador propagam-se, existem melhores implementações)

### • Circuitos Sequenciais:

- Circuitos sequenciais são aqueles em que a saída depende do valor atual e do valor passado dos entradas
- Circuito bi-estável: (estável em 1 ou em 0)



=



↓ Nem todos os loops geram memória



x: Oscilação (não estabiliza)

### • Latch SR:



|   |   | Armazena 1 bit |  |
|---|---|----------------|--|
| R | S | Q              |  |
| 0 | 0 | Q anterior     |  |
| 0 | 1 | Set            |  |
| 1 | 0 | Reset          |  |
| 1 | 1 | Inválido       |  |

↓ Estado proibido

### • Latch D:

- Latch D tem duas entradas D e clk
- determina quando os dados são escritos

| clk | D | Q          |
|-----|---|------------|
| 0   | X | Q anterior |
| 1   | 0 | 0          |
| 1   | 1 | 1          |

| clk | Q          |
|-----|------------|
| 0   | Q anterior |
| 1   | D          |



↓ Evita o estado inválido do Latch SR

| <u>clk</u> | <u>D</u> | <u><math>\bar{D}</math></u> | <u>S</u> | <u>R</u> | <u>Q</u>   | <u><math>\bar{Q}</math></u> |
|------------|----------|-----------------------------|----------|----------|------------|-----------------------------|
| 0          | X        | X                           | 0        | 0        | Q anterior | $\bar{Q}$ anterior          |
| 1          | 0        | 1                           | 0        | 1        | 0          | 1                           |
| 1          | 1        | 0                           | 1        | 0        | 1          | 0                           |

Latch SR nunca vai para o estado inválido



- Problema: Latch D é transparente de mais ! (pode causar problemas por causa dos glitches)
- Solução: Flip-Flop D

### • Flip-Flop D

→ Igual ao Latch D mas só é ativo quando o clock transita de 0 para 1, edge-triggered. (apenas em um instante a escrita é efetuada)



→ Pode ter reset, enable ou set síncronos. (Prioridade: Reset > Enable > Set)  
 ↓  
 síncrono ou assíncrono

## Memórias: (Arrays de Flip-Flops D)

→ Armazenar de modo eficiente grandes quantidades de memória

→ Os três tipos mais comuns são:

- **SRAM** → Static Random Access Memory
  - **DRAM** → Dynamic Random Access Memory
  - **ROM** → Read Only Memory
- Falamos mais para a frente

Voláteis

Não voláteis
- Necessita de alimentação, quando é desligada a memória desaparece
- Permanece independentemente da alimentação



Ex: array de memória com 2 bits de endereço e 3 bits de dados

$$\text{Número de palavras} = 2^2 = 4$$

$$\text{Espaço de endereçamento} = [0, 2^2 - 1] \text{ de dimensão } 4$$

$$\text{Tamanha dos palavras} = 3$$

$$\text{Endereçabilidade} = 3 \text{ bits}$$



→ Endereço: um número (único) que identifica cada posição de memória. Os endereços são contados sequencialmente começando em 0

→ Espaço de endereçamento: a gama total de endereços que a CPU consegue referenciar  
(depende da dimensão do barramento de endereços =  $2^N$ )

Ex: CPU com um barramento de endereços de 16 bits

$$\rightarrow \text{Pode gerar endereços na gama: } [0x0000, 0xFFFF] = [0, 2^{16} - 1]$$

ex: Seja uma memória de  $2^k \times m$  bits



- Endereço é o identificador de localização com  $K$  bits
- Espaço de endereçamento é o conjunto de endereços entre 0 e  $2^K - 1$
- O conteúdo da memória são os palavras de  $m$  bits guardados em cada endereço

✓  
○

### → Operações de leitura vs Operações de escrita:



→ WE - Write Enable

→ WE = 1 → Escrita (o valor dos linhos Data é guardado no Address)

→ WE = 0 → Leitura (o valor guardado no Address é colocado nos linhos Data)

? Se WE for active low funciona ao contrário

### → Ciclo Básico de Acesso à Memória:



→ Para uma leitura (LOAD) a CPU:

Não confundir!

1 Ativa o sinal CE (seleciona a memória)

2 Coloca o endereço a ler no barrotamento de endereços

3 Envia o sinal de Read (não escrita)

4 Lê o conteúdo da memória no barrotamento de dados



→ Para uma escrita (STORE) a CPU:

- 1 Ativa o sinal CE (seleciona a memória)
- 2 Coloca o endereço a ser escrito no barramento de endereços
- 3 Coloca o valor a escrever no barramento de dados
- 4 Ativa o sinal de write



→ Células de memória:

→ Unidade capaz de armazenar um bit - tem, pelo menos, 2 interfaces:  
 → Um para saber quando é endereçada  
 → Um para receber/transmitir informação

→ Como a memória está organizada em "palavras" o endereçamento é comum a todos os bits de cada palavra: wordline



} Desativados

} células ativas

} Desativados

## • Tipos de Memórias:

→ Os três tipos mais comuns são:

- SRAM → Static Random Access Memory
  - DRAM → Dynamic Random Access Memory
  - ROM → Read Only Memory
- } Voláteis  
} Não voláteis

→ SRAM: Static RAM (tempo de acesso mais curto)

- bit guardado em dois inversores acoplados
- o valor é mantido enquanto o circuito estiver alimentado, por isso chama-se estática
- cada célula precisa de um circuito complexo que evita os perdes

→ DRAM: Dynamic RAM

- bit é guardado como uma carga num condensador → perdes de carga
  - leitura da memória é distrutiva
  - chama-se dinâmica porque o valor precisa de ser rescrita periodicamente  
e também sempre que é lido (construção mais simples mas precisa de ser rescrita)
- Guarda por pouco tempo  
ao fim de algum tempo  
é impossível distinguir um de um 1

\* em um certo tempo temos de "refrescar" a posição para evitar perdes ⇒ Circuito de refreshamento

Nota: Em uma escala grande, gomhamos em cada célula e podemos construir o circuito de refreshamento e ainda ter mais células pelo mesmo preço e com menos espaço

→ RAM vs ROM:

Antigamente eram de leitura apenas

• RAM: Random Access Memory

↳ Volátil

↳ Pode ser lida e escrita rapidamente

• ROM: Read Only Memory

↳ Não volátil

↳ Acesso de leitura é rápido

Qualquer posição de memória é accedido com igual facilidade

Hoje em dia, já não é possível escrever muito rápido com "distruição e reprogramação" a) b)

## Máquinas de Estado:

Círculo que:

- Tem vários estados possíveis
- O estado atual é armazenado num registo (conjunto de Flip-Flops)
- O estado muda na transição do relógico



## Tipos de máquinas de estado:

Esta aula →

→ Sincronos (máquinas de Moore) - saída depende do estado atual



→ Assíncronos (máquinas de Mealy) - saída depende do estado e dos entrados



## Procedimento de projeto de Máquinas de Estado (Moore):

- 1 Identificar entradas e saídas
- 2 Desenhar o diagrama de estados e transições
- 3 Escrever a tabela de estados (em função do estado atual e dos entrados)
- 4 Escrever a tabela das saídas (em função do estado)
- 5 Escrever (e simplificar) as equações booleanas: lógica do próximo estado e lógica das saídas
- 6 Desenhar o esquema do circuito

Ex: Contador de módulo 4  $\rightarrow$  0, 1, 2, 3, 0, 1, 2, 3, 0, 1, ...

- Saída atual é igual ao estado atual
- O próximo estado apenas depende do estado atual

1 Não tem entradas e tem 2 bits de saída ( $Y_1$  e  $Y_0$ )

2 4 estado  $\Rightarrow$  2 bits de estado



3

| Estado atual<br>$S_1$ $S_0$ | Estado seguinte<br>$S_1^+$ $S_0^+$ |
|-----------------------------|------------------------------------|
| 0 0                         | 0 1                                |
| 0 1                         | 1 0                                |
| 1 0                         | 1 1                                |
| 1 1                         | 0 0                                |

4

| Estado Atual<br>$S_1$ $S_0$ | Saídos<br>$Y_1$ $Y_0$ |
|-----------------------------|-----------------------|
| 0 0                         | 0 0                   |
| 0 1                         | 0 1                   |
| 1 0                         | 1 0                   |
| 1 1                         | 1 1                   |

5

$$S_1^+ = S_1 \oplus S_0$$

$$S_0^+ = \overline{S_0}$$

$\rightarrow$  Equações de estado seguinte

$$Y_1 = S_1$$

$$Y_0 = S_0$$

$\rightarrow$  Equações dos saídos

6



## • ENIAC:

- Primeiro computador eletrônico
- Utilizado para cálculo balístico
- Demorava dias a reprogramar
- John Von Neumann propôs a armazenagem dos dados e do programa na mesma memória (Assim, os programas poderiam ser guardados e reaproveitados)

## • Modelo de Von Neumann:



"Existe apenas uma memória partilhada por instruções e dados"

- Unidades fundamentais que constituem um computador:

- Unidades de entrada: permitem a receção de informação vinda do exterior (dados, programas) e que é armazenada em memória
- Unidades de saída: permitem o envio de resultados para o exterior
- Memória: armazenamento de
  - Programos
  - Dados de processamento (dados de entrada/saída)
  - Resultados
- CPU: processamento da informação através da execução do programa armazenado em memória



→ Anquitetura básica, no modelo de Von Neumann, de um sistema computacional (Simplificado)



Data Bus: barramento de transferência de informação (CPU ↔ Memory, CPU ↔ Input/Output)

Address Bus: identifica a origem/destino da informação

Control Bus: sinais de protocolo que especificam o modo como a transferência de informação deve ser feita  
Corrente sincronismo

→ Barramento e Barramento partilhado:

Barramento:



Barramento partilhado:



Fundamental o algoritmo para gestão do barramento

## • Unidade de Processamento (CPU):

→ É organizada em vários unidades:

- Unidade de controlo (responsável pela sequencialização da execução de cada instrução)
- Unidade Aritmética e Lógica  $\xrightarrow{\text{ALU}}$  (executor operações)
- Registros (armazenamento temporário de dados e valores de controlo)  
memórios mais rápidas

→ Cumprimento da Palavra (número de bits da ALU e dos registos)

"processador"  
funciona com  
m bits"

→ Consiste em duas secções:

- Secção de dados (datapath)
  - Registos internos
  - Unidade Aritmética e Lógica
- Unidade de controlo (responsável pela coordenação dos elementos do datapath, durante a execução de um programa)

Máquinas de estado síncronos  
↳ controla os estados do sistema dependendo das instruções e do estado atual

→ Unidade de Controlo:

- controla a execução do programa (determina: a operação a ser realizada no presente; a próxima operação a ser realizada)
- lê uma instrução na memória (instruction Fetch) e interpreta a instrução (instruction Decode) gerando os sinal de controlo que indicam à unidade de processamento o que fazer

Mesa de trabalho →

Instruction Register



Program Counter

→ contém a instrução a ser executada

→ contém o endereço da próxima execução

## Noção de "instrução":

→ Independente do CPU e da sua estrutura interna, uma instrução deve permitir responder às seguintes questões:

- Qual a operação a realizar?
- Qual a localização dos operandos (se existem)? (reg. interno / memória)
- Onde colocar o resultado? (reg. interno / memória)
- Qual a próxima instrução? (instrução seguinte / endereço da próxima instrução)

→ Níveis de representação de instruções:

contém indicações explícitas e implícitas



→ Ciclo básico de execução de instrução:

① Processador acede à memória e lê a próxima instrução a ser executada

• acede à memória  
• traz a instrução

② Processador executa a instrução



• Anquitetura de computadores: = Anquitetura do conjunto de instruções (ISA)

⊕

Organização da máquina

→ Conjunto de instruções: coleção de todos os instruções que o processador pode executar

estrutura de processador para executar o conjunto de instruções

→ Microanquitetura: organização do processador (principais unidades de funcionamento e respectivos ligações e controlo)

1 arquitetura Pode conter vários microarquiteturas

→ "modelo de programação"

- Arquitetura do conjunto de instruções: descreve os funcionalidades (organização do fluxo de dados e da unidade de controle) independentemente da implementação



• Aspectos a definir numa arquitetura:

- Instruções suportadas
- Como organizar a memória e os acessos
- Quantos registos (muitos ou poucos?)
- Tipos de dados e estruturas suportados
- Modos de endereçamento e de acesso a dados e instruções
- Qual o formato das instruções (tamanho variável / fixo)
- Condições de Execução (condições imprevistas)

• Fatores a ter em conta:

- Aplicações a que se destina
- Linguagem de programação
- Sistema operativo
- Possibilidades tecnológicas
- Compatibilidade histórica

• Objetivos de uma arquitetura:

- Implementação eficiente e simples em hardware
- Fácil de entender e programar
- compiladores eficientes

→ Organização da máquina: (responde a algumas questões...)

- Características operativas e de performance das principais unidades de funcionamento
- De que modo os componentes são interligados
- Fluxo de informação entre componentes
- Lógica e meios através dos quais esse fluxo é controlado
- Coreografia das Unidades Funcionais para implementar a arquitetura do conjunto de instruções