



# Digitale Schaltungen

## 1 Moore'sches Gesetz

- alle 18-24 Monate verdoppelt sich die Anzahl der Transistoren auf gleicher Fläche
- Exponentielles Wachstum der Transistorzahl, exponentieller Rückgang des Preises pro Transistor
- Herstellungskosten (Fixkosten, Variable Kosten, Technologiefaktor), Entwicklerproduktivität, Verlustleistungsdichte

## 2 Einheiten

| Potenz    | Vorsatz | Potenz     | Vorsatz | Hz       | $s^{-1}$       |
|-----------|---------|------------|---------|----------|----------------|
| $10^{12}$ | T       | $10^{-1}$  | d       | N        | $kgms^{-2}$    |
| $10^9$    | G       | $10^{-2}$  | c       | J        | $Nm = VAs$     |
| $10^6$    | M       | $10^{-3}$  | m       | W        | $VA = Js^{-1}$ |
| $10^3$    | k       | $10^{-6}$  | $\mu$   | C        | As             |
| $10^2$    | h       | $10^{-9}$  | n       | V        | $JC^{-1}$      |
| $10^1$    | da      | $10^{-12}$ | p       | F        | $CV^{-1}$      |
|           |         | $10^{-15}$ | f       | $\Omega$ | $VA^{-1}$      |
|           |         |            |         | H        | $VsA^{-1}$     |

$$Bit \xrightarrow{8} Byte \xrightarrow{1024} kByte \xrightarrow{1024} MByte$$

## 3 Polyadische Zahlensysteme

$$Z = \sum_{i=-n}^{p-1} r^i \cdot d_i = d_{p-1} \dots d_1 d_0 \cdot d_{-1} \dots d_n$$

Z: Zahl,  $r$ : Basis,  $d_i$ : Ziffer,  $p$ : #Ziffern vorne,  $n$ : #Nachkommastellen  
Binäres Zahlensystem:

$$d_{i2} \in 0, 1 \quad B = \sum_{i=-n}^{p-1} 2^i \cdot d_i \quad d_{-n} : LSB; \quad d_{p-1} : MSB$$

Octalsystem:  
 $d_{i8} \in 0, 1, 2, 3, 4, 5, 6, 7$

Benötigte Bits:  $N$  :  $n$  Bit  $M$  :  $2n$  Bit

$$N + M = 2n + 1 \text{ Bit}$$

$$N \cdot M = 3n \text{ Bit}$$

## 3.1 Umrechnung

|                    | $Z \geq 1$                                                                                                 | $Z < 1$                                                                                         |
|--------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| $r \rightarrow 10$ | $Z_{10} = \sum r^i \cdot d_i$<br>$101_2 \rightarrow 1 \cdot 1 + 0 \cdot 2 + 1 \cdot 4$                     | $Z_{10} = \sum r^{-i} \cdot d_{-i}$<br>$0.11_2 \rightarrow 1 \cdot 0.5 + 1 \cdot 0.25$          |
| $10 \rightarrow r$ | $d_i = Z_{10} \% r^i$<br>$58/8 = 7 \text{ Rest } 2 (\text{LSB})$<br>$7/8 = 0 \text{ Rest } 7 (\text{MSB})$ | $0.4 \cdot 2 = 0.8 \text{ Übertrag } 0 (\text{MSB})$<br>$0.8 \cdot 2 = 1.6 \text{ Übertrag } 1$ |

## 3.2 Zweierkomplement

Wandle 2 in -2 um:  
Wertebereich:  $-2^{n-1} \leq Z \leq 2^{n-1} - 1$

1. Invertieren aller Bits

$$0010 \Rightarrow 1101$$

2. Addition von 1

$$1101 + 1 = 1110$$

3. Ignoriere Überträge beim MSB

$$\Rightarrow -2_{10} = 1110_2$$

## 3.3 Gleitkommadarstellung nach IEEE 754

$$Wert = (-1)^s \cdot 2^{e-127} \cdot 1.f$$

$$s: \text{Vorzeichen}, e: \text{Exponent}, f: \text{Mantisse} \quad Bsp: -0.625 = -1 \cdot 2^{-1} \cdot 1.01_2$$

$$s: \text{Vorzeichen}, e: \text{Exponent}, f: \text{Mantisse} \quad Wert = 0 \Leftrightarrow e = 0 \quad Wert = \infty \Leftrightarrow e = 255$$

Spezialwerte: Wert = 0  $\Leftrightarrow$  e = 0

Bitverteilung(single/double):

|      |         |          |
|------|---------|----------|
| s(1) | e(8/11) | f(23/52) |
|------|---------|----------|

## 4 Halbleiter

| Ladungsträger | Isolator | Metall    | undotiert   | N-Typ | P-Typ  |
|---------------|----------|-----------|-------------|-------|--------|
| Leitfähigkeit | Keine    | $e^-$     | $e^-/e^+$   | $e^-$ | $e^+$  |
|               | Keine    | Sehr hoch | $\propto T$ | Hoch  | Mittel |

## 5 MOS-FET's

Metal Oxide Semiconductor Field Effect Transistor



### 5.1 Bauteilparameter

$$\text{Verstärkung: } \beta = K' \frac{W}{L} \text{ mit } K' = \frac{\mu \epsilon_0 x \epsilon_0}{t_{ox}}$$

| Kanalweite                        | W                                                                                                               |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------|
| Kanallänge                        | L                                                                                                               |
| Elektronenbeweglichkeit           | $\mu \approx 250 \cdot 10^{-4} \frac{m^2}{Vs}$                                                                  |
| rel. Dielektrizität des Gateoxyds | $\epsilon_{ox} \approx 3,9$                                                                                     |
| Dielektrizitätskonstante          | $\epsilon_0 = 8.8541878 \cdot 10^{-12} \frac{As}{Vm}$                                                           |
| Gateoxyddicke                     | $t_{ox}$                                                                                                        |
| Verstärkung                       | $\beta = \frac{\mu \epsilon_0 x \epsilon_0}{t_{ox}} \cdot \frac{W}{L} = K' \frac{W}{L} = \frac{\mu_n C_G}{L^2}$ |
| Kapazität                         | $C_G = \epsilon_0 \epsilon_{ox} \frac{W}{t_{ox}}$                                                               |
| Verzögerungszeit                  | $t_{pH} \propto \frac{C_L t_{ox} L_p}{W_p \mu_p \epsilon_{ox} (V_{DD} -  V_{th} )}$                             |

- große Kanalweite  $\Rightarrow$  große Drain-Störme  
 $\Rightarrow$  schnelle Schaltgeschwindigkeit (da  $i_d \propto \beta \propto \frac{W}{L}$ )  
Aber: große Fläche.

- nMOS schaltet schneller als pMOS

### 5.2 pMOS und nMOS



Drainstromformel:  
nMOS (p-dotiertes Substrat, n-dotierte Drain/Source), schlechter pull up (Pegeldegenerierung)

$$I_d = \begin{cases} 0, & \text{für } U_{GS} - U_{th} \leq 0 \\ \beta[(U_{GS} - U_{th}) \cdot u_{ds} - \frac{1}{2} u_{ds}^2], & \text{für } 0 \leq U_{GS} - U_{th} \leq u_{ds} \text{ (lineare Ber.)} \\ \frac{1}{2} \beta \cdot (U_{GS} - U_{th})^2, & \text{für } U_{GS} - U_{th} \geq u_{ds} \text{ (Sättigungsber.)} \end{cases}$$

Drainstromformel:

pMOS (n-dotiertes Substrat, p-dotierte Drain/Source), schlechter pull down (Pegeldegenerierung)

$$I_d = \begin{cases} 0, & \text{für } U_{GS} - U_{th} \geq 0 \\ -\beta[(U_{GS} - U_{th}) \cdot u_{ds} - \frac{1}{2} u_{ds}^2], & \text{für } 0 \geq U_{GS} - U_{th} \leq u_{ds} \text{ (lineare Ber.)} \\ -\frac{1}{2} \beta \cdot (U_{GS} - U_{th})^2, & \text{für } U_{GS} - U_{th} \geq u_{ds} \text{ (Sättigungsber.)} \end{cases}$$

## 5.3 Disjunktive Normalform (DNF/SOP)

Eins-Zeiligen der Wertetabelle ODER verknüpfen:

$$Z = \overline{A} \cdot \overline{B} + \overline{C} \cdot D$$

## 5.4 Konjunktive Normalform (KNF/POS)

Null-Zeiligen der Wertetabelle negieren und UND verknüpfen:

$$Z = (\overline{A} + \overline{C}) \cdot (\overline{A} + \overline{D}) \cdot (\overline{B} + \overline{C}) \cdot (\overline{B} + D)$$

## 5.5 Umwandlung in jeweils andere Form

1. Doppeltes Negieren der Funktion:  $Z = \overline{\overline{A} \cdot \overline{B} + \overline{C} \cdot D}$

$$2. \text{ Umformung "untere" Negation (DeMorgan): } Z = \overline{\overline{A} \cdot \overline{B}} \cdot \overline{\overline{C} \cdot D} = (A + B) \cdot (C + D)$$

3. Ausmultiplizieren:  $Z = (A + B) \cdot (C + D) = A \cdot C + A \cdot D + B \cdot C + B \cdot D$

4. Umformung "obere" Negation (DeMorgan):

$$Z = \overline{\overline{A} \cdot \overline{B} \cdot \overline{C} \cdot \overline{D}} = (\overline{A} + \overline{B}) \cdot (\overline{C} + \overline{D}) \cdot (\overline{B} + \overline{D})$$

Analog von KNF nach DNF.

## 6 CMOS - Logik

Komplementäre Logik liefert grundsätzlich negierte Ausgänge.  $\Rightarrow$  NAND einfacher als AND. Drei Grundgatter der CMOS-Technologie:



Falls GND und VDD vertauscht würden, dann NAND  $\rightarrow$  AND und NOR  $\rightarrow$  OR. Allerdings schlechte Pegelgenerierung.

### 6.1 Gatterdesign

| Vorteil:     | (Fast)            | nur bei Schaltvorgängen                                  | Verlustleistung                     | - wenig statische Verluste |
|--------------|-------------------|----------------------------------------------------------|-------------------------------------|----------------------------|
| Transistoren | nMos<br>AND<br>OR | Serieschaltung<br>Parallelschaltung<br>Parallelschaltung | Parallelschaltung<br>Serieschaltung |                            |

1. Möglichkeit: Direkt; ggf. Inverter vor die Eingänge und Ausgänge schalten.

2. Möglichkeit: Mit bullshit Algebra die Funktion nur mit NAND und NOR darstellen.

### 6.2 CMOS Verlustleistung

Inverterschaltvorgang  $V_A : 0 \rightarrow 1$ :



|                                                                                                                      |                                                                                                     |
|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| Dynamische Verlustleistung                                                                                           | $P_{dyn} = P_{cap} + P_{short}$                                                                     |
| Kapazitive Verluste                                                                                                  | $P_{cap} = \alpha_{01} f C_L V_{DD}^2$                                                              |
| Kurzschlussstrom                                                                                                     | $P_{short} = \alpha_{01} f \beta_n \tau (V_{DD} - 2V_{thn})^3$                                      |
| Schalthäufigkeit                                                                                                     | $\alpha_{0 \rightarrow 1} = \frac{\text{Schaltvorgänge(pos. Flanke)}}{\# \text{Betrachtete Takte}}$ |
| Abhängig von den Signalflanken, mit Schaltfunktionen verknüpft                                                       |                                                                                                     |
| $\approx V_{DD1}/\infty$ Schaltzeit: $\frac{V_{DD2}}{V_{DD1}} = \frac{t_{D1}}{t_{D2}}$ (bei Schaltnetzen $t_{log}$ ) |                                                                                                     |
| Verzögerungszeit $\propto \frac{1}{V_{DD} - V_{th}}$                                                                 |                                                                                                     |

Statische Verlustleistung  $P_{stat}$ : Sub-Schwellströme, Leckströme, Gate-Ströme  
Abhängigkeit:  $V_{DD} \uparrow : P_{stat} \uparrow \quad V_{th} \uparrow : P_{stat} \downarrow$  (aber nicht proportional)

## 7 Sequentielle Logik

... Logik mit Gedächtnis. Bedingungen:

|                   |                                                                            |
|-------------------|----------------------------------------------------------------------------|
| $t_{Setup}$       | Stabilitätszeit vor der aktiven Taktflanke                                 |
| $t_{hold}$        | Stabilitätszeit nach der aktiven Taktflanke                                |
| $t_{c2q}$         | Eingang wird spätestens nach $t_{c2q}$ am Ausgang verfügbar                |
| Max. Taktpause    | $t_{clk} \geq t_{1,c2q} + t_{logic,max} + t_{2,setup}$                     |
| Max. Taktfrequenz | $f_{max} = \left\lfloor \frac{1}{t_{clk}} \right\rfloor$ (Nicht aufrunden) |
| Holdzeitbedingung | $t_{hold} \leq t_{c2q} + t_{logic,min} \rightarrow$ Dummy Gatter einbauen  |
| Durchsatz         | $\frac{1}{t_{clk,pipe}} = f$                                               |
| Latenz            | $t_{clk} \cdot \# \text{Pipelinstufen}$ (das zwischen den FFs)             |

### 7.1 Pipelining

Nur bei synchronen(taktgesteuerten) Schaltungen möglich!

- Aufteilen langer kombinatorischer Pfade durch Einfügen zusätzlicher Registerstufen  
→ Möglichst Halbierung des längsten Pfades
- Zeitverhalten beachten (evtl. Dummy-Gatter einfügen)
- Durchsatz erhöht sich entsprechend der Steigerung der Taktfrequenz
- Gesamlatenz wird eher größer
- Taktfrequenz erhöht sich

### 7.2 Parallel Processing

$$\text{Durchsatz} = \frac{\# \text{Modul}}{t_{clk, Modul}} = f \quad \text{Latenz} = t_{clk}$$

- Paralleles, gleichzeitiges Verwenden mehrerer identischer Schaltnetze
- Zusätzliche Kontrolllogik nötig (Multiplexer)
- Taktfrequenz und Latenz bleiben konstant
- Durchsatz steigt mit der Zahl der Verarbeitungseinheiten  
ABER: deutlich höherer Ressourcenverbrauch

## 8 Volladdierer (VA) / Ripple-C(u)arry-Adder



## 9 Speicherelemente

Flüchtig Speicherinhalt gehen verloren, wenn Versorgungsspannung  $V_{DD}$  wegfällt - Bsp: \*RAM  
Nicht Flüchtig Speicherinhalt bleibt auch ohne  $V_{DD}$  erhalten - Bsp: Flash  
Asynchron Daten werden sofort geschrieben/gelesen.  
Synchron Daten werden erst mit  $clk_{0 \rightarrow 1}$  geschrieben.  
Dynamisch Ohne Refreshzyklen gehen auch bei angelegter  $V_{DD}$  Daten verloren - Bsp: DRAM  
Statistisch Behält den Zustand bei solange  $V_{DD}$  anliegt (keine Refreshzyklen nötig) - Bsp: SRAM

Bandbreite: Bitanzahl, die gleichzeitig gelesen/geschrieben werden kann.

Latenz: Zeitverzögerung zwischen Anforderung und Ausgabe von Daten.

Zykluszeit: Minimale Zeitdifferenz zweier Schreib/Lesezugriffe.

$$\text{Speicherkapazität} = \text{Wortbreite} \cdot 2^{\text{Adressbreite}}$$

### 9.1 Flip-Flop

besteht aus zwei enable-Latches

Flip-Flop: ändert Zustand bei steigender / (fallender) Taktflanke.

| $clk$ | $Q$ | $\bar{Q}$ |
|-------|-----|-----------|
| 0 → 1 | $D$ | $\bar{D}$ |
| sonst | $Q$ | $\bar{Q}$ |

### 9.2 Register

Ring aus zwei Invertern.

### 9.3 Latch

#### Set-Reset Latch:

Zwei gegenseitig rückgekoppelte NAND-Gatter.  
0 an R/S schaltet.

Enable-Latch: ändert Speicherzustand auf  $D$

| e | Q |
|---|---|
| 0 | Q |
| 1 | D |

### 9.4 DRAM Zelle (dynamisch)

lange Bitlines →  $C_{BL} \uparrow$ , Laufzeit↑  
quadratisch:  $\frac{\text{Bit}}{\text{Zeile}} = \frac{! \text{Bit}}{\text{Spalte}} = \frac{\text{Wort}}{\text{Zeile}} \cdot \frac{\text{Bit}}{\text{Wort}}$

#### Schreiben

- Wortleitung wird aktiviert, d.h. auf  $V_{DD}$  gelegt
- Bitleitung wird auf den gewünschten Wert ( $V_{DD}$  für 1, GND für 0) gelegt  
⇒ Kondensator wird auf entsprechendes Potential aufgeladen oder entladen, je nach vorherigem Wert

#### Lesen

- Wortleitung wird aktiviert, d.h. auf  $V_{DD}$  gelegt.
- Bitleitung wird auf  $V_{DD}/2$  vorgeladen.
- Adresstransistor wird geöffnet  
→ Ladungsaustausch zwischen  $C_S$  und  $C_{BL}$   
→ Potential der BL wird um  $\Delta V$  erhöht (1 lesen) oder erniedrigt (0 lesen)  
 $\Rightarrow \Delta V = (V_{DD} - \frac{V_{DD}}{2}) \cdot \frac{C_S}{C_S + C_{BL}}$  i.d.R  $C_{BL} \gg C_S \rightarrow \Delta V$  sehr klein  
→ Leseverstärker nötig!

### 9.5 SRAM Zelle (statisch)



### 9.6 ROM - Read Only Memory



## 9.7 Flash (nicht flüchtig)

nMOS Transistor mit zusätzlichem floating Gate in der Oxidschicht.

Floating Gate



,0' speichern:  $V_{GS} = V_{DS} = 4 \cdot V_{DD}$ , S an GND

,0' löschen: S von GND trennen, G an GND und D an 4mal VDD

## 9.8 Organisation von Speichern

- 1 Byte besteht aus 8 Bit
- Ziel: möglichst quadratische Anordnung der Speicherzellen
- Wortbreite W berücksichtigen!

Aufteilung:

$$\text{Speicherkapazität} = 2^M \cdot 2^N \quad \text{Bester Fall für } M = N$$

# Reihen =  $N$

$$2^M = W \cdot 2^K$$

# Spalten =  $K$

## 10 Automaten

DFA 6-Tupel  $\{I, O, S, R, f, g\}$

|                                |                           |
|--------------------------------|---------------------------|
| $I$                            | Eingabealphabet           |
| $O$                            | Ausgabealphabet           |
| $S$                            | Menge von Zuständen       |
| $R \subseteq S$                | Menge der Anfangszustände |
| $f : S \times I \rightarrow S$ | Übergangsrelation         |
| $g$                            | Ausgaberelation           |

#### Moore Automat



#### Mealy Automat



#### Moore

Output hängt nur vom Zustand ab  
 $g : S \rightarrow O$

#### Mealy

Output hängt von Zustand und Eingabe ab  
 $g : S \times I \rightarrow O$

### 10.1 Vorgehensweise

- $I, O$  bestimmen
- $S$  festlegen
- $R$  bestimmen
- $f, g$  bestimmen



# Entwurfsverfahren

## 1 Boolesche Algebra

|             | Mengenalgebra<br>$(P(G); \cap, \cup, \bar{A}; G, \emptyset)$                                         | Boolesche Algebra<br>$(0, 1; +, \cdot, \bar{x})$                                                                |
|-------------|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| Kommutativ  | $A \cap B = B \cap A$<br>$A \cup B = B \cup A$                                                       | $x \cdot y = y \cdot x$<br>$x + y = y + x$                                                                      |
| Assoziativ  | $(A \cap B) \cap C = A \cap (B \cap C)$<br>$(A \cup B) \cup C = A \cup (B \cup C)$                   | $x \cdot (y \cdot z) = (x \cdot y) \cdot z$<br>$x + (y + z) = (x + y) + z$                                      |
| Distributiv | $A \cap (B \cup C) = (A \cap B) \cup (A \cap C)$<br>$A \cup (B \cap C) = (A \cup B) \cap (A \cup C)$ | $x \cdot (y + z) = x \cdot y + x \cdot z$<br>$x + (y \cdot z) = (x + y) \cdot (x + z)$                          |
| Indempotenz | $A \cap A = A$<br>$A \cup A = A$                                                                     | $x \cdot x = x$<br>$x + x = x$                                                                                  |
| Absorption  | $A \cap (A \cup B) = A$<br>$A \cup (A \cap B) = A$                                                   | $x \cdot (x + y) = x$<br>$x + (x \cdot y) = x$                                                                  |
| Neutral     | $A \cap G = A$<br>$A \cup \emptyset = A$                                                             | $x \cdot 1 = x$<br>$x + 0 = x$                                                                                  |
| Dominant    | $A \cap \emptyset = \emptyset$<br>$A \cup G = G$                                                     | $x \cdot 0 = 0$<br>$x + 1 = 1$                                                                                  |
| Komplement  | $A \cap \bar{A} = \emptyset$<br>$A \cup \bar{A} = G$                                                 | $x \cdot \bar{x} = 0$<br>$x + \bar{x} = 1$                                                                      |
| De Morgan   | $\overline{A \cap B} = \bar{A} \cup \bar{B}$<br>$\overline{A \cup B} = \bar{A} \cap \bar{B}$         | $\bar{\bar{x}} = x$<br>$\overline{x \cdot y} = \bar{x} + \bar{y}$<br>$\overline{x + y} = \bar{x} \cdot \bar{y}$ |

## 1.1 Multiplexer

$$\begin{aligned} f &= x \cdot a + \bar{x} \cdot b && \text{(2 Eingänge } a, b \text{ und 1 Steuereingang } x) \\ f &= \bar{x}_1 \bar{x}_2 a + \bar{x}_1 x_2 b + x_1 \bar{x}_2 c + x_1 x_2 d && \text{(Eingänge: } a, b, c, d \text{ Steuerung: } x_1, x_2) \end{aligned}$$

## 1.2 Wichtige Begriffe

| Wichtige Begriffe: | Definition                                                         | Bemerkung                                                |
|--------------------|--------------------------------------------------------------------|----------------------------------------------------------|
| Signalvariable     | $x$                                                                | $\hat{x} \in \{0, 1\}$                                   |
| Literal            | $l_i = x_i \text{ oder } \bar{x}_i$                                | $i \in I_0 = \{1, \dots, n\}$                            |
| Minterme, 0-Kuben  | $\text{M0C } \exists m_j = \prod_{i \in I_0} l_i$                  | $ \text{M0C}  = 2^n$                                     |
| d-Kuben            | $\text{MC } \exists c_j = \prod_{i \in I_j \subseteq I_0} l_i$     | $ \text{MC}  = 3^n$                                      |
| Distanz            | $\delta(c_i, c_j) =  \{l \mid l \in c_i \wedge \bar{l} \in c_j\} $ | $\delta_{ij} = \delta(c_i, c_j)$                         |
| Implikanten        | $MI = \{c \in MC \mid c \subseteq f\}$                             |                                                          |
| Primimplikanten    | $MPI = \{p \in MI \mid p \not\subseteq c \forall c \in MI\}$       | $MPI \subseteq MI \subseteq MC$                          |
| SOP (DNF)          | eine Summe von Produkttermen                                       | Terme sind ODER-verknüpft                                |
| POS (KNF)          | ein Produkt von Summentermen                                       | Terme sind UND-verknüpft                                 |
| CSOP (nur 1)       | Menge aller Minterme                                               | Analog CPOS                                              |
| VollISOP (nur 1)   | Menge aller Primimplikanten                                        | Bestimmung siehe Quine Methode oder Schichtenalgorithmus |
| MinSOP (min. 1)    | Minimale Summe v. Primimplikanten                                  | durch Überdeckungstabelle                                |

FPGA: Field Programmable Gate Array  
LUT: Look Up Table

## 1.3 Boolesche Operatoren (Wahrheitstabelle WT)

| x | y | AND<br>$x \cdot y$ | OR<br>$x + y$ | XOR<br>$x \oplus y$ | NAND<br>$\bar{x} \cdot \bar{y}$ | NOR<br>$\bar{x} + \bar{y}$ | EQV<br>$x \oplus y$ |
|---|---|--------------------|---------------|---------------------|---------------------------------|----------------------------|---------------------|
| 0 | 0 | 0                  | 0             | 0                   | 1                               | 1                          | 1                   |
| 0 | 1 | 0                  | 1             | 1                   | 1                               | 0                          | 0                   |
| 1 | 0 | 0                  | 1             | 1                   | 1                               | 0                          | 0                   |
| 1 | 1 | 1                  | 1             | 0                   | 0                               | 0                          | 1                   |

Konfiguration:  $f = c_1 + c_2 + c_3 \Rightarrow cov(f) = \{c_1, c_2, c_3\}$

## 2 Beschreibungsformen

### 2.1 Sum of products (SOP/DNF)

Eins-Zeilen der Wertetabelle ODER verknüpfen:  
 $f = \bar{x} \cdot \bar{y} + \bar{z} \cdot w$

### 2.2 Product of sums (POS/KNF)

Null-Zeilen der Wertetabelle negieren und UND verknüpfen:  
 $f = (\bar{x} + \bar{z}) \cdot (\bar{x} + \bar{w}) \cdot (\bar{y} + \bar{z}) \cdot (\bar{y} + w)$

### 2.3 Shannon Entwicklung

$$\begin{aligned} f &= x_i \cdot f_{x_i} + \bar{x}_i \cdot f_{\bar{x}_i} = (x_i + f_{\bar{x}_i}) \cdot (\bar{x}_i + f_{x_i}) = (f_{x_i} \oplus f_{\bar{x}_i}) \cdot x_i \oplus f_{\bar{x}_i} \\ \bar{f} &= x_i \cdot \bar{f}_{x_i} + \bar{x}_i \cdot \bar{f}_{\bar{x}_i} \end{aligned}$$

### 2.4 Umwandlung in jeweils andere Form

1. Doppeltes Negieren der Funktion:  $f = \overline{\overline{x} \cdot \bar{y} + \bar{z} \cdot w}$
2. Umformung "untere" Negation (DeMorgan):  $f = \overline{\bar{x} \cdot \bar{y} \cdot \bar{z} \cdot \bar{w}} = (x + y) \cdot (z + w)$
3. Ausmultiplizieren:  $f = (x + y) \cdot (z + w) = \overline{x \cdot z + x \cdot w + y \cdot z + y \cdot w}$
4. Umformung "obere" Negation (DeMorgan):  
 $f = \overline{\bar{x} \cdot \bar{z} \cdot \bar{y} \cdot \bar{w}} = (\bar{x} + z) \cdot (\bar{x} + w) \cdot (\bar{y} + z) \cdot (\bar{y} + w)$

Analog von POS nach SOP.

### 2.5 Quine Methode

geg.: SOP oder Wertetabelle  
ges.: alle Primimplikanten (VollSOP)

spezielles Resolutionsgesetz:  $x \cdot a + \bar{x} \cdot a = a$

Absorptionsgesetz:  $a + a \cdot b = a$

- CSOP bestimmen (z.B.  $f(x, y, z, w) = xy\bar{z} + x\bar{y}z + xyz$ )
- alle Minterne in Tabelle eintragen (Index von m ist (binär) Wert des Minterms)
- Wenn Kubenabstand = 1 (ein "don't care") in 1-Kubus aufnehmen und A abhaken. Wenn nicht ist dieser Minterm bereits ein Primimplikant.
- der 1-Kubus muss zusammenhängend sein! (d.h. alle 1-Kubus Minterne müssen zusammenhängen)
- Wenn möglich 2-Kubus bilden.
- Wenn keine Kubenbildung mehr möglich  $\rightarrow$  VollSOP

Beispiel (Quine Methode):

| $m_0$ | 0-Kubus                   | A | 1-Kubus         | R            | A     | 2-Kubus | A     |
|-------|---------------------------|---|-----------------|--------------|-------|---------|-------|
| $m_1$ | $\bar{x}_1 \bar{x}_2 x_3$ | ✓ | $\bar{x}_2 x_3$ | $m_1 \& m_5$ | $p_1$ |         |       |
| $m_4$ | $x_1 \bar{x}_2 \bar{x}_3$ | ✓ | $x_1 \bar{x}_2$ | $m_4 \& m_5$ | ✓     | $x_1$   | $p_2$ |
| $m_5$ | $x_1 \bar{x}_2 x_3$       | ✓ | $x_1 \bar{x}_3$ | $m_4 \& m_6$ | ✓     |         |       |
| $m_6$ | $x_1 x_2 \bar{x}_3$       | ✓ | $x_1 x_3$       | $m_5 \& m_7$ | ✓     |         |       |
| $m_7$ | $x_1 x_2 x_3$             | ✓ | $x_1 x_2$       | $m_6 \& m_7$ | ✓     |         |       |

### 2.6 Quine's und McCluskey's Bestimmung der MinSOP

Geg: CSOP ( $\sum m_i$ ) und VollISOP ( $\sum p_i$ )      Ges: MinSOP

$$\begin{aligned} \text{Überdeckung: } C &= (m_0 \subseteq p_1) \cdot (m_2 \subseteq p_1 + m_2 \subseteq p_2) \stackrel{!}{=} 1 \\ C &= \tau_1 \cdot (\tau_1 + \tau_2) = \tau_1 + \tau_1 \tau_2 = \tau_1 \end{aligned}$$

Alternativ: Mit Überdeckungstabelle bestimmen.

## 2.7 Kubengraph



Kubenabstand  $\delta(c_1, c_2)$ : Kleinste Anzahl an Kanten, die nötig sind, um  $c_1$  und  $c_2$  zu verbinden bzw. Anzahl an Literalen die in  $c_1$  negiert und in  $c_2$  nicht negiert vorkommen.

#Literale = #Raumdimensionen - #Kubusdimensionen

Max. Kubenabstand: #Dimensionen - #Kubusdimensionen (größter Kubus)

überdeckte Minterme:  $2^{\text{Kubendimension}}$

## 2.8 (R)OBDD

(Reduced) Ordered Binary Decision Diagram



ROBDD  $\rightarrow$  SOP: Alle Pfade zur 1 verordnen:

$$f = x + \bar{x}y$$

ROBDD  $\rightarrow$  POS: Alle Pfade zu 0 verordnen, kompletten Term negieren, DeMorgan anwenden

## 3 Funktionale Dekomposition



Bei einer Funktion  $f(\underline{v})$  mit  $n$  Eingängen und einer möglichen Aufteilung von  $\underline{v}$  in  $\underline{w} = \underline{w}(z)$  und  $\underline{y}$  (wobei die Aufteilung disjunkt ist), kann  $f(\underline{v}) = f(\underline{w}, \underline{y})$  in  $g(h(\underline{w}), \underline{y})$  zerlegt werden.

Zerlegung sinnvoll, wenn  $|\underline{z}| \leq |\underline{x}| - 1$  oder  $|Z| \leq \frac{1}{2} |X|$   
Kompositionsfunktion:  $w = g(z, y)$   
Dekompositionsfunktion:  $\underline{z} = h(\underline{x})$

$\rightarrow$  Meist kann man eine günstige Aufteilung per BDD finden.

Verfahren:

- Auswerten von  $f(\underline{z}, \underline{y})$  und Bilder der Dekompositionsmatrix:  
 $f = \bar{x}_1 \bar{x}_2 y_1 + \bar{x}_1 x_2 x_3 y_1 + x_1 x_2 \bar{x}_3 y_1 \dots$

- Trage die Funktionswerte in die Matrix ein

- Suche Spalten, die die selben Werte je  $\underline{y}$  haben

- Codiere gleiche Spalten mit gleichem  $\underline{z}$

| freie Variablen<br>( $y_1, y_2$ ) | gebundene Variablen ( $x_1, x_2, x_3$ ) |     |     |     |     |     |     |     |
|-----------------------------------|-----------------------------------------|-----|-----|-----|-----|-----|-----|-----|
|                                   | 000                                     | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
| 00                                | 0                                       | 0   | 1   | 0   | 1   | 1   | 1   | 1   |
| 01                                | 0                                       | 0   | 1   | 0   | 1   | 1   | 1   | 1   |
| 10                                | 1                                       | 1   | 0   | 1   | 0   | 0   | 0   | 0   |
| 11                                | 1                                       | 1   | 0   | 1   | 1   | 1   | 1   | 0   |

$\underline{z} = h(x)$

• Konstruiere die Dekompositionsfunktion

$\rightarrow$  via Dekompositionsmatrix (1) / Zuordnungstabelle (2)

(1) alle eingetragenen 1en  $\hat{=} 1$  am Ausgang

$\rightarrow$  müssen in der Dekompositionsfunktion auftreten

(2)  $\underline{z}_i \cdot g(z, y)$  stellen die Dekompositionsfunktion dar

$$g(\underline{z}, \underline{y}) = \bar{z}_1 \bar{z}_2 y_1 + \bar{z}_1 z_2 \bar{y}_1 + z_1 \bar{z}_2 \bar{y}_1 + z_1 z_2 y_1 = \text{Kompositionsfunktion}$$

- Notationen:  $|\underline{x}|$  = Zahl der Eingangsvariablen (gebunden)

$|\underline{z}|$  = Zahl der DekompositionsvARIABLEN

$|X| = 2^{|\underline{x}|}$  = Zahl der möglichen Zustände aller gebundenen Variablen

$|Z| = 2^{|\underline{z}|}$  = Zahl aller DekompositionsvARIABLEN

### 3.1 Funktionale Dekomposition mit ROBDD

Ermitteln der gebundenen bzw. freien Variablen mittels BDD:



Dekompositionsbedingung  $|z| \leq |\underline{x}| - 1$  bzw.  $|Z| \leq \frac{1}{2} |X|$

- Nehme immer eine Ebene an:  
Oberhalb = gebundene Variablen  
Unterhalb = freie Variablen
- Zähle die Knoten, die durch die kreuzenden Äste erreicht werden (hier mit  $\Delta$  bezeichnet)
- Auch wenn ein Knoten durch zwei oder mehrere Äste erreicht wird, darf er nur einmal gezählt werden (im Beispiel:  $\Delta = 4$ )
- Wenn  $|z| = \lceil \log_2 \Delta \rceil \leq |\underline{x}| - 1 \rightarrow$  DK-Bed. erfüllt
- Pfade zur 1 ergeben Dekompositionsfunktion ( gebundene Variablen  $\rightarrow$  freie Variablen  $\rightarrow$  1)

Zuordnungstabelle:

| geb. Variablen | $z_1$ | $z_2$ | freie Variablen                 |
|----------------|-------|-------|---------------------------------|
| 111            | 0     | 0     | $x_4 x_5$                       |
| 110, 010, 011  | 0     | 1     | $x_4 x_5 + \bar{x}_4 \bar{x}_5$ |
| 101, 100       | 1     | 0     | 1                               |
|                | 1     | 1     |                                 |

### 3.2 Heuristische Minimierung

Kofaktorbildung: Setze alle  $x_i = 1$  und alle  $\bar{x}_i = 0$   
z.B.  $f = x\bar{y} + \bar{x}yw + xw \Rightarrow f_x = \bar{y} + w$

#### 3.2.1 Kubentfernung (remove)

- $h = f \setminus c$  ( $f$  ohne den zu entfernenden Kubus)  
z.B.  $f = \bar{x}yz + xyz + \bar{x}yz \Rightarrow$  für  $c = \bar{x}yz \Rightarrow h = xyz + \bar{x}yz$   
 $\bar{h}\bar{y}z = 1 + 0 = 1 \Rightarrow$  entfernbare
- Bildung des Kofaktors  $h_c$
- Wenn  $h_c = 1 \Rightarrow c$  ist entfernbare

2 Kuben gemeinsam entfernen: teste 2. Kubus **nachdem** der 1. entfernt wurde.

#### 3.2.2 Literalentfernung (expand)

- Aufstellen von  $h = \{f \setminus c_l \cdot l\}$   
z.B.  $f = \bar{x}y + xyz + \bar{x} \cdot \bar{y} \cdot \bar{z}$  (entferne  $x$ : d.h.  $l = x$  und  $c_l = yz$ )  
 $h = \bar{x}y + \bar{x} \cdot \bar{y} \cdot \bar{z}$
- Wenn  $h_{c_l \cdot \bar{l}} = 1$  ist das Literal entfernbare  
z.B.  $h_{c_l \cdot \bar{l}} = (\bar{x}y + \bar{x} \cdot \bar{y} \cdot \bar{z})\bar{x}yz = 1$

### 3.2.3 Literal hinzufügen (reduce)

Kann man  $l$  zu  $c$  hinzufügen ohne  $f$  zu verändern?  
 $f = c + h \stackrel{?}{=} c \cdot l + h$   
Zulässigkeitsbedingung:  $c \cdot \bar{l} \subseteq h$   
z.B.  $f = xy + \bar{x}yz + xz$  (füge  $l = \bar{z}$  hinzu)  
Ist  $xyz \subseteq \bar{x}yz + xz$ ?  
 $\Rightarrow f^* = xy\bar{z} + \bar{x}yz + xz$   
Gemeinsame Literalentfernung: Prüfe 2. Literal nachdem 1. Literal entfernt wurde.

### 3.3 Strukturanalyse

Tautologie:  $f_{x_i} = 1 \wedge f_{\bar{x}_i} = 1 \Rightarrow f = 1$

Monoton steigend in  $x_i$ :  $f_{\bar{x}_i} \subseteq f_{x_i}$  dann gilt auch  $f_{\bar{x}_i} = 1 \Rightarrow f = 1$

Monoton fallend in  $x_i$ :  $f_{x_i} \subseteq f_{\bar{x}_i}$  dann gilt auch  $f_{x_i} = 1 \Rightarrow f = 1$

Beispiel:

$f = yz + xz + \bar{y}z + \bar{y}\bar{z} \Rightarrow$  monoton steigend in  $x$

$f(x, y, z) = x \varphi(z) + h(y, z) \Rightarrow$  Prüfe  $h$  auf Tautologie

## 4 Nützliches Wissen

### 4.1 Mehrfachimplikanten

Sind gleiche Implikanten in mehreren verschiedenen Funktionen vorhanden?

Prüfe  $f_1 \cap f_2$  auf Mehrfachimplikanten:  $f_1 \cdot f_2 = ?$

Nutzung von Mehrfachimplikanten ist sinnvoll wenn die Gesamtliteralzahl beider SOPs kleiner ist als ohne Verwendung von Mehrfachimplikanten.

### 4.2 VollSOP erstellen

Benutze die Resolventenmethode um alle Resolventen zu erzeugen und so aus der MinSOP eine VollSOP zu erstellen.

## 5 Automaten

Sind abstrakte Maschinen mit  $r$  Zuständen  $S_i \in S$ , die auf sequentielle Eingangssignale  $X_j \in I = \mathbb{B}^m$  mit Ausgangssignalen  $Y_l \in O = \mathbb{B}^m$  und Zustandsänderungen reagieren.

Startzustand  $S^0 \in S$

Zustandsfkt.  $\delta : S \times I \rightarrow S, S_k \mapsto \delta(S_i, X_j)$

Ausgangsfkt.  $\lambda : S \times I \rightarrow O, Y_l \mapsto \lambda(S_i, X_j)$

ZA-fkt.  $\mu : S \times I \rightarrow S \times O, (S_k, Y_l) \mapsto \mu(S_i, X_j)$

**k-Äquivalenz**  $S_i \xrightarrow{k} S_j$  Für eine Eingangssequenz der Länge  $k$  sind bei  $S_i$  und  $S_j$  die Ausgaben gleich und die Zustandsübergänge gleich bzw.  $k - 1$  Äquivalent.

**Totale Äquivalenz**  $S_i \sim S_j$  falls für alle Eingangssequenzen die Ausgaben und die Zustandsübergänge äquivalent sind.

→ Zeige: es lassen sich keine weiteren Äquivalenzklassen bilden.

## 6 Karnaugh- Diagramm

Zyklische Gray-Codierung: 2dim:00, 01, 11, 10 3dim:000, 001, 011, 010, 110, 111, 101, 100

| $z \setminus y$ | 00 | 01 | 11 | 10 |
|-----------------|----|----|----|----|
| 0               | 1  | 0  | 0  | 0  |
| 1               | X  | 1  | 1  | 0  |

Don't Care Werte ausnutzen!

## 7 Resolventenmethode

Ziel: alle Primimplikanten

Wende folgende Gesetze an:

Absorptionsgesetz:  $a + ab = a$

allgemeines Resolutionsgesetz:  $x \cdot a + \bar{x} \cdot b = x \cdot a + \bar{x} \cdot b + ab$

Anwendung mit Schichtenalgorithmus

- schreibe die Funktion  $f$  in die 0. Schicht
  - bilde alle möglichen Resolventen aus der 0. Schicht und schreibe sie in die nächste Schicht als ODER Verknüpfungen (Resolventen zu  $f$  "hinzufügen")
  - überprüfe ob Resolventen aus der 1. Schicht Kuben aus Schicht 0 überdecken (Absorption) und streiche diese Kuben aus Schicht 0
  - Schicht  $i$  besteht aus den möglichen Resolventen von Schicht 0 bis  $(i - 1)$ . Abgestrichene Kuben aus vorherigen Schichten brauchen nicht mehr beachtet werden.
  - Sobald in der  $i$ -ten Schicht +1 steht oder keine weiteren Resolventen gebildet werden können, ist man fertig. ⇒ alle nicht ausgestrichenen Terme bilden die VollSOP
- | $f(x_1, \dots, x_n)$                                                                                                                    | Schicht |
|-----------------------------------------------------------------------------------------------------------------------------------------|---------|
| $x \cdot w + \bar{x} \cdot w + x \cdot y \cdot w \cdot \bar{z} + \bar{x} \cdot y \cdot w \cdot \bar{z} + \bar{y} \cdot w \cdot \bar{z}$ | 0       |
| $+w + y \cdot w \cdot \bar{z}$                                                                                                          | 1       |
| $+w \cdot \bar{z}$                                                                                                                      | 2       |
| $+w$                                                                                                                                    | 3       |

## 8 Laufzeit

### 8.1 Laufzeitabhängige Effekte

- Race, "Wettkauf" zweier Signalwertänderungen vor einem gemeinsamen Gatter
- Hazard / Spike / Glitch, Stelle des Signalwertverlaufes, die wegen der Laufzeitverzögerung nicht den Erwartungen entspricht

### 8.2 Simulation

 Eingangsbelegung  $a = 0, b = 0$   
Eingangsergebnis  $(b, 1', 0, 2)$

Auswertung erfolgt durch eine Tabelle:

| t | a   | b   | z   | y   | ausgewertete Elemente | neue Ereignisse                                                  |
|---|-----|-----|-----|-----|-----------------------|------------------------------------------------------------------|
| 0 | '0' | '0' | '1' | '0' | init                  | $(b, 1', 0, 2)$                                                  |
| 2 |     | '1' |     |     | OR                    | $(z, 1', 2, 4)$                                                  |
| 4 |     |     | '1' |     | NOT                   | $(y, 0', 4, 5)$                                                  |
| 5 |     |     |     | '0' |                       | Ereignis: (betroffenes Signal, neuer Signalwert, t, t + $\tau$ ) |

### 8.3 Delay

- transport delay: Verzögerung um  $\tau_{pd}$
- inertial delay: Verzögerung um  $\tau_{pd}$  und Impulse die kleiner als  $\tau_{pd}$  sind werden ignoriert

### 8.4 VHDL- VHSIC Hardware Description Language

ENTITY Bausteinname IS //Definiert die Schnittstelle einer Logik  
PORT (Schnittstellenliste) //Definiert Ein- und Ausgänge  
  
ARCHITECTURE Rumpfname OF Bausteinname IS //Beschreibt den internen Aufbau  
PROCESS (Signalliste) // Alle Prozesse laufen nebeneinander ab  
COMPONENT Gattername // Beschreibt eine interne Komponente

## 9 Testverfahren

Mit wenig Fragen viel Information erhalten. Signal muss beobachtbar und einstellbar sein!

### 9.1 Begriffe

Fehlergruppe  $F_\nu = \{f_\mu \in F \mid t_\nu R f_\mu\}$ : Menge aller Fehler die vom Test  $t_\nu$  erkannt werden.  
Fehleranzahl = 2: Signalanzahl = 2(Eingänge + Interne Signale + Ausgänge)  
Testgruppe  $T_\mu = \{t_\nu \in T \mid t_\nu R f_\mu\}$  ist die Menge aller Tests die den Fehler  $f_\mu$  erkennen.

Zwei einzelne Fehler sind nicht unterscheidbar, wenn sie immer gemeinsam von einem Test entdeckt werden.

## 9.2 Bullshit-Differenz $y_z$

Ziel: schnelles finden von Testbedingungen für  $f = y(z(\underline{x}))$

$$y_z = y(z, \underline{x}) \oplus y(\bar{z}, \underline{x}) \triangleq y(z=1) \oplus y(z=0)$$

### 9.2.1 Rechenregeln

$$\begin{array}{ll} y_x = 0 \text{ falls } y \neq f(x) & (z \cdot w)_x = z \cdot w_x \oplus z_x \cdot w \oplus z_x \cdot w_x \\ y_y = 1 & (z + w)_x = \bar{z} \cdot w_x \oplus z_x \cdot \bar{w} \oplus z_x \cdot w_x \\ (\bar{y})_x = y_x & y_x = y_z \cdot z_x \text{ falls } y = y(z(x)) \\ (z \oplus w)_x = z_x \oplus w_x & (y_z)_w = (y_w)_y \end{array}$$

### 9.2.2 AND → XOR (+, $\bar{x}$ )

Vorgehen:

1. Negation über konjunkte Terme entfernen: DeMorgan  $\bar{x}\bar{y} = \bar{x} + \bar{y}$
2. Negation über disjunkte Terme entfernen:  $\bar{x} = x \oplus 1$
3. "+" entfernen  $x + y = x \oplus y \oplus xy$

$$\text{Test für } \begin{cases} a/0 : a \cdot y_a \stackrel{!}{=} 1 \\ a/1 : \bar{a} \cdot y_a \stackrel{!}{=} 1 \end{cases} \Rightarrow \text{Testmuster finden.}$$

### 9.2.3 XOR-Regeln

$$\begin{array}{ll} x \oplus y = \bar{x} \cdot y + x \cdot \bar{y} & x + y = x \cdot y \oplus x \oplus y \\ x \oplus y = (x+y) \cdot (\bar{x} + \bar{y}) & x \cdot y = x \oplus y \oplus (x+y) \\ x \cdot (y \oplus z) = x \cdot y \oplus x \cdot z & \bar{x} = x \oplus 1 \\ x \oplus x = 0 & x \oplus 0 = x \\ (x+y) \oplus y = x \cdot \bar{y} & x\bar{y} + yz = x\bar{y} \oplus yz \end{array}$$

### 9.2.4 Schaltnetze



$$\begin{aligned} y_x &= y_z z_x \bar{w}_x + y_w w_x \bar{z}_x + z_x w_x \cdot [\bar{z} \circ \bar{w} \oplus z \circ w] \\ o &= \text{XOR/XNOR} \Rightarrow [\bar{z} \circ \bar{w} \oplus z \circ w] = 0 \\ o &= \text{AND/NAND/OR/NOR} \Rightarrow [\bar{z} \circ \bar{w} \oplus z \circ w] = \bar{z} \oplus w \end{aligned}$$

Schaltnetz mit Rekonvergenzmasche (4 Fälle):

1.  $y_z z_x \bar{w}_x = 1 \Rightarrow$  Einfachpfadsensibilisierung:  $x-z-y$
2.  $y_w w_x \bar{z}_x = 1 \Rightarrow$  Einfachpfadsensibilisierung:  $x-w-y$
3.  $z_x w_x \cdot [\bar{z} \circ \bar{w} \oplus z \circ w] = 1 \Rightarrow$  Mehrfachpfadsensibilisierung
4.  $z_x w_x \cdot [\bar{z} \circ \bar{w} \oplus z \circ w] = 1 \Rightarrow$  Selbstmaskierung

Schaltnetz mit Baumstruktur:  
keine Mehrfachpfadsensibilisierung oder Selbstmaskierung!  
 $y_x = y_z \cdot z_x$  (Kettenregel für  $x-u-z-y$ )

## 9.3 Fehlersimulation

Gegeben: Testmuster    Gesucht: getestete Fehler.

Achtung    Teste immer nur für eine spezielle Belegung

Begriffe    Fanout-Stamm: Verzweigungspunkt    Vereinigungspunkt: Rekonvergenzpunkt

### 9.3.1 Fehlerbaumkonstruktion für gegebenes Testmuster

1. Alle Signalwerte der Schaltung für gegebenes Testmuster bestimmen
2. Durch die Simulation die Beobachtbarkeit der Fanout-Stämme bestimmen.
3. Schaltung an Fanout-Stämmen gedanklich auftrennen. (In Fanout-Freie Zonen zerlegen)
4. Fehlerbaumkonstruktion in den Bäumen (FF-Zonen) vom Ausgang in Richtung Eingänge auf Basis der lokalen Sensitivitäten (mit  $\bullet$  markieren).
5. Aus Fehlerbaum Menge der beobachtbaren Signale  $S^0$  (sensitiver Pfad zum Ausgang) und Menge der getesteten Fehler  $F_t$  durch Einstellbarkeit (sensitiver Pfad zum Eingang) angeben.  
z.B.  $S^0 = \{a, b, b_2, y\} \quad F_t = \{a/1, b/0, b_2/0/y/1\}$

## 9.4 Deterministische Testmustergenerierung. D-Algorithmus

Zahl aller Fehlerpfade:  $2^n - 1$  für  $n =$  Zahl der Einfachfehlerpfade

Findet für jeden stuck-at Fehler einen Test, falls möglich.

5-wertige Logik:

- |           |                                                           |
|-----------|-----------------------------------------------------------|
| 0         | Boolsche 0                                                |
| 1         | Boolsche 1                                                |
| X         | undefined                                                 |
| D         | 1 falls fehlerfrei, 0 falls fehlerhaft (teste stuck-at 0) |
| $\bar{D}$ | 0 falls fehlerfrei, 1 falls fehlerhaft (teste stuck-at 1) |



globale Implikation: mehr als 1 Gatter zwischen Testsignal und implizierten Signal:

$$A \Rightarrow B \Leftrightarrow \bar{B} \Rightarrow \bar{A}$$

Lernkriterium (für  $y = z(x)$ ):  $y_{z_1} \cdot y_{z_2} \stackrel{!}{=} 1$

Vorgehen (z.B. für Test  $x_1/0$ ):

F : Fehlertestsignal ( $x_1 = D$ )

S : Sensibilisierung ( $x_2 = 1$ )

I : Implikation ( $y = \bar{D}$ )

O : Optionale Pfade (z.B. bei XOR)

Ist Ausgang 0 bzw. 1  $\Rightarrow$  Fehler nicht testbar.

Ist Ausgang D bzw.  $\bar{D}$   $\Rightarrow$  Fehler testbar.

## 9.5 Einstellbarkeit

$$C_0 + C_1 = 1$$

$C_0$ : Nulleinstellbarkeit  $0 \leq C_0 \leq 1$   
Wahrscheinlichkeit das ein Testvektor zur 0 führt

$C_1$ : Einseinstellbarkeit  $0 \leq C_1 \leq 1$

ohne Vorgabe für Eingangsvariable x:  $C_0(x) = 0,5$  und  $C_1(x) = 0,5$

Beachte: Je nach Gatter sind bestimmte Einstellbarkeiten schneller zu berechnen! (siehe Tabelle)

| Gatter | Einstellbarkeit (Ausgang) | Berechnung                                          |
|--------|---------------------------|-----------------------------------------------------|
| AND    | $C_1$                     | $C_1(x_1) \cdot C_1(x_2)$                           |
| NAND   | $C_0$                     | $C_1(x_1) \cdot C_1(x_2)$                           |
| OR     | $C_0$                     | $C_0(x_1) \cdot C_0(x_2)$                           |
| NOR    | $C_1$                     | $C_0(x_1) \cdot C_0(x_2)$                           |
| XOR    | $C_1$                     | $C_0(x_1) \cdot C_1(x_2) + C_1(x_1) \cdot C_0(x_2)$ |
| NOT    | $C_1$                     | $C_0(x)$                                            |

Wichtig: Nur bei Baumstruktur exakt.

## 9.6 Schaltwerke

| Eingangsvariable           | X                        |
|----------------------------|--------------------------|
| Testpunkte                 | Y                        |
| nächste Schaltwerkzustände | Z                        |
| Schaltwerkzustände         | S                        |
| Es gilt: $s^t = z^{t-1}$   | $t : t$ -te Taktperiode. |

Verbesserung der Einstellbarkeit und Beobachtbarkeit durch Zusatzlogik:  
Zusätzlicher Testeingang: Mehr Platzbedarf, mehr Leistungsaufnahmen.  
Zusätzlicher Ausgang: Zusätzlicher Pin, langsameres Signal.

## 10 Auch wichtig

