

# Digitaltechnik

Wintersemester 2025/2026

Vorlesung 5



TECHNISCHE  
UNIVERSITÄT  
DARMSTADT



ENCRYPTO  
CRYPTOGRAPHY AND  
PRIVACY ENGINEERING

## 1 Boole'sche Algebra

## 2 Bubble Pushing

## 3 Logik-Realisierung mit Basis-Gattern



Harris 2016  
Kap. 2.3 - 2.5,  
2.8

|                    |                                                                                     |                      |
|--------------------|-------------------------------------------------------------------------------------|----------------------|
| Anwendungssoftware | >"hello world!"                                                                     | Programme            |
| Betriebssysteme    |  | Gerätereiber         |
| Architektur        |  | Befehle Register     |
| Mikroarchitektur   |  | Datenpfade Steuerung |
| Logik              |  | Addierer Speicher    |
| Digitalschaltungen |  | UND Gatter Inverter  |
| Analogschaltungen  |  | Verstärker Filter    |
| Bauteile           |  | Transistoren Dioden  |
| Physik             |  | Elektronen           |



Abgabefrist für Hausaufgabe B zu  
Vorlesungen 03 und 04 nächste Woche  
Freitag 23:59!  
Wöchentliches Moodle-Quiz nicht vergessen!

## 1 Boole'sche Algebra

## 2 Bubble Pushing

## 3 Logik-Realisierung mit Basis-Gattern



- Rechenregeln boole'scher Gleichungen
  - Axiome: grundlegende Annahmen der Algebra (nicht beweisbar)
  - Theoreme: komplexere Regeln, die sich aus Axiomen ergeben (beweisbar)
- analog zur Algebra auf natürlichen Zahlen
- ergänzt um Optimierungen durch Begrenzung auf  $\mathbb{B}$
- Axiome und Theoreme haben jeweils duale Entsprechung: AND  $\leftrightarrow$  OR, 0  $\leftrightarrow$  1

(Dualität: AND  $\leftrightarrow$  OR, 0  $\leftrightarrow$  1)

| Axiom                           | Duales Axiom                     | Bedeutung  |
|---------------------------------|----------------------------------|------------|
| A1 $B \neq 1 \Rightarrow B = 0$ | A1' $B \neq 0 \Rightarrow B = 1$ | Dualität   |
| A2 $\bar{0} = 1$                | A2' $\bar{1} = 0$                | Negieren   |
| A3 $0 \cdot 0 = 0$              | A3' $1 + 1 = 1$                  | Und / Oder |
| A4 $1 \cdot 1 = 1$              | A4' $0 + 0 = 0$                  | Und / Oder |
| A5 $0 \cdot 1 = 1 \cdot 0 = 0$  | A5' $1 + 0 = 0 + 1 = 1$          | Und / Oder |

| Theorem                                                                                     | Duales Theorem                                                                               | Bedeutung       |
|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-----------------|
| T1 $A \cdot 1 = A$                                                                          | T1' $A + 0 = A$                                                                              | Neutralität     |
| T2 $A \cdot 0 = 0$                                                                          | T2' $A + 1 = 1$                                                                              | Extremum        |
| T3 $A \cdot A = A$                                                                          | T3' $A + A = A$                                                                              | Idempotenz      |
| T4 $\overline{\overline{A}} = A$                                                            |                                                                                              | Involution      |
| T5 $A \cdot \overline{A} = 0$                                                               | T5' $A + \overline{A} = 1$                                                                   | Komplement      |
| T6 $A \cdot B = B \cdot A$                                                                  | T6' $A + B = B + A$                                                                          | Kommutativität  |
| T7 $A \cdot (B \cdot C) = (A \cdot B) \cdot C$                                              | T7' $A + (B + C) = (A + B) + C$                                                              | Assoziativität  |
| T8 $A \cdot (B + C) = (A \cdot B) + (A \cdot C)$                                            | T8' $A + (B \cdot C) = (A + B) \cdot (A + C)$                                                | Distributivität |
| T9 $A \cdot (A + B) = A$                                                                    | T9' $A + (A \cdot B) = A$                                                                    | Absorption      |
| T10 $(A \cdot B) + (A \cdot \overline{B}) = A$                                              | T10' $(A + B) \cdot (A + \overline{B}) = A$                                                  | Zusammenfassen  |
| T11 $(A \cdot B) + (\overline{A} \cdot C) + (B \cdot C) =$<br>$(A \cdot B) + (A \cdot C)$   | T11' $(A + B) \cdot (\overline{A} + C) \cdot (B + C) =$<br>$(A + B) \cdot (A + C)$           | Konsensus       |
| T12 $\overline{A \cdot B \cdot C \dots} = \overline{A} + \overline{B} + \overline{C} \dots$ | T12' $\overline{A + B + C \dots} = \overline{A} \cdot \overline{B} \cdot \overline{C} \dots$ | De Morgan       |

























- erster Präsident der London Mathematical Society
- Lehrer von Ada Lovelace
- De Morgan'sche Regeln:
  - Das Komplement des Produkts ist die Summe der Komplemente.
  - Das Komplement der Summe ist das Produkt der Komplemente.

- Methode 1: Überprüfen aller Möglichkeiten
- Methode 2: Gleichung durch Axiome und andere Theoreme vereinfachen

# Beweis für Distributivität (T8)

Durch Überprüfen aller Möglichkeiten

| $A$ | $B$ | $C$ | $B + C$ | $A(B + C)$ | $AB$ | $AC$ | $AB + AC$ |
|-----|-----|-----|---------|------------|------|------|-----------|
| 0   | 0   | 0   | 0       | 0          | 0    | 0    | 0         |
| 0   | 0   | 1   | 1       | 0          | 0    | 0    | 0         |
| 0   | 1   | 0   | 1       | 0          | 0    | 0    | 0         |
| 0   | 1   | 1   | 1       | 0          | 0    | 0    | 0         |
| 1   | 0   | 0   | 0       | 0          | 0    | 0    | 0         |
| 1   | 0   | 1   | 1       | 1          | 0    | 1    | 1         |
| 1   | 1   | 0   | 1       | 1          | 1    | 0    | 1         |
| 1   | 1   | 1   | 1       | 1          | 1    | 1    | 1         |

$$\begin{aligned} & A \cdot (A + B) && \text{Distributivitt} \\ &= A \cdot A + A \cdot B && \text{Idempotenz} \\ &= A + A \cdot B && \text{Neutralitt} \\ &= A \cdot 1 + A \cdot B && \text{Distributivitt} \\ &= A \cdot (1 + B) && \text{Extremum} \\ &= A \cdot 1 && \text{Neutralitt} \\ &= A && \text{q.e.d.} \end{aligned}$$



$$\begin{aligned} & A \cdot B + A \cdot \overline{B} && \text{Distributivit\"at} \\ &= A \cdot (B + \overline{B}) && \text{Komplement} \\ &= A \cdot 1 && \text{Neutralit\"at} \\ &= A && \text{q.e.d.} \end{aligned}$$

$$\begin{array}{lll} A \cdot B & + \bar{A} \cdot C + & B \cdot C \\ = A \cdot B & + \bar{A} \cdot C + & 1 \cdot B \cdot C \\ = A \cdot B & + \bar{A} \cdot C + (A + \bar{A}) \cdot B \cdot C & \\ = A \cdot B & + \bar{A} \cdot C + A \cdot B \cdot C & + \bar{A} \cdot B \cdot C \\ = A \cdot B & + A \cdot B \cdot C + \bar{A} \cdot C & + \bar{A} \cdot C \cdot B \\ = A \cdot B \cdot 1 + A \cdot B \cdot C + \bar{A} \cdot C \cdot 1 + \bar{A} \cdot C \cdot B & \\ = A \cdot B \cdot (1 + C) & + \bar{A} \cdot C \cdot (1 + B) & \\ = A \cdot B \cdot 1 & + \bar{A} \cdot C \cdot 1 & \\ = A \cdot B & + \bar{A} \cdot C & \end{array}$$

Neutralität  
Komplement  
Distributivität  
Kommutativität  
Neutralität  
Distributivität  
Extremum  
Neutralität  
q.e.d.

- Gatter-Realisierung per DNF kann sehr aufwändig sein  
⇒ Logik (Anzahl Literale und Operatoren) minimieren



$$\begin{aligned} Y &= \overline{A} \overline{B} \overline{C} + \overline{A} \overline{B} C + A \overline{B} \overline{C} + A \overline{B} C + A B C \\ &= \overline{A} (\overline{B} \overline{C} + \overline{B} C) + A (\overline{B} \overline{C} + \overline{B} C) + A B C \\ &= \overline{A} (\overline{B} (\overline{C} + C)) + A (\overline{B} (\overline{C} + C)) + A B C \\ &= \overline{A} \overline{B} + A \overline{B} + A B C \\ &= (\overline{A} + A) \overline{B} + A B C \\ &= \overline{B} + A B C \end{aligned}$$

- weitere Vereinfachungen möglich?
- $Y = \overline{B} + A C$
- Systematik notwendig, um minimale Ausdücke zu erkennen/finden



## 1 Boole'sche Algebra

## 2 Bubble Pushing

## 3 Logik-Realisierung mit Basis-Gattern

|                    |                                                                                     |                      |
|--------------------|-------------------------------------------------------------------------------------|----------------------|
| Anwendungssoftware | >"hello world!"                                                                     | Programme            |
| Betriebssysteme    |  | Gerätereiber         |
| Architektur        |  | Befehle Register     |
| Mikroarchitektur   |  | Datenpfade Steuerung |
| Logik              |  | Addierer Speicher    |
| Digitalschaltungen |  | UND Gatter Inverter  |
| Analogschaltungen  |  | Verstärker Filter    |
| Bauteile           |  | Transistoren Dioden  |
| Physik             |  | Elektronen           |

# Graphische Umformung von Schaltungen Nach De Morgan und Involution



CRYPTO  
CRYPTOGRAPHY AND  
PRIVACY ENGINEERING



- über Gatter (AND/OR/NOT/BUF) hinweg
  - vorwärts: Eingang → Ausgang
  - rückwärts: Ausgang → Eingang
  - Art des Gatters ändern: AND ↔ OR
  - Blasen an *allen* Eingängen ändern: vorhanden ↔ nicht vorhanden
  - Blase an Ausgang ändern: vorhanden ↔ nicht vorhanden
- zwischen Gattern
  - vorwärts: Treiber → *alle* Empfänger
  - rückwärts: *alle* Empfänger → Treiber
  - doppelte Blasen heben sich gegenseitig auf (Involution)
- verbleibende Buffer (vorher Inverter) können entfernt werden

# Beispiel Invertierungsblasen rückwärts verschieben



- De Morgan über G3

- Blase am Ausgang → Blase an beiden Eingängen
- AND → OR

- Blasen entlang Leitungen verschieben

- G3 → G1
- G3 → G2 (Doppelblase aufheben)

- De Morgan über G1

- Blasen an Ein- und Ausgängen *invertieren*
- OR → AND

- Buffer G2 entfernen

- zwei Inverter weniger

- Schaltungen vereinfachen
  - weniger Inverter
  - weniger Literale (z.B. nur  $A$  statt  $A, \bar{A}$ )
  - weniger verschiedene Gatter-Arten  
→ einfachere Zellbibliothek (z.B. nur AND, kein OR)
- Komplementäre Schaltungen für CMOS-Schaltung ableiten
  - $Y$  für Pull-Up Netzwerk  $\leftrightarrow \bar{Y}$  für Pull-Down Netzwerk
  - $Y = \overline{\bar{A}B + C}$
  - $\bar{Y} = \overline{\bar{A}B + C} = \overline{\bar{A}B} \ \overline{C} = (A + \bar{B})\bar{C}$

# Agenda



## 1 Boole'sche Algebra

## 2 Bubble Pushing

## 3 Logik-Realisierung mit Basis-Gattern

|                    |                 |                      |
|--------------------|-----------------|----------------------|
| Anwendungssoftware | >"hello world!" | Programme            |
| Betriebssysteme    |                 | Gerätereiber         |
| Architektur        |                 | Befehle Register     |
| Mikroarchitektur   |                 | Datenpfade Steuerung |
| Logik              |                 | Addierer Speicher    |
| Digitalschaltungen |                 | UND Gatter Inverter  |
| Analogschaltungen  |                 | Verstärker Filter    |
| Bauteile           |                 | Transistoren Dioden  |
| Physik             |                 | Elektronen           |

- Eingänge links (oder oben)
  - Ausgänge rechts (oder unten)
  - Gatter von links nach rechts (oben nach unten) angeordnet
  - gerade (oder rechtwinklige) Verbindungen
- ⇒ keine Schrägen oder Kurven
- 3-armige Kreuzungen gelten implizit als verbunden
  - 4-armige Kreuzungen gelten nur bei Markierung (Punkt) als verbunden



- direkte (konstruktive) Umsetzung der disjunktiven Normalform (DNF)

- Eingangsliterale: ein Inverter pro Variable (falls benötigt)
- Minterme: je ein „breites“ AND Gatter an passende Literale anschließen
- Summe: alle Minterme an ein „breites“ OR Gatter anschließen

- Gatter mit vielen Inputs als Bäume kleinerer Gatter

⇒ jede boole'sche Funktion realisierbar mit Basisgattern

- AND2
- OR2
- NOT



- zweistufige Logik
  - sehr mächtig
  - aufwändige Darstellung und Realisierung
  - realisiertes Verhalten nicht intuitiv ersichtlich
- weitere Basisgatter neben AND, OR, NOT:
  - XOR: Parität
  - NAND etc.
  - AND3 etc.  $n$  zu 1
- komplexere Gatter:
  - Multiplexer (MUX):  $n$  zu 1
  - Dekodierer (DEC):  $n$  zu  $2^n$

- Selektiert einen der  $n$  Dateneingänge  $A_0, \dots, A_{n-1}$  als Ausgang  $Y$
- $k = \lceil \log_2 n \rceil$  Steuersignale  $S_0, \dots, S_{k-1}$
- $Y = A_{\cup_{2,k}(S_{k-1} \dots S_0)}$



| $S_0$ | $A_0$ | $A_1$ | $Y$ |
|-------|-------|-------|-----|
| 0     | 0     | 0     | 0   |
| 0     | 0     | 1     | 0   |
| 0     | 1     | 0     | 1   |
| 0     | 1     | 1     | 1   |
| 1     | 0     | 0     | 0   |
| 1     | 0     | 1     | 1   |
| 1     | 1     | 0     | 0   |
| 1     | 1     | 1     | 1   |





- Variablen als Steuersignale verwenden
- Wahrheitwertetabelle als Konstanten an Dateneingängen
- entspricht adressiertem Speicherzugriff
  - Lookup Tabelle
  - ROM oder RAM → rekonfigurierbare Logik
- Beliebige Funktion mit  $N$  Variablen kann sogar via  $\text{MUX2}^{N-1}$  realisiert werden (s. Harris, Fig. 2.60)

| A | B | $Y = A \cdot B$ |
|---|---|-----------------|
| 0 | 0 | 0               |
| 0 | 1 | 0               |
| 1 | 0 | 0               |
| 1 | 1 | 1               |



- $n$  Eingänge  $A_0, \dots, A_{n-1}$
- $2^n$  Ausgänge  $Y_0, \dots, Y_{2^n-1}$
- „One-Hot“ Kodierung:  $Y_i = u_{2,n}(A_{n-1} \dots A_0) == i ? 1 : 0$

| $A_1$ | $A_0$ | $Y_0$ | $Y_1$ | $Y_2$ | $Y_3$ |
|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 1     | 0     | 0     | 0     |
| 0     | 1     | 0     | 1     | 0     | 0     |
| 1     | 0     | 0     | 0     | 1     | 0     |
| 1     | 1     | 0     | 0     | 0     | 1     |





- Summe über Minterme, auf denen Zielfunktion wahr ist
- ⇒ Decoder ersetzt erste Stufe der zweistufigen Logikrealisierung

| A | B | $Y = A \oplus B$ |
|---|---|------------------|
| 0 | 0 | 0                |
| 0 | 1 | 1                |
| 1 | 0 | 1                |
| 1 | 1 | 0                |



- 1 Boole'sche Algebra
- 2 Bubble Pushing
- 3 Logik-Realisierung mit Basis-Gattern

nächste Vorlesung beinhaltet

- Logikminimierung
- Mehrwertige Logik
- Zeitverhalten in kombinatorischen Schaltungen

**Hausaufgabe B zu Vorlesungen 03 und 04 muss bis  
nächste Woche Freitag 23:59 abgegeben werden.  
Wöchentliches Moodle-Quiz nicht vergessen!**

|                    |                                                                                     |                      |
|--------------------|-------------------------------------------------------------------------------------|----------------------|
| Anwendungssoftware | >"hello world!"                                                                     | Programme            |
| Betriebssysteme    |  | Gerätereiber         |
| Architektur        |  | Befehle Register     |
| Mikroarchitektur   |  | Datenpfade Steuerung |
| Logik              |  | Addierer Speicher    |
| Digitalschaltungen |  | UND Gatter Inverter  |
| Analogschaltungen  |  | Verstärker Filter    |
| Bauteile           |  | Transistoren Dioden  |
| Physik             |  | Elektronen           |