SICP Exercise 3.30 ripple-carry-adder
Exercise 3.30. Figure 3.27 shows a ripple-carry adder formed by stringing together n full-adders. This is the simplest form of parallel adder for adding two n-bit binary numbers. The inputs A1, A2, A3, ..., An and B1, B2, B3, ..., Bn are the two binary numbers to be added (each Ak and Bk is a 0 or a 1). The circuit generates S1, S2, S3, ..., Sn, the n bits of the sum, and C, the carry from the addition. Write a procedure ripple-carry-adder that generates this circuit. The procedure should take as arguments three lists of n wires each -- the Ak, the Bk, and the Sk -- and also another wire C. The major drawback of the ripple-carry adder is the need to wait for the carry signals to propagate. What is the delay needed to obtain the complete output from an n-bit ripple-carry adder, expressed in terms of the delays for and-gates, or-gates, and inverters?
SOLUTION
The code is here.
Look at the implementation and test results below. I am also printing the number of times the delay procedure is called for each addition. In a freshly constructed ripple-carry-adder when we add two 1-bit numbers, the delay proc is called 16 times. When we add two 2-bit numbers, the delay proc is called 32 times. Note that while constructing a new ripple-carry-adder, every action procedure on every device is called (sometimes even more than once) and the computation happens in response to whatever signals are wired to the adder at the start.
A full-adder contains two half adders and an or-gate.
A half-adder contains 2 and-gates, 1 or-gate and 1 inverter.
So the total number of components in a full-adder is: {2 * (2 + 1 + 1)} + 1 = 9
Note that the first computation/processing in any gate happens during its construction. The numbers 16 and 32 above are the number of times the delay proc is called when the ripple-carry-adder is constructed. Each-time an or-gate is constructed, its action procedure is called twice (since add-action! is called twice). The same is true for the and-gate. Each time an inverter is constructed, its action procedure is called once. So when a half-adder is constructed, the delay proc is called {(2 * 2) + (1 * 2) + 1} = 7 times. Since a full-adder contains two half-adders and an or-gate, when a full-adder is constructed, the delay proc is called {(7 * 2) + 2} = 16 times. (This can be seen in the test results below.)
So the delay in one full-adder is
Full-Adder Delay = {2 * (2 * and-gate-delay + or-gate-delay + inverter-delay)} + or-gate-delay
Therefore, for an n-bit ripple carry adder, the delay will be:
n * [{2 * (2 * and-gate-delay + or-gate-delay + inverter-delay)} + or-gate-delay]
We also observe in the test results below that when an existing adder is re-used for addition of new input values, there is no fixed value for the number of times the the delay proc is called. This is because only those gates are activated (and action procedures called) that are connected to wires where there is a change in signal.
Of course, in real circuits, signals flow in parallel and therefore gates will also function in
parallel so the actual delay will be lesser than what is computed above.
SOLUTION
The code is here.
Look at the implementation and test results below. I am also printing the number of times the delay procedure is called for each addition. In a freshly constructed ripple-carry-adder when we add two 1-bit numbers, the delay proc is called 16 times. When we add two 2-bit numbers, the delay proc is called 32 times. Note that while constructing a new ripple-carry-adder, every action procedure on every device is called (sometimes even more than once) and the computation happens in response to whatever signals are wired to the adder at the start.
A full-adder contains two half adders and an or-gate.
A half-adder contains 2 and-gates, 1 or-gate and 1 inverter.
So the total number of components in a full-adder is: {2 * (2 + 1 + 1)} + 1 = 9
Note that the first computation/processing in any gate happens during its construction. The numbers 16 and 32 above are the number of times the delay proc is called when the ripple-carry-adder is constructed. Each-time an or-gate is constructed, its action procedure is called twice (since add-action! is called twice). The same is true for the and-gate. Each time an inverter is constructed, its action procedure is called once. So when a half-adder is constructed, the delay proc is called {(2 * 2) + (1 * 2) + 1} = 7 times. Since a full-adder contains two half-adders and an or-gate, when a full-adder is constructed, the delay proc is called {(7 * 2) + 2} = 16 times. (This can be seen in the test results below.)
So the delay in one full-adder is
Full-Adder Delay = {2 * (2 * and-gate-delay + or-gate-delay + inverter-delay)} + or-gate-delay
Therefore, for an n-bit ripple carry adder, the delay will be:
n * [{2 * (2 * and-gate-delay + or-gate-delay + inverter-delay)} + or-gate-delay]
We also observe in the test results below that when an existing adder is re-used for addition of new input values, there is no fixed value for the number of times the the delay proc is called. This is because only those gates are activated (and action procedures called) that are connected to wires where there is a change in signal.
Of course, in real circuits, signals flow in parallel and therefore gates will also function in
parallel so the actual delay will be lesser than what is computed above.
Comments
Post a Comment