# Problem 1 (20 points)

Simulate the output behavior of a D latch that is driven with the following input. The output is low at the beginning, as shown. Assume that the latch propagation delay (D to Q and EN to Q) is 20 ns. Note that each dot on the waveform is 10 ns.



Simulate the output behavior of a D flip-flop that is driven with the following input. The output is low at the beginning, as shown. Assume that the flip-flop propagation delay (clk to Q) is 20 ns and the setup and hold times are each 10 ns. Note that each dot on the waveform is 10 ns.



### Problem 2 (30 points)

Create a state diagram for a state machine that implements the following description.

The state machine has two inputs, HOT and COLD, which indicate that an oven is too hot or too cold. Both inputs will never be asserted together, and if neither is asserted, then the temperature is correct.

The state machine has two Moore outputs, BURN and VENT. If BURN is asserted, a flame lights to heat up the oven, and if VENT is asserted, a vent opens to cool the oven. Both outputs should <u>never</u> be asserted at the same time.

If COLD is high, the flame should light as soon as possible, and if HOT is high, the vent should open as soon as possible. However, once lit, the flame must remain lit for <u>at least</u> two seconds. Other than that, it should not be lit any longer than necessary (nor should the vent be open any longer than necessary, and the vent has no requirement to stay open).

Assume that the state machine is clocked <u>once per second</u>, so you can use state transitions to keep track of time (and thus do not need any "time" input).



only active outputs are shown

# Problem 3 (30 points)

The following state machine has one input (X), three state bits  $(Q_{2-0})$ , and one output (Z).



The designer had four states, and chose the following state encodings:

| State Name | Encoding (Q <sub>2-0</sub> ) |
|------------|------------------------------|
| Eeny       | 000                          |
| Meeny      | 111                          |
| Miney      | 110                          |
| Moe        | 100                          |

1) During which state(s) is the output Z asserted?

Meeny, Minny, Moe

2) If the current state is Meeny and the input is 1, what will the next state be?

Meeny

3) Complete the blank entries in the following portion of the state machine's transition table.

| Current State | <b>Q</b> <sub>2-0</sub> | Input | Next State | <b>Q</b> <sub>2-0</sub> <sup>+</sup> | Z |
|---------------|-------------------------|-------|------------|--------------------------------------|---|
| Eeny          | 000                     | 0     | Eery       | 060                                  | 6 |
| Eeny          | 000                     | 1     | Many       | (1)                                  | 6 |
| Moe           | 100                     | 1     | Meeny      | 1 ( )                                | 1 |
| Moe           | 100                     | 1     | Meeny      | 1 ( )                                |   |

#### Problem 4 (20 points)

The state machine from the previous problem is repeated here, along with some timing parameters of the devices involved.



| Flip-flop propagation delay  | 70 ns |
|------------------------------|-------|
| Flip-flop setup time         | 15 ns |
| Flip-flop hold time          | 10 ns |
| 2-input OR propagation delay | 30 ns |
| 3-input OR propagation delay | 45 ns |

1) Based on the provided parameters, what is the minimum amount of time allowed between successive rising clock edges? Express your answer as a sum of numbers; you don't need to actually sum them into a final value.



2) [The image below is to help visualize this question] If a rising edge of the clock occurs at t=0, during what period(s) of time must the X input <u>not</u> change to avoid violating any timing requirements? Express your answer as one or more intervals around 0; for example -5 ns to 15 ns.

#### Bonus Question (up to 1 point)

All of this is only worth up to 1 point. Do not bother with this unless you are finished with everything else.

Observe the following circuit. It has an input, an output, and a clock signal, and consists of a latch and a flip-flop.



The input (signal on the left) can change at any time with respect to clock edges.

What relationship(s) between parameters of the latch and flip-flop must be true to ensure that all timing requirements are met?

Tplatch > Th