A carry-skip adder[nb 1] (also known as a carry-bypass adder) is an adder implementation that improves on the delay of a ripple-carry adder with little effort compared to other adders. The improvement of the worst-case delay is achieved by using several carry-skip adders to form a block-carry-skip adder.

Unlike other fast adders, carry-skip adder performance is increased with only some of the combinations of input bits. This means, speed improvement is only probabilistic.

Single carry-skip adder edit

The worst case for a simple one level ripple-carry adder occurs, when the propagate-condition[1] is true for each digit pair  . Then the carry-in ripples through the  -bit adder and appears as the carry-out after  .

 
Full adder with additional generate and propagate signals.

For each operand input bit pair   the propagate-conditions   are determined using an XOR-gate. When all propagate-conditions are true, then the carry-in bit   determines the carry-out bit.

The n-bit-carry-skip adder consists of a n-bit-carry-ripple-chain, a n-input AND-gate and one multiplexer. Each propagate bit  , that is provided by the carry-ripple-chain is connected to the n-input AND-gate. The resulting bit is used as the select bit of a multiplexer that switches either the last carry-bit   or the carry-in   to the carry-out signal  .

  •  

This greatly reduces the latency of the adder through its critical path, since the carry bit for each block can now "skip" over blocks with a group propagate signal set to logic 1 (as opposed to a long ripple-carry chain, which would require the carry to ripple through each bit in the adder). The number of inputs of the AND-gate is equal to the width of the adder. For a large width, this becomes impractical and leads to additional delays, because the AND-gate has to be built as a tree. A good width is achieved, when the sum-logic has the same depth like the n-input AND-gate and the multiplexer.

 
4 bit carry-skip adder.

Performance edit

The critical path of a carry-skip-adder begins at the first full-adder, passes through all adders and ends at the sum-bit  . Carry-skip-adders are chained (see block-carry-skip-adders) to reduce the overall critical path, since a single  -bit carry-skip-adder has no real speed benefit compared to a  -bit ripple-carry adder.

 

The skip-logic consists of a  -input AND-gate and one multiplexer.

 

As the propagate signals are computed in parallel and are early available, the critical path for the skip logic in a carry-skip adder consists only of the delay imposed by the multiplexer (conditional skip).

 .

Block carry-skip adders edit

 
16-bit fixed-block-carry-skip adder with a block size of 4 bit.

Block-carry-skip adders are composed of a number of carry-skip adders. There are two types of block-carry-skip adders The two operands   and   are split in   blocks of   bits.

  • Why are block-carry-skip-adders used?
  • Should the block-size be constant or variable?
  • Fixed block width vs. variable block width

Fixed size block-carry-skip adders edit

Fixed size block-carry-skip adders split the   bits of the input bits into blocks of   bits each, resulting in   blocks. The critical path consists of the ripple path and the skip element of the first block, the skip paths that are enclosed between the first and the last block, and finally the ripple-path of the last block.

 

The optimal block size for a given adder width n is derived by equating to 0

 
 
 

Only positive block sizes are realizable

 

Variable size block-carry-skip adders edit

The performance can be improved, i.e. all carries propagated more quickly by varying the block sizes. Accordingly the initial blocks of the adder are made smaller so as to quickly detect carry generates that must be propagated the furthers, the middle blocks are made larger because they are not the problem case, and then the most significant blocks are again made smaller so that the late arriving carry inputs can be processed quickly.

Multilevel carry-skip adders edit

By using additional skip-blocks in an additional layer, the block-propagate signals   are further summarized and used to perform larger skips:

 

Thus making the adder even faster.

Carry-skip optimization edit

The problem of determining the block sizes and number of levels required to make the physically fastest carry-skip adder is known as the 'carry-skip adder optimization problem'. This problem is made complex by the fact that a carry-skip adders are implemented with physical devices whose size and other parameters also affects addition time.

The carry-skip optimization problem for variable block sizes and multiple levels for an arbitrary device process node was solved by Thomas W. Lynch.[2] This reference also shows that carry-skip addition is the same as parallel prefix addition and is thus related to, and for some configurations identical to the Han–Carlson,[3][4] the Brent–Kung,[5] the Kogge-Stone adder[6] and a number of other adder types.

Implementation overview edit

Breaking this down into more specific terms, in order to build a 4-bit carry-bypass adder, 6 full adders would be needed. The input buses would be a 4-bit A and a 4-bit B, with a carry-in (CIN) signal. The output would be a 4-bit bus X and a carry-out signal (COUT).

The first two full adders would add the first two bits together. The carry-out signal from the second full adder ( )would drive the select signal for three 2 to 1 multiplexers. The second set of 2 full adders would add the last two bits assuming   is a logical 0. And the final set of full adders would assume that   is a logical 1.

The multiplexers then control which output signal is used for COUT,   and  .

Notes edit

  1. ^ Carry-skip adder is often abbreviated as CSA, however, this can be confused with carry-save adder.

References edit

  1. ^ Parhami, Behrooz (2000). Computer arithmetic: Algorithms and Hardware Designs. Oxford University Press. p. 108. ISBN 0-19-512583-5.
  2. ^ Lynch, Thomas Walker (May 1996). "Binary Adders" (Thesis). University of Texas. Archived (PDF) from the original on 2018-04-14. Retrieved 2018-04-14.
  3. ^ Han, Tackdon; Carlson, David A.; Levitan, Steven P. (October 1982). "VLSI design of high-speed, low-area addition circuitry". Proceedings 1981 IEEE International Conference on Computer Design: VLSI in Computers & Processors. IEEE: 418–422. ISBN 0-81860802-1.
  4. ^ Han, Tackdon; Carlson, David A. (October 1987). "Fast area-efficient VLSI adders". Proceedings 8th Symposium on Computer Arithmetic. IEEE: 49–56.
  5. ^ Brent, Richard Peirce; Kung, Hsiang Te (March 1982). "A regular layout for parallel adders" (PDF). IEEE Transactions on Computers. C-31 (3): 260–264. doi:10.1109/TC.1982.1675982. S2CID 17348212. Archived from the original on September 24, 2017.
  6. ^ Kogge, Peter Michael; Stone, Harold S. (August 1973). "A Parallel Algorithm for the Efficient Solution of a General Class of Recurrence Equations". IEEE Transactions on Computers. C-22 (8): 786–793. doi:10.1109/TC.1973.5009159. S2CID 206619926.

External links edit