# Digitaltechnik

Andrej Scheuer ascheuer@student.ethz.ch 27. Dezember 2020

# Gates

### AND



| A | В | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

# AND ——— AND aus NOR





#### OR



| Α | В | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |
|   |   |   |

OR ———— OR aus NAND





#### NOT







nus NOR ----- NOT aus NAND





# Weitere Gates



|   |   | O NAND | NOR | XOR | XNOR |
|---|---|--------|-----|-----|------|
| A | В | C      | D   | E   | F    |
| 0 | 0 | 1      | 1   | 0   | 1    |
| 0 | 1 | 1      | 0   | 1   | 0    |
| 1 | 0 | 1      | 0   | 1   | 0    |
| 1 | 1 | 0      | 0   | 0   | 1    |

$$XOR = (A \wedge \overline{B}) \vee (\overline{A} \wedge B)$$
$$XNOR = (A \wedge B) \vee (\overline{A \wedge B})$$

#### XOR aus NAND ---



XOR aus NOR: Gleiches Schema wie NAND + 1 Inverter

XNOR aus NAND: Gleiches Schema wie XOR aus NOR

XNOR aus NOR: Gleiches Schema wie XOR aus NAND

Es versteht sich natürlich, dass wenn von "Gleichem Schema wie…" gesprochen wird, d Gates trotzdem getauscht werden müssen.

**PMOS** 

# CMOS

NMOS -



| G | Schalter | Y |
|---|----------|---|
| 0 | offen    | 1 |
| 1 | zu       | 0 |
|   |          |   |



| $\mathbf{G}$ | Schalter | Y |
|--------------|----------|---|
| 0            | zu       | 1 |
| 1            | offen    | 0 |

# Konstruktion von CMOS-Gates

Regeln für CMOS-Schaltungen

- 1. CMOS-Gates bestehen aus gleich vielen NMOS und PMOS.
- 2. m Eingänge: m NMOS und m PMOS.
- 3. NMOS in Serie  $\rightarrow$  PMOS parallel
- 4. NMOS parallel  $\rightarrow$  PMOS Serie

# Allg. Aufbau CMOS



# Umwandlung Pull-up zu Pull-down -

- 1. Teilbereiche (Blöcke) identifizieren.
- 2. Schritt 1 wiederholen, bis nur noch einzelne Transistoren vorkommen.
- 3. Falls Pull-down:
  - Von GND aus mit äusserstem Block beginnen.
  - PMOS  $\rightarrow$  NMOS
- 4. Falls Pull-up:
  - Von  $V_{DD}$  aus mit äusserstem Block beginnen.
  - NMOS  $\rightarrow$  PMOS.



#### Funktionsgleichung

 $\begin{array}{lll} \text{parallel:} \lor & \text{Pull-Up: } y = 1 & \text{alle I: } 0 \to \text{I invert.} \\ \text{Serie:} \land & \text{Pull-Down: } y = 0 & \text{alle I: } 1 \to \text{Gl. invert.} \end{array}$ 

# Boolsche Algebra

#### Grundregeln

#### Kommutativität -

$$A \wedge B = B \wedge A$$
$$A \vee B = B \vee A$$

#### Assoziativität

$$A \wedge (B \wedge C) = (A \wedge B) \wedge C$$
$$A \vee (B \vee C) = (A \vee B) \vee C$$

## Distributivität -

$$(A \land B) \lor (A \land C) = A \land (B \lor C)$$
$$(A \lor B) \land (A \lor C) = A \lor (B \land C)$$

| Nicht      | $\overline{\overline{A}} = A$      |                              |
|------------|------------------------------------|------------------------------|
| Null-Th.   | $A \lor 0 = A$                     | $A \wedge 0 = 0$             |
| Eins-Th.   | $A\vee 1=1$                        | $A \wedge 1 = A$             |
| Idempotenz | $A \lor A = A$                     | $A \wedge A = A$             |
| V. Komp.   | $A \vee \overline{A} = 1$          | $A \wedge \overline{A} = 0$  |
| Adsorp.    | $A \vee (\overline{A} \wedge B)$   | $= A \vee B$                 |
|            | $A \wedge (\overline{A} \vee B)$   | $=A\wedge B$                 |
| Adsorp.    | $A \lor (A \land B)$               | = A                          |
|            | $A \wedge (A \vee B)$              | =A                           |
| Nachbar.G. | $(A \wedge B) \vee (\overline{A})$ | $\overline{A} \wedge B) = B$ |
|            | $(A \vee B) \wedge (\overline{A})$ | $\bar{A} \vee B) = B$        |

# De Morgan

- 1. Regel  $\overline{A \wedge B} = \overline{A} \vee \overline{B}$
- 2. Regel  $\overline{A \vee B} = \overline{A} \wedge \overline{B}$

Regeln gelten auch für n verknüpfte Terme.

## Normalformen

|   | Minterm                                          | Maxterm                                         |
|---|--------------------------------------------------|-------------------------------------------------|
| • | AND-Ausdruck                                     | OR-Ausdruck                                     |
|   | Output: 1                                        | Output: 0                                       |
|   | $n$ Schaltvar. $\rightarrow 2^n$ mögl. Minterme. | $n$ Schaltvar. $\rightarrow 2^n$ mögl Maxterme. |
|   | nicht-invertierte Var: 1                         | nicht-invertierte Var: 0                        |
|   | invertierte Var: 0                               | invertierte Var: 0                              |
|   | miveroner oc var. o                              | miverence var. o                                |

Kanonisch Normalform: Alle Terme einer Schaltfunktion; nicht vereinfacht oder gekürzt.

# Disjunktive Normalform

- 1. Identifiziere WT-Zeilen mit Output 1
- 2. Minterme für diese Zeilen aufstellen
- 3. Minterme mit  $\mathbf{OR}$  verknüpfen

#### Konjunktive Normalform -

- 1. Identifiziere WT-Zeilen mit Output 0
- 2. Maxterme für diese Zeilen aufstellen
- 3. Maxterme mit **AND** verknüpfen

| Α | В | Y | Minterme                           | Maxterme              |
|---|---|---|------------------------------------|-----------------------|
| 0 | 0 | 1 | $\overline{A} \wedge \overline{B}$ |                       |
| 0 | 1 | 0 |                                    | $A \vee \overline{B}$ |
| 1 | 0 | 0 |                                    | $\overline{A} \vee B$ |
| 1 | 1 | 1 | $A \wedge B$                       |                       |

**DNF**  $Y = (\overline{A} \wedge \overline{B}) \vee (A \wedge B)$  1 Mint. erf.  $\rightarrow$  1 **KNF**  $Y = (A \vee \overline{B}) \wedge (\overline{A} \vee B)$  1 Maxt. erf.  $\rightarrow$  0

#### NAND/NOR Schaltungen -

Schaltung nur aus:

- NAND: DNF  $\rightarrow$  2× Negieren  $\rightarrow$  1× De Morgan
- NOR: KNF  $\to 2 \times$  Negieren  $\to 1 \times$  De Morgan oder: auf jeden Term der DNF De Morgan anwenden.

# Karnaugh Diagramme (KVD)



| , | CD |    |    |    |    |
|---|----|----|----|----|----|
|   | AB | 00 | 01 | 11 | 10 |
|   | 00 | 0  | 1  | X  |    |
|   | 01 |    |    |    |    |
|   | 11 |    |    |    |    |
|   | 10 |    |    |    |    |
|   |    |    |    |    |    |

Hat das Karnaugh Diagramm 5 Dimensionen, wird die 5te Dimension auf zwei Tabellen aufgeteilt.

Don't-Care-Zustände  $X \in \{0,1\}$  Redundante, überflüssige oder unmögliche Kombinationen der Eingangsvariablen werden mit einem X markiert.

#### Schema zum Ausfüllen





#### Päckchen

- Päckchen immer rechteckig (Ausnahme: über Ecken).
- Umfassen möglichst grosse Zweierpotenz.
- Dürfen über Ecken und Grenzen hinausgehen und sich überlappen.

- KVD ausfüllen.
- Päckchen mit 1 uo X.
- aufstellen.
- binden.

# KNF ----

- KVD ausfüllen.
- 2. Päckchen mit  $\mathbf{0}$  uo X.
- 3. Vereinfachte Minterme 3. Vereinfachte Maxterme
  - aufstellen.
- 4. Minterme mit OR ver- 4. Maxterme mit AND verbinden.

# Hazard

Kurzzeitige, unerwünschte Änderung der Signalwerte, die durch Zeitverzögerung der Gatter entstehen.



Statische Hazards Stellen im KVD, an denen sich Päckchen orthogonal berühren, aber nicht überlappen.

Lösung Berührende Päckchen mit zusätzlichen (möglichst grossen) Päckchen verbinden.

# Zahlensysteme

- zu berechnende positive Zahl
- Basis/Radix von D
- Koeffizient

$$D = \sum_{-\infty}^{\infty} b_i \cdot R$$

# Darstellung D in Basis $R: \ldots b_2b_1b_0.b_{-1}b_{-2}\ldots B$

| Dezimal    | 10 | $b_i \in \{0, 1, \dots, 9\}$                   |
|------------|----|------------------------------------------------|
| Dual/Binär | 2  | $b_i \in \{0, 1\}$                             |
| Oktal      | 8  | $b_i \in \{0, 1, \dots, 7\}$                   |
| Hexa       | 16 | $b_i \in \{0, 1, \dots, 9, A, B, C, D, E, F\}$ |

# Umwandlung Zahlensysteme

- 1. Ganzzahlige Division mit R:  $D/R = Q_0 + r_0$ .
  - $Q_i/R = Q_{i+1} + r_{i+1}$
  - bis  $Q_i = 0$ .
- 3. Erste Operation gibt MSB, letze Operation gibt LSB (aka. unten nach oben lesen.)

# Für 1 > D > 0 ———

$$D \cdot R = P_0 \quad K_{-1} = \text{floor}(P_0) \quad a_{-1} = P_0 - K_{-1}$$
  
 $a_{-1} \cdot R = P_{-1} \dots$ 

 $K_i$ : Koeffizienten für Zahlensystem. Erste Operation gibt MSB, letze Operation gibt LSB (aka von oben nach unten lesen).

#### Dezimal zu Binär ---

#### Binär zu Hex ---

| 0000 | 0 | 0100                         | 4 | 1000 | 8 | 1100 | C |
|------|---|------------------------------|---|------|---|------|---|
| 0001 | 1 | 0101                         | 5 | 1001 | 9 | 1101 | D |
| 0010 | 2 | 0110                         | 6 | 1010 | A | 1110 | E |
| 0011 | 3 | 0100<br>0101<br>0110<br>0111 | 7 | 1011 | B | 1111 | F |

#### Zweierkomplement

Sign Bit 0: positiv 1: negativ

#### Konstruktion

- 1. Zahl |Z| in Binär B umwandeln.
- 2. B bitweise invertieren
- 3. 1 zu LSB addieren (! Übertrag)
- 4. Sign Bit hinzufügen (zuvorderst).

Ist die Blocklänge länger als Zahl, vorangehende 0(-en) miteinbeziehen.

# 2<sup>er</sup>Komplement zu Dezimal ————

$$D_{(10)} = -b_{n-1} \cdot 2^{n-1} + \sum_{i=0}^{n-2} b_i \cdot 2^i$$
 
$$D = \sum_{-\infty}^{\infty} b_i \cdot R^i$$
 Wertebereich  $2^{\text{er}}$ -Komp.  $\left[-2^{n-1}, 2^{n-1} - 1\right]$ 

### mQn

$$D_{(10)} = -b_m \cdot 2^m + \sum_{i=0}^{m-1} b_i \cdot 2^i + \sum_{i=1}^n b_i \cdot 2^{-i}$$

m: Vorkommabits, n: Nachkommabits Sign-Bit muss nur einmal vor dem m codiert werden.

# Addition ----

#### Subtraktion -

Bitweise Addition der Binärzahlen. Leere Slots werden mit 0 aufgefüllt.

Binäre Rechenoperationen

Addition via 2<sup>er</sup>Komp. Übertrag von MSB ignorieren.

#### Multiplikation ---

- 1. Bitweise Multiplikation des Multiplikanden a mit  $b_i$  des Multiplika-
- 2. Sukzessive Multiplikationen werden um ein Bit (0) nach links verscho-
- 3. Anzahl Nachkommabits ergibt sich aus der Summe der Anzahl Nachk.bits der Operatoren.

 $+b_2 \cdot a \ 0 \ 0$  $+b_3 \cdot a \ 0 \ 0 \ 0$ 

#### Division ----

- 1. Identifiziere Teil des Divident > Divisor (Unterblock). Für jede Stelle, sodass Divident < Divisor, 0 in Quotient.
- 2. Unterblock Divisor, 1 an Quotient anhängen, Rest behalten.
- 3. An das Resultat der Subtraktion Bits des Dividenten anhängen. Wiederholen bis Subtraktion 0 ergibt.

| 1 = 0100 | 0   R = 1 | 0 R = 11    | R = 000     | 0 R = 0000  | 111 = 0   R = 00000 |  |
|----------|-----------|-------------|-------------|-------------|---------------------|--|
| 0111     | П         | $\parallel$ | $\parallel$ | $\parallel$ | Ш                   |  |
| 0:0      | 111       | 111         | 111         | 111         | 111                 |  |
| 10       | %         | %           | %           | 8           | %                   |  |
| 11       | 1         | 11          | 111         | 0000        | 00000 % 111 =       |  |

# Parity-Bits

Hilft Bit-Fehler zu finden.

Bitsequenz wird in 4 Bits unterteilt. Pro Nibble wird ein Parity-Bit angefügt. Nach 4 Blöcken folgt ein Prüfwort.

| Parity-Bit | Anz. 1   | PB | Nibble + PB |
|------------|----------|----|-------------|
| Even $P_E$ | ungerade | 1  | gerade      |
|            | gerade   | U  |             |
| Odd $P_O$  | ungerade | 0  | ungerade    |
| Odd 10     | gerade   | 1  | ungerade    |

# 01010 11011 10111 00101 00011

# Korrekt P<sub>E</sub> -----

| 0 | 1 | 0 | 1 | 0 |  |
|---|---|---|---|---|--|
| 1 | 1 | 0 | 1 | 1 |  |
| 1 | 0 | 1 | 1 | 1 |  |
| 0 | 0 | 1 | 0 | 1 |  |
| 0 | 0 | 0 | 1 | 1 |  |

|   |   | _      |   |   |
|---|---|--------|---|---|
| 0 | 1 | 0      | 1 | 0 |
| 1 |   | 1      | 1 | 1 |
| 1 | 0 | 1<br>1 | 1 | 1 |
| 0 | 0 | 1      | 0 | 1 |
| 0 | 0 | 0      | 1 | 1 |
|   |   | _      |   |   |

# Latches und FlipFlops

# Kombinatorische Schaltung Output hängt von Inputs und Verknüpfungen ab.

Sequentielle Schaltung Enthält Rückkopplungen, Outputs hängen von vorherigen Werten ab.

# Latch

# (Takt)zustandgesteurte Schaltung $\rightarrow$ Änderungen am Eingang können während der ganzen aktiven Taktphase den Output beeinflussen.

# **FlipFlops**

Taktflankengesteuerte Schaltung → Input zum Zeitpunkt der Taktwechsels wird wirksam.

#### Latches

Alle taktzustandgesteurte Schaltungen sind gegenüber Störimpulsen empfindlich, da bei T = 1 jede Änderung



$$Q_{n+1} = S \vee \left( Q_n \wedge \overline{R} \right)$$

| Fall | $\mathbf{s}$ | $\mathbf{R}$ | $Q_{n+1}$ |               |
|------|--------------|--------------|-----------|---------------|
| 1    | 0            | 0            | $Q_n$     | speichern     |
| 2    | 0            | 1            | 0         | zurücksetzten |
| 3    | 1            | 0            | 1         | setzen        |
| 4    | 1            | 1            | -         | unzulässig    |

# SRT-Latch ----



Datenspeicherung Normales SR-Latch

Änderungen werden nur übernommen, wenn T/CLK aktiv ist.

### D-Latch ----





Bauelement, das Daten für die Periodendauer eines Taktes speichern kann.

$$Q_{n+1} = \left(Q_n \wedge \overline{\mathbf{T}}\right) \vee (\mathbf{D} \wedge \mathbf{T})$$

alter Ausgang gespeichert Input übernommen

D-Latch transparent

letzter Zustand gespeichert



#### **FlipFlops**





Input beim Übergang von  $0 \rightarrow 1$  von CLK wirkInput beim Übergang von  $1 \rightarrow 0$  von CLK wirk-



Positive/steigende Taktflanke



Negative/fallende Taktflanke

### D-FlipFlop



 $Q_{n+1} = D$  wenn CLK  $0 \to 1$ 

Master low-active CLK = 0Slave high-active CLK = 1

# SR-FlipFlop



#### JK-FlipFlop



Bei J = K = 1 wechselt Output. (toggel)

### T-FlipFlop -

V1 Ausgang wechselt bei jeder aktiven Taktflanke.



aktiver Taktflanke nur wenn T = 1.

 $Q_{n+1} = \overline{Q_n}$ wenn CLK  $0 \rightarrow 1$ 

 $Q_{n+1} = \overline{Q_n}$ wenn CLK  $0 \rightarrow 1 \land T = 1$ 

V2 Ausgang wechselt bei



#### D-FlipFlop in CMOS-Technik ----

#### **Transmission Gates**



| IN | $\mathbf{T}$ | Widerstand | OUT |
|----|--------------|------------|-----|
| 0  | 0            | hochohm.   | -   |
| 0  | 1            | niederohm. | 0   |
| 1  | 0            | hochohm.   | -   |
| 1  | 1            | niederohm. | 1   |

TG sperrt wenn Widerstand hochohmig ist. (T = 0)



CLK 0 Input ins erste Latch übertragen Latch verriegelt, Wert im Kreis gefangen



#### D-FlipFlop ⇔ JK-FlipFlop ——

1. JK-FF kann immer durch D-FF ersetzt werden.

D-FF: 
$$D_n = \left(J \wedge \overline{Q_n}\right) \vee \left(\overline{K} \wedge Q_n\right)$$
 :JK-FF

- 2. Ein D-FF kann nur durch JK-FF ersetzt werden
  - a) Schaltung eine Rückkopplung enthält.
  - b) Input D als  $(F_1 \wedge \overline{Q_n}) \vee (F_2 \wedge Q_n)$  geschrieben werden kann.

# Gleichung für D-FF $\rightarrow$ JK-FF

- 1. Wahrheitstabelle mit Einängen und Rückkopplung.
- 2. Wahrheitstabelle in  $Q_n$  und  $\overline{Q_n}$ .
- 3. Separat Päckchen in  $Q_n$  und  $\overline{Q_n}$ machen.
- 4. Päckchen mit OR verbinden. Ggf.  $Q_n$  und  $\overline{Q_n}$  ausklammern.



# Asynchroner Set/Reset Input ----

Können gespeicherte Zustände asynchron zu CLK überschreiben.

Verzögerungszeit



#### Verzögerungszeiten -

Setup-Zeit Solange muss Signal vor aktiver Taktflanke stabil anliegen. Hold-Zeit Solange muss Signal nach aktiver Taktflanke stabil anliegen.

$$T_{\min} \ge t_{\text{pd}1} + t_{\text{pd,ks}} + t_{\text{s}2}$$
  $f_{\max} = \frac{1}{T_{\min}}$ 

Durchlaufzeit

 $t_h$  kann bei der Berechnung von  $f_{\text{max}}$  vernachlässigt werden.

Es wird der längste Pfad zwischen zwei FlipFlops betrachtet.

Fehlfunktionen beim Wechsel des Eingagnssignals aktiver Taktfl.

#### Zwischenspeicher-FF --



FlipFlop, dass Input bei steigender Taktflanke übernimmt und bei der nächsten fallenden Taktflanke ausgibt. (oder umgekehrte Flanken)

- Ausgabe bei fallender Flanke
- Ausgabe bei steigender Flanke

#### Frequenzteiler und Zähler -



Kaskadieren von T-Flipflops führt zu einer Frequenzreduktion von CLK um Faktor 2.

Kann als Bitzähler verwendet werden (ohne CLK). MSB ist längste Frequenz.  $n_{T,ff} \to 0 \dots (2^n-1)$ 

# **A**utomaten

Ein System, das auf seine Eingänge reagiert und einen Ausgang produziert, der vom Eingangssignal und momentanen Zustand abhängt.

Bei synchronen Automaten besitzen alle Speicherelemente (FlipFlops) den gleichen Takteingang.

# Formale Beschreibung

 $X = (x_1, \ldots, x_n)$ Eingangsalphabet Eingängen  $Y = (y_1, \ldots, y_b)$ Ausgangsalphabet Ausgängen  $Z = (z_1, \ldots, z_m)$ Zustandsmenge mit m internen Zuständen  $Z_0 \in Z$ Anfangszustand  $f_{c1}:(X_n,Z_n)\to Z_{n+1}$ Übergangsfunktion  $f_{c2}:(X_n,Z_n)\to Y_n$ Ausgangsfunktion

### Automatentypen

# Mealy-Automat -

Ausgänge von inneren Zuständen und Eingängen abhängig.  $Y_n = f_{c2}(X_n, Z_n)$ 



#### Zustandsdiagram



#### Moore-Automat

Ausgänge nur von inneren Zuständen abhängig (keine Verbindung zwischen Input und Output).

 $Y_n = f_{c2}(Z_n)$ 



## Zustandsdiagram



# Medwedjew-Automat

Ausgänge entsprechen inneren Zuständen.

 $Y_n = Z_n$ 



### Zustandsdiagram



#### Nachtrag Zustandsdiagram

interne Zustände Knoten

Kanten Übergänge zwischen Zuständen

Wichtig Von jedem Knoten aus muss es für jeden Eingang eine Kante geben, diese können aber zusammengefasst werden.

# Zustandsfolgetabelle

Auflistung aller möglichen Kombinationen der aktuellen inneren Zuständen sowie den Eingängen mit den dazugehörigen Folgezuständen und Ausgängen.

$$x_1 \dots x_e \mid z_{1n} \dots z_{mn} \mid z_{1(n+1)} \dots z_{m(n+1)} \mid y_1 \dots y_b$$
 $e + 2m + b$  Spalten
 $2^{e+m}$  Zeilen

Wichtig: für e, m, b Anzahl Bits verwenden, nicht Anzahl Zustände.

#### **Entwurf eines Automaten**

- 1. Auftrag lesen und analysieren  $\rightarrow$  Automatentyp bestimmen.
- 2. Zustandsmenge bestimmen  $\to$  Anzahl erforderlich D-FlipFlops  $\lceil \log_2(\text{Anzahl Zustände}) \rceil$ .
- 3. Eingangs- und Ausgangsvariablen definieren, Kodierung.
- 4. Darstellung der Zustandsfolge in einem Zustandsdiagram.
- 5. Zustandsfolgetabelle aufstellen.
- Minimierte Ausgangs- und Übergangsfunktion bestimmen mit KV-Diagrammen bestimmen.
- 7. Unbenutzte Zustände überprüfen.
- 8. Schaltplan anhand Schaltfunktion konstruieren.

# **Umwandlung Mealy** ⇔ **Moore**

#### Moore → Mealy --

- 1. Ausgänge von Folgezuständen auf Kanten schreiben.
- 2. Ausgänge bei Zuständen entfernen.

#### Mealy → Moore ----

- 1. Ausgänge in Knoten schreiben, an denen Kante endet.
- 2. Knoten mit mehr als einem Ausgang multiplizieren  $\rightarrow$  neu kodieren.
- Eingehende Kanten entsprechend der Ausgänge auf neue Knoten umhängen.
- 4. Ausgehende Kanten für alle neue Knoten kopieren. Diese Umwandlung ist immer möglich, aber meistens werden mehr Zustände benötigt.

Wichtig: Das Zeitverhalten der Ausgänge verändert sich bei der Umwandlung.

Mealy Eingangsveränderungen beeinflussen den

Ausgang sofort.

Moore Eingangsveränderungen haben erst bei Taktflanke Einfluss (weniger Störungsan-

fällig)

#### Asynchronzähler

Dualzähler Kaskadierung von T-FlipFlops Vorwärtszähler negativ flankengesteuerte Flip-Flops

Rückwärtszähler  $\overline{Q_i}$  benutzen oder positive flankengesteuerte FlipFlops.

- Anzahl Bits = Anzahl T-FlipFlop
- LSB nach 1. FlipFlop, MSB ganz rechts

#### Probleme von Asynchronzählern -

- Verzögerungen der Zustandsänderungen kumulieren sich entlang der Schaltung.
- Zeitverzögerung ist bei jedem Zustand anders.

Damit jeder mögliche Zustand bei n Flip Flops (kurz) auftritt:

$$f_{max} = \frac{1}{\sum_{i=1}^{n} t_{pd,i}}$$

#### Modulo-n Zähler

Zählt bis zu einem bestimmten Zustand und springt dann auf einen definierten Zustand zurück. Es werden n Zustände durchlaufen.

Kombinatorische Schaltung (AND-Gates) registrieren den Endzustand und setzen den definierten Zustand mittels der asynchronen Set- und Reset-Eingänge.

Def. Z (Bit)  $\begin{array}{ccc} 0 & R \\ 1 & S \end{array}$  mit komb. Schalt. verbinden

Anderer asynchroner Eingang an GND.

## Synchronzähler

Alle FlipFlops haben das selbe Taktsignal. Meistens **Medwedjew**-Automaten.

#### Entwur

- 1. Zustandsgraph zeichnen.
- 2. Folgezustandstabelle aufstellen.
- 3. Für alle Folgezustände KV-Diagramme erstellen → Gleichung Folgezustand.
- 4. Zeichnen (Ausgänge = interne Zustände)

#### Vorwärts-Rückwärtszähler

Zusätzlicher Eingang bestimmt Zählrichtung  $\rightarrow$  wie Synchronzähler entwerfen.

# Alternative -

# Zähler Ausgänge: Z<sub>3</sub>Z<sub>2</sub>Z<sub>1</sub>Z<sub>0</sub>



D-FlipFlops mit Addierer kombinieren.

$$X \quad B_3B_2B_1B_0 \\ 0 \quad 0001 \quad \to \quad +1 \\ 1 \quad 1111 \quad \to \quad -1 \quad \text{addiert}$$

# Schieberegister

#### SRAM



**Wortleitung**: Anwählen Speicherzelle

Bitleitung: Speicherinhalt lesen oder setzten

| Bit | $\overline{\mathrm{Bit}}$ |              |
|-----|---------------------------|--------------|
| 1   | 0                         | 1 schreiben  |
| 0   | 1                         | 0 schreiben  |
| 1   | 1                         | lesen        |
| Wor | tleitung                  | bei allen 1. |

- $\bullet\,$  Gespeicherte Wert steht immer auf linker Seite (Bit)
- Beim Lesen gibt Bit den Wert zurück;  $\overline{\mbox{Bit}}$  den Invertierten.
- Beim Schreiben muss Bit auf den gewünschten Wert und Bit auf den Invertierten.

#### Lesen



#### 1 Schreiben



**0 Schreiben** Gleich wie Schreiben einer 1, aber Bit = 0.

#### DRAM



Wortleitung: Anwählen Speicherzelle

Bitleitung: Speicherinhalt lesen oder setzten

Schreiben: Bitleitung wird auf gewünschten Wert gesetzt → Kondensator: auflädt, entlädt oder gleich bleibt.

Lesen: Parasitäre Kapazität wird ausgenutzt, um aus Veränderung von  $V_{\rm out}$  gespeicherten Wert zu ermitteln.

#### ROM

Read-Only-Memory wird zur Herstellungszeit als 0 oder 1 programmiert.





### Diverses

# Physikalische Zuordnung logischer Zustände

 $\begin{array}{ccc} 0 & \text{Low } 0 \, \text{V} & \text{Ground} \\ 1 & \text{High } 0.8 \, \text{V} & \text{VDD} \end{array}$ 

#### Toleranzen:

- GND:  $0 V \dots 0.15 V$
- VDD 0.7 V... 0.9 V

#### Schaltelemente

#### Multiplexer -----

Sendet eines von  $2^n$ Eingangssignalen an den Ausgang. Hat n Auswahlbits. Sendet 1 Eingangssignal an einen von  $2^n$  Ausgänge. n Auswahlbits.

Demultiplexer ----

### Halbaddierer

Addiert 2 Binärzahlen A und B. Produziert Summe und Carry-Out.

$$SUM = A \oplus B$$
  $CO = A \wedge B$ 

#### Volladdierer -----

Nimmt einen zusätzlichen Input CI entgegen.

$$SUM = (A \oplus B) \oplus CI$$
  $CO = (A \land B) \lor (S_{AB} \land CI)$ 

#### Serienaddierer ———

Addition einer Stelle pro Taktschritt.

# Paralleladdierer (Normalform) -

Addition aller Stellen pro Taktschritt.

#### Vortei

- Maximal 3 Grundgatter zwischen Input und Output.
- Laufzeit ist unabhängig von Stellenzahl der Summanden.

 $\overline{\text{von } n\text{--stelligen Summanden müssen}} \sim n \cdot 2^{2n-1}$   $\overline{\text{Min-/Maxterme}}$  verknüpft werden.

Nachteile Bei Addition

→ Schnell aber Schaltungsaufwendig

# Ripple-Carry Addierer (Paralleladdierer)

# Vorteile

- Durch Kaskadierung einfach skalierbar.
- Schaltungsaufwand linear zur Stellenzahl.

# Nachteile

- SUM und CO für die i-te Stelle können erst nach der Berechnung der (i - 1)-ten Stelle gebildet werden.
- Addierzeit linear zu Stellenzahl

Langsamer als Normalformaddierer aber einfacher zu realisieren.

# Carry-Look-Ahead Addierer (Paralleladdierer)

Kombination der Vorteile des Normalform- und Ripple-Carry-Addierer  $\to$  schnelle Schaltung mit begrenztem Aufwand.

Praktische Realisierung Addierer werden kaskadiert, Berechnung der Überträge erfolgt parallel zur Summenbildung.

Berechnungsaufwand ist linear zur Stellenzahl, Laufzeit bleibt konstant.

#### **Booth-Algorithmus**

Dient der Multiplikation von Binärzahlen (A & B). Berechnung über Zwischenprodukte  $P_i$ .

Division durch 2 bedeutet: Verschiebung des Kommas nach links (shift), mit Vorzeichenverdoppelung falls nötig.

| $a_i$ | $a_{i-1}$ | Operation               |
|-------|-----------|-------------------------|
| 0     | 0         | $P_i = P_{i-1}/2$       |
| 0     | 1         | $P_i = (P_{i-1} + B)/2$ |
| 1     | 0         | $P_i = (P_{i-1} - B)/2$ |
| 1     | 1         | $P_i = P_{i-1}/2$       |

Anfangswerte:  $P_{-1}=0,\,a_{-1}=0$ Beim letzten Schritt entfällt die Division durch 2.

# Zahlencodes

| Binär | BCD | Excess-3 | Aiken | 4-2-2-1 | Gray | O'Brien |
|-------|-----|----------|-------|---------|------|---------|
| 0000  | 0   |          | 0     | 0       | 0    |         |
| 0001  | 1   |          | 1     | 1       | 1    |         |
| 0010  | 2   |          | 2     | 2       | 3    | 0       |
| 0011  | 3   | 0        | 3     | 3       | 2    |         |
| 0100  | 4   | 1        | 4     |         | 7    | 4       |
| 0101  | 5   | 2        |       |         | 6    | 3       |
| 0110  | 6   | 3        |       | 4       | 4    | 1       |
| 0111  | 7   | 4        |       | 5       | 5    | 2       |
| 1000  | 8   | 5        |       |         |      |         |
| 1001  | 9   | 6        |       |         |      |         |
| 1010  |     | 7        |       |         |      | 9       |
| 1011  |     | 8        | 5     |         |      |         |
| 1100  |     | 9        | 6     | 6       | 8    | 5       |
| 1101  |     |          | 7     | 7       | 9    | 6       |
| 1110  |     |          | 8     | 8       |      | 7       |
| 1111  |     |          | 9     | 9       |      | 8       |

# Gate Varianten

