## A High-Speed Tree-Based 64-Bit Binary Comparator

Anjuli<sup>1</sup>, Satyajit Anand<sup>2</sup>

<sup>1</sup>M.Tech. VLSI Design, E&CE Department, FET-MITS (Deemed University)

<sup>2</sup>E&CE Department, FET-MITS (Deemed University)

anjuli\_222@yahoo.com, satyajitanand45@gmail.com

Abstract— High-speed tree-based 64-bit binary comparator is proposed in this brief. Comparison is most basic arithmetic operation that determines if one number is greater than, equal to, or less than the other number. Comparator is most fundamental component that performs comparison operation. This brief presents comparison of modified and existing 64-bit binary comparator designs concentrating on delay. Means some modifications are done in existing 64-bit binary comparator design to improve the speed of the circuit. Comparison between modified and existing 64-bit binary comparator designs is calculated by simulation that is performed at 90nm technology in Tanner EDA Tool.

Keywords-Binary comparator, digital arithmetic

\*\*\*\*

#### I. INTRODUCTION

In digital system, comparison of two numbers is an arithmetic operation that determines if one number is greater than, equal to, or less than the other number [6]. So comparator is used for this purpose.

Magnitude comparator is a combinational circuit that compares two numbers, A and B, and determines their relative magnitudes (Figure 1) [6]. The outcome of comparison is specified by three binary variables that indicate whether A>B, A=B, or A<B.



Figure 1. Block Diagram of n-Bit Magnitude Comparator

The circuit, for comparing two n-bit numbers, has 2n inputs &  $2^{2n}$  entries in the truth table. For 2-bit numbers, 4-inputs & 16-rows in the truth table, similarly, for 3-bit numbers 6-inputs & 64-rows in the truth table [6].

The logic style used in logic gates basically influences the speed, size, power dissipation, and the wiring complexity of a circuit. Circuit size depends on the number of transistors and their sizes and on the wiring complexity. The wiring complexity is determined by the number of connections and their lengths. All these characteristics

may vary considerably from one logic style to another and thus proper choice of logic style is very important for circuit performance [7].

In order to differentiate all three designs existing and modified, simulations are carried out for power and delay at 1 volt supply voltage (and input voltage) at 90nm technology in Tanner EDA Tool.

### II. 64-BIT BINARY COMPARATOR

64-bit binary comparator compares two numbers each having 64 bits ( $A_{63}$  to  $A_0$  &  $B_{63}$  to  $B_0$ ). For this arrangement truth table has 128 inputs &  $2^{128}$  entries. By using comparator of minimum number of bits, a comparator of maximum number of bits can be design using tree structure logic.

## III. EXISTING 64-BIT BINARY COMPARATOR DESIGN

64-bit Comparator in reference [1], [2], [3] represents tree-based structure which is inspired by fact that G (generate) and P (propagate) signal can be defined for binary comparisons, similar to G (generate) and P (propagate) signals for binary additions.

Two number (each having 2-bits:  $A_1$ ,  $A_0$  &  $B_1$ ,  $B_0$ ) comparison can be realized by:

$$B_{Big} = \overline{A}_1 B_1 + (\overline{A_1 \oplus B_1}) \cdot (\overline{A}_0 B_0)$$
 (1)

$$EQ = (\overline{A_1 \oplus B_1}) \cdot (\overline{A_0 \oplus B_0}) \qquad (2)$$

For A<B, " $B_{Big}$ , EQ" is "1,0". For A=B, " $B_{Big}$ , EQ" is "0,1". Hence, for A>B, " $B_{Big}$ , EQ" is "0,0". Where  $B_{Big}$  is defined as output A less than B (A\_LT\_B). A closer look at equation (1) reveals that it is analogous to the carry signal generated in binary additions. Consider the following carry generation:

$$C_{out} = AB + (A \oplus B) \cdot C_{in}$$
$$= G + P \cdot C_{in}$$
(3)

Where A & B are binary inputs,  $C_{in}$  is carry input,  $C_{out}$  is carry output, and G & P are generate & propagate signals, respectively.

After comparing equations (1) & (3):

$$G_1 = \overline{A}_1 B_1 \tag{4}$$

$$EQ_1 = \overline{(A_1 \oplus B_1)} \tag{5}$$

$$C_{in} = \overline{A}_0 B_0 \tag{6}$$

 $C_{in}$  can be considered as  $G_0$ . Since for static logic, equation (1) requires tall transistor stack height, hence, an encoding scheme is employed to solve this problem. For this, encoding equation is given as:

$$G_{[i]} = \overline{A}_{[i]}B_{[i]} \tag{7}$$

$$EQ_{[i]} = \left(\overline{A_{[i]} \oplus [i]}\right) \tag{8}$$

Where  $i = 0 \dots 63$ .

Put these two values from equations (7) & (8) in equations (1) & (2).

$$B_{\text{Big}[2j+1:2j]} = G_{[2j+1]} + EQ_{[2j+1]} G_{[2j]}$$
(9)

$$EQ_{[2j+1:2j]} = EQ_{[2j+1]} \cdot EQ_{[2j]}$$
 Where  $j = 0 \dots 31$ .

G & P signals can be further combined to form group G & P signals.

$$\begin{split} B_{Big[3:0]} &= \overline{A}_2 B_2 + \left( \overline{A_3 \oplus B_2} \right) \cdot \left( \overline{A}_2 B_2 \right) + \left( \overline{A_2 \oplus B_3} \right) \cdot \left( \overline{A}_2 \oplus \overline{B}_2 \right) \cdot \left( \overline{A}_1 B_1 \right) + \left( \overline{A_3 \oplus B_2} \right) \cdot \left( \overline{A}_2 \oplus \overline{B}_2 \right) \cdot \left( \overline{A}_1 B_1 \right) + \left( \overline{A}_3 \oplus \overline{B}_2 \right) \cdot \left( \overline{A}_2 \oplus \overline{B}_2 \right) \cdot \left( \overline{A}_1 B_1 + \left( \overline{A}_1 \oplus \overline{B}_1 \right) \cdot \overline{A}_0 B_0 \right) \\ &= \overline{A}_2 B_2 + \left( \overline{A}_2 \oplus \overline{B}_2 \right) \cdot \left[ \overline{A}_2 B_2 + \left( \overline{A}_2 \oplus \overline{B}_2 \right) \cdot \left\{ \overline{A}_1 B_1 + \left( \overline{A}_1 \oplus \overline{B}_1 \right) \cdot \overline{A}_0 B_0 \right\} \right] \\ &= G_3 + EQ_3 \cdot \left\{ G_2 + EQ_2 \cdot \left( G_1 + EQ_1 \cdot G_0 \right) \right\} \end{split}$$

$$B_{Big[3:0]} = B_{Big[3:2]} + EQ_{[3:2]} . B_{Big[1:0]}$$
 (11)

$$EQ_{[3:0]} = EQ_{[3:2]} \cdot EQ_{[1:0]}$$
 (12)

Similarly, for 64-bit comparator,  $B_{\mbox{\scriptsize Big}}$  & EQ can be computed as:

$$B_{Big[63:0]} = G_{63} + \sum_{k=0}^{62} \left( G_k \cdot \prod_{m=k+1}^{63} EQ_m \right)$$
 (13)

$$EQ_{[63:0]} = \prod_{m=0}^{63} EQ_m \tag{14}$$



Figure 2. Tree-Diagram of 8-Bit Binary Comparator

Above Figure 2 shows 8-bit version of existing tree-based comparator structure and Figure (3, 4 & 5) shows corresponding circuit schematics for each logic block of each stage. Pre-encoding circuitry is aimed to minimize the number of transistors. Hence, modified pass transistor logic style is employed to reduce the number of transistors up to 9 (including inverters).

In above 8-bit example circuitry, the first stage comparison circuit implements equations (9, 10) for j=0. . . 3, whereas the second stage generates  $B_{Big[3:0]}$ ,  $B_{Big[7:4]}$  and  $EQ_{[3:0]}$ ,  $EQ_{[7:4]}$  according to equations (11 & 12). Finally,  $B_{Big[7:0]}$  and  $EQ_{[7:0]}$  are computed in the third stage according to equations (13 & 14).

Stage 0<sup>th</sup> is implemented using modified pass transistor logic style giving output in actual form, Stage 1<sup>st</sup> is implemented using CMOS logic style giving output in inverse form, Stage 2<sup>nd</sup> is also implemented using CMOS logic style giving output in actual form.

64-bit comparator is here designed by using 7 stages (from 0<sup>th</sup> to 6<sup>th</sup>). In stage 0<sup>th</sup>, modified pass transistor logic style circuitry (as in Figure 3) is employed to produce "less than" & "equal to" outputs. Outputs of stage 0<sup>th</sup> are act as inputs of stage 1<sup>st</sup>. In stage 1<sup>st</sup>, CMOS circuitry (as in Figure 4) is employed to produce inverse inputs for stage 2<sup>nd</sup>. In stage 2<sup>nd</sup>, again CMOS circuitry (as in Figure 5) is employed to produce actual inputs for stage 3<sup>rd</sup>. Now, according to tree structure given in Figure 2, again circuitry of stage 1<sup>st</sup> is used for stage 3<sup>rd</sup>. Similarly, for stage 4<sup>th</sup>, circuitry of stage 2<sup>nd</sup> is employed. For stage 5<sup>th</sup> circuitry of stage 1<sup>st</sup> is employed. For stage 6<sup>th</sup> circuitry of stage 2<sup>nd</sup> is employed. For stage 6<sup>th</sup> circuitry of stage 2<sup>nd</sup> is employed. Accordingly schematic of Existing 64-bit binary comparator is drawn and shown in Figure 6.



Figure 3. Schematic of Stage 0th of Existing 64-Bit Binary Comparator



Figure 4. Schematic of Stage  $1^{\rm st}$  of Existing 64-Bit Binary Comparator



Figure 5. Schematic of Stage 2<sup>nd</sup> of Existing 64-Bit Binary Comparator



Figure 6. Schematic of Existing 64-Bit Binary Comparator



Figure 7. Waveforms of Existing 64-Bit Binary Comparator

According to input bit stream, waveforms of existing 64-bit binary comparator are obtained and shown in Figure 7. Waveforms show that only one output is high ("1") at a time. When both the outputs "less than" & "equal to" (A\_LT\_B & A\_EQU\_B) are low ("0"), then waveforms represent that "greater than" output is high (A\_GT\_B is "1"). Simulation results for this design are given in table I for conclusion.

# IV. MODIFIED 64-BIT BINARY COMPARATOR DESIGN

Some modifications are done for stage 0<sup>th</sup>, stage 1<sup>st</sup> & stage 2<sup>nd</sup> in existing 64-bit comparator design [1] to improve the speed of the circuit.

Main idea behind PTL (pass transistor logic) is to use purely NMOS Pass Transistors network for logic operation [5]. The basic difference of pass-transistor logic style compared to the CMOS logic style is that the source

side of the logic transistor networks is connected to some input signals instead of the power lines. In this design style, Transistors are act as switch to pass logic levels from input to output [4].

For this design, stage 0<sup>th</sup> is same as existing 64-bit comparator design & implemented using modified PTL style (Figure 3) giving output in actual manner. Stage 1<sup>st</sup> is implemented using modified pass transistor logic style (MPTL) giving output in actual manner as in Figure 8. MPTL means extra PMOS circuitry is used in pass transistor logic style circuitry to pass logic high ("1") from input to output. Stage 2<sup>nd</sup> is same as stage 1<sup>st</sup> of existing 64-bit comparator design & implemented using CMOS logic style giving output in inverse manner as in Figure 4.

Final output for 64-bit comparator of this design is obtained in inverse form. So, at the end of schematic design of 64-bit comparator two inverters (Figure 10) are required to provide actual form of output waveform. Schematic (using instances of each stages) of modified 64-bit comparator design (Figure 11) is same as existing 64-bit comparator design with only the difference of including inverters.



Figure 8. Schematic of Stage 1st of Modified 64-Bit Binary Comparator



Figure 9. Schematic of Stage 2<sup>nd</sup> of Modified 64-Bit Binary Comparator



Figure 10. Schematic of Inverter of Modified 64-Bit Binary Comparator



Figure 11. Schematic of Modified 64-Bit Binary Comparator



Figure 12. Waveforms of Modified 64-Bit Binary Comparator

According to input bit stream, waveforms of modified 64-bit binary comparator are obtained and shown in Figure 12. Input bit stream for this design is same as in existing design of 64-bit comparator. Output waveforms of this design produce same position of 1,s and 0,s as in waveforms of existing design for each input bit. Simulation results for this design are given in table I for conclusion.

| Table I Description of Existing 64-Bit Binary Comparator design | Table I | Description | of Existing | 64-Bit Binary | Com | parator design |
|-----------------------------------------------------------------|---------|-------------|-------------|---------------|-----|----------------|
|-----------------------------------------------------------------|---------|-------------|-------------|---------------|-----|----------------|

| Detail           | Stage 0 <sup>th</sup> | Stage 1st        | Stage 2 <sup>nd</sup> | Transistor<br>Count |  |
|------------------|-----------------------|------------------|-----------------------|---------------------|--|
| Design           | Using MPTL Style      | Using CMOS Style | Using CMOS Style      | 1206                |  |
| Nature of output | Actual                | Inverse          | Actual                | 1200                |  |

Table II Description of Modified 64-Bit Binary Comparator Design

| Detail           | Stage 0 <sup>th</sup> | Stage 1st        | Stage 2 <sup>nd</sup> | Transistor<br>Count |  |
|------------------|-----------------------|------------------|-----------------------|---------------------|--|
| Design           | Using CMOS Style      | Same as Existing | Same as Existing      | 1782                |  |
| Nature of output | Actual                | Inverse          | Actual                | 1782                |  |

Table III Simulation results for both the designs

| Designs  | Power Consumption (watts) | Delay (se                        | Transistor      |       |
|----------|---------------------------|----------------------------------|-----------------|-------|
| Designs  |                           | $\mathbf{t}_{\mathrm{A\_LT\_B}}$ | $t_{A\_EQU\_B}$ | Count |
| Existing | 8.4347e-006               | 4.4072e-009                      | 6.8974e-010     | 1206  |
| Modified | 2.3518e-005               | 4.3916e-009                      | 6.8184e-010     | 1782  |

## V. RESULTS

After simulation of both the designs final results are obtained for power consumption and delay and are shown in table I. In modified design, delay ( $t_{A\_LT\_B}$ ) is reduced from 4.4072e-009 to 4.3144e-009 means 2.10 % reduction in comparison to existing design and delay ( $t_{A\_EQU\_B}$ ) is reduced from 6.8974e-010 to 6.7576e-010 means 2.02 % reduction in comparison to existing design.

#### VI. CONCLUSION

All of the reduction in delay is obtained after sacrificing power consumption and transistor count. But still modified design gives better result (for delay) than existing 64-bit binary comparator design. In modified design, delay ( $t_{A\_LT\_B}$ ) is reduced 2.10 % and delay ( $t_{A\_EQU\_B}$ ) is reduced 2.02 % in comparison to existing design.

## VII. REFERENCES

[1] Pierce Chuang, David Li, and Manoj Sachdev, Fellow, IEEE "A Low-Power High ----Performance Single-

- Cycle Tree-Based 64- Bit Binary Comparator" IEEE Transactions On Circuits And Systems—II: Express Briefs, Vol.59, No. 2,February 2012.
- [2] F. Frustaci, S. Perri, M. Lanuzza, and P. Corsonello, "A new low-power high-speed single-clock-cycle binary comparator," in Proc. IEEE Int. Symp. Circuits Syst., 2010, pp.317–320.
- [3] S. Perri and P. Corsonello, "Fast low-cost implementation of single-clock-cycle binary comparator," IEEE Trans. Circuits Syst. II, Exp. Briefs, vol. 55, no. 12, pp. 1239–1243, Dec. 2008.
- [4] R. Zimmermann and W. Fichtner, "Low Power Logic Styles: CMOS Versus Pass Transistor Logic" IEEE Journal of Solid State Circuits, Vol.32, No.7, pp1079-1090, July 1997.
- [5] S. Kang and Y. Leblebici "CMOS Digital Integrated Circuit, Analysis and Design" Tata McGraw-Hill, 3<sup>rd</sup> Ed, 2003.
- [6] M. Morris Mano "Digital Design". Pearson Education Asia. 3<sup>rd</sup>Ed, 2002.
- [7] A. Bellaouar and Mohamed I. Elmasry, Low Power Digital VLSI Design: Circuits and Systems," Kluwer Academic Publishers, 2<sup>nd</sup> Ed, 1995.