

Computation model  
○○○○○○○

Addition

Addition  
○○○○

Comparator networks  
○

# Algorithms and datastructures II

## Lecture 5: circuit complexity 1/2

Jan Hubička

Department of Applied Mathematics  
Charles University  
Prague

Nov 2 2020

## Parallel computing

Moore's Law – The number of transistors on integrated circuit chips (1971-2018)

Moore's law describes the empirical regularity that the number of transistors on integrated circuits doubles approximately every two years. This advancement is important as other aspects of technological progress – such as processing speed or the price of electronic products – are linked to Moore's law.



Data source: Wikipedia ([https://en.wikipedia.org/wiki/Transistor\\_count](https://en.wikipedia.org/wiki/Transistor_count))

The data visualization is available at [OurWorldInData.org](http://OurWorldInData.org). There you find more visualizations and research on this topic.

Licensed under CC-BY-SA by the author Max Roser.

Computation model  
○○○○○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Parallel computing

48 Years of Microprocessor Trend Data



Original data up to the year 2010 collected and plotted by M. Horowitz, F. Labonte, O. Shacham, K. Olukotun, L. Hammond, and C. Batten  
New plot and data collected for 2010-2019 by K. Rupp

Computation model  
●○○○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model: gate

Computation model  
○●○○○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model: circuit

Computation model  
○○●○○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model: example

Compute majority of three 1 bit inputs.

$$\text{maj}(1, 1, 0) = \text{maj}(1, 0, 1) = \text{maj}(0, 1, 1) = \text{maj}(1, 1, 1) = 1$$

$$\text{maj}(0, 0, 1) = \text{maj}(0, 1, 0) = \text{maj}(1, 0, 0) = \text{maj}(0, 0, 0) = 0$$

Computation model  
○○○●○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model

Informally circuits consists of gates connected by wires. Every wire transfer a value in alphabet  $\Sigma$ .

Computation model  
○○○●○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model

Informally circuits consists of gates connected by wires. Every wire transfer a value in alphabet  $\Sigma$ .

### Definition (Circuit)

**Circuit** is defined by:

- ① Alphabet  $\Sigma$ .
- ② Pairwise disjoint set of vertices  $I$  (input),  $O$  (output) and  $H$  (gate).

Computation model  
○○○●○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model

Informally circuits consists of gates connected by wires. Every wire transfer a value in alphabet  $\Sigma$ .

### Definition (Circuit)

**Circuit** is defined by:

- ① Alphabet  $\Sigma$ .
- ② Pairwise disjoint set of vertices  $I$  (input),  $O$  (output) and  $H$  (gate).
- ③ Acyclic directed multi-graph  $(V, E)$  with  $E = I \cup O \cup H$ .

# Computational model

Informally circuits consists of gates connected by wires. Every wire transfer a value in alphabet  $\Sigma$ .

## Definition (Circuit)

**Circuit** is defined by:

- ① Alphabet  $\Sigma$ .
- ② Pairwise disjoint set of vertices  $I$  (input),  $O$  (output) and  $H$  (gate).
- ③ Acyclic directed multi-graph  $(V, E)$  with  $E = I \cup O \cup H$ .
- ④ Mapping  $F$  which assign every gate  $g \in H$  of arity  $a(g)$  a function  $F(g) : \Sigma^{a(g)} \rightarrow \Sigma$ .

Computation model  
○○○●○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model

Informally circuits consists of gates connected by wires. Every wire transfer a value in alphabet  $\Sigma$ .

### Definition (Circuit)

**Circuit** is defined by:

- ① Alphabet  $\Sigma$ .
- ② Pairwise disjoint set of vertices  $I$  (input),  $O$  (output) and  $H$  (gate).
- ③ Acyclic directed multi-graph  $(V, E)$  with  $E = I \cup O \cup H$ .
- ④ Mapping  $F$  which assign every gate  $g \in H$  of arity  $a(g)$  a function  $F(g) : \Sigma^{a(g)} \rightarrow \Sigma$ .
- ⑤ Mapping  $z : E \rightarrow \mathbb{N}$  which maps every edge to a gate to index which argument it represents.

Computation model  
○○○●○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model

Informally circuits consists of gates connected by wires. Every wire transfer a value in alphabet  $\Sigma$ .

### Definition (Circuit)

**Circuit** is defined by:

- ① Alphabet  $\Sigma$ .
- ② Pairwise disjoint set of vertices  $I$  (input),  $O$  (output) and  $H$  (gate).
- ③ Acyclic directed multi-graph  $(V, E)$  with  $E = I \cup O \cup H$ .
- ④ Mapping  $F$  which assign every gate  $g \in H$  of arity  $a(g)$  a function  $F(g) : \Sigma^{a(g)} \rightarrow \Sigma$ .
- ⑤ Mapping  $z : E \rightarrow \mathbb{N}$  which maps every edge to a gate to index which argument it represents.

# Computational model

Informally circuits consists of gates connected by wires. Every wire transfer a value in alphabet  $\Sigma$ .

## Definition (Circuit)

**Circuit** is defined by:

- ① Alphabet  $\Sigma$ .
- ② Pairwise disjoint set of vertices  $I$  (input),  $O$  (output) and  $H$  (gate).
- ③ Acyclic directed multi-graph  $(V, E)$  with  $E = I \cup O \cup H$ .
- ④ Mapping  $F$  which assign every gate  $g \in H$  of arity  $a(g)$  a function  $F(g) : \Sigma^{a(g)} \rightarrow \Sigma$ .
- ⑤ Mapping  $z : E \rightarrow \mathbb{N}$  which maps every edge to a gate to index which argument it represents.

Satisfying:

- ① In-degree of vertices in  $I$  is 0.
- ② In-degree of vertices in  $O$  is 1 and out-degree is 0.
- ③ In-degree of every gate corresponds to its arity. Out-degree of every gate is at least 1.
- ④ Every input of every gate is assigned.

Computation model  
○○○○●○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model: computation

### Definition (Computation)

Computation happens in steps (clocks):

- ① step 0: All inputs and constants gets assigned value.
- ② step  $i + 1$ : Assign value to all gates and outputs for which all inputs are determined at step  $i$ .

Computation ends once all vertices have value assigned.

Computation model  
○○○○●○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model: computation

### Definition (Computation)

Computation happens in steps (clocks):

- ① step 0: All inputs and constants gets assigned value.
- ② step  $i + 1$ : Assign value to all gates and outputs for which all inputs are determined at step  $i$ .

Computation ends once all vertices have value assigned.

### Definition (Layer)

Layer  $i$  consist of all vertices whose value is determined in step  $i$ .

Layer is also maximal distance from some input.

Computation model  
○○○○●○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model: computation

### Definition (Computation)

Computation happens in steps (clocks):

- ① step 0: All inputs and constants gets assigned value.
- ② step  $i + 1$ : Assign value to all gates and outputs for which all inputs are determined at step  $i$ .

Computation ends once all vertices have value assigned.

### Definition (Layer)

Layer  $i$  consist of all vertices whose value is determined in step  $i$ .

Layer is also maximal distance from some input.

### Definition (Time complexity)

Time of the computation of a given circuit is determined by the number of layers.

Computation model  
○○○○●○○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model: computation

### Definition (Computation)

Computation happens in steps (clocks):

- ① step 0: All inputs and constants gets assigned value.
- ② step  $i + 1$ : Assign value to all gates and outputs for which all inputs are determined at step  $i$ .

Computation ends once all vertices have value assigned.

### Definition (Layer)

Layer  $i$  consist of all vertices whose value is determined in step  $i$ .

Layer is also maximal distance from some input.

### Definition (Time complexity)

Time of the computation of a given circuit is determined by the number of layers.

### Definition (Space complexity)

Space of the computation is determined by the number of gates in the circuit.

Computation model  
○○○○●○

Addition

Addition  
○○○○

Comparator networks  
○

## Computational model: program

### Definition (Program)

**Program** is a sequence of circuits for individual sizes of inputs.

## Computational model: program

### Definition (Program)

Program is a sequence of circuits for individual sizes of inputs.

Remarks:

- ① It is necessary to restrict types of allowed gates (or their arity) and  $\Sigma$ . Otherwise every problem can be solved by a single gate.
- ② Typically we want network for a given size to be generated by an effective non-parallel algorithm.  
We will typically consider boolean circuits where  $\Sigma = \{0, 1\}$  and arity is at most 2.

Computation model  
○○○○○●

Addition

Addition  
○○○○

Comparator networks  
○

Computational model: example (determine if there is 1 in input)

Computation model  
○○○○○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Addition using boolean circuit

Add  $(x_1, x_2, \dots, x_n; y_1, y_2, \dots, y_n)$

**Input:** numbers  $x$  and  $y$  in binary representation.

**Output:** number  $z = x + y$  represented as  $z_1, z_2, \dots, z_{n+1}$ .

Computation model  
○○○○○○○

Addition

Addition  
○○○○

Comparator networks  
○

## Addition using boolean circuit

Add  $(x_1, x_2, \dots, x_n; y_1, y_2, \dots, y_n)$

**Input:** numbers  $x$  and  $y$  in binary representation.

**Output:** number  $z = x + y$  represented as  $z_1, z_2, \dots, z_{n+1}$ .

We will use temporary carry bit information  $c_1, c_2, \dots, c_n$ .

Computation model  
○○○○○○○

Addition

Addition  
●○○○

Comparator networks  
○

# Addition using boolean circuit: simple solution

Computation model  
○○○○○○○

Addition

Addition  
○●○○

Comparator networks  
○

## Addition using boolean circuit: blocks and carry bits

Behaviour of block  $j \dots i$  is a function:

$$b(j, i) = \begin{cases} 0 & \text{output carry bit is always 0} \end{cases}$$

## Addition using boolean circuit: blocks and carry bits

Behaviour of block  $j \dots i$  is a function:

$$b(j, i) = \begin{cases} 0 & \text{output carry bit is always 0} \\ 1 & \text{output carry bit is always 1} \end{cases}$$

## Addition using boolean circuit: blocks and carry bits

Behaviour of block  $j \dots i$  is a function:

$$b(j, i) = \begin{cases} 0 & \text{output carry bit is always 0} \\ 1 & \text{output carry bit is always 1} \\ < & \text{output carry bit is same as input carry bit} \end{cases}$$

## Addition using boolean circuit: blocks and carry bits

Behaviour of block  $j \dots i$  is a function:

$$b(j, i) = \begin{cases} 0 & \text{output carry bit is always 0} \\ 1 & \text{output carry bit is always 1} \\ < & \text{output carry bit is same as input carry bit} \end{cases}$$

Behaviour of trivial blocks

Computation model  
○○○○○○○

Addition

Addition  
○●○○

Comparator networks  
○

## Addition using boolean circuit: blocks and carry bits

Behaviour of block  $j \dots i$  is a function:

$$b(j, i) = \begin{cases} 0 & \text{output carry bit is always 0} \\ 1 & \text{output carry bit is always 1} \\ < & \text{output carry bit is same as input carry bit} \end{cases}$$

Behaviour of trivial blocks

Composing behaviours of two adjacent blocks

|   | 0 | 1 | c |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 |
| < | 0 | 1 | < |

## Addition using boolean circuit: blocks and carry bits

Behaviour of block  $j \dots i$  is a function:

$$b(j, i) = \begin{cases} 0 & \text{output carry bit is always 0} \\ 1 & \text{output carry bit is always 1} \\ < & \text{output carry bit is same as input carry bit} \end{cases}$$

Behaviour of trivial blocks

Composing behaviours of two adjacent blocks

|   | 0 | 1 | c |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 |
| < | 0 | 1 | < |

Encoding behaviour as a binary function  $(p, q)$ :

$$(1, *) = < \quad (0, 0) = 0 \quad (0, 1) = 1$$

Computation model  
○○○○○○○

Addition

Addition  
○●○○

Comparator networks  
○

## Addition using boolean circuit: blocks and carry bits

Behaviour of block  $j \dots i$  is a function:

$$b(j, i) = \begin{cases} 0 & \text{output carry bit is always 0} \\ 1 & \text{output carry bit is always 1} \\ < & \text{output carry bit is same as input carry bit} \end{cases}$$

Behaviour of trivial blocks

Composing behaviours of two adjacent blocks

|   | 0 | 1 | c |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 1 | 1 | 1 | 1 |
| < | 0 | 1 | < |

Encoding behaviour as a binary function  $(p, q)$ :

$$(1, *) = < \quad (0, 0) = 0 \quad (0, 1) = 1$$

Composition:

$$p = p_U \text{ and } p_L$$

$$q = (\neg p_U \text{ and } q_L) \text{ or } (p_U \text{ and } q_L)$$

Computation model  
oooooooo

## Addition

## Addition

## Comparator networks

## Addition using boolean circuit: example

Computation model  
○○○○○○○

Addition

Addition  
○○○●

Comparator networks  
○

## Addition using boolean circuit: summary

Basic steps of algorithm:

- Determine behaviour of all **canonical** blocks  
(block is canonical if its size and position is power of 2)
  - 1  $\Theta(1)$  layers to determine behaviour of blocks of size 1.
  - 2  $\Theta(\log n)$  layers to determine behaviour of remaining canonical blocks.

Computation model  
○○○○○○○

Addition

Addition  
○○○●

Comparator networks  
○

## Addition using boolean circuit: summary

Basic steps of algorithm:

- Determine behaviour of all **canonical** blocks  
(block is canonical if its size and position is power of 2)
  - ➊  $\Theta(1)$  layers to determine behaviour of blocks of size 1.
  - ➋  $\Theta(\log n)$  layers to determine behaviour of remaining canonical blocks.
- Determine carry bits  $c_0, c_1, \dots, c_n$ 
  - ➊  $\Theta(\log n)$  layers.

## Addition using boolean circuit: summary

Basic steps of algorithm:

- Determine behaviour of all **canonical** blocks  
(block is canonical if its size and position is power of 2)
  - ➊  $\Theta(1)$  layers to determine behaviour of blocks of size 1.
  - ➋  $\Theta(\log n)$  layers to determine behaviour of remaining canonical blocks.
- Determine carry bits  $c_0, c_1, \dots, c_n$ 
  - ➊  $\Theta(\log n)$  layers.
- Determine final result  $z_i = x_i \oplus y_i \oplus c_i$ .

Computation model  
○○○○○○○

Addition

Addition  
○○○○

Comparator networks  
●

Computation model  
○○○○○○○

Addition

Addition  
○○○○

Comparator networks  
●

## Comparator networks: An example

$\Sigma$  consists of values being sorted.

Comparators are “gates” with two inputs and two outputs.

Computation model  
○○○○○○○

Addition

Addition  
○○○○

Comparator networks  
●

## Comparator networks: An example

$\Sigma$  consists of values being sorted.

Comparators are “gates” with two inputs and two outputs.

Example: Bubble sort

Computation model  
○○○○○○○

Addition

Addition  
○○○○

Comparator networks  
●

## Comparator networks: An example

$\Sigma$  consists of values being sorted.

Comparators are “gates” with two inputs and two outputs.

Example: Bubble sort

Next time: an effective sorting algorithm.