### Logic Synthesis and Verification

# Programming Assignment 1

#### B06507027 電機四 劉慕德

### List of Files

- sfa\_4num.blif is the \*.blif representation of the 4-number serial full adder.
- b06507027\_LSV\_PA1\_report is this report.

## 1 [Using ABC]

(a) The combinational part of the circuit reads 6 inputs:  $a, b, c, d, c_{\text{in}}^{(1)}, c_{\text{in}}^{(2)}$  and gives 3 outputs:  $\underbrace{s, c_{\text{out}}^{(1)}, c_{\text{out}}^{(2)}}_{\text{cout}}, \text{ where } c_{\text{in}}^{(1)}, c_{\text{out}}^{(1)} \text{ and } c_{\text{in}}^{(2)}, c_{\text{out}}^{(2)}$  are the carry-in/out of the twos and fours digits. Since  $\underbrace{c_{\text{out}}^{(2)}, c_{\text{out}}^{(1)}}_{\text{cout}} s$  is the number of 1's in the inputs, we have

$$\begin{split} s = 1 \Leftrightarrow \# \text{ of } 1'\text{s in the inputs is } 1, 3, \text{or } 5 \\ c_{\text{out}}^{(1)} = 1 \Leftrightarrow \# \text{ of } 1'\text{s in the inputs is } 2, 3, \text{or } 6 \\ c_{\text{out}}^{(2)} = 1 \Leftrightarrow \# \text{ of } 1'\text{s in the inputs is } 4, 5, \text{or } 6 \end{split}$$

A Python script is used to generate the on-sets via listing permutations of 0's, 1's, and -'s. For example, to list the cubes that covers the case where the number of 1's in the inputs is 2 or 3, we consider all possible permutations of "11000-".

- (b) 3. Figure 1 is the image that command show outputs:
  - 5. Figure 2 is the image that command show outputs after strash ing:
  - 7. Figure 3 is the image that command show outputs after collapse ing:

# 2 [ABC Boolean Function Representations]

- (a) 1. As the command aig only turn each node into AIG locally, it only affect the internal representation, which can be seen from running ps, and when show ing the network, the output is still an SOP, albeit optimized. On the other hand, the command strash turn the whole circuit into AIG, which when show n also outputs an AIG.
  - 2. As in (a), bdd has only local effects, while collapse turn the whole circuit into a BDD. However, in this case the outputs when running show\_bdd -g are exactly the same since the command strash the circuit implicitly anyway before drawing the BDD (see src/base/abci/abc.c Line: 3230).
- (b) A strash ed network cannot be turned directly into SOP, but we can first collapse it, then the BDD can be turned back into SOP by running sop.

Network structure visualized by ABC Benchmark "fa\_4num". Time was Mon Oct 4 19:12:47 2021.

The network contains 3 logic nodes and 2 latches.



Figure 1: the image that command show outputs



Figure 2: the image that command show outputs after strash ing



Figure 3: The image that command show outputs after collapse ing