Adder (BCT): Difference between revisions
| No edit summary | No edit summary | ||
| Line 1: | Line 1: | ||
| Adder can add (or subtract) two numbers together. Negating the B input will result in a subtraction. | Adder can add (or subtract) two numbers together. [[NEG (Ternary Gate)|Negating]] the B input will result in a subtraction. | ||
| == Ripple Carry Adder == | == Ripple Carry Adder == | ||
Revision as of 19:59, 4 August 2025
Adder can add (or subtract) two numbers together. Negating the B input will result in a subtraction.
Ripple Carry Adder
The ripple carry adder is the simplest of adders but it's also the slowest. The carry results ripple through all the Full Adders one after another. The output delay is the total of all Full Adders. The current design takes 56 delays.

Carry Lookahead Adder
I already have a design for a fast balanced ternary lookahead Incrementer. It's can add or subtract one from a Tryte in just 7 delays.
However, I have not figured out a working carry lookahead adder. A balanced ternary design might not be practical or even possible.
Carry Select Adder
Another fast adder design is the carry select adder. This design uses MUXs to select the correct answer from adder blocks that pre-calculate the possible carries in parallel. Most of the adder's delay then becomes the MUXs selecting correct answers just in time with the adder blocks sized to finish around the same time. The current design is 2.5 times faster than the ripple carry at 22 delays. The big disadvantage of a carry select adder is it's size and complexity. Due to ternary's base 3 logic there are three ways a carry can go so three pre-calculated answers need to be generated.

Word Adder
The lookahead Incrementer can be used to greatly speed up the adding of two Words. Both the high and low Trytes can add in parallel and then use an Incrementer to propagate the low result carry though the high result to finalize the answer. This only takes Adder + Incrementer vs Adder + Adder delays.
I wonder if the technique of using parallel carry select adding and lookahead incrementer carry propagating could possibly be hybridized to make an even faster adder? I have not had time to explore this yet.
