Adder

From Rice Wiki
Revision as of 15:35, 13 May 2024 by Rice (talk | contribs) (→‎Ripple carry adder)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

The adder circuit is the fundamental instruction of many arithmetic operations (such as subtract, multiply, divide, and modulo).

Half and full adder

ADD takes in two binary digits. It then outputs the result, which consists of a digit and a carry.

In contrast to the above, which is a half adder, a full adder has an additional input: carry-in, which modifies the result.

Full adders can be constructed with two half adders.

Circuit

Figure 1.

Consider full adder that performs A + B = Y with carry-in and carry-out. After simplification with truth table and boolean algebra, we have

with circuit shown in Figure 1.

Subtraction

The adder circuit can be used for subtraction without many changes. Simply negate the subtracted input, add a carry-in, and perform addition.

The principle behind this is two's complement.

Ripple carry adder

A ripple carry adder is constructed with multiple full adders, linking each one's carry-out to the next's carry-in. It is capable of computing multi-digit addition. Each full adder contributes some propagation delay due to the need to input carry to the next full adder.

Carry look-ahead adder

Some optimization can be done to make the ripple carry adder circuit more parallel for a faster propagation delay.

A generate signal is ab. A propagate signal is a XOR b. Rewriting sum and carry in those terms can make the circuit more parallel

Overflow detection

Consider two signed integers being operated on by our ripple carry adder. If there is an overflow, the last carry-in should be different from the first carry-out. Try proving it case by case. I gotta go do my machine learning lab now bye.