

Lehrstuhl für Rechnerarchitektur & Parallele Systeme Prof. Dr. Martin Schulz Dominic Prinz Jakob Schäffeler Lehrstuhl für Design Automation Prof. Dr.-Ing. Robert Wille Stefan Engels

# Einführung in die Rechnerarchitektur

Wintersemester 2024/2025

Übungsblatt 6: Kombinatorische Schaltungen

25.11.2024 - 29.11.2024

# 0 Digitaler Schaltungssimulator

In ERA wird zur Erstellung und Simulation von Schaltkreisen Digital – ein Projekt von Prof. Dr. Helmut Neemann (Duale Hochschule Baden-Württemberg) – verwendet. Die nötigen Dateien können direkt vom Repository unter https://github.com/hneemann/Digital heruntergeladen werden. Es ist keine betriebssystem-abhängige Installation notwendig. Für die Ausführung wird ein Java Runtime Environment (mindestens JRE 8) benötigt. Die JAR-Datei kann direkt gestartet werden, eventuell mit Hilfe des Befehls

Lade Digital herunter. Prüfe ob ein JRE korrekt installiert ist und starte Digital.

# 1 Wahrheitstabelle

Überprüfe mittels einer vollständigen Wahrheitstabelle die (Un-)Gleichheit folgender Aussagen:

Hinweis: Beachte, dass wir zu Übungszwecken in den folgenden Teilaufgaben beide Notationen aus der Vorlesung verwenden, d.h., wahlweise  $+, \cdot$  oder  $\vee, \wedge$ .

| a)                       | <u> </u>    | $\overline{x} \cdot \overline{y}$ |                  |             |        |  |  |
|--------------------------|-------------|-----------------------------------|------------------|-------------|--------|--|--|
| × Y                      | ×+Y         | X+Y                               | X                | 4           | X. 9   |  |  |
| 0 0<br>0 1<br>1 0<br>1 1 | 0<br>1<br>1 | <i>1</i> 0 0                      | 1<br>1<br>0<br>0 | 1<br>0<br>1 | 1000   |  |  |
|                          |             | Ola.                              |                  |             | rela i |  |  |

| b) $x + (y \cdot z)$ | $= (x+y) \cdot (x$ | +z)       |       |          |             |  |
|----------------------|--------------------|-----------|-------|----------|-------------|--|
| x 4 2                | 4.2                | Xx (4. Z) | x + 4 | X + 7    | (x+4)(x+ z) |  |
| 000                  | ъ                  | 0         | 0     | 0        | 0           |  |
| 0 0 1                | O                  | O         | 0     | 1        | 0           |  |
| 0 1 0                | 0                  | 0         | 1     | 0        | 0           |  |
| 0 1 1                | 1                  | 1         | 1     | 1        | $\Lambda$   |  |
| 100                  | O                  | 1         | 1     | 1        | 1           |  |
| 101                  | 0                  | 1         | 1     | 1        | Λ           |  |
| 110                  | 0                  | 1         | 1     | 1        | 1           |  |
|                      | 1                  | 1         | 1     | $\wedge$ | //          |  |
| 1 1 1                | /1                 | /1        |       |          |             |  |
|                      |                    |           |       |          |             |  |
|                      |                    | lhs !     | = l   | دہار     | _           |  |

c)  $f := \neg ((\neg x \land y) \lor (\neg y \land z)) \land (\neg x \land z)$  ist eine Kontradiktion

| × 4 7 | a:= -1×14   | b:= 7412 | C:= aub ( d:= 7c | e: 7×13 | t=dre  |
|-------|-------------|----------|------------------|---------|--------|
| 0 0 0 | 0           | O        | 0                | 0       | 0      |
| 0 6 1 | 1           | 7        | X                | 0       | 0 6    |
| D 1 1 | 1           | 0        | XXXXX            | 1       | ON     |
| 100   | 6           | 0        |                  | X       | 0 0    |
| 101   | 0           | 187      |                  | 6       |        |
| 110   | D           |          | CO AS ASS        | O       | 6 K    |
| 111   |             | 200      |                  |         | T      |
|       |             |          | 16/6 10,         |         | 0<br>N |
|       |             |          | MY KC            |         |        |
|       |             | 200      |                  |         |        |
| 2 E   | Boolesche A | Algebra  |                  | 1       |        |

Prüfe oder widerlege die folgenden Aussagen und verwende dazu die Regeln und Gesetze der Booleschen Algebra. Gib dazu bei jedem Beweisschritt die verwendete Regel bzw. das verwendete Gesetz an.

Hinweis: Beachte, dass wir zu Übungszwecken in den folgenden Teilaufgaben beide Notationen aus der Vorlesung verwenden, d.h., wahlweise  $+, \cdot$  oder  $\vee, \wedge$ .

a) 
$$\overline{a \cdot b} + b = 1$$

lbs =  $\overline{a \cdot b} + b$ 

| De Morgon

=  $\overline{a} + \overline{b} + b$ 

| Keplembing

=  $\overline{a} + 1$ 

| Extremolysetz

| Chs = vbs

b) 
$$\overline{(x+y)} + \overline{(x+y)} = (\overline{x}+y) \cdot (\overline{x}+\overline{y})$$

$$\lim_{x \to y} \overline{(x+y)} + \overline{(x+y)}$$

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

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

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

- c)  $f := \neg ((\neg x \land y) \lor (\neg y \land z)) \land (\neg x \land z)$  ist eine Kontradiktion.
- d) Was ist der duale Ausdruck von  $f = ((\neg x \land y) \lor (\neg y \land z)) \land (\neg x \land z)$
- d) Was ist der duale Ausdruck von  $f = \neg ((\neg x \land y) \lor (\neg y \land z)) \land (\neg x \land z)$ . Was können wir über diesen dualen Ausdruck aussagen?

$$\begin{cases} 0 = -7 \left( \left( -1 \times \sqrt{4} \right) \wedge \left( \frac{2}{14} \vee 2 \right) \right) \vee \left( -1 \times \sqrt{2} \right) \\ = \text{Kontradildin} \end{cases}$$

# 3 Funktionale Vollständigkeit

Eine Menge  $F \subset \mathcal{F}$  an Booleschen Funktionen heißt funktional vollständig wenn jede Boolesche Funktion sich als Komposition von Funktionen  $f \in F$  sowie den Variablen  $x_1, \dots, x_n$  schreiben

lässt. Man beachte, dass auch die Konstanten 0 und 1 als Funktionen in  $\mathcal{F}$  aufgefasst werden, nämlich diejenigen, die alle Variablenbelegungen konstant auf 0 oder 1 abbilden. Man kann zwar in der Praxis davon ausgehen, dass man beim Schaltungsentwurf immer Zugriff auf eine konstante 0- und 1-Leitung hat, in der Theorie der funktionalen Vollständigkeit bleibt dies jedoch unberücksichtig. In der Vorlesung wurde bereits erwähnt, dass die Menge  $\{\wedge, \vee, \neg, 0, 1\}$  funktional vollständig ist.

Zeige oder widerlege die funktionale Vollständigkeit der folgenden Mengen:

Hinweis: Du weißt bereits aus der Zentralübung, dass auch  $\{\land, \neg\}$  funktional vollständig ist.

- {*NOR*}
- $\{\oplus, 0, 1\}$
- $\{\neg, \leftrightarrow\}$
- {ITE, 0, 1}, wobei ITE:  $\{0, 1\}^3 \to \{0, 1\}$  mit ITE $(x, y, z) := (x \land y) \lor (\neg x \land z)^1$ .

### Bonusaufgabe:

Eine Boolsche Funktion f ist wahrheitserhaltend wenn der Wert der Funktion 1 ist wenn alle Variablen der Funktion auf 1 gesetzt werden, also  $f(1,1,\cdots,1)=1$ . Zeige, dass die Menge aller wahrheitserhaltenden Funktionen nicht funktional vollständig ist.

# 4 Arithmetische Schaltung

Gegeben sind zwei 2-bit unsigned Integer  $a = a_1 a_0$  und  $b = b_1 b_0$ . Es soll ein Schaltkreis entworfen werden der den Absolutwert der Differenz  $y = y_1 y_0 = |a - b|$  berechnet.

- Entwerfe den Schaltkreis unter Verwendung von Halb- und Volladdierern.
- Simuliere den Schaltkreis in Digital.
- Betrachte wie  $y_0$  von den Eingängen abhängt. Fällt dir eine einfache Schaltung ein die  $y_0$  direkt berechnet?

# 5 Hausaufgabe: Kombinatorische Schaltung: 16-Segment Display

Bearbeitung und Abgabe der Hausaufgabe 6 auf https://artemis.in.tum.de/courses/401 bis Sonntag, den 01.12.2024, 23:59 Uhr.

In dieser Aufgabe soll, basierend auf einer textuellen Beschreibung, eine Schaltung entwickelt werden, die ein 16-Segment-Display ansteuert. Ziel ist es, mithilfe von Logikgattern eine Schaltung zu entwerfen, die das Display steuern kann.

 $<sup>^1 {\</sup>rm ITE}$  wird auch If-Then-Else-Operator genannt, da  ${\rm ITE}(1,y,z)=y$  und  ${\rm ITE}(0,y,z)=z.$ 





Die World Monitoring & Co. KG (kurz WM & Co. KG) möchte Werbung für die ERA-Vorlesung machen und hat sich für die Nutzung eines 16-Segment-Displays entschieden, das üblicherweise zur Darstellung von Zahlen und Buchstaben verwendet wird. Der zuständige Mitarbeiter Georg benötigt jedoch eure Hilfe bei der Realisierung. Er konnte bereits ein paar Informationen sammeln, die im Folgenden dargestellt sind.



Das Display verfügt über einen 16-bit Segmenteingang. Jedes Bit (von 0 bis 15) steuert ein Segment. Wenn ein Bit auf "1" gesetzt ist, leuchtet das entsprechende Segment, wie in der Abbildung dargestellt.

Leider konnte Georg im Lager ausschließlich NAND-Gatter finden. Er hofft jedoch, dass er damit trotzdem ein Steuerelement für ein 16-Segment-Display bauen kann. Dieses soll das Display so steuern, dass es die Buchstaben E, R und A darstellen kann:

- a) Bestimme, welche Segmente des Displays aktiviert werden müssen, um die Buchstaben E, R und A korrekt darzustellen.
- b) Da nur drei Buchstaben dargestellt werden müssen, werden einige Segmente immer zusammen mit anderen eingeschaltet. Identifiziere Gruppen von Segmenten, die bei der Darstellung der Buchstaben gemeinsam leuchten. Ziel ist es, möglichst wenige Segmentgruppen zu definieren, um die Schaltung effizient zu gestalten.

  Hinweis: Es sind insgesamt 6 Gruppen. Eine dieser Gruppe umfasst die Segmente, die bei allen drei Buchstaben aus sind.

c) Unsere Schaltung benötigt nur vier Zustände, die in der folgenden Tabelle dargestellt sind. Vervollständige die Wahrheitstabelle, indem du für die Buchstaben die zuvor identifizierten Segmentgruppen als Ausgänge einträgst.

| A | В | out          |
|---|---|--------------|
| 0 | 0 | Aus          |
| 0 | 1 | $\mathbf{E}$ |
| 1 | 0 | R            |
| 1 | 1 | A            |

- d) Realisiere die Schaltung in Digital und verwende dabei ausschließlich NAND-Gatter<sup>2</sup>. Die Eingänge der NAND-Gatter dürfen nicht(!) invertiert werden.
  - Eingang: Die Schaltung soll einen 2-bit Eingang besitzen, der zwischen den vier Zuständen umschaltet.
  - Ausgang: Ein 16-bit Ausgang, der als Eingang für ein 16-Segement Display verwendet werden kann.

Hinweis: Es empfiehlt sich, zunächst eine Schaltung "nur" für die 6 Segmentgruppen zu etwickeln, da diese sonst schnell unübersichtlich und redundant wird. Mit Hilfe eines Mergers können diese 6 bit dann einfach auf die 16 Ausgangs-bit entsprechend der Überlegungen in Teilaufgabe b verdrahtet werden.

# 

### Beachte für die Abgabe auf Artemis:

- Die bestehenden Elemente dürfen nicht verändert werden, d.h., insbesondere dürfen die Namen und Bit-Breiten nicht angepasst werden. Die Elemente dürfen jedoch in ihrer Position verschoben werden.
- Das Template für Teilaufgabe d beinhaltet auch eine 16-Segment-Anzeige, die zum visuellen Debugging verwendet werden kann. Selbstverständlich wird daher auch die 16-Segment-Anzeige vom Tester als Komponente bei der Abgabe erlaubt.

<sup>&</sup>lt;sup>2</sup>Konstanten, Tunnel und Splitter/Merger aus der Untergruppe "Leitungen" dürfen in Digital immer verwendet werden.