Adder (BCT): Difference between revisions

From TernaryWiki
Jump to navigationJump to search
No edit summary
 
(11 intermediate revisions by the same user not shown)
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 ==
The ripple carry adder is the simplest of adders but it's also the slowest. The results ripple through all the [[Full Adder (BCT)|Full Adders]] one after another. The output delay is the total of all Full Adders. The current design takes 56 delays.[[File:Ripple-Adder-BCT.png|none|thumb|848x848px|BCT 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 Adder (BCT)|Full Adders]] one after another. The output delay is the total of all Full Adders. The current design takes 56 delays.[[File:Ripple-Adder-BCT.png|none|thumb|848x848px|BCT Ripple Carry Adder]]


== Carry Lookahead Adder ==
== Carry Lookahead Adder ==
I already have a design for a fast balanced ternary lookahead increment/decrementer. It's can add or subtract one from a Tryte in single digit delay.
I already have a design for a fast balanced ternary lookahead [[Incrementer (BCT)|Incrementer]]. It 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 actually not be practical or possible.
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 ==
== Carry Select Adder ==
Another fast adder design is the carry select adder. This design uses MUXs to select the correct answer from sections that pre-calculate possible carry answers in parallel. The delays
Another fast adder design is the carry select adder. This design uses [[MUX (BCT)|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 [[MUX (BCT)|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.
[[File:Carry-Select-Adder-BCT.png|none|thumb|984x984px|BCT Carry Select Adder]]
 
<table>
<tr>
<td style="vertical-align: text-top; padding-right: 32px;">
=== Prebiased Carry Select ===
[[File:Prebiased-Carry-Select-BCT.png|none|thumb|BCT Prebiased Carry Select Subcircuit]]
</td>
<td style="vertical-align: text-top; padding-right: 32px;">
==== Positive Prebiased Adder ====
[[File:Positive-Biased-Adder-BCT.png|none|thumb|BCT Positive Biased Adder Subcircuit]]
</td>
<td style="vertical-align: text-top;">
==== Negative Prebiased Adder ====
[[File:Negative-Biased-Adder-BCT.png|none|thumb|BCT Negative Prebiased Adder Subcircuit]]
</td>
</tr>
</table>
 
=== Carry Select ===
[[File:Carry-Select-BCT.png|none|thumb|BCT Carry Select Subcircuit]]
 
== Word Adder ==
The lookahead [[Incrementer (BCT)|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 (BCT)|Incrementer]] to propagate the low result carry through the high result to finalize the answer. This only takes Adder + [[Incrementer (BCT)|Incrementer]] + Final Carry delays.
 
I wonder if the technique of using parallel carry select adding and lookahead [[Incrementer (BCT)|Incrementer]] carry propagating could possibly be hybridized to make an even faster adder? I have not had time to explore this yet.

Latest revision as of 01:21, 20 October 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.

BCT Ripple Carry Adder

Carry Lookahead Adder

I already have a design for a fast balanced ternary lookahead Incrementer. It 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.

BCT Carry Select Adder

Prebiased Carry Select

BCT Prebiased Carry Select Subcircuit

Positive Prebiased Adder

BCT Positive Biased Adder Subcircuit

Negative Prebiased Adder

BCT Negative Prebiased Adder Subcircuit

Carry Select

BCT Carry Select Subcircuit

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 through the high result to finalize the answer. This only takes Adder + Incrementer + Final Carry 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.