**Laboratory 3 – Sequential circuits: memory and feedback**

**Procedure:**

This assignment has two related exercises. Demonstrate the operation of the circuits using LED’s and submit a circuit design for part B on the reverse of this sheet.

**Introduction:**

Fig 3.1 shows the difference between combinational and sequential circuits:   
(a) Combinational circuits implement one-way logic – the outputs assume the logic function implemented by the network after the transients in the current input have settled. For example, think of C=A(AND)B or C=A(OR)B.   
(b) Sequential circuits on the other hand, ‘remember’ the current state of the system in memory. The next output is computed based on the current input and the combinational logic implemented in the system.

Current

Output

Fig 3.1

CLOCK

Current

Output

COMBINATIONAL LOGIC

Current

Input

REGISTERS

(MEMORY)

COMBINATIONAL LOGIC

(b) SEQUENTIAL LOGIC

Current

Input

(a) COMBINATIONAL LOGIC

A,B

C

In case of synchronous sequential systems, an external clock signal orchestrates the operation of the circuit. *Good design principles dictate that the clock signal must always enter the system at the memory*: this will become clearer as you design and build more circuits. Today’s lab deals with building a sequential circuit.

**Part A**

Build the circuit shown in Fig 3.2 for adding 2 sets of 8-bit binary numbers using two IC7483 full adder chips. Use any random combinations of inputs (eg 11011001,00000001 etc) by applying +5V and grounding the appropriate inputs of the IC to verify that your circuit works. Add any two different sets of numbers. Connect up LED’s to the inputs and outputs for demonstration.

Fig 3.2

*CARRY 1*

A0-3

*4*

*4*

*SUM 0-3*

*4*

*1*

IC7483

FULL

ADDER

B0-3

A0-3+B0-3 = SUM0-3 + CARRY1

A4-7+B4-7 + CARRY1= SUM4-7 + CARRY2

*(here ‘+’ means binary addition*

*and the superscript* A0-3 *means the four bits A3A2A1A0 etc*

*4*

*Note: This symbol means 4-bits in parallel. This is a “4-bit bus”*

*CARRY*2

*4*

*4*

*SUM 4-7*

*4*

*1*

IC7483

FULL

ADDER

A4-7

B4-7

**Part B**

Using the principle of sequential logic discussed above in Fig 3.1, design and build a circuit to add a number with *an arbitrary (large N) number* of bits using just one IC7483 and a few D registers (money is limited and these IC’s are expensive! Besides, the amount of wiring needed for large number of additions would be very large.)

1. You can use the logic pulse generator to provide manual pulses on the clock input to your circuit. What is the function of the clock signal here?
2. You can use a fixed input of a combination of *N* bits where *N* is a multiple of four.   
   i.e. for this exercise, you can simplify:

by taking B = A

![](data:image/x-wmf;base64,183GmgAAAAAAAAASQAIACQAAAABRTgEACQAAAzABAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCQAIAEhIAAAAmBg8AGgD/////AAAQAAAAwP///7f////AEQAA9wEAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AvPASAHlIqnVAka11qwtmPAQAAAAtAQAACgAAADIKoAHzDAUAAABDQVJSWQAJAAAAMgqgAR0HAwAAAFNVTVIIAAAAMgqgAa4DAQAAAEFVCAAAADIKoAFYAAEAAABBVRwAAAD7AiD/AAAAAAAAkAEBAAAABAIAEFRpbWVzIE5ldyBSb21hbgC88BIAeUiqdUCRrXWrC2Y8BAAAAC0BAQAEAAAA8AEAAAgAAAAyCvQAkAoBAAAATlUIAAAAMgr0ALAEAQAAAE5VCAAAADIK9ABaAQEAAABOVRwAAAD7AoD+AAAAAAAAkAEAAAACBAIAEFN5bWJvbAB1UQcKC5AtLQC88BIAeUiqdUCRrXWrC2Y8BAAAAC0BAAAEAAAA8AEBAAgAAAAyCqABrAsBAAAAK1UIAAAAMgqgAegFAQAAAD1VCAAAADIKoAF2AgEAAAArVQoAAAAmBg8ACgD/////AQAAAAAAHAAAAPsCEAAHAAAAAAC8AgAAAAABAgIiU3lzdGVtADyrC2Y8AAAKADgAigEAAAAAAQAAANjyEgAEAAAALQEBAAQAAADwAQAAAwAAAAAA) and calculate this function instead

For example use:  
 *A =* 0001 0001 0001 (decimal 273) or *A =*1000 1000 1000 (decimal 2184)

![](data:image/x-wmf;base64,183GmgAAAAAAAAASQAIACQAAAABRTgEACQAAAzABAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCQAIAEhIAAAAmBg8AGgD/////AAAQAAAAwP///7f////AEQAA9wEAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AvPASAHlIqnVAka11Igxm6QQAAAAtAQAACgAAADIKoAH1DAUAAABDQVJSWQAJAAAAMgqgASAHAwAAAFNVTVIIAAAAMgqgAZ0DAQAAAEJVCAAAADIKoAFYAAEAAABBVRwAAAD7AiD/AAAAAAAAkAEBAAAABAIAEFRpbWVzIE5ldyBSb21hbgC88BIAeUiqdUCRrXUiDGbpBAAAAC0BAQAEAAAA8AEAAAgAAAAyCvQAkwoBAAAATlUIAAAAMgr0ALIEAQAAAE5VCAAAADIK9ABbAQEAAABOVRwAAAD7AoD+AAAAAAAAkAEAAAACBAIAEFN5bWJvbAB1qwoKw5AtLQC88BIAeUiqdUCRrXUiDGbpBAAAAC0BAAAEAAAA8AEBAAgAAAAyCqABrwsBAAAAK1UIAAAAMgqgAeoFAQAAAD1VCAAAADIKoAF3AgEAAAArVQoAAAAmBg8ACgD/////AQAAAAAAHAAAAPsCEAAHAAAAAAC8AgAAAAABAgIiU3lzdGVtAOkiDGbpAAAKADgAigEAAAAAAQAAANjyEgAEAAAALQEBAAQAAADwAQAAAwAAAAAA)In the real world, you would build another sequential system to feed your adder with   
 4-bit numbers on a 4-bit data bus.

1. In your logic, what is the constraint on the numbers you can add?

*Note: Keep in mind that a TTL gate with input left unconnected is assumed high, take this into account when designing and building your circuit.*

Draw your circuit design below to implement the addition of two *N*-bit numbers as above:

*Point out in particular how your circuit handles the carry bit.*

**1)Answer:** Function of CLK signal:

\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_

**2)Answer:** Constraint on the number that can be added with this design:

\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_

**3) Circuit Design:**

/5

**A.Demo**

/1

**B.1**

/1

**B.2**

/4

**B.3 design**

/4

**B.3 demo**

/15

**Total**