

## Logic Synthesis

Page No. \_\_\_\_\_  
Date \_\_\_\_\_

→ RTL to gate level net or netlist?

How to represent?

(i) Truth table = Not practical

$f_{ON}$   
 $f_{OFF}$

Reduce to minterms, maxterms  
 $(f_{ON})$        $(f_{OFF})$

This is called textual way of repr

(ii) Graphical

BDD - Binary Decision Diagram

⇒ Shannon's expression

$$f(x_1, \dots, x_n) = x_i \cdot f(x_1, \dots, \bar{x}_i=0, \dots, x_n)$$

$$+ \bar{x}_i \cdot f(x_1, \dots, \bar{x}_i=1, \dots, x_n)$$

=  $x_i$  cofactor +  $\bar{x}_i$  co-kernel

$$= x_i f_{x_i} + \bar{x}_i f_{\bar{x}_i}$$



|          |  |
|----------|--|
| Page No. |  |
| Date     |  |

$$\text{No of elements in the tree} = 1 + 2 + \dots + 2^{n-1}$$

$$= 2^n - 1$$

This requires a lot of space for storage, but lot of redundancies are present.

One way is to store only 1's and 0's in last layer and there are only elements which fully evaluates to



| a | b | c | d  | e |
|---|---|---|----|---|
| 0 | 0 | 0 | 0  |   |
| 0 | 0 | 1 | -1 |   |
| 0 | 1 | 0 | 0  |   |
| 0 | 1 | 1 | 1  |   |
| 1 | 0 | 0 | 0  |   |
| 1 | 0 | 1 | 1  |   |
| 1 | 1 | 0 | 1  |   |
| 1 | 1 | 1 | 1  |   |





Reduced order BDD - Unique form (for a given order of variables)  
Order BDD is not unique.

RO BDD - depend on order of variables  
Finding best order is NP-hard.

→ Practically one has to start with BDD- $O(2^n)$  space.  
So effectively, this is useless.

If we could find a way to outgrow a graph into ROBDD, it can be helpful.



$$h = f \text{ op } g$$

$$= \bar{\pi}_i x_i (f_{\bar{x}_i} \text{ op } g_{x_i}) + \bar{\pi}_i (f_{\bar{x}_i} \text{ op } g_{\bar{x}_i})$$

$(x_1, f_{x_1}, +, \bar{x}_1, f_{\bar{x}_1})$  op  $(\bar{x}_1, f_{\bar{x}_1})$

2

1

0

3

4

5

6

7

8

9

0

$[f_{x_1} \text{ op } g_{x_1}]$

$[f_{\bar{x}_1} \text{ op } g_{\bar{x}_1}]$

If  $g$  is independent of  $x_i$



If  $g$  is indep<sup>n</sup> of  $x_i$  take priority order



eg -  $x_1, x_2$



eg -  $\overline{x}_1 \overline{x}_2 \rightarrow$  interchange 1's and 0's

-  $\overline{x}_1 \overline{x}_2 \Rightarrow$  interchange solid and dash lines

$$x_1 \oplus x_2$$

$$x_1 \ominus x_2 = x_1 x_2 + \overline{x}_1 \overline{x}_2$$

Start with one node, then every add will add two nodes.

1/10/19

### BDD

Compact Representation  
Grows linearly  
Complexity



Two adders can be compared hierarchically (sans supply carry adders with other complicated adders)

Most representations done using BDD's.

### Synthesis



Size: No of nodes in BDD.  $\leftarrow$  Order of variable  $x_i$   $\rightarrow$  ROBDD

Performance =  $\#t_m \times \# \text{Variables}$   $\rightarrow$  height of tree

Optimal order of variables which can

Heuristic solution

Greedy kind of alg

We are more concerned about optimal order during synthesis rather than correctness checking due to recurring cost

$$l = \overline{a_1(b)} + a_2 b_2 \quad b_2 \quad (b_1 + a_2 b_2)$$

$$a_1 > a_2 > b_1 > b_2$$



this graph is much better

$$a_1 > b_1 > a_2 > b_2$$



Heuristic (greedy) alg.

Shifting:

Take one variable and move it to lower level and check if it reduces the order of graph.

Swapping: (check)  
Here we interchange only among adjacent nodes

greedy alg as a shifting done once is never changed.

For 20

The BDD described above uses Multi-level-logic.

To

2 level-logic



3 level logic if consider positive and negative levels or  
diff' level and multi-input AND gates available

3 Oct 19

BDD's - store the rtl . des in compact format

$$f_1 \stackrel{?}{=} f_2 \quad \leftarrow \text{Verification}$$

[RTL]

↓  
logic Synthesis

[Gate level synthesis]

[Transistor level netlist]

Specification

↓  
Tddr

Implementation

↓  
logical exp.  
RDBDD

↓  
Replace nobby  
mux

↓  
gate level netlist

Truth table

set of minterms

↓  
IC map

↓  
rtl

7 Oct-19

SAT

$$a + b + c$$

$$a = 0$$

Page No.

Date

$$( ) ( ) ( ) \stackrel{?}{=} 1$$

clauses

c1

c2

c3

x

Satisfiable

$$c_1 = 1$$

$$c_2 =$$

DPLL alg:

↓

assign: a value to a variable in some order  
(alphabetical order)

fails - back track

↓

Pure literal rule.

$$(a + b + c) \cdot (a + \bar{b} + \bar{c}) \cdot (a + \bar{c})$$

Clauses which we have just one literal present ~~left~~  
can be directly assigned a value

Eg - a) after assigning  $a = 0$ , we could put  $a = 1$

Concensus theorem:

$$(a+b)(\bar{a}+b) \quad (a+b)(\bar{a}+c)(b+c)$$

These clauses have to be satisfied if LHS is satisfied

$$(a+b+\bar{c}), (\bar{a}+b+\bar{c}) (\bar{c}+d) (\bar{a}+\bar{b}+c)$$

$$(\bar{a}+\bar{b}+\bar{a}+\bar{b}) \quad (\bar{a}+b+\bar{a}+\bar{b}) \quad (d+\bar{a}+\bar{b})$$

keep on doing it (applying concensus) - similar to that in CS228 (a)

3to

Saturation method:

$$(a+b) \quad (\bar{a}+c) \quad (b+d) \quad (\bar{c}+d) = 1$$

Literal based  
alg

$$a=1 \rightarrow b=c=1 \rightarrow d=1 \quad \left. \begin{array}{l} \text{(unit clause)} \\ \text{(unit clause)} \end{array} \right\}$$

Essential assignment  
 $d=1$

$$a=0 \rightarrow b=1, b=1 \rightarrow d=1$$

We should try to keep essential variables at root of tree

Recursive learning (RL) — Does it clause by clause

first clause satisfied by which literals

$$a=1 \rightarrow c=1 \rightarrow d=1 \quad \left. \begin{array}{l} \text{(unit clause)} \\ \text{(unit clause)} \end{array} \right\}$$

$$b=1 \rightarrow d=1 \rightarrow \left. \begin{array}{l} \text{(unit clause)} \\ \text{(unit clause)} \end{array} \right\} \Rightarrow d=1 \text{ is essential}$$

Random assignment:

$$a=1 \quad b=1 \quad c=1 \quad d=0$$

$$(a+b) (\bar{a}+c) \frac{(b+d)}{\text{UNSAT}} \frac{(\bar{c}+d)}{\text{UNSAT}}$$

Put

one by one of flip of which appear in UNSAT clauses

We could flip  $d$  which appears in more UNSAT variables

### Local Search methods

Other heuristics we could be to do order of variables as per their occurrence in clauses.

Figure

Non-chronological back-tracking

$$(a+b)(\bar{b}+c+d) (\bar{b}+c) (\bar{b}+\bar{c}) + 1$$



Record this

clause

$$\rightarrow (a+b+f)$$

This record clause will generate more to unit clauses which to check.



8 Oct'19

|          |  |
|----------|--|
| Page No. |  |
| Date     |  |

SAT solver  $f_1 = f_2$   $Q \in \mathbb{N}^{1000}$   $\begin{bmatrix} 10 \\ 10 \end{bmatrix} \rightarrow 10_0$

Static

[Exact Heuristic]  $\leq 2$  level set covering for FFS  
 Problem prime implies  
 SPT's prime implicit

→ Till now we have static equations but now we will see sequential circuit (thus non-static equation)

FSM

(Output level)

 $O_1 \rightarrow \text{Output}$ 

SR (State register)

NSL

eg - Adder:

Without FSM:



State transition diagram

All  $s_1, s_2, s_3, s_4$  $s_5$  are doing same job we

could minimize the state.

So you can minimize the states if the states have same output & same next state on same input

e.g.: S/T/T

| Page No. |  |
|----------|--|
| Date     |  |

| A | NS <sub>2</sub> (A/D) | NS <sub>1</sub> (D/F) |
|---|-----------------------|-----------------------|
| B | E, 0                  | D, 1                  |
| C | F, 0                  | D, 0                  |
| D | F, 0                  | B, 0                  |
| E | C, 0                  | C, 1                  |
| F | B, 0                  | C, 0                  |

A, B: If we apply  $x=0$  we see  $a/p=0$  in both  
But if we apply  $x=1$ , we see  $a/p=0$  in B &  
 $a/p=1$  in C

So 1 distinguishable



Till here it is 2 equivalent

K distinguishable  $\Rightarrow$  K-equivalent

K-equivalent

Idea Given:

$$\begin{matrix} S_i & \sim & S_j \\ \downarrow & & \downarrow \\ S_m & & S_n \end{matrix}$$

(Now if  $S_i$  &  $S_m$  are equivalent  
 $S_i$  and  $S_j$  ( $K+1$ ) equivalent)

will now try to find a method to know equivalent states

having  $P_0 = (A B C D E F)$  (0-equivalent)

$P_1 = (ACE) (BDF)$  (1-equivalent set)

He use we so of p

$P_2 = (ACG) (BD) (F)$  ( $n=0$ : B, D, F have partition same  
 $n=1$ : B, D have same but F in diff partition)

(For  $n=0$ , A, C, G have o/p state in same partition)

(for  $n=1$ , C, G have o/p state in same partition)

we use idea of rec as stated above For already existing states for (step, we have values)

$$P_3 = (A G) (B D) (F)$$

$$P_4 = (A G) (B D) (F)$$

Now gives 2 random states  
→ Now possible way



→ We can use cont

Primary Primary  
(P1) (P2)

Pseudo Primary  
(P3) Pseudo  
Primary  
(P4)

Pseudo concerning  
(P5) State.



Total no of s

Output (

output of given

|   |                          |
|---|--------------------------|
| 1 | ns = 1 (Q <sub>1</sub> ) |
| 2 | D <sub>1</sub> , 1       |
| 3 | D <sub>1</sub> , 0       |
| 4 | Q <sub>1</sub> , 0       |
| 5 | Q <sub>1</sub> , 1       |
| 6 | Q <sub>1</sub> , 0       |

$$P_3 = (A \oplus Q) (B D) (F)$$

$$P_4 = (A D) (E) (B D) (F)$$

Max. no. of steps will be n. (no. of states)

Now gives 2 random state machines, how can we check equivalence.

→ Now possible way



Another way



$M_1' \xrightarrow{\sim} M_2'$  (reduced machine)

Isomorphic (same STT)

→ We can use "comb" logic also



Pseudo concerning (P<sub>2</sub>) state.

Primary o/p  
 $S_0$  (initial state)

This should be given to Mitter, after working both machines with XDR of all o/p of AND of all. MIT ER can give non-equivalence fast but not equivalence.

A better way we should start for well defined initial state need not be same for both



$M(S, S_0, X, O, S, \lambda)$

state machine  $M_1 = (S^1, S_0^1, X^1, O^1, S_1^1, \lambda)$

$M_2 = (S^2, S_0^2, X^2, O^2, S_1^2, \lambda)$

Now  $M_1 \stackrel{?}{=} M_2$

Total no. of state this machine can have is  $|S'|^X|S|^Y$  [Product machine, as total no. of state is product of both]

Output (MIT ER) =  $\begin{cases} 0 & \text{when } Q_2 Q_1 \\ 1 & \text{otherwise} \end{cases}$

We can care about reachability states here. We do Reachability Analysis



Product machine.



initial reachability analysis as we reach



(pre-images)  
These states have images as reachable

We now have to represent states in product machine - Binary rep / boolean f^n

eg - Boolean f^n:

|       |       |       |     |
|-------|-------|-------|-----|
| $x_2$ | $x_1$ | $x_0$ | $/$ |
| 0     | 0     | 0     | 1   |
| 0     | 0     | 1     | 0   |
| 0     | 1     | 0     | 0   |
| 0     | 1     | 1     | 1   |
| 1     | 0     | 0     | 0   |
| 1     | 0     | 1     | 0   |
| 1     | 1     | 0     | 1   |
| 1     | 1     | 1     | 1   |

This  $f^n$  is rep as a function like  $f(x_2, x_1, x_0, \dots)$ . We have  $S$  - Current state,  $X$  - Next state,  $x$  - Input.

Now if new state is added we basically add to function.

Again, we represent as boolean f^n:

|     |       |       |       |       |       |     |
|-----|-------|-------|-------|-------|-------|-----|
| $x$ | $s_0$ | $s_1$ | $s_2$ | $t_1$ | $t_2$ | $/$ |
| 0   | 0     | 0     | 0     | 0     | 1     | 1   |
| 0   | 0     | 0     | 0     | 1     | 0     | 0   |

say, transition relation  $R(x, s, t)$ :  $C(s) \rightarrow \text{Reachable state}$   
Now  $C(s) \cdot R(x, s, t) = T(x, s, t)$

Oct 19:

2 state machines

$$m_1 = m_2 \quad M_1(S_1^1, S_1^0, X, 0, \delta_1, X') = M_2(S_2^1, S_2^0, X, 0, \delta_2, X')$$

Reachability Analysis for  $m = m_1 \times m_2 = (S^1, S^0, X, 0, \delta, \lambda)$



$$\delta = \begin{cases} 0 & (q_1 = 0) \\ 1 & \text{otherwise} \end{cases}$$

2 states  $\Rightarrow 1$  Boolean val for state

|   |   |
|---|---|
| 0 | 1 |
| 1 | 0 |

$$\delta(X, S) = \begin{cases} 0 & (S_1 = S_0) \\ 1 & (S_1 \neq S_0) \end{cases}$$

$$\lambda(X, S) = X \oplus S.$$

$$\lambda(X, S) = X \oplus S. \quad S = q_1 q_0 y$$

0/0



$$R(X, S, t) = (t_1 = S_1), (t_2 = S_2), (t_3 = S_3)$$

$$= \prod_i (t_i = S_i)$$

$$S \rightarrow t_2 t_1 t_3 \quad \delta = (t_0 = S_0 X + S_1 X) / X = \bar{S}_2 \bar{S}_1 X + S_1 \bar{X} / X_2 = S_1 X + S_2 X$$

$$t \rightarrow t_2 t_1 t_3 \quad \lambda = (t_0 = S_0 \bar{X} + S_1 \bar{X}) / X = \bar{S}_2 \bar{S}_1 X + S_1 \bar{X} / X_2 = S_1 \bar{X} + S_2 \bar{X}$$

$$t_1 = S_1$$

$$t_2 = S_2$$

$$t_3 = S_3$$

$$(X, S_2, S_1, S_0, t_2, t_1, t_0)$$

$$(\bar{S}_2 \bar{S}_1 \bar{S}_0) (t_1 = S_0 \bar{X} + S_1 \bar{X}) (t_2 = \bar{S}_2 \bar{S}_1 X + S_1 \bar{X})$$

$$(t_3 = S_1 X + S_2 \bar{X})$$

$$\exists X (\bar{S}_2 \bar{S}_1 \bar{S}_0) ( ) ( ) ( )$$

$$C(s) = \bar{s}_2 \bar{s}_1 \bar{s}_0$$

$$= C(s) R(x, s, t) \rightarrow \text{First state times reachable}$$



$$\delta f_x + \delta f_{\bar{x}} = \delta$$

$$T(t) = s_2 s_1 s_0 | x_2 x_1 x_0$$

$C(s) \cdot T(t) \rightarrow$  obtain all reachable states from current state.

$$\text{First state} - \bar{s}_2 \bar{s}_1 \bar{s}_0$$

$$= (x_1 = \bar{s}_2 \bar{s}_1 \bar{s}_0 x) \cdot (x_2 = \bar{s}_2 \bar{s}_1 \bar{s}_0 x)$$

$$x=0 \Rightarrow x_1=0, x_2=0, x_3=0 \rightarrow 0.0$$

$$x=1 \Rightarrow x_1=1, x_2=1, x_3=0 \rightarrow 1.1$$

$$t_1=1, t_2=1, t_3=0 \rightarrow 0 \rightarrow 1 \text{ in } m_1, 00 \rightarrow 01 \text{ in } m_2$$

$$= \bar{s}_2 \bar{s}_1 \bar{s}_0 + \bar{s}_2 s_1 s_0$$

## Logic Synthesis

### Representation

(1) Truth table

(2) Min Terms

(3) Max Terms

(4) ROBDD



ROBDD → optimise for area/part/power/testability

SAT  
Reach

Verify ✓ SAT/BDD

Test ✓

Perf optimal

Important to find out good order of variables

Shifting of minterm level circuit  
synthesis

Important when you want to use for synthesis

Need to go through all n - mult

\* Map: → May be good for human beings (not for machine)

| a | b | c | z |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 0 |

Not making any diff

cube/implicants

cube/implicants

Area  
# literal  
Performance (level of imp.)

$$\overline{a}\overline{b}\overline{c} + \overline{a}\overline{b}c \\ ab\overline{c} + \overline{a}bc$$

Roughly - area is prop to no of inputs.  
to (app)

In TTL tech policy  
did not depend on  
no of inputs.

Restrict to 2/3 levels



However in CMOS  
delay depends on  
no of inputs. → delay & no of inputs

Draw the  
CMOS switches

gates etc?



2 level/3 level

Delay of ckt  $\approx S + 3S + 4S$   
 $\approx 8S$



Quinon logic optimization

Shanon - Also figured out minimizing digital logic

Quinon - Mcclusky method  
- scalable

Tabular method

|      | 00 | 01 | 10 | 11 |
|------|----|----|----|----|
| 0 -  | 00 | 00 | 01 | 11 |
| 01 - | 01 | 10 | 11 | 11 |

prime implicant      we have covered

We could call all prime implicants to implement a ckt - But may not be optimal

We could have essential prime implicants which have to be present.  
 (Some terms are only covered by these)



Only this which of selective Pj's should be chosen?  
could be done in 2 ways - ext-covering problem

| GPI  | $\alpha$ | $\beta$ | $\gamma$ | $\delta$ | $\epsilon$ |  | Bottom of sheet |
|------|----------|---------|----------|----------|------------|--|-----------------|
| P1   | ✓        |         |          |          |            |  |                 |
| P2   |          | ✓       | ✓        |          |            |  |                 |
| P3   |          |         | ✓        | ✓        |            |  |                 |
| P4   |          |         |          | ✓        | ✓          |  |                 |
| P5   |          |         |          |          |            |  |                 |
| P6   |          |         |          |          |            |  |                 |
| P7   |          |         |          |          |            |  |                 |
| P8   |          |         |          |          |            |  |                 |
| P9   |          |         |          |          |            |  |                 |
| P10  |          |         |          |          |            |  |                 |
| P11  |          |         |          |          |            |  |                 |
| P12  |          |         |          |          |            |  |                 |
| P13  |          |         |          |          |            |  |                 |
| P14  |          |         |          |          |            |  |                 |
| P15  |          |         |          |          |            |  |                 |
| P16  |          |         |          |          |            |  |                 |
| P17  |          |         |          |          |            |  |                 |
| P18  |          |         |          |          |            |  |                 |
| P19  |          |         |          |          |            |  |                 |
| P20  |          |         |          |          |            |  |                 |
| P21  |          |         |          |          |            |  |                 |
| P22  |          |         |          |          |            |  |                 |
| P23  |          |         |          |          |            |  |                 |
| P24  |          |         |          |          |            |  |                 |
| P25  |          |         |          |          |            |  |                 |
| P26  |          |         |          |          |            |  |                 |
| P27  |          |         |          |          |            |  |                 |
| P28  |          |         |          |          |            |  |                 |
| P29  |          |         |          |          |            |  |                 |
| P30  |          |         |          |          |            |  |                 |
| P31  |          |         |          |          |            |  |                 |
| P32  |          |         |          |          |            |  |                 |
| P33  |          |         |          |          |            |  |                 |
| P34  |          |         |          |          |            |  |                 |
| P35  |          |         |          |          |            |  |                 |
| P36  |          |         |          |          |            |  |                 |
| P37  |          |         |          |          |            |  |                 |
| P38  |          |         |          |          |            |  |                 |
| P39  |          |         |          |          |            |  |                 |
| P40  |          |         |          |          |            |  |                 |
| P41  |          |         |          |          |            |  |                 |
| P42  |          |         |          |          |            |  |                 |
| P43  |          |         |          |          |            |  |                 |
| P44  |          |         |          |          |            |  |                 |
| P45  |          |         |          |          |            |  |                 |
| P46  |          |         |          |          |            |  |                 |
| P47  |          |         |          |          |            |  |                 |
| P48  |          |         |          |          |            |  |                 |
| P49  |          |         |          |          |            |  |                 |
| P50  |          |         |          |          |            |  |                 |
| P51  |          |         |          |          |            |  |                 |
| P52  |          |         |          |          |            |  |                 |
| P53  |          |         |          |          |            |  |                 |
| P54  |          |         |          |          |            |  |                 |
| P55  |          |         |          |          |            |  |                 |
| P56  |          |         |          |          |            |  |                 |
| P57  |          |         |          |          |            |  |                 |
| P58  |          |         |          |          |            |  |                 |
| P59  |          |         |          |          |            |  |                 |
| P60  |          |         |          |          |            |  |                 |
| P61  |          |         |          |          |            |  |                 |
| P62  |          |         |          |          |            |  |                 |
| P63  |          |         |          |          |            |  |                 |
| P64  |          |         |          |          |            |  |                 |
| P65  |          |         |          |          |            |  |                 |
| P66  |          |         |          |          |            |  |                 |
| P67  |          |         |          |          |            |  |                 |
| P68  |          |         |          |          |            |  |                 |
| P69  |          |         |          |          |            |  |                 |
| P70  |          |         |          |          |            |  |                 |
| P71  |          |         |          |          |            |  |                 |
| P72  |          |         |          |          |            |  |                 |
| P73  |          |         |          |          |            |  |                 |
| P74  |          |         |          |          |            |  |                 |
| P75  |          |         |          |          |            |  |                 |
| P76  |          |         |          |          |            |  |                 |
| P77  |          |         |          |          |            |  |                 |
| P78  |          |         |          |          |            |  |                 |
| P79  |          |         |          |          |            |  |                 |
| P80  |          |         |          |          |            |  |                 |
| P81  |          |         |          |          |            |  |                 |
| P82  |          |         |          |          |            |  |                 |
| P83  |          |         |          |          |            |  |                 |
| P84  |          |         |          |          |            |  |                 |
| P85  |          |         |          |          |            |  |                 |
| P86  |          |         |          |          |            |  |                 |
| P87  |          |         |          |          |            |  |                 |
| P88  |          |         |          |          |            |  |                 |
| P89  |          |         |          |          |            |  |                 |
| P90  |          |         |          |          |            |  |                 |
| P91  |          |         |          |          |            |  |                 |
| P92  |          |         |          |          |            |  |                 |
| P93  |          |         |          |          |            |  |                 |
| P94  |          |         |          |          |            |  |                 |
| P95  |          |         |          |          |            |  |                 |
| P96  |          |         |          |          |            |  |                 |
| P97  |          |         |          |          |            |  |                 |
| P98  |          |         |          |          |            |  |                 |
| P99  |          |         |          |          |            |  |                 |
| P100 |          |         |          |          |            |  |                 |

Patrick method

In ESD we use logic exp?

$$\alpha \rightarrow P_1$$

$$\beta \rightarrow P_1 + P_2$$

$$\gamma \rightarrow P_2 + P_3$$

$$\delta \rightarrow P_3 + P_4$$

$$\epsilon \rightarrow P_4$$

$$P_1, (P_1 + P_2), (P_2 + P_3), (P_3 + P_4), P_4$$

should be satisfied

logic sol

SOP

choose the one  
with least no of literals



SAT  
BDD implies P0 BDD

Page No. \_\_\_\_\_  
Date \_\_\_\_\_

Logic Optimization

Exact optimization

Patrie's method

Get all covers for given PI

$$\alpha = P_1 \quad \beta = P_1 + P_2 \quad \gamma = P_2 + P_3 \quad \delta = P_3 + P_4 \quad \Sigma = P_1 + P_2 + P_3 + P_4$$

For covering, satisfy :  $P_1(P_1 + P_2)(P_2 + P_3)(P_3 + P_4) P_4 = 1$

POS form → Convert to SOP form and solve for term with least no of literals logic soln

15/04/19

Convert to matrix problem  $Ax = b$  ( $\alpha, \beta, \gamma, \delta, \Sigma$ )

= 1 minterms

$P_1, P_2, P_3, P_4$

$$\begin{matrix}
 & P_1 & P_2 & P_3 & P_4 \\
 \alpha & 1 & 0 & 0 & 0 \\
 \beta & 1 & 1 & 0 & 0 \\
 \gamma & 0 & 1 & 1 & 0 \\
 \delta & 0 & 0 & 1 & 1 \\
 \Sigma & 0 & 0 & 0 & 1
 \end{matrix}
 \begin{bmatrix} x_1 \\ x_2 \\ x_3 \\ x_4 \end{bmatrix} = \begin{bmatrix} b_1 \\ b_2 \\ b_3 \\ b_4 \\ b_5 \end{bmatrix}$$

Let's assume,  
 $b = [1, 1, 0, 1]$  Not clear  
 $\rightarrow$  minimize area by reducing no of literals

Find  $Ax \geq 1$

Rand  $x$   
(min no of 1s)

→ Performance - literals + product term

EDB DD  $\rightarrow$  n level logic

2 level int  $\Rightarrow$  To synthesise all construct

Shannon's expression

$$f(x_1, \dots, x_n) = x_i f_{x_i} + \bar{x}_i f_{\bar{x}_i} = x_i f_x \oplus \bar{x}_i f_{\bar{x}}$$

boolean difference

$$\frac{\partial f}{\partial x_i} = f_x \oplus f_{\bar{x}} \Rightarrow \frac{\partial f}{\partial x_i} = 1 \Rightarrow f \text{ is independent of } x_i$$

$\Rightarrow f$  is independent of  $x_i$

Properties

$$\textcircled{1} \frac{\partial f}{\partial x_i} = \frac{\partial f}{\partial \bar{x}_i} \quad \textcircled{2} \frac{\partial f}{\partial x_i} = \frac{\partial f}{\partial \bar{x}_i} \quad \textcircled{3} \frac{\partial}{\partial x_i} (f \oplus g) = \frac{\partial f}{\partial x_i} \oplus \frac{\partial g}{\partial x_i}$$

$$\textcircled{4} \frac{\partial}{\partial x_i} (f \cdot g) = f \frac{\partial g}{\partial x_i} + g \frac{\partial f}{\partial x_i} + \frac{\partial f}{\partial x_i} \cdot \frac{\partial g}{\partial x_i}$$

$$\textcircled{5} \frac{\partial}{\partial x_i} (f \cdot g) = f \cdot \frac{\partial g}{\partial x_i} + g \frac{\partial f}{\partial x_i} + \frac{\partial f}{\partial x_i} \cdot \frac{\partial g}{\partial x_i}$$

Not clear  
Reducing terms  
Consensus =  $f_x - f_{\bar{x}}$  Smoothing =  $f_x + f_{\bar{x}}$   $\leftarrow$  Independence

$$f = \sum_{i=1}^n \phi_i f \phi_i \quad \phi_i \cdot \phi_j = 0 \Rightarrow \phi_i, \phi_j \text{ are orthogonal}$$

$$f = \phi_i f \phi_i + \phi_j f \phi_j \quad \text{eg: } f = ab + b \bar{c} + ac \\ \phi_i = ab \quad \phi_j = \bar{a} \bar{b} \quad \phi_i \cdot \phi_j = 0$$

$$f = abf_{ab} + (\bar{a} + b)f_{\bar{a}+\bar{b}}$$

↓  
co-factor  
terms of  $f_{ab}$

$$\bar{a} + b = 1 \quad \text{if } a/b = 1$$

$$f_{ab} = 1 \Rightarrow f_{(\bar{a}\bar{b})} = b\bar{a} + a\bar{b}$$

Positional vector:

2 bit vector

$$00 \rightarrow \emptyset$$

$$01 \rightarrow 1$$

$$10 \rightarrow 0$$

$$11 \rightarrow x$$

$$ab + b\bar{c} + \bar{a}c \rightarrow ab\bar{c} + a\bar{b}c$$

$$\begin{array}{r} ab \\ \bar{a} \\ \hline 10 \\ 00 \end{array}$$

$$Dab \rightarrow$$

$$a \quad b \quad x$$

$$01 \quad 01 \quad 11$$

$$b\bar{c} \rightarrow$$

$$a \quad b \quad x$$

$$11 \quad 01 \quad 01$$

$$a\bar{b} \rightarrow$$

$$a \quad b \quad x$$

$$01 \quad 11 \quad 01$$

$$\bar{c}$$

$$10 \quad 11 \quad 11$$

Windows 10  
Printed do...

10:23  
05/11/19

卷之三

12 Oct 19

10

• a f l

Page No. [ ]

Logic optimisation       $\Rightarrow$  Enumerate  
Exact optimisation       $\Rightarrow$

f) Enumerate P ⊂ Q M

② Solve a set covering problem to find the minimum number of sets required to cover all elements.

$P_1, P_2 \rightarrow$  containment

ESPRESSO

## ~~ESPRESSO~~ - EXACT

## ESPRESSO

~~Heweston~~

- (1) Expansion
- (2) Reduction ~~(2)~~
- (3) Reshape
- (4) Redundancy check

No further expansion

~~overduurdaat~~

~~Do bit wise and~~

~~nd~~  
7 term

3<sup>rd</sup> · 10<sup>11</sup>

$\bar{a} \bar{b}$

~~abc~~

## Positional representation

No expansion poss't poss'  
you reduce to cover the  
adjacent side

~~Positional rep.~~

a b  
2 bits

$$00 \rightarrow \phi$$

$$\begin{array}{ccc} 0 & \xrightarrow{\quad} & 1 \\ \text{C} & \xrightarrow{\quad} & 0 \end{array}$$

11 → X don't care

| a                                 | b   | c   | $ab + \bar{a}c + \bar{a}$ |
|-----------------------------------|-----|-----|---------------------------|
| represented<br>first term<br>0 1  | 0 1 | 1 1 |                           |
| represented<br>second term<br>1 0 | 1 1 | 0 1 |                           |
| represented<br>third term<br>1 0  | 1 1 | 1 1 |                           |

$$f(a, b, c) = \bar{a}b + \bar{a}c + \bar{a}$$

$$= \bar{a}bc + \bar{a}ba$$

$\bar{a} \leftarrow 10 \ 11 \ 11$

bit wise & work first term

~~0 0~~ 0 1 1 1 X 00 → implies void  
null term

2<sup>nd</sup> term 1 1 1 1 1 1

1 0 1 1 0 1  $\bar{a}c$

3<sup>rd</sup> term 1 0 1 1 1 1 0 1  $\bar{a}$

To get rid off it  
OR with comp of

on 0 1 0 0 0 0 0 1

1 1 1 1 1 1 1 1 ← universally true

$$(0 1 0 0 0 0) \oplus 1 0 1 1 = 1 0 1 1$$

1 1 1 1 + 0 0 0 0 0 0 0 0

$$ab + \bar{a}c + \bar{a}$$

$$\begin{array}{ccc|cc} & & & & \\ & 01 & 01 & 11 & \\ & 10 & 11 & 01 & \\ \hline & 10 & 11 & 11 & \\ & & & & \\ & & & & \end{array} \quad bc.$$

Do intersection with each term

$$\begin{array}{ccc|cc} & 01 & 01 & 01 & \\ & 10 & 01 & 01 & \\ \hline & 01 & 01 & 01 & \leftarrow ab \\ & & & & \leftarrow \bar{a}c \end{array}$$

$$\begin{array}{c} \text{P.R.C} \\ bc(a+\bar{a}) \\ \downarrow \\ \text{essential} \end{array}$$

Now for  $a = 01 \quad 11 \quad 11$

$$\begin{array}{ccc|ccc|ccc} & 01 & 01 & 11 & 10 & 11 & 01 & 10 & 11 & 11 \\ & 01 & 11 & 11 & 01 & 11 & 11 & 01 & 11 & 11 \\ \hline & 01 & 01 & 11 & 00 & 11 & 01 & 00 & 11 & 11 \\ \hline \oplus & 10 & 00 & 00 & 10 & 00 & 00 & 10 & 00 & 00 \\ \hline & 10 & 01 & 11 & 10 & 11 & 01 & 10 & 11 & 11 \end{array}$$

$$\begin{array}{l} \rightarrow 11 \ 01 \ 01 \Rightarrow 100 \ 1010 \\ \rightarrow \text{New for } 'bc' \\ \rightarrow bc \ f_{bc} + \bar{b}c \ f_{\bar{bc}} \end{array}$$

For each term

$$\begin{array}{r}
 01 \ 01 \ 01 \\
 11 \ 01 \ 01 \\
 \hline
 01 \ 01 \ 01 \\
 00 \ 10 \ 10 \\
 \hline
 001 \ 11 \ 11
 \end{array}$$

$$\begin{array}{r}
 10 \ 11 \ 01 \\
 11 \ 01 \ 01 \\
 \hline
 10 \ 01 \ 01 \\
 + \ 00 \ 10 \ 10 \\
 \hline
 10 \ 11 \ 11 \\
 \hline
 \overline{a} \quad \overline{a}
 \end{array}
 \quad
 \begin{array}{r}
 10 \ 11 \ 11 \\
 11 \ 01 \ 01 \\
 \hline
 10 \ 01 \ 01 \\
 + \ 00 \ 10 \ 10 \\
 \hline
 10 \ 11 \ 11
 \end{array}$$

$$\alpha + \bar{\delta} = 1 \Rightarrow f_{bc} = 1 \Rightarrow \text{Tautology}$$

22.05.19

2nd generation

|          |  |
|----------|--|
| Page No. |  |
| Date     |  |

## ① PODEM (Path Oriented Decision Making)

SAT for last generation



We satisfy objective

→ Not satisfied: still  $\times \rightarrow$  If not satisfied - re-traverse the path.

Conflict: Not satisfied conform  $\rightarrow$  Go backward. change path ass^n.

Other case: assign( $a, 0$ )





We can have multiple paths like for we could go either go  
to a or b.

Ideally, we want shortest path as it will be more controllable or observable.

So we know quantify observability and controllability

$$C_{O_a} = 1, C_{b_a} = 1$$

$C_{O_c} = 1 + \min(C_{O_a}, C_{O_b})$

$C_{I_c} = 1 + C_{I_a} + C_{I_b}$

We can analyse this way on whole graph and set the controllability. Now we use this metric to set path.

ej - observability

Here we start for primary  $\alpha/\beta$ , do reverse propagation.



Observability is same

for 1 & 0 so only 1 value.

$$O_A = 1 + O_C + C_{1b} \rightarrow (\text{we need to assign } B=1 \text{ only})$$

then we can see  $O_A$  at output.

$$\sim O_B = 1 + O_C + C_{1b}$$

We flow from primary output, to primary input & find observability.

→ While simulating, we must first decide the sequence of simulating the gates.

Second way is event driven method i.e. we simulate gate once we see a change in input.

Every change leads to 10-15% events, so we reduce work but not parallelizable.



Side note: Given Given a circuit path from output to input which is controllable and observable.

We can decide according to path orders the variable order better for BDD formation.

→ synthesis (We will focus on ways to do synthesis for better testability)

$$f(x_1, \dots, x_n) = x_i f_{x_i} + \bar{x}_i \bar{f}_{\bar{x}_i}$$

(Read Mules Decomposition)

$$f_{x_i} + \bar{x}_i \cdot d_f \text{ OR } f_{\bar{x}_i} + x_i \cdot d_f$$

$$x_i f_{x_i} + \bar{x}_i \bar{f}_{\bar{x}_i} = x_i f_{x_i} + (1+x_i) f_{\bar{x}_i}$$

$$= f_{\bar{x}_i} + x_i (f_x + f_{\bar{x}_i})$$

$$\frac{\partial f}{\partial x_i} = f_{x_i} + f_{\bar{x}_i}$$

k-map

|    |    | as $\oplus^d$ |   |
|----|----|---------------|---|
|    |    | 00 01 11 10   |   |
| 00 | 00 |               |   |
|    | 01 | 1 1           |   |
| 11 | 11 |               | 1 |
|    | 10 | 1             |   |

As inputs are not same, thus  
OR & XOR are same.  
so XOR

$$\bar{a} b d \oplus a b c d \rightarrow \text{Verify this is}$$

Testability:

YOR  
&  
AND

100% testable

(n+4) test vector

universal vector

ROBDD

Faults may develop over time.

Often at power on, we check whether chip behaves correctly.



If we make MUX as



testable.

By having one extra input, we can make it 100% testable.



How to minimize a circuit using Exact methods

Tableau method

(1) QM  $\rightarrow$  minimization

Expresso

Presto

set of PI

set of essential PI

Set of SPI (selective prime implicant)

- (1) Cover
- (2) CLP
- (3) Matrix
- (4) Boolean minimization

Heuristic

1. heuristic based minimization

for XUM etc.

Dramatic effort reduction

No guarantees are given

Optimal practically

- (1) Expansion
- (2) Reduction
- (3) Reshape
- (4) Irredundancy

abcd

abx

Expansion

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

1

method

|    |    |    |    |    |    |
|----|----|----|----|----|----|
| ab | cd | 00 | 01 | 11 | 10 |
| 00 |    |    |    |    |    |
| 01 |    |    |    |    |    |
| 11 |    |    |    |    |    |



conflict  
(a) 7 terms redundant

(b) Check whether conflict  
conflict with OFF set

ON set defines function f (ignoring D)

Some way of easy computation (computation of complement)

$$f(x_1, \dots, x_n) = \pi_i f_{x_i} + \bar{\pi}_i \bar{f}_{\bar{x}_i}$$

$$\bar{f} = \overline{(\pi_i f_{x_i} + \bar{\pi}_i \bar{f}_{\bar{x}_i})}$$



$$= (\bar{\pi}_i + \bar{f}_{\bar{x}_i}) \cdot (\pi_i + \bar{f}_{x_i})$$

$$\boxed{f = \pi_i \bar{f}_{x_i} + \bar{\pi}_i \bar{f}_{\bar{x}_i}} \quad \text{Inversion of co-factors}$$

- Define : We say a function is <sup>positive</sup> uncomplemented w.r.t  $x_i$  if  $x_i$  is always given



$$\begin{aligned} & \overline{a} \overline{b} c + \overline{a} c \\ & = \overline{a} \overline{b} c + \overline{a} (\overline{b} + c) \\ & = \overline{b} c \end{aligned}$$

Page No.  
Date

$$\begin{array}{l} \textcircled{a} \\ \textcircled{b} \\ \textcircled{c} \end{array} \quad \begin{array}{l} \textcircled{a} \\ \textcircled{b} \\ \textcircled{c} \end{array}$$

Positional representation of variables

$$00 \rightarrow \emptyset$$

$$01 \rightarrow 1$$

$$10 \rightarrow 0$$

$$11 \rightarrow x$$

$$ba = 1 \quad (\text{tautology})$$

$$f = a \cdot b + b \cdot c + \overline{a}$$

$$f = \overline{a} \cdot ba + a \cdot ba$$

$$ba + ba$$

$$ba = 1$$

$$ba = b \cdot c + b + b$$

Using positional representation

$$f = ab + bc + \overline{a}$$

$$\begin{array}{r} f \\ \times \quad \begin{array}{r} 01 \\ 01 \\ 11 \\ 10 \end{array} \\ \hline \begin{array}{r} 01 \\ 01 \\ 01 \\ 11 \\ 11 \end{array} \end{array} \quad \text{Co-factor w.r.t } \overline{a}$$

$$(1)(1) + (1)(0) = \overline{a}$$

$$10010 - 00010$$

$$01 \quad 01 \quad 11$$

$$00 \quad 00 \quad 00$$

Bit wise AND with

$$\overline{a} \rightarrow 1011111$$

$$11101 - 10101$$

$$11 \quad 01$$

$$00 \quad 00 \quad 00$$

$$\overline{abc} \rightarrow 00 \quad 01 \quad 01$$

$$\overline{a} \quad 10 \quad 01$$

$$\overline{a} \quad 10 \quad 11$$

$$\overline{a} \quad 10 \quad 11$$

$$\text{OR} \quad \begin{array}{r} 01 \quad 00 \quad 01 \\ \hline 11 \quad 01 \quad 01 \end{array}$$

$$\begin{array}{r} 10 \quad 11 \quad 11 \\ \times \quad 01 \quad 00 \quad 00 \\ \hline 11 \quad 11 \quad 11 \end{array}$$

$$\begin{array}{r} 10 \quad 01 \quad 01 \\ \hline 11 \quad 01 \quad 01 \end{array}$$

$$\begin{array}{r} 10 \quad 01 \quad 01 \\ \hline 11 \quad 01 \quad 01 \end{array}$$

$$\begin{array}{r} 10 \quad 01 \quad 01 \\ \hline 11 \quad 01 \quad 01 \end{array}$$

$$\begin{array}{r} 10 \quad 01 \quad 01 \\ \hline 11 \quad 01 \quad 01 \end{array}$$

When we do  
However to  
with invert  
of  $\overline{ba}$

If any 1  
off-set is created.

let's compute for

Terms repres

To get rid  
of with com  
representation

When we do first AND we get  $\pi$  in each term.

However to remove  $\pi$ , we OR each term obtained with invert of bit wise invert of positional representation of  $\pi$  (check why??) Not clear.

If any term gives all 1's, we get Tautology  
off sets is created from all odd sets which give reverse tautology  
like  $f_{ab} = 0$

Let's compute for  $f_{ab}$

$$f_{ab} \rightarrow 01 \quad 11 \quad 11$$

Terms representation  $\rightarrow$

$$\begin{array}{r} 01 & 01 & 101 \\ 01 & 01 & 01 \\ 00 & \cancel{011} & 11 \end{array} \times \text{repeated}$$

To get rid of a's.  
or with compl' of  
representation of a.

$$\begin{array}{r} 01 & 01 & 01 \\ 10 & 00 & 1000 \\ \hline 11 & 01 & 01 \end{array} \xrightarrow{\text{ab}}$$

$$\begin{array}{r} 011 & 01 & 0111 \\ 10 & 00 & 010 \\ \hline 101 & 01 & 1110 \end{array} \xrightarrow{\text{b}}$$

So now we do with  $b = 110111$

We will find sum of  $f_{ab}$  <sup>2nd term from prev</sup>

$$f_{ab} = 110111 \quad \text{---} \quad \begin{array}{r} 11 \\ 110111 \\ + 110111 \\ \hline 110111 \end{array}$$

$$\begin{array}{r} 00100 \\ + 110111 \\ \hline 111111 \end{array}$$

Keep on doing

7. T<sub>2</sub>

$$\begin{array}{r} 110111 \\ + 110111 \\ \hline 110111 \end{array}$$

Tautology

$f_{ab}$

$$\begin{array}{r} 110111 \\ + 110111 \\ \hline 111111 \end{array}$$

If a term with function evaluates to tautology, it ( $\lambda b$ ) is contained  
 It gives guarantee of containment

$f \circ c = 1 \Leftarrow$  Tautology

Inheredance: There should not exist a term which on removal should not change function.

- initial runoff cover



Expansion:

- Expand  $0000$  to  $\alpha = 0**0$ 
  - Drop  $0100, 0010, 0110$  from cover
- Expand  $1000$  to  $\beta = *0*0$ 
  - Drop  $1010$  from cover
- Grotesque prime implicants

  - Expand  $0101$  to  $\gamma = 001**$ 
    - Drop  $1011$  from cover
  - Expand  $1101$  to

Because we have met a two bar block left : Standard reduction doesn't do this

If every term is part of multiple covers, reduction works

Example of reshape.

- Reshape of  $\beta, \gamma, s, e$  to  $\beta, s, e$

$\{ \beta, \gamma, \{ s, e \} \}$

like changing a tree to square and soon replacing square to a lie.

- Second expand expansion

$S = 10 * 1$  to  $S = 10 * 0 * 1$  After

$G = 1101$  to  $G = (* 0) 1$

- Expansion - covers  $\{\alpha, \beta, \gamma, \delta, \epsilon\}$   
 - prime, redundant, minimal w.r.t.scc

First - Expansion (i.e.  $\{ \alpha, \beta, \gamma, \delta, \epsilon \}$ )  
 Step - Reduce  
 taken by  
 PNT  
 Reshape

→ This may redundant terms.

Second expansion (i.e.  $\{ \alpha, \beta, \gamma, \delta, \epsilon \}$ ) -

$0x1 + 1x8 = P$

$0x1 + 1x8 +$

Finally after second expansion claim is that they are redundant

examples: Steps taken by EXPRFSSD

- Expansion

Covers  $\{\alpha, \beta, \gamma, \delta, \epsilon\}$

↳ Prime, redundant, minimal w.r.t.scc

- Irredundant

Covers  $\{\beta, \gamma, \delta, \epsilon\}$

→ None of the terms is contained with others.

The Prime, irredundant

## Ordering heuristics

- Expand cubes that are unlikely to be covered by other cubes.

$$f = \bar{a}\bar{b}\bar{c} + a\bar{b}\bar{c} + \bar{a}\bar{b}\bar{c} + \bar{a}\bar{b}\bar{c}$$

$$D(\text{set } o = a\bar{b}\bar{c}) = 3$$

$$\begin{matrix} 1 & 0 & 1 & 0 \\ 0 & 1 & 1 & 0 \\ 1 & 0 & 0 & 1 \\ 0 & 1 & 0 & 1 \end{matrix}$$

Ordering

$$- \text{Vector } [3 \ 1 \ 3 \ 1]^T$$

Thus choose terms in order ascending order

→ And keep expanding so that it does not lead to order encroachment.

This is created recursively while expansion like  $f_{T_0} = 0$  earlier  $\text{OFF set}$

Expand - 01 10 10

01 11 01  
11 01 01

0 11 10 10 valid

10 11 10 valid

11 11 11 invalid ← intersection with off set gives non-empty set,

~Expand 10 10 01

11 10 01 invalid

10 11 01 invalid

10 10 11 valid

Expand cover

10 10 11

31 Oct '19

Page No. \_\_\_\_\_  
Date \_\_\_\_\_

3 level implementation for Performance  
INV ADD OR

Area  $\rightarrow$  # gates & # literals  
~~multi-level~~ multi-level

$$\text{Logic sharing} = a \cdot b + a \cdot c = a \cdot (b + c)$$

Delays are characterized by fan-outs.



Wherever we use longest path for det' clock cycle, we should be using sensitizable path.

Say:

$$f_1 = ab + bc$$

$$f_2 = a + c$$

{ By sharing, we can do better



Transformations :

Eliminate one func<sup>n</sup> from network

Example :  $s = r + b'$   $t = r + a'$   
 $s = p \cdot a' + b'$

Decomposition : Introduce new variables / blocks

$$t = a' d + \dots$$

Extraction :: Common sub-expressions

Simplify local expression

Optimization approaches

Boolean algs and algebraic methods

Use don't care op

Support set of quotient and remainder could orth<sup>+</sup> in  
boolean algebra.

4 Nov '19

## libraries and mapping

|          |  |
|----------|--|
| Page No. |  |
| Date     |  |

LS  $\rightarrow$  logic gate level netlist

3-level  
7-level

Either have  
cells (2 inputs)

OR have multiple stages

A0 to aggregate



lower technology  
gives interconnect  
as well

Multiple library cells: Interconnect instances of library cells

We should have cost  
How to choose cells?

3 cells



- We can independently tune the weights



- 4



- 5



\* Also library elements have weights to be trained

Vertex cover covering

V0

package weight

$$m_1: V_1, \text{OR2}$$

$$m_2: V_1, V_2, \text{AND2}$$

$$V_1 = \{m_1 + m_2 + m_3\}$$

$$m_2: V_2, \text{AND2}$$

$$m_3: V_1, V_3, \text{OR2}$$

$$V_2 = \{m_2 + m_3\}$$

$$m_3: V_3, \text{AND2}$$

$$V_3 = \{m_3\}$$

Sign compatibility:

match  $m_2$  requires  $m_1$  ( $m_1 \rightarrow m_2$ )

Match  $m_3$  requires  $m_2$  ( $m_2 \rightarrow m_3$ )

$$m_2' + m_1$$

Set problem:

We can a terrible solution if  $m_1 = m_2 = m_3 = \dots = 1$

Convert in SOP and evaluate cost of all and now evaluate cost of all.

Partitioning and Floor Mapping

Addresability and cache

| Factor | Plan  |
|--------|-------|
| SOP    | Logic |

(Planning)

functionality  
partitioning

partitioning  
hardware and software  
partitioning and cache (VLSI)  
partitioning and cache (hardware)

6 Nov 19  
41 Here we first  
gray those vertices with  
heaviest weight bel^n then.  
K-L algorithm



Collapse vertices into single groups and computation also done  
required edges.  $O(n^3)$

Fiduccia - Mattheyses  $O(FM)$  alg  $\approx O(n^4)$

Partitioning :



How to  
place this?

Plan  
(placement)

For Input / Output pins in each  
- exact location  
constraint on shape of places

way is to map

Easiest mapping can be done to bin pack packing problem



$M_{bin}(W \times L)$

Only horizontal and vertical  
placements are done

L

Find out co-ordinates (of each  
- hand topology)

of each rectangle placed such that  
 $M_{bin}(W, L)$  gives no overlap  
(for modules) or no overlap.

$\Downarrow$   
constraints

Standard cell-to-cell dimensions of each cell in design



Could also use FPGAs where all gates are standard cells

Wiring length estimated as  $\sum_{i,j} (c_{ij} * d_{ij})$

$c_{ij}$  - connectivity  
net id  $i$

Manhattan distance net  $d_{ij} = |i_2 - i_1| + |j_2 - j_1|$

$d_{ij}$  - a Manhattan distance  
net center of  
id  $i$



We could minimize  $\alpha A + (1-\alpha) L$

Slicing structure - Place a tree (minimize empty space)

Routing wires: How to connect wires bet' modules (which channels to use)

Routing

If routing does not happen on some layer, we may need a new layer (lots of lot)

Global  
(How you  
want to  
route?)  
Detailed  
route  
routing  
(Route  
exactly  
through  
interconnects)  
connect