# ECE253 Midterm Cheatsheet

## Boolean Algebra

De Morgan's Theorem tells us

$$\overline{xy} = \overline{x} + \overline{y}, \qquad \overline{x+y} = \overline{xy}$$
 (1)

Inverting the inputs to an **or** gate is the same as inverting the outputs to an **and** gate, and the other way around. We also have:

- $(x+y)(y+z)(\overline{x}+z) = (x+y)(\overline{x}+z)$
- $\bullet \quad x + yz = (x+y)(x+z)$
- x + xy = x (Absorption)
- $xy + x\overline{y} = x$  (Combining)
- $\bullet (x+y)(x+\overline{y}) = x$
- $\bullet \ \ x + \overline{x}y = x + y$
- $x(\overline{x} + y) = xy$
- $xy + yz + z\overline{x} = xy + z\overline{x}$  (Consensus)

### Gates

| AND |          | OR   |   | NOT | - |
|-----|----------|------|---|-----|---|
| NOR | <b>D</b> | NAND | 1 | XOR | 1 |

### SOPs and POSs

We can create boolean algebra expressions for truth tables.

**Minterm:** Corresponds to each row of truth table, i.e.  $m_3 = \overline{x_2}x_1x_0$  such that when 3 = 0b011 is substituted in,  $m_3 = 1$  and  $m_3 = 0$  otherwise.

**Maxterm:** They give  $M_i = 0$  if and only if the input is *i*. For example,  $M_3 = x_2 + \overline{x_1} + \overline{x_0}$ .

**SOP** and **POS**: Truth tables can be represented as a sum of minterms, or product of maxterms.

#### Cost

The cost of a logic circuit is given by

$$cost = gates + inputs$$
 (2)

If an inversion (NOT) is performed on the primary inputs, then it is not included. If it is needed inside the circuit, then the NOT gate is included in the cost.

## Karnaugh Map

Method of finding a minimum cost expression: We can map out truth table on a grid for easier pattern recognition. Example of a four variable map is shown below:



and the representation is  $\overline{x_2} \cdot \overline{x_4} + x_2 \cdot x_1 + \overline{x_4} \cdot x_2$ . Some *rules*:

- Side lengths should be powers of 2 and be as large as possible.
- Use **graycoding**: adjacent rows/columns should share one bit.

Some definitions:

- Literal: variables in a product term:  $x_1\overline{x_2}x_3$  has three literals.
- Implicant: a product term that indicates the input valuation(s) for which a given function is equal to 1.
- **Prime Implicant:** an implicant that cannot be combined into another implicant with fewer literals. *They are as big as possible.*
- Cover: A collection of implicants that account for all valuations for which function equals 1.
- Essential Prime Implicant: A prime implicant that includes a minterm not included in any other prime implicant. They contain at least one minterm not covered by another prime implicant.

In the above example,  $\overline{x_2} \cdot \overline{x_4} + x_2 x_1 + \overline{x_4} x_2$  are prime implicants.

#### Minimization Procedure

- 1. Generate all prime implicants for given function f
- 2. Find the set of essential prime implicants
- 3. If the set of essential prime implicants cover all valuations for which f=1, then this set is the desired cover. Otherwise, determine the nonessential prime implicants that should be added.

## Common Logic Gates

To save space, boolean expressions will be written instead of drawing diagrams. You should be familiar with how to construct diagrams from expressions.

- Mux  $2\rightarrow 1$ : mux2to1 $(s, x_0, x_1) = \overline{s}x_0 + sx_1$
- Mux  $4\rightarrow$ 1: mux4to1(s,x) = mux2to1(s1, mux2to1(s0, x0, x1), mux2to1(s0, x2, x3))
- TO BE ADDED

### RS Latch

Sequential circuits depend on sequence of inputs. A **SR** Latch are cross-coupled NOR gates.



| $\mathbf{S}$ | R | Q   | $\overline{Q}$ |
|--------------|---|-----|----------------|
| 0            | 0 | 0/1 | 1/0            |
| 0            | 1 | 0   | 1              |
| 1            | 0 | 1   | 0              |
| 1            | 1 | 0   | 0              |

When S = R = 0, it stores the last Q value. In practice, we should not have S = R = 1.

Gated D Latch and Clock Signal



|  | Clk | S | R | Q(t+1) |  |  |  |  |  |
|--|-----|---|---|--------|--|--|--|--|--|
|  | 0   | х | X | Q(t)   |  |  |  |  |  |
|  | 1   | 0 | 0 | Q(t)   |  |  |  |  |  |
|  | 1   | 0 | 1 | 0      |  |  |  |  |  |
|  | 1   | 1 | 0 | 1      |  |  |  |  |  |
|  | 1   | 1 | 1 | 1      |  |  |  |  |  |
|  |     |   |   |        |  |  |  |  |  |

Where the Clk = 1 cases refer to retain, reset, set, and last one is not used.

# Flip Flops

Consists of two gated D latches, connected in series and both connected to the same clock. However, clock input for the first D latch is inverted.

• When the clock rises up,  $Q_1$  stores value of D. When the clock rises down,  $Q_2$  stores value of D.

## Verilog

## Minimal Example

```
module mux(MuxSelect, Input, Out);
    input [7:0] Input;
    input [2:0] MuxSelect;
    output Out;
    reg Out; // declare output for always block
    always @(*) // declare always block
     begin
     case (MuxSelect[2:0]) // start case statement
     3'b000: Out = Input[0]; // case 0
     3'b001: Out = Input[1]; // case 1
     3'b010: Out = Input[2]; // case 2
     3'b011: Out = Input[3]; // case 3
     3'b100: Out = Input[4]; // case 4
     3'b101: Out = Input[5]: // case 5
     3'b110: Out = Input[6]; // case 6
     default: Out = 1'bx; // default case
     endcase
    end
endmodule
```

#### D Latch

```
module D-latch(D, clk, Q);
  input D, clk;
  output reg Q;

always@(D, clk)
  begin
    if (clk == 1'b1)
      Q = D;
  end
endmodule
```

# Flip Flop

```
module D-ff(D, clk, Q);
  input D, clk;
  output reg Q;
  always@(posedge clk)
    begin
    Q <= D; // use <= operator
  end
endmodule</pre>
```

### **TBA**

Nam dui ligula, fringilla a, euismod sodales, sollicitudin vel, wisi. Morbi auctor lorem non justo. Nam lacus libero, pretium at, lobortis vitae, ultricies et, tellus. Donec aliquet, tortor sed accumsan bibendum, erat ligula aliquet magna, vitae ornare odio metus a mi. Morbi ac orci et nisl hendrerit mollis. Suspendisse ut massa. Cras nec ante. Pellentesque a nulla. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Aliquam tincidunt urna. Nulla ullamcorper vestibulum turpis. Pellentesque cursus luctus mauris.

Nulla malesuada porttitor diam. Donec felis erat, congue non, volutpat at, tincidunt tristique, libero. Vivamus viverra fermentum felis. Donec nonummy pellentesque ante. Phasellus adipiscing semper elit. Proin fermentum massa ac quam. Sed diam turpis, molestie vitae, placerat a, molestie nec, leo. Maecenas lacinia. Nam ipsum ligula, eleifend at, accumsan nec, suscipit a, ipsum. Morbi blandit ligula feugiat magna. Nunc eleifend consequat lorem. Sed lacinia nulla vitae enim. Pellentesque tincidunt purus vel magna. Integer non enim. Praesent euismod nunc eu purus. Donec bibendum quam in tellus. Nullam cursus pulvinar lectus. Donec et mi. Nam vulputate metus eu enim. Vestibulum pellentesque felis eu massa.

Quisque ullamcorper placerat ipsum. Cras nibh. Morbi vel justo vitae lacus tincidunt ultrices. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. In hac habitasse platea dictumst. Integer tempus convallis augue. Etiam facilisis. Nunc elementum fermentum wisi. Aenean placerat. Ut imperdiet, enim sed gravida sollicitudin, felis odio placerat quam, ac pulvinar elit purus eget enim. Nunc vitae tortor. Proin tempus nibh sit amet nisl. Vivamus quis tortor vitae risus porta vehicula.

Fusce mauris. Vestibulum luctus nibh at lectus. Sed bibendum, nulla a faucibus semper, leo velit ultricies tellus, ac venenatis arcu wisi vel nisl. Vestibulum diam. Aliquam pellentesque, augue quis sagittis posuere, turpis lacus congue quam, in hendrerit risus eros eget felis. Maecenas eget erat in sapien mattis porttitor. Vestibulum porttitor. Nulla facilisi. Sed a turpis eu lacus commodo facilisis. Morbi fringilla, wisi in dignissim interdum, justo lectus sagittis dui, et vehicula libero dui cursus dui. Mauris tempor ligula sed lacus. Duis cursus enim ut augue. Cras ac magna. Cras nulla. Nulla egestas. Curabitur a leo. Quisque egestas wisi eget nunc. Nam feugiat lacus vel est. Curabitur consectetuer.

Suspendisse vel felis. Ut lorem lorem, interdum eu.

tincidunt sit amet, laoreet vitae, arcu. Aenean faucibus pede eu ante. Praesent enim elit, rutrum at, molestie non, nonummy vel, nisl. Ut lectus eros, malesuada sit amet, fermentum eu, sodales cursus, magna. Donec eu purus. Quisque vehicula, urna sed ultricies auctor, pede lorem egestas dui, et convallis elit erat sed nulla. Donec luctus. Curabitur et nunc. Aliquam dolor odio, commodo pretium, ultricies non, pharetra in, velit. Integer arcu est, nonummy in, fermentum faucibus, egestas vel, odio. Sed commodo posuere pede. Mauris ut est. Ut quis purus. Sed ac odio. Sed vehicula hendrerit sem. Duis non odio. Morbi ut dui. Sed accumsan risus eget odio. In hac habitasse platea dictumst. Pellentesque non elit. Fusce sed justo eu urna porta tincidunt. Mauris felis odio, sollicitudin sed, volutpat a, ornare ac, erat. Morbi quis dolor. Donec pellentesque, erat ac sagittis semper, nunc dui lobortis purus, quis congue purus metus ultricies tellus. Proin et quam. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos hymenaeos. Praesent sapien turpis, fermentum vel, eleifend faucibus, vehicula eu, lacus.

Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Donec odio elit, dictum in, hendrerit sit amet, egestas sed, leo. Praesent feugiat sapien aliquet odio. Integer vitae justo. Aliquam vestibulum fringilla lorem. Sed neque lectus, consectetuer at, consectetuer sed, eleifend ac, lectus. Nulla facilisi. Pellentesque eget lectus. Proin eu metus. Sed porttitor. In hac habitasse platea dictumst. Suspendisse eu lectus. Ut mi mi, lacinia sit amet, placerat et, mollis vitae, dui. Sed ante tellus, tristique ut, iaculis eu, malesuada ac, dui. Mauris nibh leo, facilisis non, adipiscing quis, ultrices a, dui.

Morbi luctus, wisi viverra faucibus pretium, nibh est placerat odio, nec commodo wisi enim eget quam. Quisque libero justo, consectetuer a, feugiat vitae, porttitor eu, libero. Suspendisse sed mauris vitae elit sollicitudin malesuada. Maecenas ultricies eros sit amet ante. Ut venenatis velit. Maecenas sed mi eget dui varius euismod. Phasellus aliquet volutpat odio. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Pellentesque sit amet pede ac sem eleifend consectetuer. Nullam elementum, urna vel imperdiet sodales, elit ipsum pharetra ligula, ac pretium ante justo a nulla. Curabitur tristique arcu eu metus. Vestibulum lectus. Proin mauris. Proin eu nunc eu urna hendrerit faucibus. Aliquam auctor, pede consequat laoreet varius, eros tellus scelerisque quam, pellentesque hendrerit ipsum dolor sed augue. Nulla nec lacus.