

# Lecture 1

## Digital system design

Introduction

*CS173 - Conception de systèmes numériques*  
*November 2016*

Digital system  
design

Prof. Dr. Theo  
Kluter

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Logic = Algebra

Boolean Algebra

Gates

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Digital Logic versus Analog circuits



## Transistor:

- ▶ Discovered in 1947 by Shockley, Bardeen and Brattain
- ▶ Basis for almost all digital and analog circuits nowadays

## Application:

- ▶ Analog as amplifier
- ▶ Possible values unlimited
- ▶ Digital as switch
- ▶ Only 2 values: **on** and **off**
- ▶ **Digital**: 2 valued digit

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Logic = Algebra

Boolean Algebra

Gates

We have seen: Digital: two valued digit

What about: Logic

## Example:

When I'm **late and take a taxi or** I'm **not late and take the bus** then I'm **on time for the course**

- ▶ Each logic expression has variables
- ▶ Each logic expression has operators
- ▶ Each logic expression has one or more inputs
- ▶ Each logic expression has one output

Digital Logic is based on **logic expressions of two valued (*binary*) variables**

Digital system  
design

Prof. Dr. Theo  
Kluter

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Logic = Algebra

Boolean Algebra

Gates

# Basic Logic Operators

| Operator:  | Example:                                                                                            | Short:                                                                 |
|------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|
| <b>NOT</b> | If you can <b>not</b> <b>see</b> then you are <b>blind</b>                                          | $\text{blind} = \neg \text{see}$                                       |
| <b>AND</b> | If you mix <b>flour</b> <b>and</b> <b>milk</b> <b>and</b> <b>eggs</b> then you have <b>pancakes</b> | $\text{pancakes} = \text{flour} \wedge \text{milk} \wedge \text{eggs}$ |
| <b>OR</b>  | If <b>John takes money or Marry takes money</b> then there is <b>less money</b>                     | $=$<br>$\text{John takes money} \vee \text{Marry takes money}$         |

Digital system design

Prof. Dr. Theo Kluter

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Logic = Algebra

Boolean Algebra

Gates

# Basic Logic Operators (cont.)

What about:

If John is walking **or** John is biking then he is active

This is a *disjunction*

But a special one, as John cannot walk and bike at the same time!

This operator is called the *Exclusive OR (XOR)*.

- ▶ Disjunction
- ▶ Short notation:  $A \oplus B$
- ▶ Equivalence:  $A \oplus B = (\neg A \wedge B) \vee (A \wedge \neg B)$

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Logic = Algebra

Boolean Algebra

Gates

## Truth Table

- ▶ Each logical expression has  $n$  inputs and one output
- ▶ Each input can **only** have two states, namely True (**T**) or False (**F**)
- ▶ For  $n$  inputs we can therefore have  $2^n$  different input combinations
- ▶ We can write the *truth table* of a logical expression
- ▶ We can compress the *truth table* by using the **don't care symbol X** or -
- ▶ The - denotes that the variable can be either **T** or **F**

If John takes money **or** Marry takes money then there is **less money**

$$Y = A \vee B$$

| A | B | Y |
|---|---|---|
| F | F | F |
| F | T | T |
| T | F | T |
| T | T | T |

| A | B | Y |
|---|---|---|
| F | F | F |
| F | T | T |
| T | - | T |

# Digital Logic $\stackrel{?}{=}$ Algebra

- ▶ We have seen a transistor giving in its digital operation the two values **On** (3.3V) and **Off** (0V)
- ▶ We have also seen logic expressions with their two values **True** and **False**
- ▶ Let us define that :
  1. **Off = False = 0** and
  2. **On = True = 1.**
- ▶ What happens than with the conjunction?
- ▶ We have a logic multiplication...

If you have **a password and a login** than **you can use the computer**

| P | L | C |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

$C = P \wedge L$

$C = P \cdot L$

Digital system design

Prof. Dr. Theo Kluter

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Boolean Algebra

Gates

# Digital Logic $\stackrel{?}{=}$ Algebra

- ▶ What happens than with the disjunction?
- ▶ Is it a logic addition?
- ▶ We cannot express **2**; we only have two quantities (**0** and **1**)
- ▶ Hence we have only two possibilities:
  1. **1+1=1**; we call this the logic addition
  2. **1+1=0**; we call this the logic exclusion

| A | O | F |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

$$\begin{aligned} F &\stackrel{?}{=} A + O \\ 0+0 &= 0 \\ 0+1 &= 1 \\ 1+0 &= 1 \\ 1+1 &= 1 \end{aligned}$$

Digital system  
design

Prof. Dr. Theo  
Kluter

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Logic = Algebra

Boolean Algebra

Gates

# Digital Logic = Algebra

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Logic = Algebra

Boolean Algebra

Gates

$$Y = A + B$$

Logic addition

| A | B | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

| A | B | Y |
|---|---|---|
| 0 | 0 | 0 |
| - | 1 | 1 |
| 1 | - | 1 |

$$Y = A \oplus B$$

Logic exclusion

| A | B | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

$$Y = A \cdot B$$

Logic multiplication

| A | B | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

| A | B | Y |
|---|---|---|
| 0 | - | 0 |
| - | 0 | 0 |
| 1 | 1 | 1 |

$$Y = \bar{A}$$

Logic complement

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

# Boolean Algebra



## George Boole (1815–1864)

- ▶ Formulated in 1847 the *Mathematical Analysis of Logic*
- ▶ Based on mathematics restricted to two quantities, 0 and 1
- ▶ Known as Boolean Algebra

## Claude Elwood Shannon (1916–2001)

- ▶ Published in 1937 *A Symbolic Analysis of Relay and Switching Circuits*
- ▶ Proofs that Boolean Algebra could be used for digital circuit simplification
- ▶ Basis for all circuit design and simplification tools/practices

Digital vs Analog

Digital Logic

Operators

Truth Table

Logic  $\stackrel{?}{=}$  Algebra

Logic = Algebra

Boolean Algebra

Gates

NOT

AND

OR

XOR

Schematic Equivalent and Gates:



The **ANSI** symbols are mainly used in the USA and ASIA, whilst the **IEC** ones are mainly seen in Europe

# Lecture 2

## Digital system design

Boolean algebra and optimizing logic functions

*CS173 - Conception de systèmes numériques*  
*November 2016*

Digital system  
design

Prof. Dr. Theo  
Kluter

Properties  
Exercise 1  
Exercise 2

Theorems

Optimization  
Karnaugh diagram  
3-variables  
Valid groups  
4-variables  
incomplete

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Properties of Boolean Algebra

- We have seen that digital logic forms an algebra; the boolean algebra
- As each algebra, the boolean algebra has properties, we will review them quickly and without proof
- Elementary properties:
  1.  $A \cdot A = A$
  2.  $A + A = A$
  3.  $A \oplus A = 0$
- Absorbtion properties:
  1.  $A \cdot (A + B) = A$
  2.  $A + (A \cdot B) = A$
- Constant properties:
  1.  $A \cdot 0 = 0$
  2.  $A \cdot 1 = A$
  3.  $A + 0 = A$
  4.  $A + 1 = 1$
  5.  $A \oplus 0 = A$
  6.  $A \oplus 1 = \bar{A}$

Digital system  
design

Prof. Dr. Theo  
Kluter

Properties

Exercise 1  
Exercise 2

Theorems

Optimization

- Karnaugh diagram
- 3-variables
- Valid groups
- 4-variables
- incomplete

# Properties of Boolean Algebra

## ► Complement properties:

1.  $A \cdot \bar{A} = 0$
2.  $A + \bar{A} = 1$
3.  $A \oplus \bar{A} = 1$
4.  $\bar{\bar{A}} = A$

## ► Commutative properties:

1.  $A \cdot B = B \cdot A$
2.  $A + B = B + A$
3.  $A \oplus B = B \oplus A$

## ► Distributive properties:

1.  $A \cdot (B + C) = (A \cdot B) + (A \cdot C)$
2.  $A + (B \cdot C) = (A + B) \cdot (A + C)$
3.  $A \cdot (B \oplus C) = (A \cdot B) \oplus (A \cdot C)$

## ► Associative properties:

- $A \cdot (B \cdot C) = (A \cdot B) \cdot C$
- $A + (B + C) = (A + B) + C$
- $A \oplus (B \oplus C) = (A \oplus B) \oplus C$

Digital system  
design

Prof. Dr. Theo  
Kluter

Properties

Exercise 1  
Exercise 2

Theorems

Optimization

- Karnaugh diagram
- 3-variables
- Valid groups
- 4-variables
- incomplete

## Properties

Exercise 1

Exercise 2

## Theorems

## Optimization

- Karnaugh diagram
- 3-variables
- Valid groups
- 4-variables
- incomplete

## Exercise

Show that  $A \oplus 1 = \bar{A}$ , using:

- A truthtable.
- Boolean algebra.

## Solution:

We know that the XOR is defined by:  $Y = A \oplus B$

### a) Truthtable

| B | A | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 1 | 0 |

$B=1$  →  $\boxed{\begin{array}{ccc} 1 & 0 & 1 \\ 1 & 1 & 0 \end{array}} \Rightarrow Y=\bar{A}$

### b) Boolean algebra

- $Y = A \oplus B$ .
- We rewrite the function in it's equivalent form.
- $A \oplus B = \bar{A} \cdot B + A \cdot \bar{B}$ .
- We take  $B = 1$ .
- $A \oplus 1 = \bar{A} \cdot 1 + A \cdot 0$ .
- $A \oplus 1 = \bar{A} + 0$ .
- $A \oplus 1 = \bar{A}$ .

- The truthtable for the XOR.
- We take  $B = 1$ .
- We see directly that  $A \oplus 1 = \bar{A}$ .

## Exercise

Show that  $\mathbf{A} \oplus (\mathbf{B} \cdot \mathbf{C}) \neq (\mathbf{A} \oplus \mathbf{B}) \cdot (\mathbf{A} \oplus \mathbf{C})$  using Boolean algebra:

### Solution:

1. We start with the left function:  $\mathbf{A} \oplus (\mathbf{B} \cdot \mathbf{C})$ .
2. Using the definition:  $\mathbf{D} \oplus \mathbf{E} = \mathbf{D} \cdot \overline{\mathbf{E}} + \overline{\mathbf{D}} \cdot \mathbf{E}$ .
3. Hence:  $\mathbf{A} \oplus (\mathbf{B} \cdot \mathbf{C}) = \mathbf{A} \cdot \overline{\mathbf{B} \cdot \mathbf{C}} + \overline{\mathbf{A}} \cdot \mathbf{B} \cdot \mathbf{C}$ .

1. Now we take the right function:  $(\mathbf{A} \oplus \mathbf{B}) \cdot (\mathbf{A} \oplus \mathbf{C})$ .
2. Using the definition:  $\mathbf{D} \oplus \mathbf{E} = \mathbf{D} \cdot \overline{\mathbf{E}} + \overline{\mathbf{D}} \cdot \mathbf{E}$ .
3. Gives us:  $(\overline{\mathbf{A}} \cdot \mathbf{B} + \mathbf{A} \cdot \overline{\mathbf{B}}) \cdot (\overline{\mathbf{A}} \cdot \mathbf{C} + \mathbf{A} \cdot \overline{\mathbf{C}})$
4. Multiplying it out gives:  $\overline{\mathbf{A}} \cdot \mathbf{B} \cdot \mathbf{C} + 0 \cdot \mathbf{B} \cdot \overline{\mathbf{C}} + 0 \cdot \overline{\mathbf{B}} \cdot \mathbf{C} + \mathbf{A} \cdot \overline{\mathbf{B}} \cdot \overline{\mathbf{C}}$ .
5. Hence:  $(\mathbf{A} \oplus \mathbf{B}) \cdot (\mathbf{A} \oplus \mathbf{C}) = \mathbf{A} \cdot \overline{\mathbf{B}} \cdot \overline{\mathbf{C}} + \overline{\mathbf{A}} \cdot \mathbf{B} \cdot \mathbf{C}$

And:  $\mathbf{A} \cdot \overline{\mathbf{B} \cdot \mathbf{C}} + \overline{\mathbf{A}} \cdot \mathbf{B} \cdot \mathbf{C} \neq \mathbf{A} \cdot \overline{\mathbf{B}} \cdot \overline{\mathbf{C}} + \overline{\mathbf{A}} \cdot \mathbf{B} \cdot \mathbf{C}$

(Hint: make a truthtable).

# Theorems of Boolean Algebra



The theorems of *August de Morgan* (1806-1871):

$$\overline{A \cdot B} = \overline{A} + \overline{B}$$



$$\overline{A + B} = \overline{A} \cdot \overline{B}$$



- De Morgen postulated two theorems.
- We can draw the gate-equivalent.
- The NOT gates can be merged.
- And the same for the second theorem.

# Theorems of De Morgan (cont.)



The theorems of *August de Morgan* (1806-1871):

$$\overline{A \cdot B} = \overline{A} + \overline{B}$$



$$\overline{A + B} = \overline{A} \cdot \overline{B}$$



- The theorems of De Morgan are very important as they show:
- Any logic expression can be formulated with **only OR** and **NOT**
- Any logic expression can be formulated with **only AND** and **NOT**

# Theorems of De Morgan (Example)

| A | B | C | Y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

$$Y = A + B + C$$

- ▶ Enumerating all terms for which  $Y= 1$  (**minterms**) leads to a sum of 7 products!
- ▶ Better: Enumerate all terms for which  $Y= 0$  (**maxterms**) and use De Morgan

# Theorems of De Morgan (Example 2)

| A | B | C | Y | Y =                                                                                                                                |
|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------------|
| 0 | 0 | 0 | 0 | $\bar{A} \cdot B \cdot \bar{C} + A \cdot \bar{B} \cdot \bar{C} + A \cdot B \cdot C$                                                |
| 0 | 0 | 1 | 0 | $\overline{(\bar{A} \cdot B \cdot \bar{C})} \cdot \overline{(A \cdot \bar{B} \cdot \bar{C})} \cdot \overline{(A \cdot B \cdot C)}$ |
| 0 | 1 | 0 | 1 |                                                                                                                                    |
| 0 | 1 | 1 | 0 |                                                                                                                                    |
| 1 | 0 | 0 | 0 | $(A + \bar{B} + C) \cdot (\bar{A} + B + C) \cdot (\bar{A} + \bar{B} + \bar{C})$                                                    |
| 1 | 0 | 1 | 0 | $\overline{(A + \bar{B} + C)} + \overline{(\bar{A} + B + C)} +$                                                                    |
| 1 | 1 | 0 | 1 |                                                                                                                                    |
| 1 | 1 | 1 | 1 | $\overline{(\bar{A} + \bar{B} + \bar{C})}$                                                                                         |

- ▶ A logic equation can be formulated in the *disjunct* form; this form is also called *sum of products*
- ▶ A logic equation can be formulated in the *conjunct* form; this form is also called *product of sums*

# Theorems of De Morgan (Example 2 gate)

$Y =$

$$\bar{A} \cdot B \cdot \bar{C} + A \cdot B \cdot \bar{C} + A \cdot B \cdot C$$



$$\overline{(\bar{A} \cdot B \cdot \bar{C})} \cdot \overline{(A \cdot B \cdot \bar{C})} \cdot \overline{(A \cdot B \cdot C)}$$



$$(A + \bar{B} + C) \cdot (\bar{A} + \bar{B} + C) \cdot (\bar{A} + \bar{B} + \bar{C})$$



$$(A + \bar{B} + C) + (\bar{A} + \bar{B} + C) + (\bar{A} + \bar{B} + \bar{C})$$



# Optimizing Logic Functions

| A | B | Y |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 1 |
| 1 | 0 | 0 |
| 1 | 1 | 0 |

$$Y = \bar{A} \cdot \bar{B} + \bar{A} \cdot B$$



- The *disjunct* form does not always provide the smallest equation
- For this simple example, it can be seen in the truth table, but what about equations with five inputs?
- We can use the graphic optimizing method of Karnaugh, the **Karnaugh diagram**
- By selecting all groups of  $2^m$  1's we can eliminate variables:  
$$Y = \bar{A}$$

# The Karnaugh diagram



And we can continue for 4+ variables



# Optimizing Logic Functions with three Variables

Properties

Exercise 1

Exercise 2

Theorems

Optimization

Karnaugh diagram

3-variables

Valid groups

4-variables

incomplete

$$Y = C + \bar{A} \cdot B$$

| A | B | C | Y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |



- We start selecting the biggest *group* of 1's (**minterms**)
- We continue until all **minterms** are selected

[Properties](#)
[Exercise 1](#)
[Exercise 2](#)
[Theorems](#)
[Optimization](#)
[Karnaugh diagram](#)
[3-variables](#)
[Valid groups](#)
[4-variables](#)
[incomplete](#)


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

- We can put **C** outside of the brackets; the variable **C** is important for this group!
- We can also put **A** and  **$\bar{A}$**  outside brackets. As easily can be seen: there are exactly  $2^{m-1}$  minterms in the area where **A=1** and the other  $2^{m-1}$  minterms are in the area where **A=0**
- Finally we play with  $(\bar{B} + B)$ .
- Both **A** and **B** are *don't care* for this group as  $(\bar{A} + A) = 1$  and  $(\bar{B} + B) = 1$ !

## Valid Karnaugh groups

Hence we have a valid group when:

1. The group has exactly  $2^m$  minterms or  $2^m$  maxterms.
2. The group has exactly  $m$ -variables *don't care*.

A variable **E** is *don't care* when:

1. There are exactly  $2^{m-1}$  minterms/maxterms from the group in the region where **E=1**.
2. There are exactly  $2^{m-1}$  minterms/maxterms from the group in the region where **E=0** ( $\bar{E}$ -region).

A variable **F** influences the function when either:

1. All  $2^m$  minterms/maxterms from the group are in the region where **F=1**.
2. All  $2^m$  minterms/maxterms from the group are in the region where **F=0** ( $\bar{F}$ -region).

All  $m$ -variables have to be checked for the above rules.

Any violation of the above rules renders the group invalid!

# Valid Karnaugh groups

## Homework

Given the group in the Karnaugh diagram below.



Is this a valid group?

# Optimizing Logic Functions with four Variables

$$Y = \overline{A} \cdot B + \overline{B} \cdot \overline{D}$$



- ▶ We start again with the biggest groups of **minterms**
- ▶ This group is redundant, as it is included in the other two!
- ▶ We are done

$$Y = A \cdot B + \overline{B} \cdot \overline{D}$$



- ▶ We can also start with the biggest groups of **maxterms**
- ▶ This group is redundant, as it is included in the other two!
- ▶ We are done

## Homework:

Show with boolean algebra that both functions are identical;  
what can you observe?

Digital system design

Prof. Dr. Theo Kluter

Properties

Exercise 1  
Exercise 2

Theorems

Optimization

- Karnaugh diagram
- 3-variables
- Valid groups
- 4-variables
- incomplete

# Incomplete Defined Functions

$$Y = \overline{A} + \overline{B} \cdot \overline{D}$$



- ▶ We start again with the biggest *groups* of **minterms**
- ▶ When assuming a **1** for the **don't care** we can find a group of 8!
- ▶ We continue until all **1**'s are covered
- ▶ We are done

- ▶ In mathematics logic functions are always completely defined: for each of the input combinations the function is always either **1** or **0**
- ▶ In practice a logic function can have input combinations where we as designer do not mind the outcome: the function is incomplete defined and shows one or multiple **don't cares**

Digital system design

Prof. Dr. Theo Kluter

Properties

Exercise 1

Exercise 2

Theorems

Optimization

Karnaugh diagram

3-variables

Valid groups

4-variables

incomplete

# Lecture 3

## Digital system design

Memory

*CS173 - Conception de systèmes numériques*  
*October 2015*

Digital system  
design

Prof. Dr. Theo  
Kluter

Sequential  
SR-Latch

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Elevator Intro



- ▶ Schematic of the elevator system with it's initial situation.
- ▶ Complete Voltage behavior over time for the given scenario.
- ▶ We transformed the scenario to a sequence of logic quantities.

# Elevator Logic Function



- What is the corresponding logic function and circuit?
- This circuit is called a *Set-Reset Latch (SR-Latch)*.
- This logic function has memory! It is called a *Sequential Logic Function*.
- All logic functions without memory are called *Combinational Logic Functions*

# Set-Reset Latch

Let's play with De Morgan:

$$\text{Lamp} = \overline{\overline{S} \cdot \overline{R} \cdot \text{Lamp}}$$



| R | S | Lamp |
|---|---|------|
| 0 | 0 | Lamp |
| - | 1 | 1    |
| 1 | 0 | 0    |



$$\text{Lamp} = S + \overline{R} \cdot \text{Lamp}$$

- The truthtable only contains two entries where the 'old' value of the output has an influence.
- We can use an alternate notation to shorten the truthtable. The entry **Lamp** denotes that the circuit *remembers* its previous value.

# Set-Reset Latch

Let's look into the details:



| R | S | Lamp | Y    |
|---|---|------|------|
| 0 | 0 | Y    | Lamp |
| 0 | 1 | 1    | 0    |
| 1 | 0 | 0    | 1    |
| 1 | 1 | 1    | 1    |

It is the inverse of Lamp , except for the situation where:  
 $R = 1$  and  $S = 1$

- When  $R=1$  and  $S=1$  then  $\text{Lamp}=1$  and  $Y=1$  !
- This situation is often referred to as *forbidden*.

# Set-Reset Latch

Set-Reset Latch with Set priority:

| R | S | Lamp |
|---|---|------|
| 0 | 0 | Lamp |
| - | 1 | 1    |
| 1 | 0 | 0    |

$$\text{Lamp} = S + \overline{R} \cdot \text{Lamp}$$



Set-Reset Latch with Reset priority:

| R | S | Lamp |
|---|---|------|
| 0 | 0 | Lamp |
| 0 | 1 | 1    |
| 1 | - | 0    |

$$\overline{\text{Lamp}} = R + \overline{S} \cdot \overline{\text{Lamp}}$$



- The latch we saw thus far is a Set-Reset Latch with a Set Priority. This means that if both **S** and **R** are **1** the Set wins.
- There exists also a Set-Reset Latch with a Reset Priority.

# Lecture 4

## Digital system design

### Flipflops and Latches

*CS173 - Conception de systèmes numériques*  
*October 2015*

Digital system  
design

Prof. Dr. Theo  
Kluter

Sequential  
D-Latch  
Edges  
DFF  
Clocks

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# D-Latch



- The circuit retains the last value seen on the input **D** at the moment the input **E** changed from **1** to **0**.
- The D-Latch has its own electric symbol as shown above.
- In the transparent mode (**E=1**) the output follows the input **D** ; hence here the behavior of the output can be written as **Q=D**. Therefore, we can symplify the truthtable.

# Levels and Edges



= positive edge (change from logic 0 → logic 1)



= negative edge (change from logic 1 → logic 0)

- We have seen that a logic function can have a logic **level 0**.
- Or a logic **level 1**.
- In time the function can change from a logic **level 0** to a logic **level 1**, we call this a *positive edge*.
- In time the function can also change from a logic **level 1** to a logic **level 0**, we call this a *negative edge*.
- Hence a logic function has **edges**,
- and **levels** in time.

# D-FlipFlop

## Sequential

D-Latch

Edges

DFF

Clocks



What happens if we use 2 Latches and 2 Inverters like in the circuit above?

# What is a clock?



- ▶ What is a clock?
- ▶ A clock is a period  $T_1$  at a logic level 1.
- ▶ a period  $T_0$  at a logic level 0
- ▶ and repeats this pattern each  $T_p = T_1 + T_0$
- ▶ The frequency of this signal is  $f_{\text{clock}} = \frac{1}{T_p}$ ,
- ▶ And the duty-cycle is defined as  $\frac{T_1}{T_p} \%$ .
- ▶ At a duty-cycle of 50% we have  $T_1 = T_0$

Sequential

D-Latch

Edges

DFF

Clocks

# Lecture 5

## Digital system design

Representations

*CS173 - Conception de systèmes numériques*  
*August 2014*

Digital system  
design

Prof. Dr. Theo  
Kluter

Representations  
 $\mathbb{N}$   
Arithmetic

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Representations

- ▶ We have seen that a circuit can have multiple ( $n$ ) inputs, e.g. **A**, **B**, **C**, ...
- ▶ We have also seen that a circuit can have multiple ( $m$ ) outputs, e.g. **X**, **Y**, **Z**, ... ; or formulated differently, the circuit contains  $m$  logic functions
- ▶ Finally we have seen how to derive the smallest representation of those  $m$  logic functions
- ▶ The question is now: How do we interpret as designer those inputs and outputs?
- ▶ Each of the  $n$  inputs and  $m$  outputs represent a quantity that can be either **1** or **0**; we call this a **Bit**
- ▶ Multiple **Bits** can be grouped together to form one dimensional arrays; the well known groups are:
  - ▶ The **Nibble** as a group of 4 **Bits**, e.g. **1011**
  - ▶ The **Byte** as a group of 8 **Bits** (2 **Nibbles**), e.g. **10110011**

# Ordering

- ▶ The groups are nice, but how do we form a **Nibble** from the inputs **A**, **B**, **C**, and **D**?
  1. **ABCD**?
  2. **BCDA**?
  3. **CBDA**?
  4. ...
- ▶ We need to define an order to be able to uniquely identify the inputs and outputs
- ▶ Let us define  $I_i \quad \forall i \in [0..(n - 1)]$  as the set of ordered inputs of a circuit, e.g. for  $n=8$  the **Byte** formed by the inputs is:  
 $I_7 I_6 I_5 I_4 I_3 I_2 I_1 I_0$
- ▶ Let us define  $O_j \quad \forall j \in [0..(m - 1)]$  as the set of ordered outputs of a circuit, e.g. for  $m=4$  the **Nibble** formed by the outputs is:  
 $O_3 O_2 O_1 O_0$
- ▶ The **Bits**  $I_0$  and  $O_0$  are called the **Least Significant Bits**
- ▶ The **Bits**  $I_{n-1}$  and  $O_{m-1}$  are called the **Most Significant Bits**
- ▶ We always write : **MSB**...**LSB**

# Interpretation



- Here we have a house with 5 light switches (inputs) and 3 lamps (outputs). The interpretation of the inputs and outputs is in this case the switching of the light sources. This functions can be as complex as we want.
- There are various interpretations of the inputs and outputs of a digital system, numbers are one of them

# Natural Numbers ( $\mathbb{N}$ )

- ▶ For the remainder of the discussion of the number systems we will use the interpretation of the set of ordered inputs  $I_i$ ; the interpretation of the set of ordered outputs  $O_j$  is identical
- ▶ Assuming a byte of ordered inputs, than we could interpret the bit patterns as:

| $I_7 I_6 I_5 I_4 I_3 I_2 I_1 I_0$ | Decimal |
|-----------------------------------|---------|
| $00000000_b$                      | 0       |
| $00000001_b$                      | 1       |
| $00000010_b$                      | 2       |
| $00000100_b$                      | 3       |
| $00001000_b$                      | 4       |
| $00010000_b$                      | 5       |
| $00100000_b$                      | 6       |
| $01000000_b$                      | 7       |
| $10000000_b$                      | 8       |

This is the so called **one-hot** encoding

- ▶ However these encodings are not very efficient!

Digital system  
design

Prof. Dr. Theo  
Kluter

Representations

$\mathbb{N}$   
Arithmetic

# Natural Numbers ( $\mathbb{N}$ ) in place-value notation

More compact and elegant are the positional systems like the decimal system we are used to:

$$\begin{array}{c} 3 \cdot 10^2 + 2 \cdot 10^1 + 1 \cdot 10^0 \\ \downarrow \quad \downarrow \quad \downarrow \\ 3 \quad 2 \quad 1 \\ \downarrow \quad \downarrow \quad \downarrow \\ 300 + 20 + 1 \end{array}$$

Digital system design

Prof. Dr. Theo Kluter

Representations

$\mathbb{N}$   
Arithmetic

- ▶ Each number consists of  $i$  digits
- ▶ The position of the digit denotes its “importance”
- ▶ A digit  $d_p \in [0..(B - 1)]$  at position  $p \in [0..(i - 1)]$  given the base  $B$  has the “importance”  $B^p$
- ▶ The number  $N \in \mathbb{N}$  is thereby defined by:  $N = \sum_{p=0}^{i-1} d_p \cdot B^p$

## Other place-valued numbers:

- ▶ The binary number system:

$$I_{11} I_{10} I_9 I_8 I_7 I_6 I_5 I_4 I_3 I_2 I_1 I_0 \equiv 101001101001_b$$

The base  $B = 2$ , and the digit range is  $d_p \in [0, 1]$

$$101001101001_b = 2^{11} + 2^9 + 2^6 + 2^5 + 2^3 + 2^0 = 2665$$

- ▶ The octal number system:

$$I_{11} I_{10} I_9 I_8 I_7 I_6 I_5 I_4 I_3 I_2 I_1 I_0 \equiv 101\ 001\ 101\ 001_b \equiv 5151_o$$

The base  $B = 8$ , and the digit range is  $d_p \in [0..7]$

$$5151_o = 5 \cdot 8^3 + 1 \cdot 8^2 + 5 \cdot 8^1 + 1 \cdot 8^0 = 2665$$

- ▶ The hexadecimal number system:

$$I_{11} I_{10} I_9 I_8 I_7 I_6 I_5 I_4 I_3 I_2 I_1 I_0 \equiv 1010\ 0110\ 1001_b \equiv 0xA69$$

The base  $B = 16$ , and the digit range is

$$d_p \in [0..9, A, B, C, D, E, F]$$

$$0xA69 = 10 \cdot 16^2 + 6 \cdot 16^1 + 9 \cdot 16^0 = 2665$$

# Natural Numbers ( $\mathbb{N}$ ) in place-value notation

How to transform  $3645_{\text{dec}}$  to a place-value number with base  $B = 7$ ?

The image shows four division steps:

- Step 1:  $7 \overline{)10} \quad 1$  (The '1' is circled in red.)  
$$\begin{array}{r} 7 \\ \overline{)10} \\ -7 \\ \hline 3 \end{array}$$
- Step 2:  $7 \overline{)74} \quad 10$   
$$\begin{array}{r} 7 \\ \overline{)74} \\ -7 \\ \hline 04 \end{array}$$
- Step 3:  $7 \overline{)520} \quad 74$   
$$\begin{array}{r} 7 \\ \overline{)520} \\ -49 \\ \hline 30 \end{array}$$
- Step 4:  $7 \overline{)3645} \quad 520$   
$$\begin{array}{r} 7 \\ \overline{)3645} \\ -35 \\ \hline 14 \end{array}$$

A red arrow points from the circled '1' in the first step to the final result below:

$$3645_{\text{dec}} = 13425_{B=7}$$

- We start the division
- The rest is the digit at position 0, e.g.  $3645 = 520 \cdot 7^1 + 5 \cdot 7^0$
- As  $520 \notin [0..6]$  we have to continue the division
- Now  $1 \in [0..6]$  we are done. Let's check:

$$3645 = 2401 + 1029 + 196 + 14 + 5$$

# The Addition

How do we add two place-valued numbers?

Carries:  
0 1 0  
1 2 3  
5 9 2 +  
—————  
7 1 5

- ▶ Assume we want to determine  $N = 123 + 592$
- ▶ We start adding the digits at position  $p = 0$ , e.g.  
 $S_0 = d_0^1 + d_0^2 = 3 + 2 = 5$ , the resulting digit  
 $d_0^r = \begin{cases} S_0 & S_0 < B \\ S_0 - B & S_0 \geq B \end{cases}$ , and the carry  $c_1 = \begin{cases} 0 & S_0 < B \\ 1 & S_0 \geq B \end{cases}$
- ▶ We continue to position  $p = 1$ ; at all positions  $p \geq 0$  the sum equals to  $S_p = d_p^1 + d_p^2 + c_p$ , **note:  $c_0 = 0$ !**
- ▶ What happens if carry  $c_3 = 1$  (for example if  $N = 110_b + 010_b$ )?

# The Addition; Limitations of Digital Systems

Assume following binary adder:



- ▶ We have a circuit that adds the numbers  $a$  and  $b$
- ▶ In case  $a = 110_b$  and  $b = 010_b$  something strange happens, as  $N = 110_b + 010_b \neq 000_b$ !
- ▶ We call this an **overflow** situation
- ▶ An **overflow** can occur as any digital system has only a limited number of  $k$ -bits ( $k = 3$  for this example)
- ▶ Given this limitation of  $k$ -bits, a digital system has a range in which it can represent numbers, e.g. for  $N \in \mathbb{N}$  and  $k = 3$  the representation range is  $N \in [0..(2^k - 1)] \equiv N \in [0..7]$

# The Subtraction

Similar to the addition we can also subtract two place-valued numbers:

Borrows:  
0 1 0  
7 1 5  
5 9 2 -  
1 2 3

- ▶ Assume we want to determine  $N = 715 - 592$
- ▶ We start at position  $p = 0$ , e.g.  $S_0 = d_0^1 - d_0^2 = 5 - 2 = 3$ , the resulting digit  $d_0^r = \begin{cases} d_0^1 - d_0^2 & d_0^1 \geq d_0^2 \\ (B + d_0^1) - d_0^2 & d_0^1 < d_0^2 \end{cases}$ , and the borrow

$$b_1 = \begin{cases} 0 & d_0^1 \geq d_0^2 \\ 1 & d_0^1 < d_0^2 \end{cases}$$

- ▶ We continue to position  $p = 1$ ; at all positions  $p \geq 0$  the subtraction equals to

$$S_p = \begin{cases} d_p^1 - d_p^2 - b_p & d_p^1 \geq d_p^2 + b_p \\ (B + d_p^1) - d_p^2 - b_p & d_p^1 < d_p^2 + b_p \end{cases}$$

Note:  $b_0 = 0!$

# The Subtraction; No Negative Numbers

Assume following binary subtractor:



- ▶ We have a circuit that subtract the numbers  $a$  and  $b$
- ▶ In case  $a = 010_b$  and  $b = 011_b$  something strange happens, as  $N = 010_b - 011_b \neq 111_b$ !
- ▶ We call this an **underflow** situation

# Lecture 6

## Digital system design

Representations

*CS173 - Conception de systèmes numériques*  
*August 2014*

Digital system  
design

Prof. Dr. Theo  
Kluter

Representations  
 $\mathbb{Z}$   
 $A \times B$  and  $\frac{A}{B}$   
 $\mathbb{R}$

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Integers ( $\mathbb{Z}$ ) sign-and-magnitude representation

- ▶ The set of integers  $\mathbb{Z}$  contains the Natural Numbers  $\mathbb{N} \subset \mathbb{Z}$  and their negatives  $(-0, -1, -2, -3, -4, \dots)$
- ▶ In the decimal system we use the sign-and-magnitude notation, e.g. **+4** and **-4** where the “**+**” is often omitted
- ▶ Important: the sign-and-magnitude notation has two 0's, namely **+0 AND -0!**
- ▶ In the binary system, we do not have a **+** and **-**, we only have **0** and **1**
- ▶ However, by the introduction of the **MSB** as **sign-bit** we can create a binary form of the sign-and-magnitude representation by interpreting **0=+** and **1=-**:  
 $I_3 I_2 I_1 I_0 \equiv 0 010_b \equiv +2 \equiv 0x2!$   
 $I_3 I_2 I_1 I_0 \equiv 1 010_b \equiv -2 \equiv 0xA!$

# Addition and Subtraction with Integers ( $\mathbb{Z}$ )

- ▶ A decimal subtraction  $Z = A - B$  we normally rewrite to a decimal addition  $Z = A + C$  by forming the negate of the substractor, e.g.  $C = -B$ , this can be easily accomplished by changing the sign in a sign-and-magnitude system. For a binary sign-and-magnitude interpretation this operation would be an inversion of the **sign-bit**.
- ▶ In a sign-and-magnitude representation we can write this addition as:  $s_z|Z| = s_a|A| + s_c|C| \Rightarrow -|-3| = -|-4| + (+|1|)$
- ▶ The addition is “complex”:

| $s_a$ | $s_c$ | Condition:     | $s_z$ | $ Z $       | Examples:        |
|-------|-------|----------------|-------|-------------|------------------|
| +     | +     | none           | +     | $ A  +  C $ | $1 + 2 = 3$      |
| -     | -     | none           | -     | $ A  +  C $ | $-1 + (-2) = -3$ |
| +     | -     | $ A  \geq  C $ | +     | $ A  -  C $ | $2 + (-1) = 1$   |
|       |       | $ A  <  C $    | -     | $ C  -  A $ | $1 + (-2) = -1$  |
| -     | +     | $ A  \geq  C $ | -     | $ A  -  C $ | $-2 + 1 = -1$    |
|       |       | $ A  <  C $    | +     | $ C  -  A $ | $-1 + 2 = 1$     |

# Integers ( $\mathbb{Z}$ ) one's-complement representation

Addition and subtraction in the sign-and-magnitude representation requires an adder and a subtractor, can't we find another representation that requires less "complexity"?

- ▶ What if instead of inverting only the sign bit to represent a negative number, we invert (one's-complement) all bits:

| Dec.: | Inputs:           | sign-and-magnitude: | 1's-complement: |
|-------|-------------------|---------------------|-----------------|
| +3    | $l_2 \ l_1 \ l_0$ | $0\ 11_b$           | $0\ 11_b$       |
| +2    | $l_2 \ l_1 \ l_0$ | $0\ 10_b$           | $0\ 10_b$       |
| +1    | $l_2 \ l_1 \ l_0$ | $0\ 01_b$           | $0\ 01_b$       |
| +0    | $l_2 \ l_1 \ l_0$ | $0\ 00_b$           | $0\ 00_b$       |
| -0    | $l_2 \ l_1 \ l_0$ | $1\ 00_b$           | $1\ 11_b$       |
| -1    | $l_2 \ l_1 \ l_0$ | $1\ 01_b$           | $1\ 10_b$       |
| -2    | $l_2 \ l_1 \ l_0$ | $1\ 10_b$           | $1\ 01_b$       |
| -3    | $l_2 \ l_1 \ l_0$ | $1\ 11_b$           | $1\ 00_b$       |

- ▶ NOTE: one's-complement representation also has 2 representations for 0!

# Integers ( $\mathbb{Z}$ ) one's-complement representation

Addition and subtracting one's-complement numbers is easier than doing the same in a sign-and-magnitude representation:

- ▶ A subtraction  $Z=A-B$  is again transformed into an addition  $Z=A+C$  by forming the one's-complement  $C=-B$  (by inverting [complementing] all the bits of  $B$ ).
- ▶ The addition  $Z=A+C$  can now be performed by a binary addition as for  $N \in \mathbb{N}$ , with the difference that carry  $c_k$  has to be added at the **LSB** position; this is the so called **end-around carry** addition:

$$\begin{array}{r} & \begin{array}{r} 1 & 0 & 0 \\ 1 & 1 & 0_b \\ 1 & 0 & 1_{b+} \\ \hline 0 & 1 & 1_b \\ \downarrow & 1_{b+} \\ \hline 1 & 0 & 0_b \end{array} & \text{One's-complement:} \\ \begin{array}{r} -1 \\ -2 \\ + \\ \hline \end{array} & \begin{array}{l} \xrightarrow{\quad} \\ \xrightarrow{\quad} \end{array} & \begin{array}{ll} 0 & 1 & 1_b + 3 & 1 & 0 & 0_b - 3 \\ 0 & 1 & 0_b + 2 & 1 & 0 & 1_b - 2 \\ 0 & 0 & 1_b + 1 & 1 & 1 & 0_b - 1 \\ 0 & 0 & 0_b + 0 & 1 & 1 & 1_b - 0 \end{array} \end{array}$$

Digital system  
design

Prof. Dr. Theo  
Kluter

Representations

$\mathbb{Z}$   
 $A \times B$  and  $\frac{A}{B}$   
 $\mathbb{R}$

# Integers ( $\mathbb{Z}$ ) one's-complement representation

$$\begin{array}{r} -1 \\ -2 + \\ \hline \cancel{\times} \\ \downarrow \\ -3 \end{array} \quad \begin{array}{c} 1 \ 0 \ 0 \\ 1 \ 1 \ 0_b \\ 1 \ 0 \ 1_{b+} \\ \hline 0 \ 1 \ 1_b \\ \rightarrow 1_{b+} \\ \hline 1 \ 0 \ 0_b \end{array} \quad \begin{array}{ll} \text{One's-complement:} & \\ 0 \ 1 \ 1_b + 3 & 1 \ 0 \ 0_b - 3 \\ 0 \ 1 \ 0_b + 2 & 1 \ 0 \ 1_b - 2 \\ 0 \ 0 \ 1_b + 1 & 1 \ 1 \ 0_b - 1 \\ 0 \ 0 \ 0_b + 0 & 1 \ 1 \ 1_b - 0 \end{array}$$

- One's-complement is great, as for both the addition and subtraction of integers we **only** require inverters and an end-around carry adder
- However, an end-around carry adder is slow!
- Observation: The end carry  $c_n$  is only **1** when one of the variables **A** or **C** in  $\mathbf{Z}=\mathbf{A}+\mathbf{C}$  is negative!
- Why not add **1** to all negative numbers?

# Integers ( $\mathbb{Z}$ ) two's-complement representation



- ▶ The positive numbers in two's-complement notation have same bit encodings as the other presented number interpretation systems
- ▶ The **+0** and **-0** map on the same bit pattern in the two's-complement notation resulting in a single **0**!
- ▶ The remaining bit pattern is mapped to **-4**

# Integers ( $\mathbb{Z}$ ) one's versus two's complement



- One's complement is slow due to the end-around carry
- Two's complement is faster, and has only one 0!

# Integers ( $\mathbb{Z}$ ) Excess-N representation

- ▶ The two's complement representation is commonly used to represent integers in for example Processors, Digital Signal Processors, and others
- ▶ However, there exists another important representation: the *Excess-N* representation, also called the **biased representation**
- ▶ The *Excess-N* representation uses a pre-specified number  $N$  as biasing value.
- ▶ The decimal number  $-N$  is represented by all **0**'s
- ▶ Example: The three bit **Excess-3** representation

|   |   |   |              |   |   |   |   |              |    |
|---|---|---|--------------|---|---|---|---|--------------|----|
| 1 | 1 | 1 | <sub>b</sub> | 4 | 0 | 1 | 1 | <sub>b</sub> | 0  |
| 1 | 1 | 0 | <sub>b</sub> | 3 | 0 | 1 | 0 | <sub>b</sub> | -1 |
| 1 | 0 | 1 | <sub>b</sub> | 2 | 0 | 0 | 1 | <sub>b</sub> | -2 |
| 1 | 0 | 0 | <sub>b</sub> | 1 | 0 | 0 | 0 | <sub>b</sub> | -3 |

- ▶ The *Excess-N* representation is mainly used in Analog to Digital converters and the IEEE floating-point standard
- ▶ Performing calculations in the *Excess-N* representation is only in a few cases simple and out of the scope of this course!

# Integers ( $\mathbb{Z}$ ) Overflow and Underflow

- ▶ Did we solve the **overflow** and **underflow** problem?
- ▶ No, as we still have **only  $k$ -bits** to represent numbers!
- ▶ We just changed the ranges:

| Representation:       | Number:            | Decimal range:                           |
|-----------------------|--------------------|------------------------------------------|
| <b>Binary</b>         | $x \in \mathbb{N}$ | $0 \leq x \leq 2^k - 1$                  |
| <b>Sign-and-Magn.</b> | $x \in \mathbb{Z}$ | $-(2^{k-1} - 1) \leq x \leq 2^{k-1} - 1$ |
| <b>One's-compl.</b>   | $x \in \mathbb{Z}$ | $-(2^{k-1} - 1) \leq x \leq 2^{k-1} - 1$ |
| <b>Two's-compl.</b>   | $x \in \mathbb{Z}$ | $-(2^{k-1}) \leq x \leq 2^{k-1} - 1$     |
| <b>Excess-N</b>       | $x \in \mathbb{Z}$ | $-N \leq x \leq 2^k - (N + 1)$           |



- ▶ NOTE: The two's complement and excess-N representations have an asymmetric range and do not have a  $+0$  and  $-0$ ; they have a single 0!
- ▶ In case the decimal calculation results in a value  $x$  outside the given ranges we phase an **overflow** or **underflow** problem!
- ▶ The detection of overflow and underflow is outside the scope of this course!

# Summary ( $\mathbb{N}$ and $\mathbb{Z}$ )

- ▶ All number representations are noted as a series of bits from **MSB...LSB**:  $10110010_b$
- ▶ For a number representation of  $k$ -bits we can represent the decimal equivalents like:

| Representation:       | Number:            | Decimal range:                           |
|-----------------------|--------------------|------------------------------------------|
| <b>Binary</b>         | $x \in \mathbb{N}$ | $0 \leq x \leq 2^k - 1$                  |
| <b>Sign-and-Magn.</b> | $x \in \mathbb{Z}$ | $-(2^{k-1} - 1) \leq x \leq 2^{k-1} - 1$ |
| <b>One's-compl.</b>   | $x \in \mathbb{Z}$ | $-(2^{k-1} - 1) \leq x \leq 2^{k-1} - 1$ |
| <b>Two's-compl.</b>   | $x \in \mathbb{Z}$ | $-(2^{k-1}) \leq x \leq 2^{k-1} - 1$     |
| <b>Excess-N</b>       | $x \in \mathbb{Z}$ | $-N \leq x \leq 2^k - (N + 1)$           |

Representations  
 $\mathbb{Z}$   
 $A \times B$  and  $\frac{A}{B}$   
 $\mathbb{R}$

- ▶ To convert a positive (negative) integer into a negative (positive) one we have to complement the representation as:

| Representation:       | Complement:               |
|-----------------------|---------------------------|
| <b>Sign-and-Magn.</b> | Invert sign bit           |
| <b>One's-compl.</b>   | Invert all bits           |
| <b>Two's-compl.</b>   | Invert all bits and add 1 |
| <b>Excess-N</b>       | lookup in table           |

# Multiplication

**Remember:**  
The classic decimal pen  
and paper multiplication:

$$\begin{array}{r} 24 \\ 18 \times \\ \hline 010 \\ 32 \\ 160 \\ 40 \\ \hline 200 + \\ \hline 432 \end{array}$$

Binary multiplication:

$$\begin{array}{r} 0100_b \\ 0011_b \times \\ \hline 0000 \\ 0100_b \\ 0100_b \\ 000000_b \\ 000000_b + \\ \hline 1100_b \end{array}$$

- ▶ Binary multiplication is performed similar, but much simpler!
- ▶ As:  $1_b \times 1_b = 1_b$  and  $1_b \times 0_b = 0_b$  (**Note:** This represent an **AND** gate!)

# Multiplication



$$O = I^a \times I^b$$

# Division

**Remember:**  
The classic decimal pen  
and paper division:

$$\begin{array}{r} 18 \quad / \quad 414 \quad \backslash \quad 23 \\ 18 - \\ \hline 23 \\ 18 - \\ \hline 54 \\ 18 - \\ \hline 36 \\ 18 - \\ \hline 18 \\ 18 - \\ \hline \end{array}$$

Remainder  $\longrightarrow 0$

Binary division:

$$\begin{array}{r} 0111_b \quad / \quad 1110 \quad \backslash \quad 0010_b \\ 0001110_b \\ 0111_b - \\ \hline 1010_b \\ 1100 \quad \cancel{0} \\ 00111_b \\ 0111_b - \\ \hline 1010_b \\ 0000 \quad \cancel{0} \\ 0111_b - \\ \hline 000000_b \end{array}$$

Remainder  $\longrightarrow 000000_b$

- Binary division is performed identical, but simpler!
- As for each resulting digit we **only** have to subtract **once**!

# Division



- ▶ How can we represent the number when **Remainder  $\neq 0$** , e.g.  
 $\frac{3}{2} = 1\frac{1}{2}$

# Fixed Point representation ( $\mathbb{R}$ )

- The set on Real numbers  $\mathbb{R}$  contains all integers  $\mathbb{Z} \subset \mathbb{R}$  and all fractions  $\frac{m}{n}$
- Real numbers are normally noted in the decimal system by placing a decimal point: **321.535**
- We call this notation the **fixed point** representation of a real number.
- Recall: Place-and-value notation

$$\begin{array}{c} 3 \cdot 10^2 + 2 \cdot 10^1 + 1 \cdot 10^0 + 5 \cdot 10^{-1} + 3 \cdot 10^{-2} + 5 \cdot 10^{-3} \\ \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \\ 3 \ 2 \ 1.5 \ 3 \ 5 \\ \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \\ 300 + 20 + 1 + \frac{5}{10} + \frac{3}{100} + \frac{5}{1000} \end{array}$$

- Therefore:  $N = \sum_{p=0}^{i-1} d_p \cdot B^p$  becomes  $R = \sum_{p=-j}^{i-1} d_p \cdot B^p$
- We can do the same for all place-and-value notated numbers of any base  $B$ !

# Floating Point representation ( $\mathbb{R}$ )

- ▶ What about very big and very small numbers?
- ▶ A big number like **845294294967295.85321** we normally write as  $0.84529 \times 10^{15}$  or  $0.84529 \text{ E}15$
- ▶ And small numbers like **0.0000000000000012** we similarly write as  $0.1275245 \times 10^{-15}$  or  $0.1275245 \text{ E} - 15$
- ▶ We call this the **floating point** representation, where a number  $R$  is represented by a **mantissa** and **exponent**. The mantissa is in a fixed-point representation, whilst the exponent is in a place-and-value representation:

$$R = 0.1275245 \times 10^{-15}$$

**mantissa** = 0.1275245 where:  $-1 < \text{mantissa} < 1$

**exponent** = -15 where:  $-\infty < \text{exponent} < \infty$

# Floating Point representation ( $\mathbb{R}$ )

- We can also represent floating point numbers using a set of bits (IEEE 754 standard)
- This is for example used in every computer to represent the types **float**, **double**, etc.
- For a **float** often a single precision floating point representation is used:



# Lecture 7

## Digital system design

Finite State Machines

*CS173 - Conception de systèmes numériques  
November 2016*

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Introduction

Digital system  
design

Prof. Dr. Theo  
Kluter

Finite State  
Machines

Introduction

Sequence

Structure

Medvedev

Moore

Mealy



# Sequence



This sequence repeats itself



# Basic Structure





# Medvedev FSM



# Medvedev FSM



# Moore FSM



# Moore FSM



# Moore FSM



# Mealy FSM



# Mealy FSM



# Lecture 8

## Digital system design

Finite State Machines (2)

*CS173 - Conception de systèmes numériques  
February 2017*

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Howto design an FSM: step 1

## FSM Howto

Step1

Step2

Complete

Consistent

Step3

Ghost states

Transition table

Step4



- We take as example a Medvedev state machine
- First we define the states of the state machine
- Than we define the different transitions and their conditions
- Please note that the conditions are the inputs of the system
- Also note that the clock is not used as condition

# Howto design an FSM: step 2



- To be able to realize this state-diagram we have to make sure that:
- For each of the states that they are:
- **Complete**
- and
- **Consistent**

# Completeness



- ▶ A state is complete when *for all possibilities of the inputs there is at least one transition* active.
- ▶ Let's name the transition conditions.
- ▶ We can check by using a truthtable.
- ▶ We can fill in the transition conditions.
- ▶ We can now check on completeness.

# Completeness



- A state is complete when *for all possibilities of the inputs* there is *at least one transition* active.
- We can also do the check with boolean algebra
- By performing the OR of the transition conditions:

$$\begin{aligned}\alpha + \beta + \gamma &= L + \bar{L} \cdot T + \bar{L} \cdot \bar{T} \\ &= L + \bar{L} \cdot (T + \bar{T}) \\ &= L + \bar{L} \\ &= 1\end{aligned}$$

# Example of an incomplete state



Truthtable:

| S | T | L | α | β | γ |             |
|---|---|---|---|---|---|-------------|
| 0 | 0 | 0 | 0 | 0 | 1 | ✓complete   |
| 0 | 0 | 1 | 1 | 0 | 1 | ✓complete   |
| 0 | 1 | 0 | 0 | 0 | 0 | ✗incomplete |
| 0 | 1 | 1 | 1 | 0 | 0 | ✓complete   |
| 1 | 0 | 0 | 0 | 1 | 1 | ✓complete   |
| 1 | 0 | 1 | 1 | 0 | 1 | ✓complete   |
| 1 | 1 | 0 | 0 | 1 | 0 | ✓complete   |
| 1 | 1 | 1 | 1 | 0 | 0 | ✓complete   |

- ▶ A state is complete when *for all possibilities of the inputs* there is *at least one transition* active.
- ▶ Let's look at this state.
- ▶ We start again with the truthtable method.
- ▶ And check all possibilities.
- ▶ We found already 1 entry that is incomplete, we can stop here!

# Consistency



Truthtable:

| S T L | α | β | γ |             |
|-------|---|---|---|-------------|
| 0 0 0 | 0 | 0 | 1 | ✓consistent |
| 0 0 1 | 1 | 0 | 0 | ✓consistent |
| 0 1 0 | 0 | 1 | 0 | ✓consistent |
| 0 1 1 | 1 | 0 | 0 | ✓consistent |
| 1 0 0 | 0 | 0 | 1 | ✓consistent |
| 1 0 1 | 1 | 0 | 0 | ✓consistent |
| 1 1 0 | 0 | 1 | 0 | ✓consistent |
| 1 1 1 | 1 | 0 | 0 | ✓consistent |

- A state is consistent when *for all possibilities of the inputs* there is *at most one transition* active.
- Let's name the transition conditions.
- We can check by using a truthtable.
- We can now check on consistency.

# Consistency



- A state is consistent when *for all possibilities of the inputs* there is *at most one transition* active.
- We can also use the boolean algebra:
  - 1)  $\alpha \cdot \beta = (L) \cdot (\bar{L} \cdot T) = L \cdot \bar{L} \cdot T = 0$
  - 2)  $\alpha \cdot \gamma = (L) \cdot (\bar{L} \cdot \bar{T}) = L \cdot \bar{L} \cdot \bar{T} = 0$
  - 3)  $\beta \cdot \gamma = (\bar{L} \cdot T) \cdot (\bar{L} \cdot \bar{T}) = \bar{L} \cdot T \cdot \bar{T} = 0$

# Example of an inconsistent state



- A state is consistent when *for all possibilities of the inputs* there is *at most one transition* active.
- We start again with the truthtable method.
- And check all possibilities.
- We found already 1 entry that is inconsistent, we can stop here!

## Howto design an FSM: step 2



Now that we determined that the state diagramm is **complete** and **consistent** we can continue. Otherwise:

*To make a state complete  
we have to:*

Add to each incomplete  
line in the truthtable one 1  
for one of the conditions

*To make a state consistent  
we have to:*

Remove from each inconsis-  
tent line in the truthtable as  
many 1's such that only one  
of the conditions is active

# Howto design an FSM: step 3



- The next step is to define the code table.
- But how many bits  $n$  do we require?
- To code  $I$  states we require at least  $n \geq \left\lceil \frac{\ln(I)}{\ln(2)} \right\rceil$  bits.
- Hence we could code with 5 bits like this.
- The minimum number of bits ( $n$ ) required here is 3, like for example this.
- Note: The coding can impose that you have to use a Moore machine, or that you can use a Medvedev machine.

# Ghost states



- From the 8 possible codes we only used 5, what about the other 3?
- These unused codes represent the *ghost states* of our state machine.
- There are two ways to deal with these *ghost states*:
  - We can just ignore them and treat them as *don't care*. This is good for non-critical applications.
  - We can make sure that they point to a *save state*. This is good for critical applications like medical implants.

# Transition table

## FSM Howto

Step1

Step2

Complete

Consistent

Step3

Ghost states

Transition table

Step4



- ▶ Now we can create the transition table.
- ▶ We start with the version with the ignored ghost states.
- ▶ As comparision the version with the “save” ghost states.

# Power On Reset



- ▶ What happens with my FSM when powering on?
- ▶ The state at power on is random.
- ▶ To be able to have a defined state we use a Power-On-Reset (POR).

# Asynchronous Power On Reset

## FSM Howto

Step1  
Step2  
Complete  
Consistent  
Step3  
Ghost states  
Transition table

Step4



- ▶ How to use the POR?
- ▶ We identify the *Reset State*.
- ▶ We can use now the asynchronous Set and asynchronous reset inputs of a flipflop.
- ▶ This is a asynchronous POR, we note it with a flash in the state-diagram.

# Synchronous Power On Reset

## FSM Howto

Step1

Step2

Complete

Consistent

Step3

Ghost states

Transition table

Step4



- We can also feed the POR into the transition logic.
- We call this a synchronous POR.
- We have to modify the state-diagram with the reset transitions.
- And finally we have to make the state-diagram complete and consistent.

# Lecture 9

## Digital system design

None Ideal Behavior

*CS173 - Conception de systèmes numériques*  
*March 2017*

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

- ▶ Today all gates are implemented in **semiconductor** material
- ▶ However, the **transistors** used are different
- ▶ The two famous families are:
- ▶ **T**ransistor to **T**ransistor **L**ogic
- ▶ **C**omplementary **M**etal **O**xide **S**ilicon
- ▶ The gates come in the form of an **I**ntegrated **C**ircuit



# Technology



- ▶ Let's take a closer look at the NOR-gate.
- ▶ In TTL-technology it is build up like this, and in CMOS-technology like this.
- ▶ In both cases we need a power suply, otherwise they won't work!
- ▶ Everywhere there are capacitors, resulting in a delayed reaction of the gate!

# Hazards



- ▶ What happens with this circuit?
- ▶ This is the theoretical behavior, also called the *zero-delay model*; what about reality?
- ▶ Each gate has a gate-delay. In this example we simplify and assume that all the gates have the same delay  $t_{delay}$ .
- ▶ We get due to the gate delays unexpected level changes! These delay-caused level changes are called *hazards* which cannot be avoided!

# Gated clocks



- ▶ A situation which seems often to be “logical”:
- ▶ We call these kind of circuits *gated-clock* circuits.
- ▶ This is a very **bad** idea; we think there are only two rising edges.
- ▶ But in the real circuit there can be an awfull lot more rising edges due to *hazards*!
- ▶ So don’t do this, unless you know what you are doing! Use the signal Y as input to the transition-logic!

# Real DFF's



- ▶ So we should always connect like this. But what about the real behavior of the d-flipflop?
- ▶ In the zero-delay model we know it works like this.
- ▶ In reality the output of the flipflop reacts a time  $t_{clock\_to\_output}$  after the rising edge of the clock.
- ▶ And it becomes even worst.....

# Metastability



- ▶ Let's look at one positive edge.
- ▶ There are two time regions, the setup time  $t_{setup}$ , and the hold time  $t_{hold}$ ; D must be kept stable in this period, otherwise:
- ▶ The D-flipflop goes in metastability, and it settles at either 1 or 0, independent of the value of D!

# TODO

- ▶ critical path
- ▶ max. frequency
- ▶ synchronisation

Real gates  
Technology  
Hazards  
Gated clock

Real memory

| E  | Q |
|----|---|
| 00 | A |
| 01 | B |
| 10 | C |
| 11 | D |



$$Q = \underline{\alpha \cdot \bar{E}_2 + \beta \cdot E_1}$$

| D | WE | Q |
|---|----|---|
| 0 | 0  | 0 |
| 0 | 1  | 0 |
| 1 | 0  | 1 |
| 1 | 1  | 1 |



- 1) diagram d'état pour 1 bit  
 2) D et Q ont 2 bit dressé le circuit correspondant

table fonctionnelle:

| WE | D | Q | $\alpha$ |
|----|---|---|----------|
| 0  | - | 0 | 0        |
| 0  | - | 1 | 1        |
| 1  | 0 | - | 0        |
| 1  | 1 | - | 1        |



| WE | 0 | 1 | 0 | 1 | $\alpha$ |
|----|---|---|---|---|----------|
| 0  | 0 | 0 | 0 | 0 | 0        |
| 1  | 0 | 1 | 0 | 1 | 1        |





$$a \ll b \quad 0 \rightarrow \text{---} \quad a = 4 \text{ bit}$$

$$\begin{aligned} c &= a \ll b \quad b = 2 \text{ bit} \\ &= a \ll (b_1 \cdot 2^2 + b_0 \cdot 2^0) \\ &= \cancel{a \ll (b_1 \cdot 2)} + a \ll b_0 \end{aligned}$$

$$1 \ll 2$$



$$1 \ll 1$$



# Lecture 11

## Digital system design

Programmable Logic (1)

*CS173 - Conception de systèmes numériques*  
*April 2017*

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Introduction

- ▶ Today all digital (and analog) circuits are realized as ASIC.
- ▶ The ASIC (*Application Specific Integrated Circuit*) contains billions of transistors.
- ▶ Making an ASIC is very expensive as:
  - ▶ The design process takes more than a year.
  - ▶ The initial cost starts from \$100,000.= and can go as high as \$5,000,000.=
- ▶ Therefore, it is only interesting for high-volume market.
- ▶ This is one of the reasons why *programmable logic devices* were introduced.
- ▶ Of course a programmable logic device is an ASIC.



# Programmable Array Logic

- ▶ The first of the family of programmable logic devices was introduced in 1978.
- ▶ In 1978 the company MMI (*Monolithic Memories Inc.*) introduced the PAL.
- ▶ PAL stands for *Programmable Array Logic*.
- ▶ The basic concept of a PAL is based on the kanonical form in which a logic function can be written:

$$Q = A \cdot B \cdot C + \overline{A} \cdot B \cdot C + A \cdot \overline{B} \cdot \overline{C}$$







## Exercise

Simple

Intro

PAL

GAL

CPLD

Realize the function  $Q = A \cdot B \cdot C + \bar{A} \cdot B \cdot C + A \cdot \bar{B} \cdot \bar{C}$  on the following macro-cell:



# Programmable Array Logic

► A PAL was very successful as:

1. It allowed for any logic function to be realized.
2. The input-to-output delay is fixed (namely:  $t_{not} + t_{and} + t_{or}$ )
3. Low power.
4. Once programmed, even when the power is switched-off, the programming stays.  
We call this *non-volatile*.

► The PAL has one draw-back:

It can only be programmed once. We call this *OTP (=One Time Programmable)*.

When the designer made a mistake :



# Generic Array Logic

- ▶ To overcome the problems of *OTP*, *Lattice Semiconductors* introduced in 1985 the GAL.
- ▶ GAL stands for *Generic Array Logic*
- ▶ Lattice had the great idea to replace the *antifuses* of the PAL by E<sup>2</sup>(=Electrical Erasable)-switches.



- ▶ These E<sup>2</sup>-switches are realized by *floating-gate-transistors*, which are still the basis of nowadays used FLASH devices.

# Generic Array Logic

Simple

Intro

PAL

GAL

CPLD



- The advantage of this device is that programming and normal-operation are orthogonal, making ISP(*=In System Programming*), also referred to as ICP(*=In Circuit Programming*), possible.

# Generic Array Logic

Simple

Intro

PAL

**GAL**

CPLD



- GAL superseded the PAL.

# Generic Array Logic

Simple

Intro

PAL

GAL

CPLD

- ▶ The GAL is in many aspects better than a PAL, however the E<sup>2</sup>-switch technology has some restrictions:
  1. It can only be reprogrammed about 10.000 times.
  2. The programming stays for about 20 years.
- ▶ Another disadvantages of PAL's and GAL's is that only combinational functions can be realized.
- ▶ This has lead to a second generation of GAL's that incorporated in each macro-cell a D-flipflop:

# Generic Array Logic



- The second generation GAL, also referred to as PLD (=Programmable Logic Device).

# Complex Programmable Logic Device

As complexity of digital system increased,  
and technology shrink smaller,  
a new area of PLD's emerged,  
the CPLD(=*Complex Programmable Logic Device*) was  
born.

The *complex* was not related to the programming,  
but to the size of the device

the CPLD can be seen as several tens to hundreds of  
GAL's in one package.

Simple  
Intro  
PAL  
GAL  
**CPLD**

# Complex Programmable Logic Device



- The CPLD uses still the same macro-cell, but connect them internally by a routing array.

# Complex Programmable Logic Device

- ▶ The “heart” of the CPLD is the routing array.
- ▶ The routing array consists of a matrix of connections.
- ▶ The horizontal lines are the outputs of the macro-cells.
- ▶ The vertical lines provide the inputs to the macro-cells.
- ▶ On each cross-point an  $E^2$ -switch is placed.
- ▶ In this way any connection can be made internal to the CPLD.



# Complex Programmable Logic Device

- ▶ But how to connect to the outside?
- ▶ The CPLD introduced a programmable connection.
- ▶ This connection is called IOB(=Input Output Block).
- ▶ It allows to use a connection as Input
- ▶ Or as Output
- ▶ Or bi-directional



# Complex Programmable Logic Device

- ▶ Example: Altera's/Intel's EPM7032 CPLD



Digital system  
design

Prof. Dr. Theo  
Kluter

Simple

Intro

PAL

GAL

CPLD

# Lecture 12

## Digital system design

Programmable Logic (2)

*CS173 - Conception de systèmes numériques*  
May 2018

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

## From CPLD to FPGA

- ▶ We have seen the three basic components of a CPLD.
- ▶ We have also seen that the scalability of the CPLD is restricted by its routing array.
- ▶ To generate more complex designs, bigger devices are required.
- ▶ This has lead to the introduction of the FPGA.
- ▶ FPGA stand for *Field Programmable Gate Array*
- ▶ Where the CPLD used the *Sum-of-Products* representation of a logic function, the FPGA takes another approach.



## Look Up Table

- ▶ The FPGA takes the truthtable as basis of representing a logic function.
- ▶ Taking a MUX one can select each of the entries.
- ▶ With a D-flipflop we have the possibility to make FSM's.
- ▶ We call this structure (in yellow) a LUT (=Look Up Table).

| A | B | C | D | Y |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 |
| 0 | 1 | 0 | 1 | 1 |
| 0 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 1 |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 | 0 |



## Look Up Table

- ▶ To store each of the entries in the truth-table we need to add memory.
- ▶ This memory-pane is the configuration part.
- ▶ It consists of D-flipflops in a shift-register configuration.
- ▶ During configuration the configuration pane is loaded with the values.



# Architecture

- ▶ To overcome the scaling-problem of the CPLD, in the FPGA each LUT has it's own routing-array (*distributed routing*).
- ▶ This structure can be copied horizontally and vertically.
- ▶ To provide interconnects, the routing arrays are connected horizontally and vertically.



**Exercise:**

Implement the function  $X = \overline{A} \cdot (\overline{B} \oplus \overline{C}) + D \cdot \overline{C}$  on the below shown FPGA-structure:



## Place and Route

- ▶ In the previous exercise you had two problems, namely:
  1. On which LUT to map the function, we call this the *placement*.
  2. How to connect the inputs to the selected LUT and how to connect the LUT to the output, we call this the *routing*.
- ▶ Both actions are NP-hard problems. However, we have software that solve these problems, which are called the *Place and Route software* (P&R-software). Altera/Intel's Quartus performs this task.



## Routing Array

- ▶ But how does the distributed routing array look like? Very similar to the CPLD, we use the same structure, namely a *cross-bar*.
- ▶ However, we replace the  $E^2$ -switches by pass-gates (*tri-state buffers*).
- ▶ Let's look into the details, we have again the *use-pane* and the *programming pane*.
- ▶ As with the LUT we have to make a difference between configuration and *programming*.



## Only four inputs?

This is all great, but each LUT is limited to four inputs!

This is quite limiting, isn't it?

At least in the CPLD we had macro-cells with 22+ inputs...

How do we implement functions with more than four inputs on an FPGA?

Let's see:

**Exercise:**

Given is the function X below. Realize this function on an FPGA.

| E | D | C | B | A | X |
|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 | 1 | 1 |
| 0 | 0 | 0 | 1 | 0 | 0 |
| 0 | 0 | 0 | 1 | 1 | 1 |
| 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 | 0 |
| 0 | 0 | 1 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 1 | 1 |
| 0 | 1 | 0 | 0 | 0 | 1 |
| 0 | 1 | 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 |
| 0 | 1 | 0 | 1 | 1 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 | 1 | 1 |
| 0 | 1 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | 0 | 0 |
| 1 | 1 | 0 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 | 1 |

| E | D | C | B | A | X |
|---|---|---|---|---|---|
| 1 | 0 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 0 | 1 | 0 |
| 1 | 0 | 0 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 | 1 | 1 |
| 1 | 0 | 1 | 1 | 0 | 1 |
| 1 | 0 | 1 | 1 | 1 | 0 |
| 1 | 1 | 0 | 1 | 0 | 1 |
| 1 | 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 | 1 |

## Exercise:



## Input and Output

- ▶ But how do we connect the inputs and outputs to the outside world.
- ▶ Remember the IOB (=Input Output Block) from the CPLD?
- ▶ The FPGA uses them also, they are connected to the “outer” routing arrays.
- ▶ Of course in the FPGA the E<sup>2</sup>-switches are replaced by multiplexers and tri-state buffers.



## Summary

- ▶ So we see that the FPGA is very scalable (devices with 454240 LUT's are no exceptions).
- ▶ Contrary to the CPLD, the FPGA is *volatile* (remember the configuration pane)
- ▶ This means that if the power is switched off, the FPGA loses its functionality.
- ▶ Each time the FPGA is turned on we have to configure it. This is done by means of a *bit-file*.
- ▶ The bit-file contains the content for each of the D-flipflop in the configuration-pane. It also contains the “initial values” of the D-flipflops in the LUTs.
- ▶ The bit-file is generated by the P&R(Place and Route)-software.
- ▶ When we look at the time-delays inside an FPGA, it shows that due to the distributed routing-network, most of the delay is generated by the routing. In “big”-designs about 80% of the delay is routing delay, and 20% is LUT-delay.
- ▶ But is that all there is?

## The evolving FPGA

- ▶ Of course not. In the 1990's this was about how an FPGA looked like.
- ▶ But soon the FPGA was used to implement calculations.
- ▶ Due to the routing- and LUT-delays these calculations were slow.
- ▶ Hence hardware (fast) multipliers were added to the FPGA.



## The evolving FPGA

- ▶ Having multipliers need's data.
- ▶ Using the flipflops in the LUT's is a waste of resources.
- ▶ So RAM(=*Random Access Memory*)'s were added to the FPGA.
- ▶ This architecture provided very fast MAC(=*Multiply ACumulate*)'s.



## The evolving FPGA

- ▶ As technology evolved, the IOB's were not good enough.
- ▶ There was a requirement for faster IO.
- ▶ This has led to the integration of hardware IP(=Intellectual Property) blocks.
- ▶ And integration of specialized IO-blocks.



## The evolving FPGA

- ▶ Why putting a processor outside?
- ▶ We can also integrate it in the FPGA.
- ▶ The SOC(=System On Chip) was born.
- ▶ Examples of these SOC's are Xilinx's Zynq FPGA's and Altera/Intel's Cyclone V FPGA's.



## Why FPGA

- ▶ This is all great, but why is the FPGA so successfull.
- ▶ Intel lanced in 2016 the HARP-program. They combined a Xeon processor with an FPGA.
- ▶ There must be a good reason for this.
- ▶ Intel even purchased Altera, one of the two leaders in the FPGA-market.



# Why FPGA

- ▶ Let's see, an FPGA runs at approx. 300MHz-600MHz.
- ▶ That's slow, a Xeon runs upto a factor 10 faster.....
- ▶ Ah, on an FPGA I can do massive parallelism, so I gain.
- ▶ A GPU(=*Graphic Processing Unit*) does this also, but much faster....
- ▶ Ah, I got it, an FPGA can do massive parallelism and can be tuned to each task/thread.
- ▶ Indeed, the FPGA can be reconfigured during task/thread switching and can be tailored completely to given operations. Both GPU and CPU are fixed architecturs and are therefore limited.

## How to use an FPGA

- ▶ But how to use all these resources....
- ▶ Doing it in a graphic-entry program like logisim is not very productive
- ▶ We need the means to design systems at a higher level
- ▶ For this reason nowadays a HDL(=Hardware Description Language) is used.
- ▶ There exists two flavours, namely (1) VHDL and (2) Verilog.
- ▶ From next week we will look into the details of VHDL.



# Lecture 13

## Digital system design

VHDL Introduction

*CS173 - Conception de systèmes numériques*  
May 2018

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences



- ▶ Is this the way to design a digital system?
- ▶ Yes, upto about 1985 this was used to design systems.
- ▶ For simple designs this method works, but as complexity increases new methodologies are required.
- ▶ Compare gate-level designing with writing programs in assembly language.
- ▶ We are not going to use gate-level design methods for 1 billion transistors!

## Design flow

- ▶ So how to go about it, let's compare a software flow to a hardware flow.
- ▶ We use a high-level language to describe the functionality, than use a compiler that generates the assembly.
- ▶ At the same level as assembly we can think in hardware the gates.
- ▶ Hence we need a “compiler”, which is called a synthesizer that can translate a hardware description to gates.
- ▶ These Hardware Description Languages(HDL's) are VHDL and Verilog.



- ▶ We will look into the hardware description language VHDL.
- ▶ VHDL stands for: **Very high-speed integrated circuits Hardware Description Language**
- ▶ VHDL is a formal language for specifying digital systems, equally good at structural as behavioral level.
- ▶ VHDL is used for:
  - ➡ System description.
  - ➡ Simulation.
  - ➡ Conceptual modeling.
  - ➡ Documentation.
- ▶ VHDL's main characteristics are:
  - ➡ Hierarchical.
  - ➡ Event-driven simulation.
  - ➡ Modular.
  - ➡ Extensible.
  - ➡ General language, strongly typed, similar to Ada.

# VHDL's history

- ▶ **1980:**  
Beginning of the project, financed by the American Department of Defense(=DoD) with 400M \$US.
- ▶ **1982:**  
Contracts for Intermetrics, IBM et Texas.
- ▶ **1985:**  
Version 7.2 released public domain.
- ▶ **1987:**  
Standarisation by the standard IEEE 1076 (VHDL-87).
- ▶ **1993:**  
New version of the standard by adding the standard IEEE 1164 (VHDL-93).  
*Most commonly used nowadays.*
- ▶ **2008:**  
Release of VHDL 4.0 by the standard IEEE 1076-2008.  
*Many simplifications and supported by most tools.*

- ▶ VHDL is a very rich language and provides syntactical elements for describing:
  - ⇒ Synthesizable digital systems.
  - ⇒ Functional description of complex components (processors, DSPs, etc.).
  - ⇒ Description of libraries of elementary gates with internal delays rise and fall times, etc.
  - ⇒ ...
- ▶ Many of VHDL's features were invented for system simulation.
- ▶ For hardware design only a small subset of the language is used, namely: the description of *synthesizable zero-delay digital systems*.
- ▶ VHDL's syntactical rules are:
  - ⇒ VHDL is a **case insensitive** language.
  - ⇒ VHDL has free formatting.
  - ⇒ Each command sequence is **terminated by a ;** (note: there are exceptions).
  - ⇒ A remark can be placed by using **-- in front of the remark**. A remark ends at the end of the line (<EOL>).

- ▶ VHDL consists of two main items:
  1. The **black-box** view of the digital circuit. This is described in the syntactical element called *Entity*.
  2. The **functionality** of the digital circuit. This is described in the syntactical element called *Architecture*.
- ▶ Let's start in looking into the **black-box** view.



## The black-box view

- ▶ Each VHDL-description contains the view of the circuit as black-box. This is indicated by the **ENTITY**.
- ▶ Each Entity has some syntactical elements, namely:
  - A library definition. We will always use the one showed below (similar to **#include <stdlib.h>** in C/C++). Note: Each Entity requires it, as it is not inherited in hierarchy like in C/C++.
  - A unique name . This name has to start with a letter ( $A..Z, a..z$ ) and may *only* contain letters ( $A..Z, a..z$ ), numbers ( $0..9$ ), and underscores ( $_$ ).
  - Optionally a **PORT** section to define the input(s) and output(s) of the black-box.

### VHDL syntax definition:

```
LIBRARY ieee;  
USE ieee.std_logic_1164.all;  
  
ENTITY <entity_name> IS  
  PORT ( ... );  
END <entity_name>;
```

## Example

VHDL snippet:

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY t_ff IS
  PORT (
    Toggle : IN std_logic;
    Reset  : IN std_logic;
    Clock  : IN std_logic;
    Q      : OUT std_logic);
END t_ff;
```



## Ports

- ▶ The PORT-section contains all connections to the outside world.
- ▶ Each line in the PORT-section contains:
  - ➔ A unique name, or a list of unique names that have the same <port\_type> and <signal\_type> (as shown in the second line).
  - ➔ A type of the connection, valid port-types are **IN** , **OUT** , and **INOUT**. We will seldom (maybe never...) use the port type **INOUT**.
  - ➔ A signal type. We will look into details of the signal type a bit later.
- ▶ Important: As always there are exceptions, also here, the last line in the PORT-section is **not terminated** by a ;

VHDL syntax definition:

```
PORT (
    <port_name>          : <port_type> <signal_type>;
    <port_name>, <port_name> : <port_type> <signal_type>;
    ...
    <port_name>          : <port_type> <signal_type>
);
```

## Signal types

- ▶ VHDL knows various types, like:

- ⇒ Real
- ⇒ Integer
- ⇒ Time
- ⇒ File
- ⇒ Character
- ⇒ ...

However, these types have no real meaning in *synthesizable digital systems*.

- ▶ As we have seen in the first half of the course, there are two possible quantities, namely:

- ⇒ A **bit**. This is represented in VHDL by the type:

**std\_logic**

- ⇒ A **set of n-bits** (also called a bus). This is represented in VHDL by the type:

**std\_logic\_vector( (n-1) DOWNTO 0 )**

These quantities do not contain any interpretation (we will see later in the course that there also exists types that contain an interpretation).

## Signal types



- A **`std_logic`**, and each bit of a **`std_logic_vector`** can hold nine values:

- '**0**' = logic 0.
- '**1**' = logic 1.
- '**U**' = Undefined state (for example of a D-flipflop).
- '**X**' = Unknown (often caused by a short circuit).
- '**-**' = Don't care (used in not completely defined functions).
- '**Z**' = high impedance (output of tri-state buffer).
- '**L**' = weak 0 (pull-down).
- '**H**' = weak 1 (pull-up).
- '**W**' = weak unknown (neither H nor L).

The last four we will not see/use in this course.

## Exercise

Write the complete entity for the following state-machine called **moore**:



## What's next

- We now have seen the first item of a VHDL-description, the **ENTITY**.



- Let's look into the details of the second part, the **ARCHITECTURE**.

# Lecture 14

## Digital system design

VHDL Behavior(1)

*CS173 - Conception de systèmes numériques*  
May 2018

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

- ▶ Last time we saw the first item of a VHDL-description, the **ENTITY**.



- ▶ Let's look into the details of the second part, the **ARCHITECTURE**.

# Architecture and entity relationship

VHDL snippet:

```
ENTITY exp IS  
  PORT ( ... );  
END example;
```

```
ARCHITECTURE im1 OF exp IS  
BEGIN  
  ...  
END example;
```

VHDL snippet:

```
ARCHITECTURE im2 OF exp IS  
BEGIN  
  ...  
END example;
```

VHDL snippet:

```
ARCHITECTURE im3 OF exp IS  
BEGIN  
  ...  
END example;
```

- ▶ Each entity has at least one functional description (architecture).
- ▶ But an entity can have multiple functional descriptions (architectures).

# Architecture and entity relationship (example)



VHDL syntax definition:

```
ARCHITECTURE <id_name> OF <entity_name> IS  
    »declaration section«  
BEGIN  
    »description section«  
END <id_name>;
```

- ▶ The architecture body is defined as above.
- ▶ Each architecture has a unique name (<id\_name>).
- ▶ Each architecture has a reference to its corresponding entity (<entity\_name>).
- ▶ Each architecture has a declaration section.
- ▶ Each architecture has a description section.

## Architecture: »declaration section«

- ▶ The »*declaration section*« of an **ARCHITECTURE** can contain:
  - ➡ **SIGNAL** declarations. Signals are the “wires” or “state” of the circuit.
  - ➡ **CONSTANT** definitions. Constants are fixed value “wires” or fixed value “state” within the circuit.
  - ➡ **COMPONENT** declarations. Components give us the possibility to design hierarchical.
  - ➡ **FUNCTION** definitions. Functions can be used for actions which are often required in the functional description.
  - ➡ **PROCEDURE** definitions. Similar to Functions also procedures can be used.
- ▶ In this course we will only use the **SIGNAL** , **CONSTANT** , and **COMPONENT** syntactical elements.
- ▶ Each of this topics will be explained later on in this course.

## Architecture: »description section«

- ▶ The »*description section*« of an **ARCHITECTURE** contains:
  - ➡ *Implicite processes* also called “*concurrent statements*”.
  - ➡ *Explicite processes*.
  - ➡ Component instantiations.
- ▶ Each of these parts execute in parallel (in contrast with most software programming languages where instructions are executed sequentially)!
- ▶ Most VHDL code written and used nowadays by designers is written following the RTL (=Register Transfer Level) principle.
- ▶ The RTL principle consists of separating the sequential logic (e.g., memory, flip-flops and latches) from the combinatorial logic. Finally we connect the different parts by wires.
- ▶ How do we do this:
  - ➡ Identify the combinatorial and sequential elements.
  - ➡ Write the VHDL description for all these elements.
  - ➡ Control that no memory action is introduced in the combinatorial elements (to be elaborated later on in this course).
  - ➡ Connect the elements by using wires (e.g., signals).

## Architecture: »description section«; let's start simple: gates

Assume following entity:

VHDL snippet:

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY gate IS
PORT ( A : IN std_logic;
       B : IN std_logic;
       C : IN std_logic;
       Y : OUT std_logic);
END gate;
```

How do we describe a gate in the »*description section*« of the corresponding architecture?



$Y \leq A \text{ OR } B \text{ OR } C;$



$Y \leq A \text{ AND } B \text{ AND } C;$



$Y \leq (A \text{ XNOR } B) \text{ XNOR } C;$

- ▶ We can easily describe gates.
- ▶ Known gates are **AND**, **NAND**, **OR**, **NOR**, **NOT**, **XOR**, and **XNOR**.
- ▶ NOTE: The output of the gate is on the left hand side of the `<=` operator; the inputs of the gate are on the right hand side of the `<=` operator.

## Exercise

Draw the circuit that is described by the below VHDL-description:

VHDL snippet:

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY exercise IS
PORT (
    A,B,C : IN std_logic_vector(1 DOWNTO 0);
    X : OUT std_logic_vector(1 DOWNTO 0) );
END exercise;

ARCHITECTURE example OF exercise IS
BEGIN
    X <= (A AND NOT (B)) NOR C;
END example;
```

# Exercise



Digital system design

Prof. Dr. Theo Kluter

Architecture

Implicit processes

## Architecture: more gates

VHDL snippet:

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY full_adder IS
PORT ( A,B,Cin : IN std_logic;
       Sum,Cout : OUT std_logic);
END full_adder;
```



- ▶ Let's take a look at a more “complex” circuit.
- ▶ The information “flows” always from the inputs through the gates to the outputs; the inputs “write” the logic values and the outputs “read” the result.
- ▶ The entity defines the shown connection and wires in the architecture.
- ▶ However, there are wires in the architecture that are not visible at entity level, we have to define them!

## Architecture: »declaration section«; signals and constants

VHDL snippet:

```
ARCHITECTURE gate OF full_adder IS
  >>> declaration section <<
BEGIN
  ...
END gate;
```



- ▶ Each of these wires need to be defined in the »declaration section« of the architecture.
- ▶ Wires are represented in VHDL by **signals**, or in case of fixed-value wires by **constant**.

## Architecture: »declaration section«; signals and constants

VHDL syntax definition:

```
SIGNAL <signal_name>[,<signal_name>,..] : <signal_type>;
```

- ▶ Each signal has a unique name (<signal\_name>) that has to start with a letter (a..z,A..Z), may contain numbers (0..9), letters (a..z,A..Z), and underscores (\_).
- ▶ It is good practice to start each signal name with the prefix **s\_**.
- ▶ It is also good practice to use camel-case for all names used in VHDL. E.g. the signal called “this is my nice signal” would be written as **s\_ThisIsMyNiceSignal**.
- ▶ Each signal has to have a type (<signal\_type>), e.g. **std\_logic** or **std\_logic\_vector** (we will see others later on).
- ▶ Signals of the same <signal\_type> can be concatenated by separating their name by a comma.
- ▶ **Note:** Signals do not have a pre-defined signal flow (hence no **IN** or **OUT** after the **:**).

## Architecture: more gates

VHDL snippet:

```
ARCHITECTURE gate OF full_adder IS
  SIGNAL s_Xor,s_And1,s_And2 : std_logic;
BEGIN
  Cout <= s_And1 OR s_And2;
  s_And1 <= A AND B;
  Sum <= s_Xor XOR Cin;
  s_And2 <= s_Xor AND Cin;
  s_Xor <= A XOR B;
END gate;
```



- ▶ Let's name the wires.
- ▶ We can combine the signal definitions also like this.
- ▶ Now we can describe the system.
- ▶ **Note:** The order in which we put the implicit processes is of no importance as hardware is parallel!

## Architecture: more gates

VHDL snippet:

```
ARCHITECTURE gate1 OF full_adder IS
SIGNAL s_Xor,s_And1,s_And2 : std_logic;
BEGIN
    Cout <= s_And1 OR s_And2;
    s_And1 <= A AND B;
    Sum <= s_Xor XOR Cin;
    s_And2 <= s_Xor AND Cin;
    s_Xor <= A XOR B;
END gate1;
```

VHDL snippet:

```
ARCHITECTURE gate2 OF full_adder IS
SIGNAL s_Xor,s_And1,s_And2 : std_logic;
BEGIN
    Cout <= s_And1 OR s_And2;
    s_And1 <= A AND B;
    s_And2 <= s_Xor AND Cin;
    s_Xor <= A XOR B;
    Sum <= s_Xor XOR Cin;
END gate2;
```

VHDL snippet:

```
ARCHITECTURE gate3 OF full_adder IS
SIGNAL s_Xor,s_And1,s_And2 : std_logic;
BEGIN
    s_And2 <= s_Xor AND Cin;
    s_Xor <= A XOR B;
    Cout <= s_And1 OR s_And2;
    s_And1 <= A AND B;
    Sum <= s_Xor XOR Cin;
END gate3;
```

VHDL snippet:

```
ARCHITECTURE gate4 OF full_adder IS
BEGIN
    Cout <= (A AND B) OR
        (Cin AND (A XOR B));
    Sum <= (A XOR B) XOR Cin;
END gate4;
```

- All these descriptions are correct. We can suppress wires (but is not required).

## Exercise

Remember this one?



| R | S | Lamp | Y    |
|---|---|------|------|
| 0 | 0 | Y    | Lamp |
| 0 | 1 | 1    | 0    |
| 1 | 0 | 0    | 1    |
| 1 | 1 | 1    | 1    |

Write the complete VHDL description of this latch.

## Pitfalls (1)

### Entity:

VHDL snippet:

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY RS_LATCH IS
PORT ( S,R : IN std_logic;
         Lamp,Y : OUT std_logic);
END RS_Latch;
```

### Architecture:

VHDL snippet:

```
ARCHITECTURE wrong OF RS_LATCH IS

BEGIN
    Lamp <= (NOT (S)) NAND Y;
    Y <= (NOT (R)) NAND Lamp;
END wrong;
```

- ▶ We could think that this is correct. However, Lamp and Y are outputs and their value can only be “assigned”, not read!
- ▶ We have to introduce two signals, s\_lamp and s\_Y.

- ▶ The correct version is than:

VHDL snippet:

```
ARCHITECTURE Correct OF RS_LATCH IS
SIGNAL s_Lamp,s_Y : std_logic;
BEGIN
    s_Lamp <= (NOT (S)) NAND s_Y;
    s_Y <= (NOT (R)) NAND s_Lamp;
    -- Don't forget to assign the outputs!
    Y <= s_Y;
    Lamp <= s_Lamp;
END Correct;
```

## Exercise (2)

Given following VHDL description:



VHDL snippet:

```
ARCHITECTURE common OF DoesItWork IS
  SIGNAL s_MySignal : std_logic;
BEGIN
  s_MySignal <= NOT (A(0)) AND A(1);
  Q <= s_MySignal;
  s_MySignal <= A(0) AND NOT (A(1));
END common;
```

Draw the corresponding circuit:

- The entity gives us this. The »declaration section« of the architecture adds a wire.
- We can select each bit of a `std_logic_vector` by using the bit index in `( )`. Therefore the first *implicite process* in the architecture adds this circuit.
- The second *implicite process* adds this circuit.
- And finally the third *implicite process* adds this circuit.
- **Booom.** As the signal `s_MySignal` appears twice on the left hand side of the `<=` operator a short circuit is generated! This is a common pitfall.

## VHDL syntax definition:

```
CONSTANT <constant_name> : <constant_type> := <value>;
```

- ▶ We can also define constants.
- ▶ It is good practice to start each constant name with the prefix **c\_**.
- ▶ Each constant has to have a type (<constant\_type>), e.g. **std\_logic** or **std\_logic\_vector** (we will see others later on).
- ▶ A signal/constant of type **std\_logic** is assigned a constant value by using "", example:
  - ⇒ **CONSTANT** c\_example1 : **std\_logic** := '1'; *--(in the »declaration section«)*
  - ⇒ s\_MySuperSignal <= 'Z'; *--(in the »description section«)*
- ▶ A signal/constant of type **std\_logic\_vector** is assigned a constant value by using " ", example:
  - ⇒ **CONSTANT** c\_example2 : **std\_logic\_vector**( 2 **DOWNT0** 0) := "110";
  - ⇒ s\_MySuperBus <= "0100";

## Architecture: signals and constants

- ▶ Assume following signal definition in the »declaration section« of an architecture:

```
SIGNAL s_MyExampleBus : std_logic_vector( 23 DOWNTO 0 );
```

- ▶ To assign a constant to it we can do it like:

```
s_MyExampleBus <= "100000000000000000000000000000";
```

- ▶ We can simplify this by using the hexadecimal representation like this:

```
s_MyExampleBus <= X"800000";
```

**IMPORTANT:** When using the hexadecimal representation each *digit* represents exactly 4 bits!

- ▶ We can also use a combination between the two by using concatenation (& as glue element):

```
s_MyExampleBus <= X"80"&"0000"&X"000";
```

This is equal to:

```
s_MyExampleBus(23 DOWNTO 16) <= X"80";  
s_MyExampleBus(15 DOWNTO 12) <= "0000";  
s_MyExampleBus(11 DOWNTO 0) <= X"000";
```

- ▶ Or we can use the macro **OTHERS**:

```
s_MyExampleBus <= ( 23 => '1', OTHERS => '0' );
```

# Lecture 15

## Digital system design

VHDL Behavior(2)

*CS173 - Conception de systèmes numériques*  
May 2018

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# System



VHDL snippet:

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY SR_LATCH IS
PORT ( Set,Reset :  IN std_logic;
       Q : OUT std_logic);
END SR_LATCH;
```

VHDL snippet:

```
ARCHITECTURE simple OF SR_LATCH IS
SIGNAL s_Q,s_Y : std_logic;
BEGIN
    Q  <= s_Q;
    s_Q  <= reset NOR s_Y;
    s_Y  <= set NOR s_Q;
END simple;
```

- We can describe the above system with three *implicite processes*.
- We know that hardware is parallel. We also know that a computer is sequential.
- So how do we simulate a parallel system on a sequential machine...

## Simulation



```
force reset 0 0 , 1 10
force set 0
run 20
```



- ▶ Lets look into the simulation.
- ▶ Of course in the beginning most signals are undefined (**U**); remember logisim also.
- ▶ Most of the time the signals are stable, hence no new values need to be calculated.
- ▶ Only if a signal changes (we call this an *event*) the state of the system may change.
- ▶ For simulation purposes we use hence an *event-driven* approach.

## Simulation



$Q \leq s_Q;$

$s_Q \leq \text{reset NOR } s_Y;$

$s_Y \leq \text{set NOR } s_Q;$

- To explain *event-driven* simulation the notion of *sensitivity* is introduced.
- The output Q of process 1 is sensitive to a change on  $s_Q$ .
- Hence each process is *sensitive* to the signals right of the  $\leq$  symbol.

# Simulation



- ▶ So in case of an event, only the processes that are *sensitive* to this event need to be taken into account.
- ▶ However, this event may trigger another event, triggering process 1 and process 2!
- ▶ And this process continues until a new “stable” situation is found; hence no more *resulting events* are generated.
- ▶ **Note:** There is in this event-triggering no notion of time (as we look at the zero-delay model); it is an effect of simulating a parallel system on a sequential machine.

## Simulation: $\delta$ -iterator



| $\delta$ | $s_{Q_\delta}$ |
|----------|----------------|
| 0        | u              |
| 1        | 0              |
| 2        | 0              |

- ▶ At the event process 2 is triggered as it is sensitive to reset.
- ▶ At this moment two things happen, namely:
  - ⇒ A sequential  $\delta$ -iterator is initialised for all signals in the process left of the  $\leq$  operator.
  - ⇒ These signals get now two values, namely the value seen before the event, and the resulting  $\delta$ -value.
- ▶ One  $\delta$ -step is taken, determining the resulting value of the event.
- ▶ As  $s_{Q_\delta=1} \neq s_{Q_\delta=0}$  a resulting event is “fired” triggering process 1 and 3.
- ▶ Another  $\delta$ -step is taken. As now  $s_{Q_\delta=2} = s_{Q_\delta=1}$  a new stable situation is found, and  $s_Q$  is assigned the value of  $s_{Q_\delta=2}$ .

## Simulation: $\delta$ -iterator

Tr=Triggered by an event, Fi=Fire an event, St=Stable

| $\delta$ | Q $\leq s_Q;$ |            |          |          | s_Q $\leq$ reset NOR s_Y; |                |          |          | s_Y $\leq$ set NOR s_Q; |                |          |          |
|----------|---------------|------------|----------|----------|---------------------------|----------------|----------|----------|-------------------------|----------------|----------|----------|
|          | Tr            | $Q_\delta$ | Fi       | St       | Tr                        | $s_{Q_\delta}$ | Fi       | St       | Tr                      | $s_{Y_\delta}$ | Fi       | St       |
| 0        |               | <b>u</b>   |          | <b>X</b> | <b>X</b>                  | <b>u</b>       |          |          |                         | <b>u</b>       |          | <b>X</b> |
| 1        |               |            |          | <b>X</b> |                           | <b>0</b>       | <b>X</b> |          |                         |                |          | <b>X</b> |
| 2        | <b>X</b>      |            |          |          |                           | <b>0</b>       |          | <b>X</b> | <b>X</b>                |                |          |          |
| 3        |               | <b>0</b>   | <b>X</b> |          |                           |                |          | <b>X</b> |                         | <b>1</b>       | <b>X</b> |          |
| 4        |               | <b>0</b>   |          | <b>X</b> | <b>X</b>                  |                |          |          |                         | <b>1</b>       |          | <b>X</b> |
| 5        |               |            |          | <b>X</b> |                           | <b>0</b>       |          | <b>X</b> |                         |                |          | <b>X</b> |

- ▶ The initial situation at the event for the whole system.
- ▶ Process 2 fires a resulting event.
- ▶ Process 1 and 3 get triggered by the resulting event.
- ▶ Process 2 gets triggered by the resulting event of process 3.
- ▶ A new stable situation is found, hence the last values assigned are the resulting values.

## Exercise

Given circuit below, fill out the  $\delta$  table below



| $\delta$ | $Y \leq s_Y;$ |            |    |    | $s_Y \leq a \text{ NAND } s_Y;$ |              |    |    |
|----------|---------------|------------|----|----|---------------------------------|--------------|----|----|
|          | Tr            | $Y_\delta$ | Fi | St | Tr                              | $s_Y_\delta$ | Fi | St |
| 0        |               |            |    |    |                                 |              |    |    |
| 1        |               |            |    |    |                                 |              |    |    |
| 2        |               |            |    |    |                                 |              |    |    |
| 3        |               |            |    |    |                                 |              |    |    |
| 4        |               |            |    |    |                                 |              |    |    |
| 5        |               |            |    |    |                                 |              |    |    |
| 6        |               |            |    |    |                                 |              |    |    |
| 7        |               |            |    |    |                                 |              |    |    |
| 8        |               |            |    |    |                                 |              |    |    |

- ▶ As demonstrated in the previous exercise, not all zero-delay systems can be simulated.
- ▶ In case of a non-zero delay model (hence the gates have a gate-delay) the *fire* is delayed by the gate-delay time.
- ▶ Non-zero delay VHDL description, however, are not synthesizable.
- ▶ Simulating *implicite processes* is very calculation intensive as they are *sensitive* to all input signals of the process.
- ▶ In the time VHDL was developed, the computers were not very fast, hence a simulation could take hours to complete.
- ▶ To reduce the calculation time the concept of the *explicite process* was introduced.

## Explicite Process

VHDL syntax definition:

```
<process_identifier>: PROCESS ( <sensitivity_list>) IS
BEGIN
  »process body«
END PROCESS <process_identifier>;
```

- ▶ An *explicite process* is used similar as an *implicite process* in the »description section« of an **ARCHITECTURE**.
- ▶ Each explicite process may have a unique identifier.
- ▶ Each explicite process has a sensitivity list.
- ▶ The functionality is described in the process body.
- ▶ Each implicite process can be written in its explicite form:

Implicit form:

VHDL snippet:

```
Z  <= A NAND B;
```

Explicite form:

VHDL snippet:

```
test : PROCESS ( A,B ) IS
BEGIN
  Z  <= A NAND B;
END PROCESS test;
```

## Explicite Process

Implicit form:

VHDL snippet:

```
Z <= A NAND B;
```

Explicite form:

VHDL snippet:

```
test1 : PROCESS (B) IS
BEGIN
    Z <= A NAND B;
END PROCESS test1;
```



- ▶ *Explicite processes* are particular in the sense that in simulation it will **only** trigger on events of the signals in it's sensitivity list.
- ▶ In the above vhdl-snippets, the implicit process will trigger on events on A and B.
- ▶ Whereas the explicite process will *only* trigger on B, as only B is in it's sensitivity list.
- ▶ Exercise: Complete the simulation of the above two processes.

## Explicite Process

### Implicite form:

VHDL snippet:

```
Z <= A NAND B;
```

### Explicite form:

VHDL snippet:

```
test1 : PROCESS (A,B) IS
BEGIN
    Z <= A NAND B;
END PROCESS test1;
```

- ▶ The explicite process in the previous exercise does *not* simulate as being a NAND-gate!
- ▶ However, both processes describe for the synthesizer a NAND-gate, and hence we have a difference between simulation and the hardware realized!
- ▶ To align simulation with the hardware realized we have to put all “inputs” of the logic in the sensitivity list of an explicite process! Hence in this case we have to add A.
- ▶ Okay, but why then using the explicite form, it is way more work to write it.....
- ▶ It has to do with the behaviour of the explicit process’s body, let’s look into detail.

## Explicite Process's body

- ▶ To understand the behaviour of an explicite process we have to remember the  $\delta$ -iterator.
- ▶ What happened in simulation:
  - ➡ An event triggers the simulator.
  - ➡ All signals are replaced by their  $\delta = 0$ -representatives (e.g.  $A_{\delta=0}$ ).
  - ➡ The simulator takes  $\delta$ -iteration steps determining eventual new values for the  $\delta$ -signal-representatives (e.g.  $A_\delta$ ).
  - ➡ This  $\delta$ -iteration continues until a new *stable* situation is found.
  - ➡ All signals are assigned the value of their latest  $\delta$ -representative (e.g.  $A = A_\delta$ ).
- ▶ The sequential nature of this  $\delta$ -evaluation is used in the body of an explicite process.
- ▶ Huh.... I do not understand.... Let's look at an example:

## Explicite Process's body

VHDL snippet:

```
example : PROCESS (A, B) IS
BEGIN
    Z <= NOT (A);
    Z <= '0';
    Z <= NOT (A) AND B;
    Z <= A NOR B;
END PROCESS example;
```

- ▶ Which hardware is described in the above explicite process?
- ▶ I know: **Boooooooooooooom!**
- ▶ Actually: no, the above explicite process describes a NOR-gate.
- ▶ So how does it work:

## Explicit Process's body

VHDL snippet:

```
example : PROCESS (A, B) IS
BEGIN
(1)    Zδ  <= NOT (Aδ=0) ;
(2)    Zδ  <= '0' ;
(3)    Zδ  <= NOT (Aδ=0) AND Bδ=0 ;
(4)    Zδ  <= Aδ=0 NOR Bδ=0 ;
END PROCESS example;
```

- ▶ To understand the behaviour of the process we have to put it in the  $\delta$ -iterator form.
- ▶ The moment we have an event on either A or B all three signals are transformed into their  $\delta = 0$ -representatives (e.g.  $A_{\delta=0}$ ,  $B_{\delta=0}$ , and  $Z_{\delta=0}$ ).
- ▶ On each  $\delta$ -iteration the simulator will determine eventual new values of the  $\delta$ -representatives (in this case  $Z_\delta$ ).
- ▶ In an explicit process this calculation is done by execution one line after the other (hence first line (1), then (2), etc.).
- ▶ Finally when the stable situation is reached the signal is assigned the value of its  $\delta$ -representative (e.g.  $Z = Z_\delta$ ).

## Explicite Process's body

VHDL snippet:

```
example : PROCESS (A, B) IS
BEGIN
(1)    Zδ  <= NOT (Aδ=0) ;
(2)    Zδ  <= '0' ;
(3)    Zδ  <= NOT (Aδ=0) AND Bδ=0 ;
(4)    Zδ  <= Aδ=0 NOR Bδ=0 ;
END PROCESS example;
```

- ▶ There are two observations to be made:
  - ⇒ The values seen on the right hand side of the `<=` operator are always the values at  $\delta$ -iteration 0 (hence the values seen at the event).
  - ⇒ The lines in an explicite process are evaluated in sequential order, hence their position does matter for the functionality.
- ▶ In this example the first three lines the process are redundant, as they do not describe any functionality. Only the last line describes the functionality, and hence the hardware!

## Exercise

Which hardware is described by the following explicite process?

VHDL snippet:

```
exercise : PROCESS (A, B, C) IS
BEGIN
  IF (A = '1') THEN
    X <= B;
    Y <= C;
  ELSE
    X <= C;
  END IF;
END PROCESS exercise;
```

## Memory or no memory

VHDL snippet:

```
exercise : PROCESS (A, B, C) IS
BEGIN
(1)    IF (Aδ=0 = '1') THEN
(2)        Xδ <= Bδ=0;
(3)        Yδ <= Cδ=0;
(4)    ELSE
(5)        Xδ <= Cδ=0;
(6)    END IF;
END PROCESS exercise;
```

- ▶ Let us review this exercise.
- ▶ We put it in the  $\delta$ -iterator representation.
- ▶ We see that  $X_\delta$  is always assigned a value. Either in line (2) when  $A_{\delta=0}='1'$ , or in line (5) when  $A_{\delta=0}='0'$ .  $X$  represents, therefore, combinational logic.
- ▶ We see also that  $Y_\delta$  is only assigned a value in line (3) when  $A_{\delta=0}='1'$ . If  $A_{\delta=0}='0'$ ,  $Y_\delta$  is not assigned a new value meaning that  $Y \leq Y_{\delta=0}$ ; the signal retains its “old” value, we have memory. In this case we have the behaviour of a D-latch.

## Exercise

Which hardware is described by the following explicite process?

VHDL snippet:

```
exercise : PROCESS (A, B) IS
BEGIN
    Y <= '0';
    IF (A = '1') THEN
        Y <= B;
        X <= B;
    END IF;
    X <= '0';
END PROCESS exercise;
```

## Exercise

VHDL snippet:

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;

ENTITY Example IS
PORT ( A,B : IN std_logic,
       Y : OUT std_logic);
END Example;

ARCHITECTURE test OF example IS
BEGIN

    Y  <= A AND B;

    procl :  PROCESS (A,B) IS
    BEGIN
        IF  (A = '1') THEN
            Y  <= B;
        END IF;
    END PROCESS procl;
END test;
```

Does it matter in which order the processes are placed?

# Lecture 16

## Digital system design

VHDL Behavior(3)

*CS173 - Conception de systèmes numériques*  
May 2018

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Multiplexers

**Implicite form:**



VHDL syntax definition:

```
<signal>  <= <true_value>
           WHEN <condition> ELSE
             <false_value>;
```

**Explicite form:**



VHDL syntax definition:

```
IF <condition> THEN
  <true_body>
END IF;
```

- ▶ In the implicite form only one signal can be defined.
- ▶ The explicite form allows for multiple statements in both the <true\_body> as well as in the <false\_body>.
- ▶ The implicite form **requires** the **ELSE** , whereas the explicite form allows for only the <true\_body> realizing possibly one/multiple memory(es).
- ▶ The condition is evaluated “boolean”.

# Multiplexers



VHDL syntax definition:

```
<signal>  <= <value1>
          WHEN <condition1> ELSE
            <value2>
          WHEN <condition2> ELSE
            <value3>;
```

VHDL syntax definition:

```
IF <condition1> THEN
  IF <condition2> THEN ...
    ...
  ELSE ...
END IF;
ELSE
  IF <condition3> THEN ...
    ...
  ELSE ...
END IF;
END IF;
```

- We can nest the multiplexers (prioritized muxes).

## D-flipflops



VHDL snippet:

```
dff:PROCESS (<rst_signal>,<clk_signal>) IS
BEGIN
  IF (<rst_signal> = '1') THEN
    <state_signal> <= <rst_value>;
  ELSIF (rising_edge(<clk_signal>)) THEN
    <state_signal> <= <d_value>;
  END IF;
END PROCESS dff;
```



VHDL snippet:

```
dff:PROCESS (<clk_signal>) IS
BEGIN
  IF (rising_edge(<clk_signal>)) THEN
    IF (<rst_signal> = '1') THEN
      <state_signal> <= <rst_value>;
    ELSE
      <state_signal> <= <D_value>;
    END IF;
  END IF;
END PROCESS dff;
```

- ▶ Can describe D-flipflops by using the macro **`rising_edge()`** or **`falling_edge()`**.
- ▶ The left explicit process describes a D-flipflop with asynchronous reset, as the `<rst_signal>` has “priority” over the **`rising_edge()`**.
- ▶ The right explicit process describes a D-flipflop with synchronous reset as the **`rising_edge()`** has “priority” over the `<rst_signal>`.

## Unconditional multiplexers



### Implicite form:

VHDL syntax definition:

```

WITH <cnd_signal> SELECT <result_signal>  =<
  <value_1> WHEN <c1>,
  <value_2> WHEN <c2>,
  <value_3> WHEN <c3>,
  <value_4> WHEN OTHERS;
  
```

### Explicite form:

VHDL syntax definition:

```

CASE <cnd_signal> IS
  WHEN <c1>  => <body_c1>;
  WHEN <c2>  => <body_c2>;
  WHEN <c3>  => <body_c3>;
  WHEN OTHERS  => <body_default>;
END CASE ;
  
```

- ▶ We can also use unconditional multiplexers. Note the **OTHERS**-statement.
- ▶ <body\_c1> could be for example: <result\_signal> <= <value\_1>;
- ▶ Each selection in the explicite form can contain multiple statements (even **IF .. THEN .. ELSE .. END IF;**).

## Design example

- ▶ We now know all constructs to describe a digital system.
- ▶ Let's put it into practice; realize below functionality in VHDL:
- ▶ Of course you need to know the coding: it is binairy.



# Lecture 17

## Digital system design

VHDL Behavior(4)

*CS173 - Conception de systèmes numériques  
Mai 2017*

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Design example



# Divide and Conquer



- We can divide this problem in 3 sub-problems, namely:
  1. The addition of one bit, this is a full-adder already seen in an earlier TP.
  2. The serial control, as the bits come in one after the other, we have to keep track if we are processing bits, and when, which bit we are processing.
  3. The output control, as seen in the timing diagramm all are synchronous to the rising edge of the clock.

# Full adder



- ▶ Let's start with the simple part, the full-adder.
- ▶ Write the complete VHDL-description for this full-adder:

VHDL snippet:

```
LIBRARY ieee;
USE
ieee.std_logic_1164.all;

ENTITY FullAdder IS
```

VHDL snippet:

```
ARCHITECTURE dataflow OF
FullAdder IS
```

# Full adder



- ▶ The full-adder is super, however, there are some particularities in this system.
- ▶ When the LSB arrives, the Cin of the full-adder needs to be zero, hence:  $Cin_0 = 0$ .
- ▶ For the following bits we need to have the carry-out of the previous calculation. Hence:  $Cin_n = Cout_{n-1}$ .
- ▶ The overflow is the carry-out of the last calculation, hence:  $Overflow = Cout_n$ .

# Carry-in and Carry-out



- ▶ How to solve the problem:  $Cin_n = Cout_{n-1}$ ?
- ▶ We want the timely behavior as shown in the timing diagram.
- ▶ We can observe that Cin is the one clock cycle delayed version of Cout; we can use a D-flipflop to delay Cout. It gives us directly the overflow at the right position.
- ▶ However, Cin should be 0 at the LSB-position (when start=1), so we add following logic function.

# Datapath



- Write the complete VHDL-description of this system.

VHDL snippet:

```
LIBRARY ieee;
USE
ieee.std_logic_1164.all;

ENTITY SerialAdd IS
```

VHDL snippet:

```
ARCHITECTURE datapath OF
SerialAdd IS
```

- I could again describe the circuit of the full-adder, but is there not a way of using the already created VHDL-description?

# Components

VHDL snippet:

```
LIBRARY ieee;
USE
ieee.std_logic_1164.all;

ENTITY FullAdder IS
PORT ( A,B,Cin :  IN
std_logic;
Sum,Cout :  OUT
std_logic);
END FullAdder;
```

VHDL snippet:

```
COMPONENT FullAdder IS
PORT ( A,B,Cin :  IN
std_logic;
Sum,Cout :  OUT
std_logic);
END COMPONENT ;
```

- ▶ Yes, we can. We do this by using components.
- ▶ In the «declaration section» of an architecture we can reference the usage of the FullAdder by copying the entity description and embed it in the **COMPONENT** syntax.
- ▶ This indicates that we are going to use one or multiple instances of this hardware in the «description section» of the architecture.

# Components



- ▶ With an implicite process the combinational logic is described.
- ▶ With an explicite process the D-flipflop is described.
- ▶ Finally the component is instantiated.

VHDL snippet:

```
ARCHITECTURE datapath OF
SerialAdd IS

COMPONENT FullAdder
IS
PORT ( A,B,Cin :  IN
std_logic;
Sum,Cout :  OUT
std_logic);
END COMPONENT ;

SIGNAL
s_Cin,s_Cout,s_Cout_del :
std_logic;

BEGIN
s_Cin <= s_Cout_del
AND NOT (start);

dff :  PROCESS (
clock ) IS
BEGIN
IF
(falling_edge(clock))
THEN
s_Cout_del  <=
s_Cout;
END IF;
END PROCESS ;

add :  FullAdder
PORT MAP ( A  => A,
B  => B,
Cin  =>
s_Cin,
```

# Components



VHDL snippet:

```
add : FullAdder
PORT MAP (A => A,
           B => B,
           Cin =>
s_Cin,
           Sum =>
Sumx,
           Cout =>
s_Cout);
```

- ▶ How does it work:
- ▶ Each instance of a component needs a unique name.
- ▶ Followed by the <entity\_name> of the component.
- ▶ Then the connections are made with a **PORT MAP**.
- ▶ The names left of the => operator are the names used in the entity of the component.
- ▶ The names right of the => operator are the names of the signals in the current architecture.
- ▶ All “maps” are separated by a comma.

# Divide and conquer



- We now solved the first sub-problem of our serial adder.
- This part is called the *datapath* of the system.
- Let's continue with the control part.

# Determining the sequence



- Let us determine the state diagram.
- As long as there is no start signal there is nothing to do (we are in idle).
- After the start the LSB is calculated. And one by one the next bits.
- The sequence has ended and we are in idle again.
- Upto the moment another start indicates a new series of bits.

# What about the outputs



- ▶ What about the outputs of this finite state machine.
- ▶ We can observe that the valid is high during the states  $\text{Bit}_0 \dots \text{Bit}_3$ . So this signal is a direct output of the state machine.
- ▶ We can also observe that state  $\text{Bit}_3$  can be used to enable the storage of the overflow bit.
- ▶ We can even optimize the sequence a bit, as the state  $\text{Ov1}$  has no use, so we can jump directly from state  $\text{Bit}_3$  in state  $\text{IDLE}$ .

# Exercise



- ▶ Write the complete VHDL description for this state machine.
- ▶ The Entity is given by:

VHDL snippet:

```
LIBRARY ieee;
USE
ieee.std_logic_1164.all;

ENTITY ControlMachine
IS
PORT ( clock,start,reset :
IN std_logic;
valid,ovl : OUT
std_logic);
END ControlMachine;
```

# Many possibilities



- ▶ There are many possible implementations of this functionality.
- ▶ Do we really care about the implementation?
- ▶ Can't we just describe the functionality and let the synthesizer "pick" a implementation?
- ▶ Yes we can!

## VHDL syntax definition:

```
TYPE <type_name> IS  
(<name_1>, . . . , <name_n>) ;
```

- ▶ We can define types in VHDL in the «declaration section» of an architecture.
- ▶ The synthesizer will automatically generate a code-table for the entires included in the type definition.
- ▶ Each type needs a unique name.
- ▶ Each type is local to it's architecture.
- ▶ A type can have as many entries as required, seperated by a comma.
- ▶ The entry names must be unique and may not be a VHDL keyword.

# One description



- ▶ Let's see how it works.
- ▶ We define a type with the state names.
- ▶ We define the current and next state signals of this type.
- ▶ We assign the outputs.
- ▶ We infer the state

VHDL snippet:

```
ARCHITECTURE UseType OF
ControlMachine IS
    TYPE StateType IS
        (IDLE,BIT0,BIT1,BIT2,BIT3);
        SIGNAL s_cur_state,
        s_next_state : StateType;
    BEGIN
        Ovl <= '1' WHEN s_cur_state =
        BIT3 ELSE '0';
        Valid <= '1' WHEN s_cur_state
        = BIT0 OR
                                s_cur_state
        = BIT1 OR
                                s_cur_state
        = BIT2 OR
                                s_cur_state
        = BIT3 ELSE '0';
        dff : PROCESS ( clock )
        BEGIN
            IF (rising_edge(clock))
        THEN
            IF (reset = '1') THEN
                s_cur_state <= IDLE;
            ELSE
                s_cur_state <= s_next_state;
            END IF;
        END IF;
    END PROCESS dff;
    transition : PROCESS (
        start,s_cur_state) IS
    BEGIN
        CASE (s_cur_state) IS
            WHEN IDLE => IF (start
            = '1') THEN
                s_next_state
```

# The complete system



- Now we have solved the second problem.
- And this is how it looks like when we put all together.
- This combination is called a *FSM-D* and a simple version of a processor.

# Lecture 19

## Digital system design

VHDL Behavior(5)

*CS173 - Conception de systèmes numériques  
Mai 2017*

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

# Introduction

- ▶ In the last lecture we have seen how to make a state machine by using types.
- ▶ But what about state machines with 500+ states?
- ▶ or comparisons,
- ▶ or additions ....
- ▶ The types `std_logic` and `std_logic_vector` have no interpretation....
- ▶ Would it not be nice to have a binairy or two's complement representation?

Numbers

conversions  
operators

generics

- ▶ We have, in the **numeric\_std** package.
- ▶ To use this package we have to define before the **ENTITY** :

```
LIBRARY ieee;  
USE ieee.std_logic_1164.all;  
USE ieee.numeric_std.all;
```

- ▶ The **numeric\_std** package defines two types, namely:
  - ⇒ **unsigned(<nr\_of\_bits-1> DOWNTO 0)**  
This defines a set of *nr\_of\_bits* bits with a binary interpretation.
  - ⇒ **signed(<nr\_of\_bits-1> DOWNTO 0)**  
This defines a set of *nr\_of\_bits* bits with a two's complement interpretation.
- ▶ But how to use.....

# Conversions



- We have the **unsigned** and **signed** vectors with the same number of bits.
- We are used to use **integers**. With macros we can convert the **integers** to their binairy or two's complement representation.
- But what about the **std\_logic\_vector**?
- We can do “*type-casting*”.

# Operators

- ▶ So which operators exist:
  - ⇒ **+**: Addition. The synthesiser will realize a chain of full-adders (think about TP2).
  - ⇒ **-**: Subtraction. The synthesiser will realize a chain of full-subtractors (think about TP2).
  - ⇒ **>**: Bigger than.
  - ⇒  **$\geq$** : Bigger or equal.
  - ⇒ **<**: Smaller than.
  - ⇒  **$\leq$** : Smaller or equal.
  - ⇒ **\***: Multiplication: Never use this operator, as not all synthesisers know which hardware to generate!
  - ⇒ **/**: Division: Never use this operator, as all synthesisers don't know which hardware to generate!
  - ⇒ **sll,srl**: Shift logic left and shift logic right.
  - ⇒ **sla,sra**: Shift arithmetic left and shift arithmetic right.
  - ⇒ **rol,ror**: rotate left and rotate right.
- ▶ **Important:** Never use the above shift functions as their implementations may result in unexpected behavior (use manual concatenation instead).
- ▶ Note the order of the **=** and the **</>** symbols in the comparision, they have to be in this order!
- ▶ **Important:** Of course the types left and right of the operator need to be of same *type* and need to have the same *number of bits*!

# Exercise



- We want to design a counter with 432 states.
- The counter is reset synchronously in state 356.
- Its state diagram is given above.
- The output **X** of this state-machine is active for the states 0..10.
- Create the complete VHDL-description for this counter.

# Exercise

Digital system  
design

Prof. Dr. Theo  
Kluter

Numbers

conversions

operators

generics

# Another one



- We want to design a counter with 894 states.
- The counter is reset synchronously in state 513.
- Its state diagram is given above.
- The output **X** of this state-machine is active for the states 0..50.
- Create the complete VHDL-description for this counter.
- Not again, can't we do something more intelligent?

# Another one



- ▶ Where are the differences between this counter and the previous one:
  - ⇒ The number states.
  - ⇒ The number of bits required.
  - ⇒ The reset state.
  - ⇒ The number of states required for the output.
- ▶ Would it not be nice to be able to parameterize a component?

## VHDL syntax definition:

```
ENTITY <name> IS
  GENERIC ( <list> );
  PORT ( <list> );
END <name>;
```

Digital system  
design

Prof. Dr. Theo  
Kluter

Numbers  
conversions  
operators

generics

- ▶ Yes we can, we can insert a **GENERIC** block in the **ENTITY** definition.
- ▶ In the **GENERIC** block we can define the parameters.
- ▶ And as such we can describe a parameterized circuit description.
- ▶ Note that the parameters are *fixed* the moment a component is used, as there exist no such thing as dynamic hardware.
- ▶ So how to use this for our counter?

# Generics

VHDL snippet:

```
ENTITY GenericCounter IS
    GENERIC ( MaxState : INTEGER;
                NrOfBits : INTEGER;
                ResetState : INTEGER;
                OutState : INTEGER);
    PORT ( clock,reset,e : IN std_logic;
            X : OUT std_logic);
END GenericCounter;
```

- ▶ What were the parameters:
  - ⇒ The number states.
  - ⇒ The number of bits required.
  - ⇒ The reset state.
  - ⇒ The number of states required for the output.
- ▶ **Note :** As in the port declaration also the last line in the generic declaration is not ended with a ;!

# Exercise

VHDL snippet:

```
ENTITY GenericCounter IS
  GENERIC ( MaxState : INTEGER;
              NrOfBits : INTEGER;
              ResetState : INTEGER;
              OutState : INTEGER);
  PORT ( clock,reset,e : IN std_logic;
          X : OUT std_logic);
END GenericCounter;
```

- ▶ Modify your architecture such that it uses the above parameters.

# Exercise

Digital system  
design

Prof. Dr. Theo  
Kluter

Numbers

conversions  
operators

generics

# How to use

VHDL snippet:

```
Example1 : GenericCounter
  GENERIC MAP ( MaxState
=> 432,
                NrOfBits
=> 9,
                ResetState
=> 356,
                OutState
=> 10 )
  PORT MAP ( ... );
```

VHDL snippet:

```
Example2 : GenericCounter
  GENERIC MAP ( MaxState
=> 894,
                NrOfBits
=> 10,
                ResetState
=> 513,
                OutState
=> 50 )
  PORT MAP ( ... );
```

- ▶ We can now instantiate in an architecture the parameterized versions of the generic counter as shown above.
- ▶ **Important:** After the closing ) of the **GENERIC MAP** and the start of the **PORT MAP** there is no ;!

# Lecture 19

## Digital system design

VHDL Behavior(5)

*CS173 - Conception de systèmes numériques*  
May 2018

Numbers  
conversions  
operators  
generics

Prof. Dr. Theo Kluter  
Bern University of Applied Sciences

- ▶ In the last lecture we have seen how to make a state machine by using types.

- ▶ In the last lecture we have seen how to make a state machine by using types.
- ▶ But what about state machines with 500+ states?

- ▶ In the last lecture we have seen how to make a state machine by using types.
- ▶ But what about state machines with 500+ states?
- ▶ or comparisons,

- ▶ In the last lecture we have seen how to make a state machine by using types.
- ▶ But what about state machines with 500+ states?
- ▶ or comparisons,
- ▶ or additions ....

- ▶ In the last lecture we have seen how to make a state machine by using types.
- ▶ But what about state machines with 500+ states?
- ▶ or comparisons,
- ▶ or additions ....
- ▶ The types `std_logic` and `std_logic_vector` have no interpretation....

**Numbers**

conversions

operators

generics

- ▶ In the last lecture we have seen how to make a state machine by using types.
- ▶ But what about state machines with 500+ states?
- ▶ or comparisons,
- ▶ or additions ....
- ▶ The types `std_logic` and `std_logic_vector` have no interpretation....
- ▶ Would it not be nice to have a binary or two's complement representation?

## arithmetic

- We have, in the **numeric\_std** package.

Numbers

conversions

operators

generics

- ▶ We have, in the **numeric\_std** package.
- ▶ To use this package we have to define before the **ENTITY** :

```
LIBRARY ieee;  
USE ieee.std_logic_1164.all;  
USE ieee.numeric_std.all;
```

Numbers

conversions

operators

generics

- ▶ We have, in the **numeric\_std** package.
- ▶ To use this package we have to define before the **ENTITY** :

```
LIBRARY ieee;  
USE ieee.std_logic_1164.all;  
USE ieee.numeric_std.all;
```

- ▶ The **numeric\_std** package defines two types, namely:

- ▶ We have, in the **numeric\_std** package.
- ▶ To use this package we have to define before the **ENTITY** :

```
LIBRARY ieee;  
USE ieee.std_logic_1164.all;  
USE ieee.numeric_std.all;
```

- ▶ The **numeric\_std** package defines two types, namely:
  - ➡ **unsigned(<nr\_of\_bits-1> DOWNTO 0)**  
This defines a set of *nr\_of\_bits* bits with a binairy interpretation.

- ▶ We have, in the **numeric\_std** package.
- ▶ To use this package we have to define before the **ENTITY** :

```
LIBRARY ieee;  
USE ieee.std_logic_1164.all;  
USE ieee.numeric_std.all;
```

- ▶ The **numeric\_std** package defines two types, namely:
  - ⇒ **unsigned(<nr\_of\_bits-1> DOWNTO 0)**  
This defines a set of *nr\_of\_bits* bits with a binairy interpretation.
  - ⇒ **signed(<nr\_of\_bits-1> DOWNTO 0)**  
This defines a set of *nr\_of\_bits* bits with a two's complement interpretation.

- ▶ We have, in the **numeric\_std** package.
- ▶ To use this package we have to define before the **ENTITY** :

```
LIBRARY ieee;  
USE ieee.std_logic_1164.all;  
USE ieee.numeric_std.all;
```

- ▶ The **numeric\_std** package defines two types, namely:
  - ⇒ **unsigned(<nr\_of\_bits-1> DOWNTO 0)**  
This defines a set of *nr\_of\_bits* bits with a binairy interpretation.
  - ⇒ **signed(<nr\_of\_bits-1> DOWNTO 0)**  
This defines a set of *nr\_of\_bits* bits with a two's complement interpretation.
- ▶ But how to use.....

`signed( <nr_of_bits-1) DOWNTO 0)`

`unsigned( <nr_of_bits-1) DOWNTO 0)`

- We have the **unsigned** and **signed** vectors with the same number of bits.

`signed( <nr_of_bits-1) DOWNTO 0)`

`unsigned( <nr_of_bits-1) DOWNTO 0)`

Integer

- ▶ We have the **unsigned** and **signed** vectors with the same number of bits.
- ▶ We are used to use **integers**.

to\_unsigned(127, 3);  
to\_unsigned(-3, 3);



- We have the **unsigned** and **signed** vectors with the same number of bits.
- We are used to use **integers**. With macros we can convert the **integers** to their binairy or two's complement representation.



- ▶ We have the **unsigned** and **signed** vectors with the same number of bits.
- ▶ We are used to use **integers**. With macros we can convert the **integers** to their binairy or two's complement representation.



- We have the **unsigned** and **signed** vectors with the same number of bits.
- We are used to use **integers**. With macros we can convert the **integers** to their binairy or two's complement representation.
- But what about the **std\_logic\_vector**?



- We have the **unsigned** and **signed** vectors with the same number of bits.
- We are used to use **integers**. With macros we can convert the **integers** to their binairy or two's complement representation.
- But what about the **std\_logic\_vector**?
- We can do “*type-casting*”.



- We have the **unsigned** and **signed** vectors with the same number of bits.
- We are used to use **integers**. With macros we can convert the **integers** to their binairy or two's complement representation.
- But what about the **std\_logic\_vector**?
- We can do “*type-casting*”.



- We have the **unsigned** and **signed** vectors with the same number of bits.
- We are used to use **integers**. With macros we can convert the **integers** to their binairy or two's complement representation.
- But what about the **std\_logic\_vector**?
- We can do “*type-casting*”.

- ▶ So which operators exist:

Numbers

conversions

operators

generics

- So which operators exist:

- ⇒ +: Addition. The synthesiser will realize a chain of full-adders (think about TP2).

Numbers

conversions

operators

generics

► So which operators exist:

- ⇒  $+$ : Addition. The synthesiser will realize a chain of full-adders (think about TP2).
- ⇒  $-$ : Subtraction. The synthesiser will realize a chain of full-subtractors (think about TP2).

Numbers  
conversions  
**operators**  
generics

► So which operators exist:

- ➡  $+$ : Addition. The synthesiser will realize a chain of full-adders (think about TP2).
- ➡  $-$ : Subtraction. The synthesiser will realize a chain of full-subtractors (think about TP2).
- ➡  $>$ : Bigger than.
- ➡  $\geq$ : Bigger or equal.
- ➡  $<$ : Smaller than.
- ➡  $\leq$ : Smaller or equal.

► So which operators exist:

- ⇒  $+$ : Addition. The synthesiser will realize a chain of full-adders (think about TP2).
- ⇒  $-$ : Subtraction. The synthesiser will realize a chain of full-subtractors (think about TP2).
- ⇒  $>$ : Bigger than.
- ⇒  $\geq$ : Bigger or equal.
- ⇒  $<$ : Smaller than.
- ⇒  $\leq$ : Smaller or equal.
- ⇒  $*$ : Multiplication: Never use this operator, as not all synthesisers know which hardware to generate!
- ⇒  $/$ : Division: Never use this operator, as all synthesisers don't know which hardware to generate!

► So which operators exist:

- ⇒ **+**: Addition. The synthesiser will realize a chain of full-adders (think about TP2).
- ⇒ **-**: Subtraction. The synthesiser will realize a chain of full-subtractors (think about TP2).
- ⇒ **>**: Bigger than.
- ⇒  **$\geq$** : Bigger or equal.
- ⇒ **<**: Smaller than.
- ⇒  **$\leq$** : Smaller or equal.
- ⇒ **\***: Multiplication: Never use this operator, as not all synthesisers know which hardware to generate!
- ⇒ **/**: Division: Never use this operator, as all synthesisers don't know which hardware to generate!
- ⇒ **sll,srl**: Shift logic left and shift logic right.
- ⇒ **sla,sra**: Shift arithmetic left and shift arithmetic right.
- ⇒ **rol,ror**: rotate left and rotate right.

**Important:** Never use the above shift functions as their implementations may result in unexpected behavior (use manual concatenation instead).

- ▶ So which operators exist:
  - ⇒ **+**: Addition. The synthesiser will realize a chain of full-adders (think about TP2).
  - ⇒ **-**: Subtraction. The synthesiser will realize a chain of full-subtractors (think about TP2).
  - ⇒ **>**: Bigger than.
  - ⇒  **$\geq$** : Bigger or equal.
  - ⇒ **<**: Smaller than.
  - ⇒  **$\leq$** : Smaller or equal.
  - ⇒ **\***: Multiplication: Never use this operator, as not all synthesisers know which hardware to generate!
  - ⇒ **/**: Division: Never use this operator, as all synthesisers don't know which hardware to generate!
  - ⇒ **sll,srl**: Shift logic left and shift logic right.
  - ⇒ **sla,sra**: Shift arithmetic left and shift arithmetic right.
  - ⇒ **rol,ror**: rotate left and rotate right.  
**Important:** Never use the above shift functions as their implementations may result in unexpected behavior (use manual concatenation instead).
- ▶ Note the order of the **=** and the **</>** symbols in the comparison, they have to be in this order!

- ▶ So which operators exist:
  - ⇒ **+**: Addition. The synthesiser will realize a chain of full-adders (think about TP2).
  - ⇒ **-**: Subtraction. The synthesiser will realize a chain of full-subtractors (think about TP2).
  - ⇒ **>**: Bigger than.
  - ⇒  **$\geq$** : Bigger or equal.
  - ⇒ **<**: Smaller than.
  - ⇒  **$\leq$** : Smaller or equal.
  - ⇒ **\***: Multiplication: Never use this operator, as not all synthesisers know which hardware to generate!
  - ⇒ **/**: Division: Never use this operator, as all synthesisers don't know which hardware to generate!
  - ⇒ **sll,srl**: Shift logic left and shift logic right.
  - ⇒ **sla,sra**: Shift arithmetic left and shift arithmetic right.
  - ⇒ **rol,ror**: rotate left and rotate right.  
**Important:** Never use the above shift functions as their implementations may result in unexpected behavior (use manual concatenation instead).
- ▶ Note the order of the **=** and the **</>** symbols in the comparison, they have to be in this order!
- ▶ *Important:* Of course the types left and right of the operator need to be of same *type* and need to have the same *number of bits*!



- We want to design a counter with 432 states.
- The counter is reset synchronously in state 356.
- Its state diagram is given above.
- The output **X** of this state-machine is active for the states 0..10.
- Create the complete VHDL-description for this counter.



$$\begin{aligned}
 R_{01} \log e &= 50 \text{ MHz} & T_p &= 20 \text{ ns} \\
 T_d &= 10 \text{ ns} & T_2 &= 10 \text{ ns} \\
 DC &= 50\%
 \end{aligned}$$



```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
USE ieee.numeric_std.all;
```

```
ENTITY counter IS
  GENERIC( NrBits : INTEGER;
           NrDesEtats : INTEGER;
           ResetState : INTEGER;
           ValueSortie : INTEGER );
  PORT( E,reset,clock : IN std_logic;
        X : OUT std_logic );
END counter;

ARCHITECTURE behave OF counter IS
  SIGNAL s_next,s_current : unsigned( (NrBits-1) DOWNTO 0 );

  BEGIN
    -- output logic:
    X <= '1' WHEN s_current < to_unsigned(ValueSortie,NrBits) ELSE '0';

    -- transition logic
    s_next <= s_current WHEN E = '0' ELSE
      to_unsigned(NrDesEtats-1,NrBits) WHEN s_current = to_unsigned(0,NrBits) ELSE
      s_current - to_unsigned(1,NrBits);

    -- Flipflops:
    dff : PROCESS ( clock ) IS
    BEGIN
      IF (rising_edge(clock)) THEN
        IF (reset = '1') THEN s_current <= to_unsigned(ResetState,NrBits);
        ELSE s_current <= s_next;
      END IF;
    END IF;
  END PROCESS dff;
END behave;
```

cnt1: counter  
GENERIC MAP ( NrBits => 9,  
NrDesEtats => 432,  
ResetState => 356,  
ValueSortie => 11)  
PORT MAP();



- ▶ We want to design a counter with 894 states.
- ▶ The counter is reset synchronously in state 513.
- ▶ Its state diagram is given above.
- ▶ The output **X** of this state-machine is active for the states 0..50.
- ▶ Create the complete VHDL-description for this counter.

## Another one



- We want to design a counter with 894 states.
- The counter is reset synchronously in state 513.
- Its state diagram is given above.
- The output **X** of this state-machine is active for the states 0..50.
- Create the complete VHDL-description for this counter.
- Not again, can't we do something more intelligent?

## Another one



- Where are the differences between this counter and the previous one:

## Another one



- Where are the differences between this counter and the previous one:
  - ➡ The number states.

## Another one



- ▶ Where are the differences between this counter and the previous one:
  - ➡ The number states.
  - ➡ The number of bits required.



- ▶ Where are the differences between this counter and the previous one:
  - ➡ The number states.
  - ➡ The number of bits required.
  - ➡ The reset state.



- ▶ Where are the differences between this counter and the previous one:
  - ➡ The number states.
  - ➡ The number of bits required.
  - ➡ The reset state.
  - ➡ The number of states required for the output.



- ▶ Where are the differences between this counter and the previous one:
  - ➡ The number states.
  - ➡ The number of bits required.
  - ➡ The reset state.
  - ➡ The number of states required for the output.
- ▶ Would it not be nice to be able to parameterize a component?

VHDL syntax definition:

```
ENTITY <name> IS
  GENERIC ( <list> );
  PORT ( <list> );
END <name>;
```

Numbers  
conversions  
operators  
generics

- ▶ Yes we can, we can insert a **GENERIC** block in the **ENTITY** definition.

## VHDL syntax definition:

```
ENTITY <name> IS
  GENERIC ( <list> );
  PORT ( <list> );
END <name>;
```

Numbers  
conversions  
operators  
generics

- ▶ Yes we can, we can insert a **GENERIC** block in the **ENTITY** definition.
- ▶ In the **GENERIC** block we can define the parameters.

VHDL syntax definition:

```
ENTITY <name> IS
  GENERIC ( <list> );
  PORT ( <list> );
END <name>;
```

Numbers  
conversions  
operators  
generics

- ▶ Yes we can, we can insert a **GENERIC** block in the **ENTITY** definition.
- ▶ In the **GENERIC** block we can define the parameters.
- ▶ And as such we can describe a parameterized circuit description.

VHDL syntax definition:

```
ENTITY <name> IS
  GENERIC ( <list> );
  PORT ( <list> );
END <name>;
```

Numbers  
conversions  
operators  
generics

- ▶ Yes we can, we can insert a **GENERIC** block in the **ENTITY** definition.
- ▶ In the **GENERIC** block we can define the parameters.
- ▶ And as such we can describe a parameterized circuit description.
- ▶ Note that the parameters are *fixed* the moment a component is used, as there exist no such thing as dynamic hardware.

## VHDL syntax definition:

```
ENTITY <name> IS
  GENERIC ( <list> );
  PORT ( <list> );
END <name>;
```

Numbers  
conversions  
operators  
generics

- ▶ Yes we can, we can insert a **GENERIC** block in the **ENTITY** definition.
- ▶ In the **GENERIC** block we can define the parameters.
- ▶ And as such we can describe a parameterized circuit description.
- ▶ Note that the parameters are *fixed* the moment a component is used, as there exist no such thing as dynamic hardware.
- ▶ So how to use this for our counter?

VHDL snippet:

```
ENTITY GenericCounter IS
    GENERIC (
        );
    PORT ( clock,reset,e :  IN std_logic;
           X : OUT std_logic);
END GenericCounter;
```

Numbers  
conversions  
operators  
generics

- ▶ What were the parameters:

VHDL snippet:

```
ENTITY GenericCounter IS
    GENERIC ( MaxState : INTEGER;
              );
    PORT ( clock,reset,e : IN std_logic;
            X : OUT std_logic);
END GenericCounter;
```

Numbers  
conversions  
operators  
generics

- ▶ What were the parameters:
  - ⇒ The number states.

VHDL snippet:

```
ENTITY GenericCounter IS
    GENERIC ( MaxState : INTEGER;
              NrOfBits : INTEGER;
              );
    PORT ( clock,reset,e : IN std_logic;
           X : OUT std_logic);
END GenericCounter;
```

Numbers  
conversions  
operators

generics

- ▶ What were the parameters:
  - ⇒ The number states.
  - ⇒ The number of bits required.

VHDL snippet:

```
ENTITY GenericCounter IS
    GENERIC ( MaxState : INTEGER;
              NrOfBits : INTEGER;
              ResetState : INTEGER;
              );
    PORT ( clock,reset,e : IN std_logic;
           X : OUT std_logic);
END GenericCounter;
```

Numbers  
conversions  
operators  
generics

► What were the parameters:

- ➡ The number states.
- ➡ The number of bits required.
- ➡ The reset state.

VHDL snippet:

```
ENTITY GenericCounter IS
    GENERIC ( MaxState : INTEGER;
              NrOfBits : INTEGER;
              ResetState : INTEGER;
              OutState : INTEGER);
    PORT ( clock,reset,e : IN std_logic;
           X : OUT std_logic);
END GenericCounter;
```

Numbers  
conversions  
operators  
generics

- ▶ What were the parameters:
  - ⇒ The number states.
  - ⇒ The number of bits required.
  - ⇒ The reset state.
  - ⇒ The number of states required for the output.

VHDL snippet:

```
ENTITY GenericCounter IS
    GENERIC ( MaxState :  INTEGER;
              NrOfBits :  INTEGER;
              ResetState :  INTEGER;
              OutState :  INTEGER);
    PORT ( clock,reset,e :  IN std_logic;
           X : OUT std_logic);
END GenericCounter;
```

Numbers  
conversions  
operators  
generics

- ▶ What were the parameters:
  - ⇒ The number states.
  - ⇒ The number of bits required.
  - ⇒ The reset state.
  - ⇒ The number of states required for the output.
- ▶ **Note :** As in the port declaration also the last line in the generic declaration is not ended with a ;!

VHDL snippet:

```
ENTITY GenericCounter IS
  GENERIC ( MaxState :  INTEGER;
            NrOfBits :  INTEGER;
            ResetState :  INTEGER;
            OutState :  INTEGER);
  PORT ( clock,reset,e :  IN std_logic;
         X : OUT std_logic);
END GenericCounter;
```

Numbers  
conversions  
operators  
generics

- ▶ Modify your architecture such that it uses the above parameters.

Numbers

conversions

operators

generics

VHDL snippet:

```
Example1 : GenericCounter
  GENERIC MAP ( MaxState  => 432,
                 NrOfBits  => 9,
                 ResetState => 356,
                 OutState   => 10 )
  PORT MAP ( ... );
```

VHDL snippet:

```
Example2 : GenericCounter
  GENERIC MAP ( MaxState  => 894,
                 NrOfBits  => 10,
                 ResetState => 513,
                 OutState   => 50 )
  PORT MAP ( ... );
```

Numbers  
conversions  
operators  
**generics**

- We can now instantiate in an architecture the parameterized versions of the generic counter as shown above.

VHDL snippet:

```
Example1 : GenericCounter
  GENERIC MAP ( MaxState  => 432,
                 NrOfBits  => 9,
                 ResetState => 356,
                 OutState   => 10 )
  PORT MAP ( ... );
```

VHDL snippet:

```
Example2 : GenericCounter
  GENERIC MAP ( MaxState  => 894,
                 NrOfBits  => 10,
                 ResetState => 513,
                 OutState   => 50 )
  PORT MAP ( ... );
```

Numbers  
conversions  
operators  
**generics**

- ▶ We can now instantiate in an architecture the parameterized versions of the generic counter as shown above.
- ▶ **Important:** After the closing ) of the **GENERIC MAP** and the start of the **PORT MAP** there is no ;!