# COE 561, Term 081 <br> Digital System Design and Synthesis HW\# 3 

Due date: Sunday, Jan. 4
Q.1. Consider the following function:

$$
\begin{aligned}
X= & A B E G^{\prime}+A B F G+A B E^{\prime} G+A C E G^{\prime}+A C F G+A C E^{\prime} G+D \\
& E G^{\prime}+D F G+D E^{\prime} G
\end{aligned}
$$

(i) Compute all the kernels of $X$ using the recursive kernel computation algorithm. Show all the steps.
(ii) Compute all the kernels of X based on matrix representation. Compare your answer to the result obtained in (i).
(iii) Find a quick factor of $X$ by using the first level-0 kernel found. Assume that input variables are sorted in lexicographic order. Determine the number of literals obtained. Compare your solution with the result obtained by running the sis commands factor -q $\boldsymbol{x}$; print_factor; print_stats $\mathbf{- f}$.
Q.2. Consider the following function:

$$
\begin{aligned}
X= & A C D E+B C D E+A^{\prime} B^{\prime} F G+A^{\prime} B^{\prime} F^{\prime} G^{\prime}+E C F+E C^{\prime} G+E^{\prime} C F^{\prime}+ \\
& E^{\prime} C^{\prime} G^{\prime}
\end{aligned}
$$

(i) Compute all double-cube divisors of $X$ along with their bases and their weights. Show only double-cube divisors that have non-empty bases.
(ii) Apply the fast extraction algorithm based on extracting double-cube divisors along with complements or single-cube divisors with two-literals. Show all steps of the algorithm. Determine the number of literals saved. Compare your solution with the result obtained by running the sis commands $\boldsymbol{f x}$.
Q.3. Consider the logic network defined by the following expressions:

$$
\begin{aligned}
& X=A C+B ; \\
& Y=X+A^{\prime} B ; \\
& Z=Y C^{\prime} ;
\end{aligned}
$$

Inputs are $\{\mathrm{A}, \mathrm{B}, \mathrm{C}\}$ and output is $\{\mathrm{Z}\}$.
(i) Compute the SDC set for node X .
(ii) Using the SDC set of node X , simplify the function Y .
(iii) Compute the ODC set for node Y.
(iv) Simplify the function of Y using both its ODC and SDC of node X.
(v) Apply the sis command full_simplify and compare the solution obtained with your obtained solution based in (iv).
Q.4. Consider the logic network defined by the following expressions:

$$
\begin{aligned}
& k=a \cdot b \\
& l=a \cdot c \\
& h=a+c \\
& e=a^{\prime}+b \\
& g=k+l \\
& f=d^{\prime} \cdot g \\
& i=f \oplus d \\
& x=e \oplus i \\
& j=f+d \\
& y=j+h
\end{aligned}
$$

Inputs are $\{\mathrm{a}, \mathrm{b}, \mathrm{c}, \mathrm{d}\}$ and outputs are $\{\mathrm{x}, \mathrm{y}\}$. Assume that the delay of each inverter, AND and OR gates is 1 and that the delay of each XOR gate is 2 . Also, assume that the input data-ready times are zero except for input a, which is equal to 2 .
(i) Draw the logic network graph and compute the data ready times and slacks for all vertices in the network.
(ii) Determine the maximum propagation delay and the topological critical path.
(iii) Suggest an implementation of the function $\boldsymbol{g}$ in terms of the Inputs $\{a, b, c\}$ to reduce the delay of the circuit. What is the maximum propagation delay after the modified implementation?

