# Performance of CMOS Current Mode Full Adders. 

K. Navi, A. Kazeminejad and D. Etiemble.<br>LRI - UA 410 CNRS<br>Bat 490, Université Paris Sud<br>91405 Orsay Cedex, France


#### Abstract

We present the performance of three different multivalued current mode 1-bit adders. These circuits have been simulated with the electrical parameters of a standard $1.2 \mu \mathrm{~m}$ CMOS technology. The performance of a binary voltage mode 1-bit adder is also presented. The binary version uses twice more transistors comparing with multivalued ones, but it is two or three times faster. Multivalued versions are more complicated to design and optimize. These results confirm the chip density advantage of multivalued circuits and the speed advantage of binary versions when using CMOS technologies.


## 1. Introduction

For many years, CMOS multivalued current mode circuits have been proposed [1-4], but most of them [13] used a standard CMOS technology. In 1986, a $2-\mu \mathrm{m}$ current-mode CMOS $32 \times 32$ bit multiplier [5] has been demonstrated, with the same speed and half chip area and power dissipation compared with the best corresponding binary one at the same period. However, this chip used a non standard technology, with depleted pMOS transistors to implement current sources.

Multivalued current-mode circuits could be useful only if they can be implemented with today and tomorrow technologies. It means that they should be compatible with advanced CMOS, BiCMOS or CMLECL bipolar technologies using reduced power supplies (3.3 V or 2 V ). It is highly desirable to use a standard advanced technology to keep the same IC process complexity.

The tolerance issue has always been the Achilles' heel of current-mode circuits [6]. To operate with m different current levels, m-1 threshold detectors are needed and the tolerance constraints are more and more difficult to satisfy when the number of current levels increases. We roughly know that 8 levels is an upper limit for many technologies. Multivalued circuits are the
most efficient (speed, complexity) with 3 or 4 current levels.

In $[7,8]$, we have set up the basis for a comparison of current mode multivalued circuits with voltage mode binary circuits for the multioperand addition that is required to perform high speed multiplication. 3 -valued and 4 -valued circuits have been defined for implementing 2 -input and 3 -input adders with the Borrow Save Carry redundant number representation, which is the number representation used in [9]. They are based on 3 -valued to binary converter ( $3-\mathrm{BC}$ ) and 4 valued to binary converter ( $4-\mathrm{BC}$ ) circuits. These circuits are fundamental ones. Moreover, as we will detail, the $3-\mathrm{BC}$ cell is the only cell that is needed to implement the current mode binary half-adder and the 4 BC cell is the only cell to implement the current-mode binary full adder.

In this paper, we will present the performance of various implementations of 4-BC circuits. It gives significant figures both for the comparison of voltage mode and current-mode versions of Carry-Save Adder of the binary world, and for the potentialities of using m valued current mode cells ( $\mathrm{m} \leq 4$ ) in arithmetic operators based on redundant number systems.

## 2. Multivalued current-mode circuits

### 2.1. Basic building blocks

We use the following notations and definitions: Let $E_{n}$ be the digit set $\{0,1, \ldots, n-1\}$.
$X, i \in E_{m}, L_{i}(X), G_{i}(X) \in E_{2}$
Current mode multivalued circuits have m different current levels, ranging from 0 to $m-1$. One basic operation is the analog sum of currents, which is free to implement. For m-valued circuits, the basic operators are the current sources, which deliver one given level of current, and the threshold detectors, which indicate if a current is greater or not than a given threshold value. The threshold detectors implement the binary functions L (Less or Equal) which have the following definition : $L_{i}(x)=1$ iff $x \leq i$, and 0 otherwise. The binary functions G (Greater) are the binary complement of the
corresponding L functions: $\mathrm{G}_{\mathrm{i}}(\mathrm{x})=1$ iff $\mathrm{x}>\mathrm{i}$, and 0 otherwise. Current mirrors are also needed to convert source to sink currents or sink to source currents.

The first implementation of current sources (figure 1) and threshold detectors (figure 2) with a standard CMOS technology has been presented by Freitas and Current in 1983 [2]. The current source value is determined by the diode-connected $\mathrm{T}_{1}$ pMOS and $\mathrm{T}_{2}$ nMOS transistors. $\mathrm{T}_{4}$ is controlled by the voltage input c . When it is on, I is mirrored by $\mathrm{T}_{1}$ and $\mathrm{T}_{3}$. The threshold detectors compare a copy of the input current $\mathrm{I}_{\text {in }}$ (through $\mathrm{T}_{5}-\mathrm{T}_{7}, \mathrm{~T}_{5}-\mathrm{T}_{9}$, $\mathrm{T}_{5}-\mathrm{T}_{11}$ (current mirrors) with reference currents that are obtained by using $\mathrm{T}_{1}-\mathrm{T}_{6}, \mathrm{~T}_{1}-\mathrm{T}_{8}$ and $\mathrm{T}_{1}-\mathrm{T} 1_{0}$ current mirrors.


Figure 1 : CMOS current source.


Figure 2 : CMOS threshold detectors

### 2.2. The $m-B C$ cells

For $m \leq 4$, the $m$-valued to binary converters deliver the binary outputs $c_{i+1}$ and $w_{i}$ corresponding to the $m$ valued input $p_{i}$ according to the following definition :
$p_{i}=2 c_{i+1}+w_{i}$, where $c_{i+1}$ and $w_{i}$, are respectively the carry and sum outputs.

The corresponding circuits are called m-BC. Tables1 and 2 give the truth table of the $3-B C$ and the $4-B C$ cells.

### 2.3. Digital implementation of $\mathbf{m}$ - BC cells

Digital implementation of m-BC cells is obtained when using threshold detector circuits and current sources, according to the following formulas for the 3BC cell :
$\mathrm{c}_{\mathrm{i}+1}=\mathrm{G}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$
$\mathrm{w}_{\mathrm{i}}=\mathrm{G}_{0}\left(\mathrm{p}_{\mathrm{i}}\right) \cdot \mathrm{L}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$
and for the 4-BC cell :
$\mathrm{c}_{\mathrm{i}+1}=\mathrm{G}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$
$\mathrm{w}_{\mathrm{i}}=\mathrm{G}_{0}\left(\mathrm{p}_{\mathrm{i}}\right) \cdot \mathrm{L}_{1}(\mathrm{pi})+\mathrm{G}_{2}\left(\mathrm{p}_{\mathrm{i}}\right)$.
In the last formula, the $G_{0}\left(p_{i}\right) \cdot L_{1}(p i)$ and $G_{2}\left(p_{i}\right)$ terms cannot be simultaneously equal to $1 .+$ can be implemented as a logical Or or as an analog sum.

Functional schemes for these two circuits are given in Figure 3 and 4. These circuits are level-restoring.

| $\mathrm{p}_{\mathrm{i}}$ | $\mathrm{c}_{\mathrm{i}+1}$ | $\mathrm{w}_{\mathrm{i}}$ | $\mathrm{G}_{0}\left(\mathrm{p}_{\mathrm{i}}\right)$ | $\mathrm{G}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 |
| 2 | 1 | 0 | 1 | 1 |

Table 1 : 3-BC cell

| $\mathrm{p}_{\mathrm{i}}$ | $\mathrm{c}_{\mathrm{i}+1}$ | $\mathrm{w}_{\mathrm{i}}$ | $\mathrm{G}_{0}\left(\mathrm{p}_{\mathrm{i}}\right)$ | $\mathrm{G}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$ | $\mathrm{G}_{2}\left(\mathrm{p}_{\mathrm{i}}\right)$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 | 0 |
| 2 | 1 | 0 | 1 | 1 | 0 |
| 3 | 1 | 1 | 1 | 1 | 1 |

Table 2 : 4-BC cell


Figure 3 : 3-BC cell


Figure 4 : 4-BC cell

### 2.4. Semi-analog implementation of $\mathbf{m - B C}$ cells.

Different schemes for 3-BC and 4-BC cells can be used if semi-analog computation is allowed. In this case, the circuits are not totally level restoring, and noise margins can be a potential issue.

Formulas for 3-BC cell are now :
$\mathrm{c}_{\mathrm{i}+1}=\mathrm{G}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$
$\mathrm{w}_{\mathrm{i}}=\mathrm{p}_{\mathrm{i}}$ when $\mathrm{p}_{\mathrm{i}} \leq 1$ and $\mathrm{w}_{\mathrm{i}}=0$ otherwise. We use the notation $w_{i}=p_{i} \Lambda L_{1}\left(p_{i}\right)$

Formulas for 4-BC cells are now:
$\mathrm{c}_{\mathrm{i}+1}=\mathrm{G}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$
$w_{i}=p_{i} \Lambda L_{1}\left(p_{i}\right)+G_{2}\left(p_{i}\right)$, where $+i$ is the analog sum.
This version uses 2 threshold detectors. Another option would only uses one threshold detector, where $\mathrm{w}_{\mathrm{i}}=\mathrm{p}_{\mathrm{i}} \Lambda \mathrm{L}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)+\max .\left(0, \mathrm{p}_{\mathrm{i}}-2\right)$.

Figures 5 and 6 give the corresponding semi-analog $3-\mathrm{BC}$ and $4-\mathrm{BC}$ cells.


Figure 5: semi-analog 3-BC cell


Figure 6: Semi-analog 4-BC cell

## 3. Circuit issues

In this section, we will consider the actual implementation of current sources and threshold detectors. In the rest of this paper, we will use the electrical parameters of the HF3CMOS technology, which is a $1.2 \mu \mathrm{~m}$ BiCMOS technology from SGSThomson. The basic features of the technology are given in Table 3. We only use the MOS transistors.

| CMOS | NPN |
| :--- | :--- |
| NMOS (50/50) Vth $: 0.7 \mathrm{~V}$ | Se $: 3.6 \times 3.6 \mu \mathrm{~m} 2$ |
| PMOS (50/50) | Vth $: 1.0 \mathrm{~V}$ |
| BVDSS | hee $: 90$ |
| td (fin=fout) | $>7 \mathrm{~V}$ |
|  | $: 220 \mathrm{ps}$ |
|  |  |
|  | BVCEO $: 14 \mathrm{~V}$ |
|  | BVCBO $: 25 \mathrm{~V}$ |
|  | BVEBO $: 5 \mathrm{~V}$ |
|  | VEA $: 50 \mathrm{~V}$ |
|  | Ceb $: 37.5 \mathrm{fF}$ |
|  | Ccb $: 27 \mathrm{fF}$ |
|  | Ccs $: 106 \mathrm{fF}$ |
|  | rbb $: 370 \Omega$ |
|  | ft max $: 8 \mathrm{GHz}$ |

## Table 3: HF3CMOS Technology

### 3.1. Implementation of current sources

In [5], depleted pMOS transistors are used to implement the current sources. With depleted MOS transistors, true current sources, that only depends on the threshold voltages can be obtained as $\mathrm{I}_{\mathrm{p}}=1 / 2 \mu_{\mathrm{p}} \mathrm{C}_{\mathrm{ox}}$ $\mathrm{W}_{\mathrm{p}} / \mathrm{L}_{\mathrm{p}} \mathrm{V}_{\mathrm{tp}^{2}}$, when connecting the transistor gate and source. But depleted pMOS transistors are not available with a standard CMOS technology.

The typical current source has been shown in figure 1. It is presented again in figure 7, with the different transistor sizes. Another one can be defined: it simply uses a p-MOS transistor, assuming that it is working in
saturated mode when a low level voltage input is applied on its gate (Figure 8).


Figure 7 : current source
In figure 7, when all transistors have the minimum size ( $\mathrm{W}=\mathrm{L}=1.2 \mu \mathrm{~m}$ ) delivers current source $30 \mu \mathrm{~A}$ in a diode-connected minimum size transistor. When T3 has $\mathrm{W}=1.8 \mu \mathrm{~m}$ and $\mathrm{L}=3 \mu \mathrm{~m}$, it delivers $20 \mu \mathrm{~A}$. With the simplified current source (figure 8), the transistor with $\mathrm{L}=1.8 \mu \mathrm{~m}$ and $\mathrm{W}=1.2 \mu \mathrm{~m}$ delivers $60 \mu \mathrm{~A}$ in a diodeconnected transistor with $\mathrm{L}=1.2 \mu \mathrm{~m}$ and $\mathrm{W}=1.8 \mu \mathrm{~m}$.


Figure 8 : simplified current source

### 3.2. Implementation of threshold detectors

We have first implemented the threshold detectors according to the scheme presented in figure 2. This version 0 has $0,20 \mu \mathrm{~A}, 40 \mu \mathrm{~A}$ and $60 \mu \mathrm{~A}$ current levels (T3 in the current source has $\mathrm{W}=1.8 \mu \mathrm{~m}$ and $\mathrm{L}=3 \mu \mathrm{~m}$ ). Table 4 gives the sizes of p and n transistors for the threshold functions. It should be noticed that the transistor sizing is different than in the preliminary version presented in [1-2], where all nMOS transistors had the same size and pMOS transistors had different sizes.

We have experimented another scheme for the threshold detectors, which is presented in figure 9. The threshold function is simply implemented by a CMOS inverter, which the n transistor forms a current mirror
with the transistor that sinks the input current. The voltage output of the "inverter" controls the current source, which is one of the current source defined in the previous section.

|  | Threshold <br> $0-1$ | Threshold <br> $1-2$ | Threshold <br> $2-3$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{~W}_{\mathrm{n}} / \mathrm{L}_{\mathrm{n}}$ | $2.4 / 1.2$ | $1.2 / 1.2$ | $1.2 / 1.8$ |
| $\mathrm{~W}_{\mathrm{p}} / \mathrm{L}_{\mathrm{p}}$ | $1.2 / 1.2$ | $1.2 / 1.2$ | $2.4 / 2.4$ |
| Threshold <br> current | $10 \mu \mathrm{~A}$ | $30 \mu \mathrm{~A}$ | $50 \mu \mathrm{~A}$ |

Table 4: Transistor sizes for the threshold detectors (version 0 )
The version 1 with complete current sources (figure 7) has $0,30 \mu \mathrm{~A}, 60 \mu \mathrm{~A}$ and $90 \mu \mathrm{~A}$ current levels. The diode connected transistor has $\mathrm{W}=1.2 \mu \mathrm{~m}$. Table 5 gives the sizes of p and n transistors for the threshold functions. The version 2 with simplified current sources (figure 8) has $0,60 \mu \mathrm{~A}, 120 \mu \mathrm{~A}$ and $180 \mu \mathrm{~A}$ current levels. The diode connected transistor has $\mathrm{W}=1.8 \mu \mathrm{~m}$. Table 6 gives the sizes of $p$ and $n$ transistors for the threshold functions. In both cases, the threshold value is obtained by drawing the curve $\mathrm{I}_{\text {out }}=\mathrm{f}\left(\mathrm{I}_{\mathrm{in}}\right)$. Figures 10 and 11 show the current transfer characteristics for version 1 and version 2 . With simplified current sources, the transfer curves is not so good, because the transistor no longer operates in the saturated mode when current increases. The current value is more sensitive to current input variations.


Figure 9: Threshold detector circuit.

|  | Threshold <br> $0-1$ | Threshold <br> $1-2$ | Threshold <br> $2-3$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{~W}_{\mathrm{n}} / \mathrm{L}_{\mathrm{n}}$ | $1.8 / 1.8$ | $1.8 / 1.2$ | $1.2 / 1.2$ |
| $\mathrm{~W}_{\mathrm{p}} / \mathrm{L}_{\mathrm{p}}$ | $1.2 / 2.4$ | $3.6 / 1.2$ | $5.4 / 1.2$ |
| Threshold <br> current | $18 \mu \mathrm{~A}$ | $47 \mu \mathrm{~A}$ | $72 \mu \mathrm{~A}$ |

Table 5: Transistor sizes for the threshold detectors (version 1)

|  | Threshold <br> $0-1$ | Threshold <br> $1-2$ | Threshold <br> $2-3$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{~W}_{\mathrm{n}} / \mathrm{L}_{\mathrm{n}}$ | $1.2 / 1.2$ | $1.8 / 1.2$ | $1.2 / 1.2$ |
| $\mathrm{~W}_{\mathrm{p}} / \mathrm{L}_{\mathrm{p}}$ | $1.2 / 1.8$ | $1.2 / 1.8$ | $7.2 / 1.2$ |
| Threshold <br> current | $44 \mu \mathrm{~A}$ | $84 \mu \mathrm{~A}$ | $134 \mu \mathrm{~A}$ |

Table 6: Transistor sizes for the threshold detectors (version 2)


Figure 10: Threshold detector transfer characteristics (version 1)


Figure 11: Threshold detector transfer characteristics (version 2).

### 3.3. Switching speed of threshold detectors.

Before examining the performance of the current mode adders, it is interesting to characterize the switching performance of the threshold detectors. As the outputs of the current mode full adder are given by $c_{i+1}$ $=\mathrm{G}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$ and $\mathrm{w}_{\mathrm{i}}=\mathrm{G}_{0}\left(\mathrm{p}_{\mathrm{i}}\right) \cdot \mathrm{L}_{1}\left(\mathrm{p}_{\mathrm{i}}\right)$, it is quite evident that the delay times for the carry and sum outputs cannot be smaller than the delay time for each of the function $\mathrm{G}_{\mathrm{i}}(\mathrm{p})$.

We examine three typical circuit configurations, that are shown in figure 12 . For $\mathrm{G}_{0}$, the input and output current swings are between 0 and I. For $G_{1}$, swings are between I and 2 I . For $\mathrm{G}_{2}$, swings are between 2 I and 3 I . It should be noticed that $\mathrm{G}_{2}$ test circuit corresponds to the maximum output load, when 3 current sources are summed to deliver the output current. $\mathrm{G}_{1}$ (res. $\mathrm{G}_{0}$ ) test circuit gives more optimistic results as the output load is only two (res. one) current source. These test circuits give absolute minimum delay that can be expected with the actual current mode circuits.

Table 7 gives the propagation delays of $G_{i}$ circuits for version 0 (original threshold detectors and true current sources). Table 8 gives the propagation delays of $\mathrm{G}_{\mathrm{i}}$ circuits for version 1 (modified threshold detectors and true current sources) and table 9 gives the corresponding delays with version 2 (modified threshold detectors and simplified current sources). In each table, propagation delays are given for the rising edges and the falling edges.


Figure 12: Test circuits for $\mathrm{G}_{\mathrm{i}}$ propagation delay (i=0, 1, 2)

| Test circuit | $\mathrm{t}_{\mathrm{dr}}$ <br> (rising edges) | $\mathrm{t}_{\mathrm{df}}$ <br> (falling edges) |
| :---: | :---: | :---: |
| $\mathrm{G}_{0}$ | 3.8 ns | 1.8 ns |
| $\mathrm{G}_{1}$ | 3 ns | 4.2 ns |
| $\mathrm{G}_{2}$ | 3.6 ns | 6.6 ns |

Table 7: $\mathrm{G}_{\mathrm{i}}$ test circuit delays for version 0.

| Test circuit | $\mathrm{t}_{\mathrm{dr}}$ <br> (rising edges) | $\mathrm{t}_{\mathrm{df}}$ <br> (falling edges) |
| :---: | :---: | :---: |
| $\mathrm{G}_{0}$ | 2.6 ns | 2.4 ns |
| $\mathrm{G}_{1}$ | 1.6 ns | 1.6 ns |
| $\mathrm{G}_{2}$ | 1.6 ns | 3.3 ns |

Table 8: $\mathrm{G}_{\mathrm{i}}$ test circuit delays for version 1.

| Test circuit | $\mathrm{t}_{\mathrm{dr}}$ <br> (rising edges) | $\mathrm{t}_{\mathrm{df}}$ <br> (falling edges) |
| :---: | :---: | :---: |
| $\mathrm{G}_{0}$ | 4 ns | 1.2 ns |
| $\mathrm{G}_{1}$ | 2 ns | 2.4 ns |
| $\mathrm{G}_{2}$ | 1.5 ns | 2.4 ns |

## Table 9: $\mathbf{G}_{\boldsymbol{j}}$ test circuit delays for version 2.

Propagation delays will be greater than 6.6 ns with version $0,3.3 \mathrm{~ns}$ with version 1 and 4 ns with version 2 . Although the current swing is only $50 \%$ greater with version $1(30 \mu \mathrm{~A})$ compared to version $0(20 \mu \mathrm{~A})$, version 1 is two times faster than version 0 . The CMOS inverter-like threshold detector seems more efficient, as the reduced swing on the gate of the nMOS transistor is also applied on the gate of the pMOS transistor, instead of a constant voltage in the classical scheme. It can be compared with the switching speed advantage of a CMOS binary inverter versus the switching speed of nMOS inverter with depleted load.

For modified or classical threshold detectors, the propagation delays strongly depends on the W/L ratios of the transistor pairs that realize the threshold functions. The threshold values lead to W/L ratios, that give the corresponding switching speed. When the current swing is chosen and the transistor sizes are determined to implement the threshold detectors, the switching speed is determined and there is no way to improve it!

## 4. Performance of current mode adders

In this section, we only present performance of current mode adders which use the CMOS inverter-like threshold detectors.

### 4.1. Version a : true current sources - digital implementation

The first 1-bit current mode adder that has been simulated use the digital approach and the classical current source. It is presented in Figure 13. It uses $13+2$ transistors. The threshold detectors have the features which have been presented in Table 5. The switching characteristics are presented in Table 10. Delay values between * correspond to switching hazards.


Figure 13: 1-bit current mode full adder (a)

| Input | $\mathrm{t}_{\text {sum }}$ | $\mathrm{t}_{\text {carry }}$ |
| :---: | :---: | :---: |
| $0-1$ | 7 ns | ---- |
| $1-2$ | 2.4 ns <br> 6 ns (overshoot) | 2 ns |
| $2-3$ | 2.6 ns | ----- |
| $0-2$ | $* 4 \mathrm{~ns} *$ | 4 ns |
| $1-3$ | $* 3.6 \mathrm{~ns} *$ | 3 ns |
| $0-3$ | $* 5.6 \mathrm{~ns}^{*}$ | 1.8 ns |

Table 10 : 1-bit current mode adder (a)

### 4.2. Version b: simplified current sources digital implementation

The second 1-bit current mode adder that has been simulated use the digital approach and the simplified current source. It is presented in Figure 14. It has 11 transistors. The threshold detectors have the features which have been presented in Table 6. The switching characteristics are presented in Table 11.

### 4.3. Version c : simplified current sources - semianalog implementation

The third 1-bit current mode adder use the semianalog approach and the simplified current source. It is presented in Figure 15. Only two threshold detectors are used, with following W/L ratios: 7.2/1.2 ( $\mathrm{T}_{\mathrm{p}}$ ) and $1.2 / 1.2\left(\mathrm{~T}_{\mathrm{n}}\right)$ for the threshold between $120 \mu \mathrm{~A}$ and 180 $\mu \mathrm{A} ; 2.4 / 1.2\left(\mathrm{~T}_{\mathrm{p}}\right)$ and 1.2/1.2 $\left(\mathrm{T}_{\mathrm{n}}\right)$ for the threshold between $60 \mu \mathrm{~A}$ and $120 \mu \mathrm{~A}$. All the other transistor sizes
can be found in Figure 15. This adder uses 11 transistors. The switching characteristics are presented in Table 12.


Figure 14: 1-bit current mode adder (b)

| Input | $\mathrm{t}_{\text {sum }}$ | $\mathrm{t}_{\text {carry }}$ |
| :---: | :---: | :---: |
| $0-1$ | 5.8 ns | ---------- |
| $1-2$ | 4 ns | 3 ns |
| $2-3$ | 2 ns | --------- |
| $0-2$ | $* 3.2 \mathrm{~ns}^{*}$ | 4.2 ns |
| $1-3$ | $* 5.2 \mathrm{~ns}^{*}$ | 3 ns |
| $0-3$ | $* 3.6 \mathrm{~ns}^{*}$ | 3 ns |

Table 11: 1-bit current mode adder (b)


Figure 15: 1-bit current mode full adder (c)

## 5. Performance of the voltage mode Carry Save Adder

### 5.1. Circuit scheme

The voltage mode CSA, which is used for the implementation of the adder tree in combinational multiplier, is the circuit that we have used as a base for the comparison. The CSA design optimizes both sum and carry delays. The CSA scheme is given in Figure 16.

| Input | $\mathrm{t}_{\text {sum }}$ | $\mathrm{t}_{\text {carry }}$ |
| :---: | :---: | :---: |
| $0-1$ | 3.8 ns | ----- |
| $1-2$ | 3.4 ns | 2.4 ns |
| $2-3$ | 2 ns | ---- |
| $0-2$ | $* 3 \mathrm{~ns}^{*}$ | 3.2 ns |
| $1-3$ | $* 4.4 \mathrm{~ns}^{*}$ | 3 ns |
| $0-3$ | $* 3.5 \mathrm{~ns}^{*}$ | 2.2 ns |

Table 12: 1-bit current mode adder (c)



Figure 16 : Binary voltage mode CSA functional diagram.
The usual semi-analog scheme, with pass transistors is used to generate the xor and the nxor functions of two inputs X and Y . A second stage generates the sum and carry outputs. Sum output is generated as $X \oplus Y \oplus Z=\bar{Z}(X \oplus Y)+Z(\overline{X \oplus Y})$ and the carry output corresponds to X when $\mathrm{X}=\mathrm{Y}$ and Z when $\mathrm{X} \neq \mathrm{Y}$. The CSA uses 24 transistors.

### 5.2. Simulation results

The CSA has been simulated with HCMOS3 parameters. All transistors have $\mathrm{L}=1.2 \mu \mathrm{~m}$. The inverters
and pseudo-inverters use transistors with $\mathrm{W}_{\mathrm{p}}=7.2 \mu \mathrm{~m}$ and $\mathrm{W}_{\mathrm{n}}=3.6 \mu \mathrm{~m}$. The pass transistors uses $\mathrm{W}_{\mathrm{p}}=2.4$ $\mu \mathrm{m}$ and $\mathrm{W}_{\mathrm{n}}=1.2 \mu \mathrm{~m}$. Carry and sum outputs are loaded with one xor gate. Simulation results with typical parameters and typical power supply are given in Table 13. Input configurations are indicated as "TIJ", where T means a transition, and I and J the values on the other inputs. TT (res. TTT) means a same transition on two (res. three) inputs.

| Input <br> transitions | $\mathrm{t}_{\mathrm{dsum}}$ | $\mathrm{t}_{\text {dcarry }}$ |
| :---: | :---: | :---: |
| T00 | 2 ns | --- |
| T01 | 2 ns | 2 ns |
| T11 | 1.8 ns | -- |
| TT0 | ---- | 2 ns |
| TT1 | ---- | 2 ns |
| TTT | 1.8 ns | 2 ns |

## Table 13 : binary voltage mode CSA performance

## 6. Conclusion

We have presented three different versions of current mode 1-bit adder, which propagation delays are respectively $7 \mathrm{~ns}, 5.8 \mathrm{~ns}$ and 4 ns with a $1.2 \mu \mathrm{~m}$ CMOS technology. These adders use 11 or 13 transistors. The propagation delays principally result on dynamic hazards ( $0-2,1-3$ or $0-3$ transitions). They strongly depend on the input transition which occurs. Sometimes current overshoots must be considered. The corresponding binary voltage mode carry save adder uses 24 transistors (more than twice the current-mode version), but the propagation delay is limited to 2 ns , more than 2 or 3 times faster than the corresponding mvalued current mode versions. The propagation delays are nearly the same for any input transition, and there is no visible hazard, whatever the input configuration is.

With current mode circuits, the transistor sizes are fixed by the threshold values. When the sizes are fixed up, the switching speed is determined by these sizes, and there is no way to improve it. With the voltage mode circuit, the transistor sizes can be optimized to reduce propagation delays according to the capacitive loads in each node.

This study of m-valued current mode circuits, with $\mathrm{m}=4$, shows that a reduced chip area can be obtained. However, the circuits have a static power dissipation, with an average current per adder which is half the
maximum current level. They are several times slower than the corresponding voltage mode binary ones.

Practical uses of m-valued current mode circuits seem very difficult. To get a significant advantage at circuit architecture level, larger values of m are needed. 7valued circuits were used in [4-5] with bi-directional current. But, tolerance issues must then be considered, and it is not so easy to implement a large number of threshold detectors with simple circuits (a transistor pair per threshold detector). On the other hand, with $\mathrm{m}=4$ (and may be $m=5$ ), the intrinsic speed disadvantage of m -valued circuits make difficult to compete with binary circuits.

The only significant advantage of CMOS m-valued current mode circuit is chip density, when reduced operating speed is allowed. When speed is a significant factor, the attempt to use CMOS multivalued circuits looks like a dead-end.

## 7. References

[1] D. A. Freitas and K.W. Current, "CMOS current comparator circuit", Electron. Lett., 1983, 19, pp. 695-697.
[2] D. A. Freitas and K.W. Current, "A quaternary logic encoder-decoder circuit design using CMOS", in Proc. Int'1 Symp. Multiple Valued Logic, pp. 190-195, May 1983.
[3] S.P. Onneweer and H.G. Kerkhoff, "Current-Mode High Radix Circuits", Proc. Int'l. Symp. Multiple Valued Logic, pp. 60-69, May 1986
[4] S. Kawahito, M. Kameyama and T. Higuchi," "VLSIOriented Bi-Directional Current Mode Arithmetic Circuits Based on the Radix-4 Signed Digit Number System", in Proc. Int'l Symp. Multiple Valued Logic, pp. 70-77, May 1986
[5] S. Kawahito, M. Kameyama, T. Higuchi, H. Yamada, "A 32 x 32 bit Multiplier Using Multiple-Valued MOS Current-Mode Circuits", IEEE J. Solid-State Circuits, vol. SC-23, pp. 124-132, Feb. 1988
[6] D. Etiemble, "On the performance of multivalued integrated circuits: Past, Present and Future", Proc. Int'l. Symp. Multiple Valued Logic, pp. 156-164., May 1992
[7] D. Etiemble and K. Navi, "A basis for the Comparison of Binary and m-valued Current Mode Circuits: the Multioperand Addition with Redundant Number System", Proc. Int'l. Symp. Multiple Valued Logic, pp. 216-221, May 1993
[8] D. Etiemble and K. Navi, "Algorithms and Multivalued Circuits for the Multioperand Addition in the Binary Stored-Carry Number System", in Proc. 11th Symposium on Computer Arithmetic, pp. 194-201
[9] S. Kawahito, Y. Mitsui, M. Ishida and T. Nakamura, "Parallel Hardware Algorithms with Redundant Number Representations for Multiple-Valued Arithmetic VLSI", in Proc. Int'l Symp. Multiple Valued Logic, pp. 337-345, May 1992

