# INF 1400 - Oppsummering

## Dawid Kuleczko

# December 7, 2016

# Contents

| 1 Digital representasjon og binær logikk: |     |          |                                                 |    |
|-------------------------------------------|-----|----------|-------------------------------------------------|----|
|                                           | 1.1 | Tallsy   | stemer:                                         | 3  |
|                                           | 1.2 | Konve    | ertering:                                       | 3  |
|                                           |     | 1.2.1    | Konvertering fra grunntall r til desimaltall:   | 3  |
|                                           |     | 1.2.2    | Konvertering av desimal til binær:              | 4  |
|                                           |     | 1.2.3    | Konvertering av kommatall i desimal til binær : | 4  |
|                                           |     | 1.2.4    | Konvertering fra desimal til grunntall "r":     | 4  |
|                                           |     | 1.2.5    | Sannhetstabell:                                 | 5  |
|                                           | 1.3 | Huntin   | ngton's postulater                              | 7  |
| 2                                         | Boo | olsk alg | gebra:                                          | 7  |
|                                           | 2.1 | Boolsk   | ke funksjoner med sannhetstabell                | 9  |
|                                           | 2.2 | Forenl   | kling av uttryk                                 | 9  |
|                                           | 2.3 | Makst    | erm/Minterm                                     | 10 |
|                                           |     | 2.3.1    | Minterm:                                        | 11 |
|                                           |     | 2.3.2    | Maksterm:                                       | 11 |
|                                           | 2.4 | Design   | nprosedyre                                      | 12 |
| 3                                         | Kar | naugh    | diagram:                                        | 12 |

| 4 | Kob             | oinatorisk logikk:                           | <b>14</b> |  |  |  |  |  |  |  |  |  |
|---|-----------------|----------------------------------------------|-----------|--|--|--|--|--|--|--|--|--|
|   | 4.1             | Binær addisjon:                              | 14        |  |  |  |  |  |  |  |  |  |
|   | 4.2             | Binær substraksjon:                          |           |  |  |  |  |  |  |  |  |  |
|   | 4.3             | Binære addere:                               | 16        |  |  |  |  |  |  |  |  |  |
|   |                 | 4.3.1 Halvadder:                             | 16        |  |  |  |  |  |  |  |  |  |
|   |                 | 4.3.2 Fulladder:                             | 16        |  |  |  |  |  |  |  |  |  |
|   |                 | 4.3.3 Et adder system                        | 17        |  |  |  |  |  |  |  |  |  |
|   | 4.4             | "Carry Lookahead"                            | 18        |  |  |  |  |  |  |  |  |  |
|   | 4.5             | Komparator:                                  | 18        |  |  |  |  |  |  |  |  |  |
|   | 4.6             | Dekoder:                                     | 20        |  |  |  |  |  |  |  |  |  |
|   | 4.7             | Enkoder:                                     | 20        |  |  |  |  |  |  |  |  |  |
|   | 4.8             | Multiplekser (MUX):                          | 21        |  |  |  |  |  |  |  |  |  |
|   | 4.9             | Demulitplekser:                              | 22        |  |  |  |  |  |  |  |  |  |
|   | 4.10            | Aritmetisk logisk enhet (ALU):               | 22        |  |  |  |  |  |  |  |  |  |
| 5 | Sek             | vensiell logikk:                             | 23        |  |  |  |  |  |  |  |  |  |
|   | 5.1             | Logisk dybde                                 | 23        |  |  |  |  |  |  |  |  |  |
|   | 5.2             | Latcher(låsekretser):                        | 24        |  |  |  |  |  |  |  |  |  |
|   | 5.3             | Flip-Floper:                                 | 26        |  |  |  |  |  |  |  |  |  |
| 6 | $\mathbf{Tils}$ | tandsmaskiner:                               | 33        |  |  |  |  |  |  |  |  |  |
|   | 6.1             | Tilstandstabell                              | 34        |  |  |  |  |  |  |  |  |  |
|   | 6.2             | Tilstandsdiagram                             | 35        |  |  |  |  |  |  |  |  |  |
|   | 6.3             | Reduksjon av antall tilstander               | 37        |  |  |  |  |  |  |  |  |  |
|   | 6.4             | Tilordning av tilstandskoder                 | 39        |  |  |  |  |  |  |  |  |  |
|   | 6.5             | Ubrukte tilstander                           | 40        |  |  |  |  |  |  |  |  |  |
|   | 6.6             | Designprosedyre<br>(basert på D flip-floper) | 41        |  |  |  |  |  |  |  |  |  |
|   | 6.7             | Eksempel                                     | 41        |  |  |  |  |  |  |  |  |  |
| 7 | Dat             | amaskinarkitektur                            | 41        |  |  |  |  |  |  |  |  |  |
|   | 7.1             | Pipelining                                   | 41        |  |  |  |  |  |  |  |  |  |
|   |                 | 7.1.1 ERROR 404 - Pipeline                   | 42        |  |  |  |  |  |  |  |  |  |

| 8 | $\mathbf{CM}$ | OS - Komplementær metalloksidhalvleder | 42 |
|---|---------------|----------------------------------------|----|
|   | 8.1           | Transistor som bryter                  | 42 |
|   |               | 8.1.1 nMOS                             | 42 |
|   |               | 8.1.2 pMOS                             | 42 |
|   |               | 8.1.3 pMOS + nMOS $\dots$              | 43 |
|   | 8.2           | MOS transistorer                       | 43 |
|   | 8.3           | Fakta og regler                        | 44 |
|   | 8.4           | Serie og parallelkobling               | 45 |
|   | 8.5           | Komplementær logikk                    | 47 |

# 1 Digital representasjon og binær logikk:

#### 1.1 Tallsystemer:

I dette kurset skal vi legge spesielt vekt på binære tall, men heksadesimale tall og octale tall, samt tall fra andre tallsystemer, kan også forekomme.

Til daglig bruker vi desimal, altså 10-tallsystemet. Et desimalt tall er representert ved symbolene fra 0 til 9.

eks. 
$$(951)_{dec} = 9 \cdot 10^2 + 5 \cdot 10^1 + 1 \cdot 10^0$$

Et binært tall er representert ved symbolene 0 og 1.

eks. 
$$(101)_{bin} = 1 \cdot 2^2 + 0 \cdot 2^1 + 1 \cdot 2^0$$

Et heksadesimalt tall er representert ved symbolene fra 0 til F der tallene

etter 9 er: 
$$10 = A$$
  $11 = B$   $12 = C$   $13 = D$   $14 = E$   $15 = F$ 

eks. 
$$(5BF)_{hex} = 5 \cdot 16^2 + 11 \cdot 16^1 + 15 \cdot 16^0$$

Et oktalt tall er representert ved symbolene fra 0 til 8.

eks. 
$$(853)_{oct} = 8 \cdot 8^2 + 5 \cdot 8^1 + 3 \cdot 3^0$$

#### 1.2 Konvertering:

#### 1.2.1 Konvertering fra grunntall r til desimaltall:

Generelt: 
$$(...a_2a_1a_0, a_{-1}a_{-2}...) = ... + a_2 \cdot r^2 + a_1 \cdot r^1 + a_0 \cdot r^0, a_{-1} \cdot r^{-1}a_{-2} \cdot r^{-2} + ...$$
  
eks.  $(1A5, 1C)_{16} = 1 \cdot 16^2 + A \cdot 16^1 + 5 \cdot 16^0 + 1 \cdot 16^{-1} + 12 \cdot 16^{-2} = (421, 109375)_{10}$ 

#### 1.2.2 Konvertering av desimal til binær:

Eks.  $(23)_{10}$ 

$$23/2 = 11 + 1/2 \qquad a_0 = 1$$

$$11/2 = 5 + 1/2$$
  $a_1 = 1$ 

$$5/2 = 2 + 1/2$$
  $a_2 = 1$ 

$$2/2 = 1 + 0/2$$
  $a_3 = 0$ 

$$1/2 = 0 + 1/2$$
  $a_4 = 1$ 

Vi leser det binære tallet nedfra (10111)<sub>2</sub>

#### 1.2.3 Konvertering av kommatall i desimal til binær:

Eks.  $(0.3125)_{10}$ 

$$0.3125 * 2 = 0.625 \qquad a_{-1} = 0$$

$$0.625 * 2 = 1.25$$
  $a_{-2} = 1$ 

$$0.25 * 2 = 0.5$$
  $a_{-3} = 0$ 

$$0.5 * 2 = 1.0$$
  $a_{-4} = 1$ 

Vi leser det binære tallet oppfra (0.0101)<sub>2</sub>

#### 1.2.4 Konvertering fra desimal til grunntall "r":

Samme måte som over bare med "r" isteden for 2.

Eks.  $(12)_{10}$  til 3-tallsystemet:

$$12/3 = 4 + 0/3 \qquad a_0 = 0$$

$$4/3 = 1 + 1/3$$
  $a_1 = 1$ 

$$1/3 = 0 + 1/3$$
  $a_2 = 1$ 

Tallet blir da  $(110)_3$  i 3 tallsystemet.

### 1.2.5 Sannhetstabell:

# **Logic Gates**

| Name           | N        | TC          |          | ANI      | )           | 1        | NAN             | D      |          | OR       |          |          | NOI              | ₹.            |          | XOI          | 3      | <b>Y</b> | NO           | R      |
|----------------|----------|-------------|----------|----------|-------------|----------|-----------------|--------|----------|----------|----------|----------|------------------|---------------|----------|--------------|--------|----------|--------------|--------|
| Alg. Expr.     |          | Ā           |          | AB       |             |          | $\overline{AB}$ |        |          | A + I    | }        |          | $\overline{A+I}$ | 3             |          | $A \oplus I$ | 3      |          | $A \oplus I$ | 3      |
| Symbol         | <u>A</u> | >> <u>x</u> | A<br>B   |          | )— <u>×</u> |          |                 | )o—    |          |          | <u> </u> | _        |                  | <u>&gt;</u> — |          |              | >-     |          |              | >-     |
| Truth<br>Table |          | X           | <b>B</b> | <b>A</b> | X           | <b>B</b> | <b>A</b>        | X<br>1 | <b>B</b> | <b>A</b> | X<br>0   | <b>B</b> | <b>A</b>         | X<br>1        | <b>B</b> | <b>A</b>     | X<br>0 | <b>B</b> | <b>A</b>     | )<br>1 |
| 14010          | 1        | 0           | 0        | 1        | 0           | 0        | 1<br>0          | 1      | 0        | 1        | 1        | 0        | 1<br>0           | 0             | 0        | 1<br>0       | 1      | 0        | 1            |        |
|                |          |             | 1        | 1        | 1           | 1        | 1               | 0      | 1        | 1        | 1        | 1        | 1                | 0             | 1        | 1            | 0      | 1        | 1            |        |

Figure 1: Logiske porter



Figure 2: Logiske porter som 2 inputs NAND-porter

### 1.3 Huntington's postulater

### **Huntington postulater**

```
(P0)
(P1)
         Mengden {0,1} er lukket under "+" og "•"
                                                                   lukket
        x + 0 = x
(P2)
                                      x • 1 = x
                                                                   ident.el.
(P2b) x + 1 = 1
                                     x \cdot 0 = 0
(P5)
(P6)
                                     x • x'= 0
        x + x' = 1
                                                                   komplem.
                                                                   minst 2 el.
(P3)
                                     x \cdot y = y \cdot x
                                                                   kommutativ
         x + y = y + x
         x \cdot (y + z) = x \cdot y + x \cdot z x + (y \cdot z) = (x + y) \cdot (x + z) distributiv
(P5)
Dualitet for postulatene:
         Kan bytte "•" med + hvis man bytter "0" med "1"
Presedens:
         Først utføres "0", så "'", så "•" og til slutt "+"
```

Figure 3: Huntington's postulater

# 2 Boolsk algebra:

# **DeMorgans teorem**

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

På invertert form:

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

Figure 4: DeMorgans teorem

# Komplement av funksjon

# Inverterer begge sider og bruker DeMorgan

| Eksempel:             | Eksempel:              |
|-----------------------|------------------------|
| F = x'yz'+x'y'z       | F = x(y'z'+yz)         |
| F' = (x'yz'+x'y'z)'   | F' = (x(y'z'+yz))'     |
| F' = (x'yz')'(x'y'z)' | F' = x' + (y'z' + yz)' |
| F' = (x+y'+z)(x+y+z') | F' = x' + (y'z')'(yz)' |
|                       | F' = x' + (y+z)(y'+z') |

Figure 5: Komplement av funkson

# Regneregler - oversikt

| x + 0 = x             | $x \cdot 1 = x$       |
|-----------------------|-----------------------|
| x + x' = 1            | xx' = 0               |
| x + y = y + x         | xy = yx               |
| x + (y+z) = (x+y) + z | x (yz) = (xy)z        |
| x(y+z) = xy + xz      | x + (yz) = (x+y)(x+z) |
| x + x = x             | $x \cdot x = x$       |
| x + 1 = 1             | $x \cdot 0 = 0$       |
| x + xy = x            | x(x+y) = x            |
| (x+y)' = x'y'         | (xy)' = x' + y'       |

Figure 6: Regne regler for boolsk algebra

## 2.1 Boolske funksjoner med sannhetstabell

En boolsk funksjon kan visualiseres i en sannhetstabell. En gitt funksjon har kun en sannhetstabell Men, en gitt sannhetstabell har uendelig mange funksjonsuttrykk.

Eksempel: F = x + y'z

| XYZ | F |
|-----|---|
| 000 | 0 |
| 001 | 1 |
| 010 | 0 |
| 011 | 0 |
| 100 | 1 |
| 101 | 1 |
| 110 | 1 |
| 111 | 1 |
|     |   |

## 2.2 Forenkling av uttryk

En funksjon kan forenkles ved regneregler for å gjøre den lettere å håndere og implementere.

# Forenklingseksempler

| Eksempel:    | Eksempel:       | Eksempel:       |  |  |
|--------------|-----------------|-----------------|--|--|
| F = x(x'+y)  | $F = x+x^{3}y$  | F = (x+y)(x+y') |  |  |
| F = xx' + xy | F = (x+x')(x+y) | F = x + (yy')   |  |  |
| F = 0+xy     | F = 1(x+y)      | F = x + 0       |  |  |
| F = xy       | F = x+y         | F = x           |  |  |

Figure 7: Forenklingseksempler av noen funksjoner

# Forenklingseksempler II

Eksempel: Eksempel:  $F = xy+x'z+yz \qquad F = (x+y)(x'+z)(y+z)$   $F = xy+x'z+yz(x+x') \qquad F = (x+y)(x'+z) \qquad \text{Dualitet}$  F = xy+x'z+xyz+x'yz F = xy(1+z)+x'z(1+y) F = xy+x'z

Figure 8: Forenklingseksempler av noen funksjoner

# 2.3 Maksterm/Minterm

| Variable |   |   | М      | interm         | Maxterm  |                |  |  |
|----------|---|---|--------|----------------|----------|----------------|--|--|
| Х        | у | z | Term   | Designation    | Term     | Designation    |  |  |
| 0        | 0 | 0 | x'y'z' | m <sub>0</sub> | x+y+z    | M <sub>0</sub> |  |  |
| 0        | 0 | 1 | x'y'z  | m <sub>1</sub> | x+y+z'   | M <sub>1</sub> |  |  |
| 0        | 1 | 0 | x'yz'  | m <sub>2</sub> | x+y'+z   | M <sub>2</sub> |  |  |
| 0        | 1 | 1 | x'yz   | m <sub>3</sub> | x+y'+z'  | $M_3$          |  |  |
| 1        | 0 | 0 | xy'z'  | m <sub>4</sub> | x'+y+z   | $M_4$          |  |  |
| 1        | 0 | 1 | xy'z   | m <sub>5</sub> | x'+y+z'  | M <sub>5</sub> |  |  |
| 1        | 1 | 0 | xyz'   | m <sub>6</sub> | x'+y'+z  | $M_6$          |  |  |
| 1        | 1 | 1 | xyz    | m <sub>7</sub> | x'+y'+z' | M <sub>7</sub> |  |  |

Figure 9: Tabell for minterm og maksterm

Mintermer har notasjon  $m_x$ 

$$F(x, y, z) = \sum (m_3, m_6) = \sum (3, 6) = x'yz + xyz'$$

Makstermer har notasjon  $M_x$ 

$$F(x, y, z) = \Pi(M_3, M_6) = \Pi(3, 6) = (x + y' + z')(x' + y' + z)$$

#### **2.3.1** Minterm:

I en funksjon kan en binær variabel x opptre som x eller x'. En funksjon kan være gitt på "sum av produkt" form. Eksempel: F = xy + xy' + x

Hvert "produktledd" som inneholder alle variablene kalles en minterm. For to variable finnes det 4 forskjellige mintermer: xy + xy' + x'y + x'y' For 3 variable finnes det  $2^3$  forskjellige mintermer.

Hvis man generer en funksjon ut i fra sannhetstabellen får man en sum av mintermer

Eksempel: F = x'y'z + xy'z' + xyz'

| XYZ | F |
|-----|---|
| 000 | 0 |
| 001 | 1 |
| 010 | 0 |
| 011 | 0 |
| 100 | 1 |
| 101 | 0 |
| 110 | 1 |
| 111 | 0 |
|     |   |

En sannhetstabell kan sees på som en liste av mintermer.

#### 2.3.2 Maksterm:

En funksjon kan være gitt på "produkt av sum" form.

Eksempel: F = (x+y)(x+y')y Hvert "summeledd" som inneholder alle variablene kalles maksterm.

For to variable finnes det 4 forskjellige makstermer: (x'y)(x+y')(x'+y)(x'+y')

For n variable finnes det  $2^n$  forskjellige makstermer.

### 2.4 Designprosedyre

Det er ikke alltid at det enkleste funksjonsuttrykket resulterer i den enkleste port-implementasjonen.

Ved forenkling på portnivå må man vite hvilke porter man har til rådighet, og så justere funksjonsuttrykket mot dette. (håndverk)

#### Generell design prosedyre

- 1.Bestem hvilke signal som er innganger og utganger
- 2.Sett opp sannhetstabell for alle inngangskombinasjoner
- 3.Generer funksjonsuttrykket som sum av mintermer
- 4. Tilpass / forenkle funksjonsuttrykket mot aktuelle porter

# 3 Karnaugh diagram:

Grafisk metode for forenkling av Boolske uttryk

| $m_0$    | $m_1$    | $m_3$           | $m_2$    |
|----------|----------|-----------------|----------|
| $m_4$    | $m_5$    | $m_7$           | $m_6$    |
| $m_{12}$ | $m_{13}$ | m <sub>15</sub> | $m_{14}$ |
| $m_8$    | $m_9$    | $m_{11}$        | $m_{10}$ |

|      |        | yz       |         |        | y       |   |
|------|--------|----------|---------|--------|---------|---|
| 1    | vx     | 0.0      | 01      | 11     | 10      |   |
|      | 00     | w'x'y'z' | w'x'y'z | w'x'yz | w'x'yz' |   |
|      | 01     | w'xy'z'  | w'xy'z  | w'xyz  | w'xyz'  |   |
| w    | 11     | wxy'z'   | wxy'z   | wxyz   | wxyz'   | X |
|      | 10     | wx'y'z'  | wx'y'z  | wx'yz  | wx'yz'  | , |
| Omid | I Mirm | notahari |         | ,      |         |   |

Figure 10: Karnaugh diagram med mintermene



Figure 11: XOR



Figure 12: XNOR og XOR

# 4 Kobinatorisk logikk:

## 4.1 Binær addisjon:

Prosedyren for binær addisjon er identisk med prosedyren for desimal addisjon:

Eks: 
$$\begin{bmatrix} 0101 \\ 1011 \\ ----- \\ 10000 \end{bmatrix} + 5 + 11 = 16$$

### 4.2 Binær substraksjon:

Figure 13: Representasjon av binære negative tall

For å substrahere negative binære tall, bruker man toerkomplement metoden.

Det tallet som skal substraherers med må inverteres og plusses på 1, deretter skal det plusses med den andre tallet. Tallet til overs går ut.

Eks: 
$$\begin{bmatrix} 1101 \\ 1011 \\ ----- \end{bmatrix} \begin{bmatrix} 1101 \\ 0101 \\ ----- \\ (1)0010 \end{bmatrix} 13-11 = 2$$
$$13+5=18=1\ 0\ 0\ 1\ 0$$

### 4.3 Binære addere:

#### 4.3.1 Halvadder:

Halvaddere tar ikke mente inn.

Halvadder implementasjon



Figure 14: Halvadder implementasjon

#### 4.3.2 Fulladder:

Fulladder tar mente inn.

Fulladder implementasjon



Figure 15: Fulladder implementasjon

## 4.3.3 Et adder system



Figure 16: Et system av halv og fulladdere

### Adderer 0101 og 1011



Figure 17: Et eksempel på addisjon av to binære 4-bits tall

### 4.4 "Carry Lookahead"

Ønsker å unngå menteforplantning – gir økt hastighet

 ${\cal G}_i$  – generate: brukes i menteforplantningen  $P_i$  – propagate: påvirker menteforplantningen

#### 4.5 Komparator:

Komparator – sammenligner to tall A og B

3utganger: A = B, A > BogA < B

### Utgang A=B

Slår til hvis  $A_0=B_0$  og  $A_1=B_1$  og  $A_2=B_2$  og  $A_3=B_3$ 

Kan skrives:  $(A_0 \oplus B_0)'(A_1 \oplus B_1)'(A_2 \oplus B_2)'(A_3 \oplus B_3)'$ 

Figure 18: A=B

## Utgang A>B slår til hvis:

$$(A_3>B_3)$$
 eller  
 $(A_2>B_2 \text{ og } A_3=B_3)$  eller  
 $(A_1>B_1 \text{ og } A_2=B_2 \text{ og } A_3=B_3)$  eller  
 $(A_0>B_0 \text{ og } A_1=B_1 \text{ og } A_2=B_2 \text{ og } A_3=B_3)$ 

### Kan skrives:

$$(A_3B_3') + (A_2B_2') (A_3 \oplus B_3)' + (A_1B_1') (A_2 \oplus B_2)' (A_3 \oplus B_3)' + (A_0B_0')(A_1 \oplus B_1)' (A_2 \oplus B_2)' (A_3 \oplus B_3)'$$

Figure 19: A > B

### Utgang A<B slår til hvis:

$$(A_3 < B_3)$$
 eller  $(A_2 < B_2 \text{ og } A_3 = B_3)$  eller  $(A_1 < B_1 \text{ og } A_2 = B_2 \text{ og } A_3 = B_3)$  eller  $(A_0 < B_0 \text{ og } A_1 = B_1 \text{ og } A_2 = B_2 \text{ og } A_3 = B_3)$ 

#### Kan skrives:

$$(A_3 B_3) + (A_2 B_2) (A_3 B_3)' + (A_1 B_1) (A_2 B_2)' (A_3 B_3)' + (A_0 B_0)(A_1 B_1)' (A_2 B_2)' (A_3 B_3)'$$

Figure 20: A < B

### 4.6 Dekoder:

Dekoder – tar inn et binært ord og gir ut alle mintermer Kan generere generelle logiske funksjoner direkte fra mintermene på utgangen Eksempel: 3bit inn/8bit ut

# Eksempel: 3bit inn

| Innganger | Utganger |       |       |       |       |       |       |       |
|-----------|----------|-------|-------|-------|-------|-------|-------|-------|
| xyz       | $D_0$    | $D_1$ | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | $D_7$ |
| 000       | 1        | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0 0 1     | 0        | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0 1 0     | 0        | 0     | 1     | 0     | 0     | 0     | 0     | 0     |
| 0 1 1     | 0        | 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 100       | 0        | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 101       | 0        | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 1 1 0     | 0        | 0     | 0     | 0     | 0     | 0     | 1     | 0     |
| 111       | 0        | 0     | 0     | 0     | 0     | 0     | 0     | 1     |

Figure 21: Sannhetstabell til en 3 bits decoder

### 4.7 Enkoder:

Enkoder er motsatt av dekoder

## Eksempel: 8x3 enkoder

| Innganger |       |       |       |       |       |       | Utganger |       |
|-----------|-------|-------|-------|-------|-------|-------|----------|-------|
| $D_0$     | $D_1$ | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | $D_7$    | хуz   |
| 1         | 0     | 0     | 0     | 0     | 0     | 0     | 0        | 000   |
| 0         | 1     | 0     | 0     | 0     | 0     | 0     | 0        | 0 0 1 |
| 0         | 0     | 1     | 0     | 0     | 0     | 0     | 0        | 0 1 0 |
| 0         | 0     | 0     | 1     | 0     | 0     | 0     | 0        | 0 1 1 |
| 0         | 0     | 0     | 0     | 1     | 0     | 0     | 0        | 100   |
| 0         | 0     | 0     | 0     | 0     | 1     | 0     | 0        | 101   |
| 0         | 0     | 0     | 0     | 0     | 0     | 1     | 0        | 110   |
| 0         | 0     | 0     | 0     | 0     | 0     | 0     | 1        | 111   |

Figure 22: Sannhetstabell for en 8x3 enkoder

Prioritets-enkoder:

Hvis flere "1"ere inn - ser kun på inngang med høyst indeks (prioritet)

# 4.8 Multiplekser (MUX):

Velger hvilke innganger som slippes ut

## Hver inngang kan bestå av ett eller flere bit



Figure 23: MUX

# Eksempel: 2-1 MUX



Figure 24: En 2-1 MUX

# 4.9 Demulitplekser:

Motsatt av MUX, velger hvilke utganger som slippes ut



Figure 25: Demultiplekser

## 4.10 Aritmetisk logisk enhet (ALU):

En elektronisk krets som utfører aritmetiske og logiske operasjoner

## 5 Sekvensiell logikk:

Kombinatorisk logikk: Utgangsverdiene er entydig gitt av nåværende kombinasjon av inngangsverdier.

Sekvensiell logikk: Inneholder hukommelse (låsekretser). Utgangsverdiene er gitt av nåværende kombinasjon av inngangsverdier, samt sekvensen av tidligere inngangs-/utgangsverdier.

Mekaniske brytere gir ikke "rene" logiske nivå ut i overgangsfasen. Slike signaler må ofte "renses" ved bruk av låsekretser.

I synkrone sekvensielle kretser skjer endringen(e) i output samtidig med endringen i et klokkesignal.

I asynkrone sekvensielle kretser skjer endringen(e) i output uten noe klokkesignal.

Nesten alle kretser er synkrone.

Et klokkesignal er et digitalt signal som veksler mellom 0 og 1 med fast takt.



Figure 26: Flanker

Ønsker så høy klokkefrekvens som mulig, for at hver enkelt operasjon bruker så kort tid som mulig

Maksimal klokkefrekvens bestemmes av: - Lengde på singalveiene - Last - Forsinkelsene gjennom porter(delay) - Teknologi

#### 5.1 Logisk dybde

Antall proter et singal passerer fra inngang til utgang, ved å redusere dette minsker forsinkelsen gjennom kretsen.

# 1-fase klokking



Tc = klokkeperioden

**Ts** = tiden før klokkeflanken hvor inngangen må være stabil og tilgjengelig

Th = tiden etter klokkeflanker hvor inngangssignalet må fortsatt være stabil

Tq = tiden det tar fra klokkeflanken til utgangen er klar

Figure 27: Klokking

### 5.2 Latcher(låsekretser):

De ulike latchene:

#### SR - Latch

Set Reset - Latch

Setter Q til "1" hvis den får "1" på inngang S.

Når inngang S går tilbake til "0" skal Q forbli på "1"

Kretsen skal resette Q til "0" når den får "1" på inngang R.

Når inngang R går tilbake til "0" skal Q forbli på "0"

Tilstanden "1" på både S og R brukes normalt ikke



Figure 28: SR-Latch med NAND



| S | R | Q     | Q     |
|---|---|-------|-------|
| 0 | 0 | latch | latch |
| 0 | 1 | 0     | 1     |
| 1 | 0 | 1     | 0     |
| 1 | 1 | 0     | 0     |

Figure 29: SR-Latch med 2 NOR

### D - Latch

Data - Latch

Dataflyten gjennom en D-latch kontrolleres av et klokkesignal

Slipper gjennom et digital signal så lenge klokkeinngangen er "1" (transparent)

I det øyeblikket klokkeinngangen går fra "1" til "0" låser utgangen seg på sin nåværende verdi.

Forandringer på inngangen vil ikke påvirke utgangsverdien så lenge klokkesignalet er "0"



Figure 30: D-Latch

## 5.3 Flip-Floper:

Et 1-bits hukommelseselement som kan lagre ett bit kalles en flip-flop

En ny verdi kan bare leses inn og lagres når klokkesignalet går fra 0 til 1 (eller 1 til 0, avhengig av konstruksjonen)

En flip-flop'er har enten en eller to innganger (pluss klokkesignal) og en utgang

| Name /<br>Symbol                                                                                          | Characteristic<br>(Truth) Table                                                                                                                                                                                                                                                                                                                                                     | State Diagram /<br>Characteristic Equations                                                                                                                                        | Excitation Table                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\begin{array}{ccc} \mathbf{SR} & & & \\ & & S & & Q \\ & & & \\ & & & CIk \\ & & & R & & Q' \end{array}$ | S R Q Qnext<br>0 0 0 0 0<br>0 0 1 1<br>0 1 0 0<br>0 1 1 0<br>1 0 0 1<br>1 0 0 1<br>1 0 1 1<br>1 1 0 ×<br>1 1 1 ×                                                                                                                                                                                                                                                                    | $SR=00 \text{ or } 01$ $SR=00 \text{ or } 10$ $SR=01$ $Q_{next} = S + R'Q$ $SR = 0$                                                                                                | Q         Qnext         S         R           0         0         0         ×           0         1         1         0           1         0         0         1           1         1         ×         0 |
| $ \begin{array}{ccc} JK \\ & \downarrow & Q \\ & \downarrow & CIk \\ & \downarrow & & Q' \end{array} $    | J         K         Q         Qnext           0         0         0         0           0         0         1         1           0         1         0         0           0         1         1         0           1         0         0         1           1         0         1         1           1         1         1         1           1         1         1         0 | $JK=10 \text{ or } 11$ $JK=00 \text{ or } 01$ $Q=0$ $JK=01 \text{ or } 11$ $Q_{next} = J'K'Q + JK' + JKQ'$ $= J'K'Q + JK'Q + JK'Q' + JKQ'$ $= K'Q(J'+J) + JQ'(K'+K)$ $= K'Q + JQ'$ | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                       |
| $\begin{array}{c c} \mathbf{D} & \mathcal{Q} \\ \longrightarrow Clk & \mathcal{Q} \end{array}$            | $\begin{array}{ccc} D & Q & Q_{next} \\ 0 & \times & 0 \\ 1 & \times & 1 \end{array}$                                                                                                                                                                                                                                                                                               | $D=0$ $Q=0$ $Q=0$ $Q=1$ $Q=0$ $Q_{next}=D$                                                                                                                                         | Q         Qnext         D           0         0         0           0         1         1           1         0         0           1         1         1                                                   |
| T                                                                                                         | T Q Qnext 0 0 0 0 1 1 1 0 1 1 1 0                                                                                                                                                                                                                                                                                                                                                   | $T=0$ $Q=0$ $T=1$ $Q_{next} = TQ' + T'Q = T \oplus Q$                                                                                                                              | Q Qnext T<br>0 0 0 0<br>0 1 1<br>1 0 1<br>1 1 0                                                                                                                                                             |

Figure 31: Typer Flip-floper

Flip-Flop'er kommer i to varianter:

- Positiv flanketrigget
- $\bullet$ Negativ flanketrigget

På en positiv flanketrigget Flip-Flop kan utgangen kun skifte verdi i det øyeblikk klokkesignalet går fra "0" til "1".

På en negativ flanketrigget Flip-Flop kan utgangen kun skifte verdi i det øyeblikk klokkesignalet går fra "1" til "0".

De ulike Flip-Flopene:

### $\mathbf{SR}$ - $\mathbf{Flip}\text{-}\mathbf{flop}$ Set Reset - Flip-Flop



(a) Logic diagram

| QSR   | Q(t+1)        |
|-------|---------------|
| 000   | 0             |
| 0 0 1 | 0             |
| 010   | 1             |
| 0 1 1 | indeterminate |
| 100   | 1             |
| 101   | 0             |
| 110   | 1             |
| 111   | indeterminate |

(b) Truth table

Clocked SR flip-flop

Figure 32: Kretsoppbygging til en SR-Flip-Flop

 $\mathbf{JK}$  -  $\mathbf{Flip}\text{-}\mathbf{flop}$   $\mathbf{J}(\mathbf{Set})$   $\mathbf{K}(\mathbf{Reset})$  -  $\mathbf{Flip}\text{-}\mathbf{Flop}$ 



Figure 33: Kretsoppbygging til en JK-Flip-Flop



Figure 34: Typer Flip-floper

# **D - Flip-flop** Data - Flip-Flop



Figure 35: Kretsoppbygning til en D-Flip-Flop



(a) Logic diagram with NAND gates



(b) Graphical symbol

| QD  | Q(t+1) |
|-----|--------|
| 0.0 | 0      |
| 0 1 | 1      |
| 1 0 | 0      |
| 1 1 | 1      |

(c) Transition table

Clocked D flip-flop

Figure 36: Kretsoppbygning til en D-Flip-Flop

 ${\bf T}$  - Flip-flop Toggle - Flip-Flop

# T flip-flop

- ◆ Full name: Toggle flip-flop
  - ⇔ Common in counter design
  - Can construct a T from a D and mux
- ◆ When CLK↑
  - ❖ The output toggles if the input is a "1"
  - ...and holds its present value if the input is a "0"



| T(t) | Q(t) | $Q(t + \Delta t)$ |
|------|------|-------------------|
| 0    | 0    | 0                 |
| 0    | 1    | 1                 |
| 1    | 0    | 1                 |
| 1    | 1    | 0                 |

Figure 37: T - Flip-Flop



Figure 38: T - Flip-Flop

# 6 Tilstandsmaskiner:

Tilstandsmaskiner er en metode til å beskrive systemer med logisk og dynamisk (tidsmessig) oppførsel.

En tilstandsmaskin er et sekvensielt system som gjennomløper et sett med tilstander styrt av verdiene på inngangssignalene

Brukes mye innen:

- -Logiske/digitale styresystemer
- -Sanntidssystemer
- -Telekommunikasjon
- -Kompilator teknikk
- -Digital teknikk

Modellen av en tilstandsmaskin:

-Tilstander

er et begrep som benyttes til å beskrive systemets tilstand. er et verdisett/attributter som beskriver systemets egenskaper

- Hendelser endrer systemet fra en tilstand til en annen er et begrep som benyttes om innganger/påvirkninger på systemet kan beskrives som en plutselig og kortvarig påvirkning av systemet.
- Aksjoner er det som kommer ut av systemet(resultatet) er en respons på en hendelse

### 6.1 Tilstandstabell

Sannhetstabell for tilstandsmaskiner

|   | Q0 | X2 | X1 | X0 | D1 | D0 | Out |
|---|----|----|----|----|----|----|-----|
| 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0   |
| 0 | 0  | 0  | 0  | 1  | 0  | 1  | 0   |
| 0 | 0  | 0  | 1  | 0  | 0  | 0  | 0   |
| 0 | 0  | 0  | 1  | 1  | 0  | 0  | 0   |
| 0 | 0  | 1  | 0  | 0  | 0  | 0  | 0   |
| 0 | 0  | 1  | 0  | 1  | 0  | 0  | 0   |
| 0 | 0  | 1  | 1  | 0  | 0  | 0  | 0   |
| 0 | 0  | 1  | 1  | 1  | 0  | 0  | 0   |
| 0 | 1  | 0  | 0  | 0  | 0  | 1  | 0   |
| 0 | 1  | 0  | 0  | 1  | 0  | 1  | 0   |
| 0 | 1  | 0  | 1  | 0  | 0  | 0  | 0   |
| 0 | 1  | 0  | 1  | 1  | 1  | 0  | 0   |
| 0 | 1  | 1  | 0  | 0  | 0  | 0  | 0   |
| 0 | 1  | 1  | 0  | 1  | 0  | 0  | 0   |
| 0 | 1  | 1  | 1  | 0  | 0  | 0  | 0   |
| 0 | 1  | 1  | 1  | 1  | 0  | 0  | 0   |
| 1 | 0  | 0  | 0  | 0  | 1  | 0  | 0   |
| 1 | 0  | 0  | 0  | 1  | 0  | 0  | 0   |
| 1 | 0  | 0  | 1  | 0  | 0  | 0  | 0   |
| 1 | 0  | 0  | 1  | 1  | 1  | 0  | 0   |
| 1 | 0  | 1  | 0  | 0  | 0  | 0  | 0   |
| 1 | 0  | 1  | 0  | 1  | 0  | 0  | 1   |
| 1 | 0  | 1  | 1  | 0  | 0  | 0  | 0   |
| 1 | 0  | 1  | 1  | 1  | 0  | 0  | 0   |
| 1 | 1  | 0  | 0  | 0  | 0  | 0  | 0   |
| 1 | 1  | 0  | 0  | 1  | 0  | 0  | 0   |
| 1 | 1  | 0  | 1  | 0  | 0  | 0  | 0   |
| 1 | 1  | 0  | 1  | 1  | 0  | 0  | 0   |
| 1 | 1  | 1  | 0  | 0  | 0  | 0  | 0   |
| 1 | 1  | 1  | 0  | 1  | 0  | 0  | 0   |
| 1 | 1  | 1  | 1  | 0  | 0  | 0  | 0   |
| 1 | 1  | 1  | 1  | 1  | 1  | 0  | 0   |

Figure 39: Eksempel på en tilstandstabell fra oblig 2

# 6.2 Tilstandsdiagram

For å visualisere oppførselen til systemer brukes gjerne til<br/>standsdiagramer

- Sirkler angir tilstander
- · Piler angir tilstandsendring
- · Hendelse og aksjoner settes over piler som angir tilstandsendringen



Figure 40: Tilstandsdiagram

- Sirkler angir tilstanderPiler angir tilstandsendring
- · Hendelse og aksjoner settes over piler som angir tilstandsendringen



Figure 41: Tilstandsdiagram



Figure 42: Eksempel på en tilstandsdiagram

## 6.3 Reduksjon av antall tilstander

Hvis to tilstander har samme utgangssignal, samt leder til de samme nye tilstandene gitt like inngangsverdier, er de to opprinnelige tilstandene like. En tilstand som er lik en annen tilstand kan fjernes

Eksempel:

| Nåværende tilsta | nd<br>Inngang | Neste<br>tilstand | Utgang |  |
|------------------|---------------|-------------------|--------|--|
| A                | 0             | В                 | 0      |  |
| A                | 1             | В                 | 0      |  |
| В                | 0             | С                 | 0      |  |
| В                | 1             | D                 | 0      |  |
| C                | 0             | Α                 | 0      |  |
| C                | 1             | D                 | 0      |  |
| D                | 0             | E                 | 0      |  |
| D                | 1             | F                 | 1      |  |
| E                | 0             | Α                 | 0      |  |
| E                | 1             | F                 | 1      |  |
| F                | 0             | G                 | 0      |  |
| F                | 1             | F                 | 1      |  |
| G                | 0             | Α                 | 0      |  |
| G                | 1             | F                 | 1      |  |

Figure 43: Eksempel på reduksjon av tilstander

Vi ser at tilstand G er lik E

Vi kan fjerne tilstand G og erstatte hopp til G med hopp til E Etter det ser vi at tilstand F blir lik D, da fjerner vi F Slik kan vi redusere tilstandene.

# 6.4 Tilordning av tilstandskoder

I en tilstandsmaskin med M tilstander må hver tilstand tilordnes en kode basert på minimum N bit der  $2^N \ge M$ 

Kompleksiteten til den kombinatoriske delen avhenger av valg av tilstandskode

Anbefalt strategi for valg av kode: prøv-og-feil i tilstandsdiagrammet



Figure 44: Tilordning av tilstandskoder

#### 6.5 Ubrukte tilstander

I en tilstandsmaskin med N flip-flopper vil det alltid finnes  $2^N$  tilstander. Designer man for M tilstander der M <  $2^N$  vil det finnes ubrukte tilstander.

Problem: Under oppstart (power up) har man ikke full kontroll på hvilken tilstand man havner i først. Havner man i en ubrukt tilstand som ikke leder videre til de ønskede tilstandene vil systemet bli låst.



Løsning: Design systemet slik at alle ubrukte tilstander leder videre til en ønsket tilstand.

Figure 45: Ubrukte tilstander

## 6.6 Designprosedyre(basert på D flip-floper)

- 1) Definer tilstandene, inngangene og utgangene
- Velg tilstandskoder, og tegn tilstandsdiagram
- Tegn tilstandstabell
- Reduser antall tilstander hvis nødvendig
- Bytt tilstandskoder hvis nødvendig for å forenkle
- 6) Finn de kombinatoriske funksjonene
- 7) Sjekk at ubrukte tilstander leder til ønskede tilstander
- 8) Tegn opp kretsen

Figure 46: Designprosedyre

## 6.7 Eksempel

#### 7 Datamaskinarkitektur

### 7.1 Pipelining

Innfører samlebåndsprinsipp for eksekvering av instruksjoner

Hver instruksjon må splittes opp i uavhengige deler(subinstruksjonener) som utføres etter hverandre

Hver subinstruksjon kan utføres uavhengig av de andre subinstruksjonene

Neste instruksjon settes i gang før forrige instruksjon er helt ferdig.

Hver instruksjon tar like lang tid å utføre, men prosessoren utfører flere instruksjoner i et gitt tidsrom.

En 4-trinns pipeline er den korteste som finnes for en CPU Men det å ha en 4-trinns pipeline betyr ikke at man får 4 ganger raskere prosessering. Det går alltid bort noe tid til administrering av instruksjoner.

#### 7.1.1 ERROR 404 - Pipeline

Til enhver tid kan det være subinstruksjoner fra opptil 4 instruksjoner i en pipeline

Noen ganger er ikke alle subinstruksjonene gyldige

Neste instruksjon kan ikke eksekveres rett etter hvis hopp-betingelsen slår til, noe som kalles HAZARD

Det er tre typer HAZARD:

- -Resource Hazard
- -Data Hazard
- -Control Hazard

# 8 CMOS - Komplementær metalloksidhalvleder

#### 8.1 Transistor som bryter

#### 8.1.1 nMOS

En nMOS transistor har tre terminaler; Gate(inngang), Source og Drain. En nMOS transistor kan betraktes som en bryter, avhengig av inngang vil det kunne gå strøm mellom drain og source. Når inngangen er 0 går det ingen strøm mellom drain og source, og vi sier at transistoren er AV. Når inngangen er 1 kan det gå strøm mellom drain og source, og vi sier at transistoren er På.

Lavest spenning - Source

Høyest spenning - Drain

En positiv strøm vil alltid gå fra drain til source.

#### 8.1.2 pMOS

En pMOS transistor har også tre like terminaler akkurat som pMOS. Når inngangen er logisk 0 kan det gå strøm mellom source og drain, og vi sier at transisitoren er PÅ. Når inngangen er logisk 1 går det ingen strøm mellom source og drain, og vi sier at transistoren er AV.

Høyest spenning - Source

Lavest spenning - Drain

En positiv strøm vil alltid gå fra source til drain.

#### 8.1.3 pMOS + nMOS

Dersom vi setter en pMOS og en nMOS transistor sammen og kobler til spenningsreferansene Vdd og Vss får vi en CMOS inverter.

CMOS teknologi er med andre ord grunnleggende inverterende.



Figure 47: Inverter skjematikk og sannhetstabell

## 8.2 MOS transistorer

MOSFET - Metal On Semiconductor Field Effect Transistor - er integrerte transistorer.

nMOS - fordi Source og Drain terminalene er koblet til n-type silisium. Disse

områdene kalles for diffusjon og er kraftig dopet med et stort antall frie elektroner. Diffusjonsområdene ligger i en svakt dopet silisium halvleder som kalles substrat. Mellom gates og p-substrat er det et isolerende sjikt som separerer gaten fra substrat slik at det ikke skal gå strøm mellom gate og substrat.

pMOS - fordi Source og Drain terminalene er koblet til p-type silisium. Disse områdenen kalles diffusjon og er kraftig dopet med et stort antall frie hull. Ved å sette på en positiv spenning(logisk 1) på gate terminalen vil elektroner tiltrekkes overfalten på halvlederen og invertere p-substrat til n-positiv substrat.

### 8.3 Fakta og regler

Det er vanlig i digital CMOS å benytte minimumsstørrelser på ulike strukturer, dette medfører et redusert arel og mindre tidsforsinkelse. Liten tidsforsinkelse gir raske kretser som kan fungere med svært høye klokkefrekvenser.

Vi definerer opptrekksnettverk og nedtrekksnettverk som på dersom det finnes en strømvei mellom utgangen og spenningsreferesne, Vdd(1) og GND(0).

Et nedtrekk er PÅ dersom det finnes en serie av nMOS transistorer som alle er PÅ og som forbinder utgangen med GND, i motsatt tilfelle er nedtrekk AV.

For et opptrekk som er PÅ finnes det en serie av pMOS transistorer som alle er PÅ og som forbinder utgangen med Vdd, i motsatt tilfelle er opptrekket AV.

I komplementær CMOS logikk vil alltid en og bare en av opptrekk- og nedtrekksnettverkee være på.



Figure 48: Generell logisk port med opptrekk bestående av pMOS transistorer og nedtrekk bestående av nMOS transistorer

# 8.4 Serie og parallelkobling

n<br/>MOS i serie = NAND dersom GND = 0 på minst en inngang, A\*B



Figure 49: nMOS transistorer i serie

n<br/>MOS i parallell = NOR dersom Vdd = 1 på minst en inngang, A+B



Figure 50: pMOS transistorer i parallellkobling

p<br/>MOS i serie = NOR dersom Vdd = 1 på minst en inngang, A+B



Figure 51: pMOS transistorer i serie

pMOS i parallell = NAND dersom GND = 0 på minst en inngang, A\*B



Figure 52: pMOS transistorer i parallellkobling

# 8.5 Komplementær logikk

Eks på en funksjon implementert ved CMOS  $Y = \overline{(A \times B) + (C \times D)}$ 

Nedtrekket vil bestå av nMOS transistorer og vi<br/> har at Y bare kan bli 0 når  $(A\times B)+(C\times D)=1 \text{ Som forutsetter at A*B eller C*D er på. Nedtrekket må$ 

da bestå av to grener med seriekoblete nMOS transistorer.

Opptrekket vi bestå av pMOS transistorer og vi har at Y bare kan bli 1 når  $(A \times B) + (C \times D) = 0$  Som forutsetter at A og/eller B  $(A \times B = 0)$  og C og/eller D  $(C \times D = 0)$  er PÅ, altså 0. Opptrekket må da bestå av to grener med parallellkoblete pMOS transistorer. Til slutt må disse to parallellgrenen settes i serie slik at forutsetningen for opptrekket blir oppflyt.



Figure 53: Komplementær CMOS port for funksjonen  $Y = \overline{(A \times B) + (C \times D)}$