# A New Description of MOS Circuits at Switch-Level With Applications 

Massoud PEDRAM<br>Department of Electrical Engineering-Systems, University of Southern California, Los Angeles, CA 90007-2562, USA<br>Xunwei WU*<br>Department of Electronic Engineering, Hangzhou University, Hangzhou, Zhejiang 310028, China<br>(* Xunwei Wu is presently on leave at University of Southern California.)

SUMMARY After analyzing the limitations of the traditional description of CMOS circuits at the gate level, this paper introduces the notions of switching and signal variables for describing the switching states of MOS transistors and signals in CMOS circuits, respectively. Two connection operations for describing the interaction between MOS transistors and signals and a new description for MOS circuits at the switch level are presented. This new description can be used to express the functional relationship between inputs and the output at the switch level. It can also be used to describe the circuit structure composed of MOS switches. The new description can be effectively used to design both CMOS circuits and nMOS pass transistor circuits.

Key words: MOS, LSI, pass-transistor logic, switching theory, low power design

## 1. Traditional Description of CMOS Circuits at Gate Level

The traditional description of CMOS circuits is based on Boolean algebra. Its elementary points are:
(1) Boolean variables are used to represent signals in circuits. The two values of a variable, 1 and 0 are physically represented by two levels of a signal, for example 5 V and 0 V .
(2) The basic operations among variables in Boolean algebra are NOT, AND and OR operations. Usually, two composite operations, NAND and NOR, are also introduced. These operations are realized by the corresponding basic circuit units called gates, such as NOT gate (inverter), AND gate, OR gate, NAND gate and NOR gate.
(3) NOT, AND and OR operations form a complete set and can be used to express any functions. Besides, NAND alone (or NOR alone) can form a complete basis by itself.

Therefore, as long as we get the function expression we can obtain its corresponding circuit configuration by using gates from the complete set. For example, the Exclusive-OR function is given by its truth table shown in Fig. 1 (a). Based on the Boolean algebra, we can describe the Exclusive-OR function of $x$ and $y$ by the following expression:

$$
x \oplus y=\left(x_{\mathrm{I}} \bar{y}\right) \mathrm{Y}_{\mathrm{Y}}\left(\bar{x}_{\mathrm{I}} y\right)=\overline{\overline{\left(x_{\mathrm{I}} \bar{y}\right)} \mathrm{I}_{\mathrm{I}} \overline{\left(\bar{x}_{\mathrm{I}} y\right)}},
$$

Which yields the corresponding circuits in Fig. 1(b) and (c), respectively. This example explains how the description is used for both the function and the circuit structure at the gate level.

## Figure 1

Fig. 1 Definition and circuits for Exclusive-OR operation (a) truth table, (b) circuit composed of NOT, AND and OR gates, (c) circuit composed of NOT and NAND gates.

We should also point out the following limitations of the traditional description.
(1) The internal structure of a gate cannot be described, or derived from the function expression. For example, Boolean algebra cannot describe the internal structures of CMOS inverter and CMOS NAND gate shown in Fig. 2 (a) and (b).
(2) A compound gate, which also realizes the Exclusive-OR function, is shown in Fig. 2 (c). Boolean algebra cannot describe the structure because it is not composed of gates. Reference [1] introduces the following procedure to derive the structure from its Boolean expression. First, we obtain the inverted expression: $x \oplus y=\overline{\left(x_{\mathrm{I}} y\right) \mathrm{Y}(\bar{x} \mathrm{I} \bar{y})}$. For the n -side of the CMOS structure, we take the non-inverted expression $\left(x_{\mathrm{I}} y\right) \mathrm{Y}\left(\bar{x}_{\mathrm{I}} \bar{y}\right)$. Here the operations I and Y may be considered connections of nMOS transistors in series and in parallel. After having the $n$-structure, a dual p-structure can be derived and the whole configuration is obtained as shown in Fig. 2 (c). Obviously, the procedure is not included in Boolean algebra.
(3) NOT, AND and OR operations in Boolean algebra form a complete set, but they cannot be used to describe the relationship of the output to the inputs of a CMOS circuit that has a high-impedance state $\phi$. The output of a simple CMOS transmission gate shown in Fig. 2 (d) is expressed as $f=\left(c_{\mathrm{I}} x\right) \mathrm{Y}\left(\Phi_{\mathrm{I}} \bar{x}\right)$ in some textbooks. However, we do not define the operations related to the high-impedance state F in Boolean algebra.

## Figure 2

Fig . 2 Switch structure of a few CMOS gates (a) inverter, (b) NAND gate, (c) composed Exclusive-OR gate, (d) transmission gate.

According to the above discussion, Boolean algebra can be used to describe the CMOS circuit structure at the gate level, but cannot be used to describe the switching states of MOS transistors in the circuit and the circuit structure at switch level. The description at switch level is however desired for the switch-level techniques [2,3].

In the recent past, there has been renewed interest in pass-transistor logic circuits because they comprise of fewer transistors and exhibit smaller stray capacitance, compared conventional static CMOS circuits [4,5], and hence lead to lower power dissipation. A number of papers on pass-transistor logic have been published, for example, CPL (Complementary Pass-transistor Logic), DCVSPG (Differential Cascade Voltage Switch with Pass-Gate), DPL (Double pass-transistor Logic), SRPL (Swing Restored Passtransistor Logic), and SAPL (Sense-Amplifying Pass-transistor Logic) [6-10]. However, pass transistor logic has not succeeded in playing a major role in practical LSI designs. In particular, pass transistors are used only in a small portion of arithmetic macros or XOR logic. One reason is that no synthesis tools are available for pass-transistor based design. The other reason is that the nMOS pass-transistor circuits are generally perceived to have poor low-voltage performance compared to their full static CMOS counterparts which raises doubts about their future applicability.

Reference [11] investigates various issues relative to the design of nMOS pass-transistor circuits. A cell library and an automatic synthesis tool utilizing the functionality of pass-transistors are constructed. The preliminary results appear to be quite positive. By designing some small arithmetic circuits, the others demonstrate excellent quality of pass-transistor logic in terms of area, delay time, and power dissipation. In addition, the authors find that the low-voltage performance of nMOS-based pass-transistor circuits is better than the conventional CMOS circuits down to 1 V , when the threshold voltage is 0.4 V . However, a number of key issues related to direct synthesis of pass-transistor circuits from a Boolean description remain.

Up until now, the pass-transistor design and the traditional fully complementary logic design have been considered to be very different design methods [12]. In this paper we will show that these methods are based on the same switch-level view of the MOS transistor. Therefore, by focusing on the switching process, we derive a relationship between the two methods, which then enables us to solve the problem of synthesizing pass-transistor circuits. The remainder of this paper is organized as follows. Section 2 gives a new description that describes both signal and switching state of transistors in MOS circuits and reflects the circuit structure, where each MOS transistor is recognized as a switch for transmitting its source signal to its drain. Sections 3 and 4 present application of the new description to the design of CMOS and nMOS pass-transistor circuits. Section 5 contains our concluding remarks.

## 2. Description of MOS Circuits at Switch Level

To describe the MOS circuit structure, we introduce an additional variable that describes switches in circuits; we should distinguish the new variable from the variable that is used to describe signals.
(1) Assume $\alpha, \beta \ldots$ are switching variables that take two values, T and F , which in turn represent the two opposite states of on and off for a MOS transistor. The basic operations related to switching variables are NOT, AND and OR. Their definitions are as follows:
NOT operation

$$
\tilde{\alpha}=\left\{\begin{array}{lll}
\mathrm{T} & \text { if } \quad \alpha=\mathrm{F},  \tag{1}\\
\mathrm{~F} & \text { if } \quad \alpha=\mathrm{T} ;
\end{array}\right.
$$

AND operation

$$
\alpha \cdot \beta= \begin{cases}\mathrm{T} & \text { if } \alpha=\beta=\mathrm{T}  \tag{2}\\ \mathrm{~F} & \text { otherwise }\end{cases}
$$

## OR operation

$$
\alpha+\beta= \begin{cases}\mathrm{F} & \text { if } \alpha=\beta=\mathrm{F}  \tag{3}\\ \mathrm{~T} & \text { otherwise }\end{cases}
$$

Based on the above basic operations, a binary switching algebra is established.
(2) Assume $x, y, \ldots$ are binary signal variables. They take two values, 1 and 0 , which represent the two signal levels, high and low, in a circuit. They have a precise magnitude and can be identified by comparing their magnitude with a threshold value, denoted by 0.5 . The basic operations that are related to binary signal variables are Complement, Minimum and Maximum. Their definitions are as follows:
Complement operation

$$
\bar{x}=\left\{\begin{array}{lll}
1 & \text { if } & x=0  \tag{4}\\
0 & \text { if } & x=1
\end{array}\right.
$$

## Minimum operation

$$
x_{\text {I }} y= \begin{cases}1 & \text { if } x=y=1  \tag{5}\\ 0 & \text { otherwise }\end{cases}
$$

## Maximum operation

$$
x \mathrm{Y} y= \begin{cases}0 & \text { if } \quad x=y=0  \tag{6}\\ 1 & \text { otherwise }\end{cases}
$$

Based on the above basic operations, binary signal algebra is formed.
Therefore, we have two kinds of binary algebra systems; it can be shown that the two systems are isomorphic. However, in the existing literature they are always substituted for one another confused without considering their essential differences and their isomorphism. Therefore, gates that realize Complement, Minimum, and Maximum operations are traditionally named NOT, AND and OR gates.

Taking the inverter in Fig. 2(a) as an example to explain two kinds of variables, we can use $x, \bar{x}, \alpha_{p}$ and $\alpha_{\mathrm{n}}$ to express the input and output signal, and the switching states of pMOS and nMOS transistors, respectively. Their relationship is given in Table 1.

Table 1 Relationship between signals and switching states in a CMOS inverter.

## Table 1

We can further introduce operations between two kinds of variables for describing the connection between the on-off states of switching elements and the voltage levels of the signals, as shown in Fig. 3. They are:

Connection operation I - which describes the physical process of how the binary signal controls the on-off state of an element.

Connection operation II - which describes the physical process of how the on-off state of an element controls the transmission of the binary signal.

## Figure 3

Fig. 3 Connections between binary switching variables and binary signal variables.
In a CMOS digital circuit, the on-off state of a MOS transistor is dependent on the comparison between the gate signal and the threshold. Therefore, we define the connection operation I as follow:
High-threshold comparison operation

$$
{ }^{0.5} x=\left\{\begin{array}{lll}
\mathrm{T} & \text { if } & x>0.5(i . e ., x=1)  \tag{7}\\
\mathrm{F} & \text { if } & x<0.5(i . e ., x=0)
\end{array}\right.
$$

Low-threshold comparison operation

$$
x^{0.5}=\left\{\begin{array}{lll}
\mathrm{T} & \text { if } & x<0.5 \text { (i.e., } \mathrm{x}=0)  \tag{8}\\
\mathrm{F} & \text { if } & x>0.5 \text { (i.e., } \mathrm{x}=1)
\end{array}\right.
$$

In Eqs. (7) and (8), the gate signal $x \in\{0,1\}$ and 0.5 indicates that the detection threshold is set in the middle of two logic levels, 0 and 1 . If $x$ assumes an intermediate value other than 0 or 1 , then the switching state of the MOS transistor will be indeterminate. This case is not allowed. Note that these two equations represent the high-active switching characteristic of a nMOS transistor and the low-active switching characteristic of a pMOS transistor, respectively.

The following properties can be easily verified by use of the above definitions:

$$
\begin{align*}
& \bar{x}^{0.5}={ }^{0.5} x=x^{0.5}  \tag{9}\\
& \widetilde{\sim},  \tag{10}\\
& 0.5 \bar{x}=x^{0.5}={ }^{0.5} x,
\end{align*}
$$

Which state that the two threshold comparison operations can be transformed by complementing the signal variable.

$$
\begin{align*}
& { }^{0.5}\left(x_{\mathrm{I}} y\right)={ }^{0.5} x \cdot{ }^{0.5} y,  \tag{11}\\
& { }^{0.5}(x \mathrm{Y} y)={ }^{0.5} x+{ }^{0.5} y . \tag{12}
\end{align*}
$$

In Eqs. (10)-(12) the corresponding relationships between Complement, Minimum and Maximum in binary signal algebra and NOT, AND and OR in switching algebra are established by use of the high-threshold comparison operations. Furthermore, the high-threshold comparison operation penetrates through a function $f(x, y, \Lambda ;-, \mathrm{I}, \mathrm{Y})$ in binary signal algebra as follows:

$$
\begin{equation*}
{ }^{0.5} f(x, y, \Lambda ;-, \mathrm{I}, \mathrm{Y})=f\left({ }^{0.5} x,,^{0.5} y, \Lambda ; \sim, \cdot,+\right) . \tag{13}
\end{equation*}
$$

On the other hand, the on-off state of a MOS transistor determines whether the source signal is transmitted to the drain or not. Therefore, we may introduce the connection operation II as follows.

## Transmission operation

$$
c * \alpha=\left\{\begin{array}{lll}
\mathrm{c} & \text { if } & \alpha=\mathrm{T}  \tag{14}\\
\Phi & \text { if } & \alpha=\mathrm{F}
\end{array}\right.
$$

Where the binary variable $c$ is called transmitted source signal, and $a$ represents the switching state of a transmission switch network. If $\alpha=\mathrm{T}$, signal $c$ is transmitted to the output; if $\alpha=\mathrm{F}$, the switch network is off and its output is in the high-impedance state, denoted by symbol $\phi$. The switch network is composed of a nMOS transistor, if $c=0$, or a pMOS transistor, if $c=1$.

To denote the joining of the outputs of two (or more) transmission branches, we define the following operation further.

## Union Operation

$$
c_{1} * \alpha_{1} \# c_{2} * \alpha_{2}=\left\{\begin{array}{lcc}
c_{1} * \alpha_{1} & \text { if } & c_{2} * \alpha_{2}=\Phi  \tag{15}\\
c_{2} * \alpha_{2} & \text { if } & c_{1} * \alpha_{1}=\Phi
\end{array}\right.
$$

In Eq. (15), the transmission operation * takes priority over the Union operation \#. Note that $1 \# \Phi=1$ and $0 \# \Phi=0$. We notice that if $c_{1} \neq c_{2}$ there must be $\alpha_{1} \cdot \alpha_{2}=\mathrm{F}$, so that a voltage conflict between sources $c_{1}$ and $c_{2}$ is avoided. As an example, we can use the above operations to re-express $\bar{x}$ in Eq. (4) at switch level:

$$
\begin{equation*}
\bar{x}=1 * x^{0.5} \# 0 *{ }^{0.5} x, \tag{16}
\end{equation*}
$$

Which exactly describes the circuit structure in Fig.1(a) and its working process shown in Table 1. We find that the exclusive relationship between two switching functions ( $x^{0.5},{ }^{0.5} x$ ) is naturally conformed.

It can be proved that the following laws related to the transmission operation and union operation hold.
Serial transmission law

$$
\begin{equation*}
\left(c * \alpha_{1}\right) * \alpha_{2}=c *\left(\alpha_{1} \cdot \alpha_{2}\right), \tag{17}
\end{equation*}
$$

Parallel transmission law

$$
\begin{equation*}
c * \alpha_{1} \# c * \alpha_{2}=c *\left(\alpha_{1}+\alpha_{2}\right), \tag{18}
\end{equation*}
$$

## Commutation law

$$
\begin{equation*}
c_{1} * \alpha_{1} \# c_{2} * \alpha_{2}=c_{2} * \alpha_{2} \# c_{1} * \alpha_{1}, \tag{19}
\end{equation*}
$$

Associative law

$$
\begin{equation*}
\left(c_{1} * \alpha_{1} \# c_{2} * \alpha_{2}\right) \# c_{3} * \alpha_{3}=c_{1} * \alpha_{1} \#\left(c_{2} * \alpha_{2} \# c_{3} * \alpha_{3}\right)=c_{1} * \alpha_{1} \# c_{2} * \alpha_{2} \# c_{3} * \alpha_{3}, \tag{20}
\end{equation*}
$$

Distributive law

$$
\begin{equation*}
\left(c_{1} * \alpha_{1} \# c_{2} * \alpha_{2}\right) * \alpha_{3}=c_{1} *\left(\alpha_{1} \cdot \alpha_{3}\right) \# c_{2} *\left(\alpha_{2} \cdot \alpha_{3}\right), \tag{21}
\end{equation*}
$$

We can use the connection operations to derive a new canonical function form. For example, a twovariable function $f(x, y)$ has the following canonical expansion form at the switch level:

$$
\begin{equation*}
f(x, y)=f(0,0) *\left(x^{0.5} \cdot y^{0.5}\right) \# f(0,1) *\left(x^{0.5} .0 .5 y\right) \# f(1,0) *\left({ }^{0.5} x \cdot y^{0.5}\right) \# f(1,1) *\left({ }^{\left({ }^{0.5}\right.} x \cdot{ }^{0.5} y\right) \tag{22}
\end{equation*}
$$

In comparison, the two-variable function $f(x, y)$ has its traditional min-term expansion at the gate level:

$$
f(x, y)=\left[\begin{array}{lll}
f(0,0)_{\mathrm{I}} & \bar{x}_{\mathrm{I}} \bar{y} \tag{23}
\end{array}\right] \mathrm{Y}\left[f(0,1)_{\mathrm{I}} \bar{x}_{\mathrm{I}} y\right] \mathrm{Y}\left[f(1,0)_{\mathrm{I}} x_{\mathrm{I}} \bar{y}\right] \mathrm{Y}\left[f(1,1)_{\mathrm{I}} x_{\mathrm{I}} y\right]
$$

Equation (23) shows how the circuit is realized by using gates, which could be renamed Complement gate (inverter), Minimum gate (AND gate) and Maximum gate (OR gate), as show in Fig. 4 (a). However, Eq. (22) explains how four signals, $f(i, j)$, are transmitted to the output through two switches in series, as shown in Fig. 3 (b). These equations illustrate the difference in philosophy between switch-level and gatelevel descriptions. In fact, the structure shown in Fig. 4 (b) is relative to the pass transistor circuits. Therefore, the above new description for CMOS circuits is also suitable to nMOS pass transistor circuits.

## Figure 4

Fig. 4 Circuit realizations of a two-variable function (a) at gate level, (b) at switch level.

## 3. Application to Designing CMOS Circuits

Since in Eq. (22) the expansion coefficient $f(i, j) \in\{0,1\}$, we can factor coefficients 1 and 0 , respectively, and obtain the following form:

$$
\begin{equation*}
f=1 * *^{0.5} f \# 0 * f^{0.5}, \tag{24}
\end{equation*}
$$

Where ${ }^{0.5} f$ and $f^{0.5}$ are complementary. They are the switching functions of source 1 and source 0 , respectively. By using Eq. (9) the above equation can be rewritten as

$$
\begin{equation*}
f=1 *{ }^{0.5} f \# 0 * *^{0.5} \bar{f} . \tag{25}
\end{equation*}
$$

If we have the simplified function expression $\overline{f(x, y, \Lambda ;-, \mathrm{I}, \mathrm{Y})}$ in traditional binary signal algebra, we can easily derive its corresponding switch-level expression ${ }^{0.5} \overline{f(x, y, \Lambda ;-, \mathrm{I}, \mathrm{Y})}$ by using Eq. (13). The latter shows how to use serial and parallel nMOS switch connections for controlling the transmission of source 0 . According to ${ }^{0.5} \bar{f}={ }^{0.5} f$ in Eq. (25) and De Morgan's Law, the two switch-level expressions, ${ }^{0.5} f$ and ${ }^{0.5} \bar{f}$, are dual. And that is the principle of the design procedure presented in [1].

Taking $f_{1}=\overline{x_{\mathrm{I}} y}$ and $f_{2}=x \oplus y$ as examples, we have $\bar{f}_{1}=x_{\mathrm{I}} y$ and $\bar{f}_{2}=\left(x_{\mathrm{I}} y\right) \mathrm{Y}\left(\bar{x}_{\mathrm{I}} \bar{y}\right)$. Then the following switch-level expressions can be obtained:

$$
\begin{equation*}
{ }^{0.5} \bar{f}_{1}={ }^{0.5} x \cdot{ }^{0.5} y \quad \text { And } \quad{ }^{0.5} \bar{f}_{2}={ }^{0.5} x \cdot{ }^{0.5} y+{ }^{0.5} \bar{x} \cdot{ }^{0.5} \bar{y} . \tag{26}
\end{equation*}
$$

The above two expressions describe the n-branches in Fig. 2 (b) and (c). By De Morgan's Law, we have the following dual expressions for describing the corresponding p -branches:

$$
\begin{equation*}
{ }^{0.5} f_{1}=x^{0.5}+y^{0.5} \quad \text { And }{ }^{0.5} f_{2}=\left(x^{0.5}+y^{0.5}\right) \cdot\left(\bar{x}^{0.5}+\bar{y}^{0.5}\right) . \tag{27}
\end{equation*}
$$

In fact, the duality between p-part and n-part in a CMOS circuit is unnecessary. Because $f_{2}=x \oplus y$ also can be expressed as $f_{2}=\left(x_{\mathrm{I}} \bar{y}\right) \mathrm{Y}\left(\bar{x}_{\mathrm{I}} y\right)$, we have the following expression instead:

$$
\begin{equation*}
{ }^{0.5} f_{2}={ }^{0.5} x \cdot{ }^{0.5} \bar{y}+{ }^{0.5} \bar{x}^{0.5} y=\bar{x}^{0.5} \cdot y^{0.5}+x^{0.5} \cdot \bar{y}^{0.5} . \tag{28}
\end{equation*}
$$

The above expression will guide a new pMOS connection model, which would eliminate the internal connection in the p-branch in Fig. 2(c).

Another example is given in design of a combinational adder as follows. For a circuit with output inverting buffers, we can design a circuit with inverse outputs, $\overline{C_{+}}$and $\bar{S}$, first. From Eq. (25) we have

$$
\begin{align*}
& \overline{C_{+}}=1 *{ }^{0.5} \overline{C_{+} \# 0 *{ }^{0.5} C_{+},}  \tag{29}\\
& \bar{S}=1 *{ }^{0.5} \bar{S} \# 0 *{ }^{0.5} S . \tag{30}
\end{align*}
$$

Based on the traditional Boolean algebra the following expressions are derived:

$$
\begin{align*}
& C_{+}=\left(A_{\mathrm{I}} B\right) \mathrm{Y}\left[(A \mathrm{Y} B)_{\mathrm{I}} C\right],  \tag{31}\\
& \left.\overline{C_{+}}=\left(\bar{A}_{\mathrm{I}} \bar{B}\right)_{\mathrm{Y}[ }\left(\bar{A}_{\mathrm{Y}} \bar{B}\right)_{\mathrm{I}} \bar{C}\right],  \tag{32}\\
& S=\left[\left(A_{\mathrm{Y}} B \mathrm{Y}_{\mathrm{Y}} C\right)_{\mathrm{I}} \bar{C}_{+}\right]_{\mathrm{Y}}\left(A_{\mathrm{I}} B_{\mathrm{I}} C\right),  \tag{33}\\
& \bar{S}=\left[\left(\bar{A}_{\mathrm{Y}} \bar{B} \overline{\mathrm{Y}}\right)_{\mathrm{I}} C_{+}\right] \mathrm{Y}\left(\bar{A}_{\mathrm{I}} \bar{B}_{\mathrm{I}} \bar{C}\right) . \tag{34}
\end{align*}
$$

Note that in the above expressions $C_{+}$and $\overline{C_{+}}, S$ and $\bar{S}$ are symmetric rather than dual with each other. By using Eq. (13), their corresponding expressions at switch-level are:

$$
\begin{align*}
& { }^{0.5} \overline{C_{+}}=A^{0.5} \cdot B^{0.5}+\left(A^{0.5}+B^{0.5}\right) \cdot C^{0.5},  \tag{35}\\
& { }^{0.5} C_{+}={ }^{0.5} A \cdot{ }^{0.5} B+\left({ }^{0.5} A+{ }^{0.5} B\right) \cdot{ }^{0.5} C,  \tag{36}\\
& 0.5 \bar{S}=\left(A^{0.5}+B^{0.5}+C^{0.5}\right) \cdot \overline{C_{+}}{ }^{0.5}+A^{0.5} \cdot B^{0.5} \cdot C^{0.5},  \tag{37}\\
& 0.5  \tag{38}\\
& { }^{0.5}=\left({ }^{0.5} A+{ }^{0.5} B+{ }^{0.5} C\right) \cdot{ }^{0.5} \overline{C_{+}}+{ }^{0.5} A \cdot{ }^{0.5} B \cdot{ }^{0.5} C .
\end{align*}
$$

Therefore we obtain the corresponding circuit design at switch level, as shown in Fig. 5 [1]. Obviously, the p -branch and n -branch in the optimized schematic are symmetric.

Figure 5

Fig. 5 CMOS design of a full adder.
In addition to transformation from the traditional Boolean expression, the switch-level expression can be also derived directly from truth table or Karnaugh map. Figure 6 shows three Karnaugh maps for outputs of the NAND gate, the transmission gate, and the Exclusive-OR gate. From the mapping synthesis shown in Fig. 6 (a), we directly obtain the switch-level expression:

$$
\begin{equation*}
\overline{x_{\mathrm{I}} y}=1 *\left(x^{0.5}+y^{0.5}\right) \# 0 *\left({ }^{0.5} x \cdot{ }^{0.5} y\right) . \tag{39}
\end{equation*}
$$

The above expression describes how the source $1\left(V_{\mathrm{DD}}\right)$ transmitted through two p-transistors in parallel to the output, and the source 0 (Ground) transmitted through two n-transistors in series to the output, as shown in Fig. 6(a).

According to the mapping in Fig. 6(b), we use the variable $c$ as its transmitted source and obtain the switch-level expression:

$$
\begin{equation*}
f=c *{ }^{0.5} x . \tag{40}
\end{equation*}
$$

The above expression shows that the source $c$ is transmitted by an n-transistor. To avoid the poor transmission for $c=1$ we rewrite the expression as:

$$
\begin{equation*}
f=c *\left({ }^{0.5} x+\bar{x}^{0.5}\right), \tag{41}
\end{equation*}
$$

Where two terms, ${ }^{0.5} x$ and $\bar{x}^{0.5}$, are equal based on Eq. (9). However, they describe that the variable source is transmitted by a complementary MOS construction, as shown in Fig. 6(b).

## Figure 6

Fig. 6 Mapping synthesis of some CMOS circuits at switch-level (a) NAND gate, (b) Transmission gate, (c) Exclusive-OR gate.

Based on the previous example, we can synthesize Exclusive-OR by its Karnaugh map in Fig. 6(c):

$$
\begin{equation*}
x \oplus y=y *\left(x^{0.5}+{ }^{0.5} \bar{x}\right) \# x(1) * y^{0.5} \# \bar{x}(0) * *^{0.5} y . \tag{42}
\end{equation*}
$$

Notice that the parts overlapped in Karnaugh map have been realized by $y *\left(x^{0.5}+{ }^{0.5} \bar{x}\right)$, and therefore the branch with source $x\left(\operatorname{term} x(1) * y^{0.5}\right)$ only has to transmit a 1 and never a 0 , and the branch with source $\bar{x}$ (term $\bar{x}(0) *{ }^{0.5} y$ ) only has to transmit a 0 and never a 1 . Hence each of these transmission branches can be realized with a single MOS transistor as shown in Fig. 6(c). This simple circuit realization previously has
been considered as something that "... does not follow from any systematic (design) method" [13]. Comparing all three designs of Exclusive-OR gate in Fig. 1(c), Fig. 2(c) and Fig. 6(c) we find that the number of transistors in the circuits are 16, 12 and 6 , respectively. Besides, the numbers of internal nodes in circuits are 5, 3 and 2, respectively. This means that the design based on switch-level description may lead to a circuit with a simpler structure as well as higher quality (delay and power).

It should be pointed out that the description of MOS circuits at switch-level also offers a new method for analyzing and optimizing circuits. However, since there are physical capacitance and resistance associated with the MOS transistors, the permutation of the inputs to a series chain of transistors will lead to different input pin loads and pin dependent delays. It is well known that the signal to pin assignment in a CMOS logic gate has a sizable impact on the propagation delay through the gate [14]. Besides, researchers have pointed out that the assignments of input signal with different probability of assuming a controlling value (zero for nMOS and one for pMOS), or input signal with different switching activity when all other inputs are set to their non-controlling values must be considered for power reduction [14,15]. Therefore, we have to describe the circuit more accurately at switch level. It means that each transistor in seriesconnected structure should be located exactly. In fact, by weakening the communication law of switching variables, those two switching variables in Eq. (17) cannot be permuted. Thus, the order of AND'ed switching variables will represent corresponding location accurately in the series-connected structure. Taking the Exclusive-OR gate shown in Fig. 2(c) as the example, its output can be expressed as

$$
\begin{equation*}
x \oplus y=1 *\left[\left(x^{0.5}+y^{0.5}\right) \cdot\left(\bar{x}^{0.5}+\bar{y}^{0.5}\right)\right] \# 0 *\left[^{0.5} x \cdot{ }^{0.5} y+{ }^{0.5} \bar{x}^{0.5} \bar{y}\right] . \tag{43}
\end{equation*}
$$

The above expression indicates that the two nMOS transistors, which are controlled by signals $x$ and $\bar{x}$ are close to Ground since their corresponding switching variables, are near the source 0 in the above expression. Obviously, the other two nMOS transistors are close to the output terminal. Therefore, the proposed description of CMOS circuits is modified to locate each transistor in the circuit. It is expected that the new switch-level description will provide a basis for analyzing and optimizing delay and power dissipation of CMOS circuits.

## 4. Application to Designing nMOS Pass Transistor Circuits

An nMOS pass-transistor circuit, as shown in Fig. 7 (a) has a structure similar to the one in Fig. 4 (b) except for the following differences:
(1) Each switch in the transmission branches is a nMOS transistor independent of the signal value, 0 or 1 , to be transmitted. In contrast, if the transmitted signal $f(i, j)$ in Fig. 4 (a) is a variable source, each switch in the branch should be a transmission gate, which consists of a pair of complementary MOS transistors.
(2) Since nMOS transistor has a poor transmission for high level, it is necessary to restore the output level using an output inverter, as shown in Fig. 7 (a). This inverter consists of three MOS transistors, as shown in Fig. 7 (b). The feedback to the pull-up pMOS transistor improves the slope of transient passtransistor output waveform if the input of the inverter is at high level. If the load capacitance is extremely large, an extra feedback inverter should be added to avoid its influence on the feedback action [11]. We notice that in Fig. 7 (a) all source signals are inverted because of the output inverter.

## Figure 7

Fig. 7 (a) A nMOS pass-transistor circuit, (b) output inverter.
By explaining the differences between conventional CMOS transmission circuit and nMOS passtransistor circuit we can modify the new description for CMOS circuit and use it to describe and design nMOS pass-transistor circuits as follows.

In the design of CMOS circuits, since source 1 should be transmitted by pMOS transistors, ${ }^{0.5} f$ in Eq. (25) have to be expressed by arguments $x^{0.5}, y^{0.5}$, etc. However, source 1 in nMOS pass-transistor circuit is also transmitted by nMOS transistors, therefore, the low threshold comparison operations $x^{0.5}, y^{0.5}$, etc. should not appear. For example, consider $f_{1}=\overline{x_{\mathrm{I}} y}=\bar{x} \mathrm{Y} \bar{y}$ and $f_{2}=x \oplus y=\left(x_{\mathrm{I}} \bar{y}\right) \mathrm{Y}\left(\bar{x}_{\mathrm{I}} y\right)$ as in the last section we obtain following expressions, in place of Eqs. (27). (Note that Eq. (26) remains unchanged).

$$
\begin{equation*}
{ }^{0.5} f_{1}={ }^{0.5} \bar{x}+{ }^{0.5} \bar{y} \text { And } \quad{ }^{0.5} f_{2}={ }^{0.5} \bar{x} \cdot 0.5 y+{ }^{0.5} x \cdot{ }^{0.5} \bar{y}, \tag{44}
\end{equation*}
$$

## Figure 8

Fig. 8 nMOS pass-transistor circuits with constant source (a) $\overline{x_{\mathrm{I}} y}$, (b) $x \oplus y$.
The above expressions describe the nMOS pass-transistor circuits for realizing $f_{1}$ and $f_{2}$, as show in Fig. 8 (a) and (b). If we add an output inverter to restore the logic level, the source signals should be inverted. If comparing the above nMOS designs with CMOS designs in Fig. 2 (b) and (c), we cannot see any advantage with the nMOS design. In fact, the feature of nMOS pass-transistor circuits is that nMOS transistor is used to transmit both source 0 and source 1 . This means that a single nMOS transistor can be used to transmit a variable source. The use of variable signal sources rather than constant sources frequently allows simpler circuit to be designed. As an example, we can rewrite $x \oplus y$ as

$$
x \oplus y=\left(\bar{x}_{\mathrm{I}} y\right) \mathrm{Y}\left(x_{\mathrm{I}} \bar{y}\right)= \begin{cases}y, & \text { if } x=0 ;  \tag{45}\\ \bar{y}, & \text { if } x=1 .\end{cases}
$$

By using the high threshold comparison operation the above equation can be transformed into a switching expression:

$$
\begin{equation*}
x \oplus y=y * x^{0.5} \# \bar{y}^{* 0.5} x=y^{* 0.5} \bar{x} \# \bar{y}^{* 0.5} x . \tag{46}
\end{equation*}
$$

The corresponding nMOS pass-transistor circuit is shown in Fig. 9 (a), which is much simpler than the one in Fig. 8 (b). (In fact, if the two nMOS transistors controlled by $x$ and the two nMOS transistors controlled by $\bar{x}$ in Fig. 8 (b) are merged respectively, we get the design of Fig. 9 (a).) The example indicates that as long as a Boolean function $f(x, y, \Lambda, \mathrm{I}, \mathrm{Y})$ is expressed in a MUX form by using the Shannon expansion:

$$
\begin{equation*}
f(x, y, \Lambda, \mathrm{I}, \mathrm{Y})=[f(0, y, \Lambda, \mathrm{I}, \mathrm{Y}) \mathrm{I} \bar{x}] \mathrm{Y}[f(1, y, \Lambda, \mathrm{I}, \mathrm{Y}) \mathrm{I} x] \tag{47}
\end{equation*}
$$

We will have its corresponding switching expression:

$$
\begin{equation*}
f(x, y, \Lambda, \mathrm{I}, \mathrm{Y})=f(0, y, \Lambda, \mathrm{I}, \mathrm{Y})^{* 0.5} \bar{x} \# f(1, y, \Lambda, \mathrm{I}, \mathrm{Y})^{* 0.5} x, \tag{48}
\end{equation*}
$$

Which will lead its realization with nMOS pass-transistor MUX. Notice that in the above expression the exclusive relationship of two switching functions is met by ${ }^{0.5} \bar{x} \cdot{ }^{0.5} x=\mathrm{F}$.

Taking conventional two-variable Boolean operations, $x_{\mathrm{I}} y$ and $x_{\mathrm{Y}} y$ as examples we have

$$
\begin{equation*}
x \mathrm{I} y=(0 \mathrm{I} \bar{y}) \mathrm{Y}(x \mathrm{I} y)=0^{* 0.5} \bar{y} \# x^{* 0.5} y, \tag{49}
\end{equation*}
$$

$$
\begin{equation*}
x \mathrm{Y} y=(x \mathrm{I} \bar{y}) \mathrm{Y}(1 \mathrm{I} y)=x^{* 0.5} \bar{y} \# 1^{* 0.5} y . \tag{50}
\end{equation*}
$$

The corresponding nMOS pass-transistor circuits are shown in Fig. 9 (b) and (c). If we add the output inverter to restore level, all transmitted sources in these circuits should be inverted.

Figure 9

Fig. 9 nMOS pass-transistor circuits with variable source (a) $x \oplus y$, (b) $x \mathrm{I} y$, and (c) $x \mathrm{Y} y$.
Furthermore, we take the full adder as a practical design example. If we introduce $C_{p}={ }_{A}{ }^{\oplus} B$, which is the carry propagation term, as an intermediate variable, we obtain the following Boolean expressions:

$$
\begin{equation*}
C_{p}=A{ }^{\oplus} B=(B \mathrm{I} \bar{A}) \mathrm{Y}(\bar{B} \mathrm{I} A), \tag{51}
\end{equation*}
$$

$$
\begin{equation*}
C_{+}=\left(A \mathrm{I} \bar{C}_{p}\right) \mathrm{Y}\left(C \mathrm{I} C_{p}\right), \tag{52}
\end{equation*}
$$

$$
\begin{equation*}
S=\left(C \mathrm{I} \bar{C}_{p}\right) \mathrm{Y}\left(\bar{C} \mathrm{I} C_{p}\right) . \tag{53}
\end{equation*}
$$

Based on the above design procedure we can construct the nMOS pass transistor circuit with simple nMOS MUX, as shown in Fig. 10 (a). In the circuit only 14 MOS transistors are used. However, the simple nMOS MUX without output inverter cannot work well. If we use the inverted nMOS MUX with output inverter in Fig. 7 (b) instead, we can obtain the improved design by inserting inverters into the circuit of Fig. 10 (a), as shown in Fig. 10 (b). The basic building cell is framed by dotted line in Fig. 10 (a). The conventional design shown in Fig. 5 requires 28 MOS transistors. However, our nMOS pass-transistor design only needs 23 MOS transistors and has an extra carry propagation output $C_{\mathrm{P}}$, which is useful for carry look ahead technique.

## Figure 10

Fig. 10 nMOS pass-transistor design of a full adder
(a) With simple nMOS MUX, (b) with inverted nMOS MUX.

The above design procedure of nMOS pass-transistor network is based on the binary division expressed by Eq. (48). The exclusive relationship between two switching functions is guaranteed for each division operation. This procedure makes the design of nMOS pass-transistor circuits as same as the synthesis for MUX networks. In fact, this procedure also conforms to the representation of BDD. Therefore, the designed circuit construction based on Eq. (48) can be described by its corresponding BDD representation. For example, for circuits in Fig. 9 and Fig. 10 (a) we have their corresponding BDDs, as shown in Fig. 11. An effective synthesis method of pass-transistor network based on BDD has been developed [16]. As long as the reduced BDD is obtained it can be mapped to nMOS transistor circuit easily (e.g. we derive circuits in Fig. 9 and Fig. 10 (a) from BDDs in Fig.11). We notice that in Fig. 11 (d) we adopt super-node labeled by $C_{P}$ in the BDD [17]. It can reduce number of transistors and delay.

## Figure 11

Fig. 11 BDDs (a) $x \oplus y$, (b) $x_{\mathrm{I}} y$, (c) $x \mathrm{Y} y$, (d) $C_{+}, S$ and $C_{P}$.
However, we should point out that synthesis of nMOS pass transistor network does not have to be confined to binary division given by Eq. (48). For example, we can express $x_{\mathrm{I}} y_{\mathrm{I}} z$ as follows:

$$
\begin{equation*}
x_{\mathrm{I}} y_{\mathrm{I}} z=x^{* 0.5}\left(y_{\mathrm{I}} z\right) \# 0^{* 0.5}\left(\overline{y_{\mathrm{I}} z}\right)=x^{*}\left({ }^{0.5} y x^{0.5} z\right) \# 0^{*}\left({ }^{0.5} \bar{y} x^{0.5} \bar{z}\right) \tag{54}
\end{equation*}
$$

The corresponding circuit realization is shown in Fig. 12 (a). This circuit is not mapped from BDD. Therefore, the synthesis of nMOS transistor network based on BDD is just one canonical design method by using the new description of MOS circuits at switch level. A bridge-connected circuit shown in Fig. 12 (b) gives another example. It is difficult to analyze its function by traditional method. However, we can describe it at switch level as follows. If $c=1$, the above bridge transistor conducts and the below one shuts off. Based on the switch connection we can get

$$
\begin{equation*}
\left.f(c=1)=1 *\left[0^{0.5} a+{ }^{0.5} b\right) \cdot\left({ }^{0.5} d+{ }^{0.5} e\right)\right] \# 0 *\left[{ }^{0.5} \bar{a} \cdot{ }^{0.5} \bar{b}+{ }^{0.5} \bar{d} \cdot{ }^{0.5} \bar{e}\right] . \tag{55}
\end{equation*}
$$

Similarly, if $c=0$, we have

$$
\begin{equation*}
f(c=0)=1 *\left[{ }^{0.5} a \cdot{ }^{0.5} d+{ }^{0.5} b \cdot{ }^{0.5} e\right] \# 0 *\left[\left({ }^{0.5} \bar{a}+{ }^{0.5} \bar{d}\right) \cdot\left({ }^{0.5} \bar{b}+{ }^{0.5} \bar{e}\right)\right] . \tag{56}
\end{equation*}
$$

It is easy to prove that two switching functions in Eq. (55) (or Eq. (56)) are exclusive with each other. It guarantees that the circuit shown in Fig. 12 (b) is source-conflict free.

## Figure 12

Fig. 12 (a) Three AND gate, (b) nMOS circuit with bridge connection.
From Eq. (25) we obtain

$$
{ }^{0.5} f==^{0.5} c \cdot\left[\left({ }^{0.5} a+{ }^{0.5} b\right) \cdot\left({ }^{0.5} d+{ }^{0.5} e\right)\right]+{ }^{0.5} \bar{c} \cdot\left[{ }^{0.5} a \cdot{ }^{0.5} d+{ }^{0.5} b \cdot{ }^{0.5} e\right] .
$$

Thus, we have

$$
\begin{align*}
f & =\left\{c \mathrm{I}\left[\left(a_{\mathrm{Y} b)}^{\mathrm{I}}(d \mathrm{Y} e)\right]\right\} \mathrm{Y}\left\{\bar{c}_{\mathrm{I}}\left[\left(a_{\mathrm{I}} d\right) \mathrm{Y}\left(b_{\mathrm{I}} e\right)\right]\right\}\right.  \tag{57}\\
& =\left\{c_{\mathrm{I}}\left[\left(a_{\mathrm{Y}} e\right) \mathrm{I}\left(b_{\mathrm{Y}} d\right)\right]\right\} \mathrm{Y}\left[\left(a_{\mathrm{I}} d\right) \mathrm{Y}\left(b_{\mathrm{I}} e\right)\right]
\end{align*}
$$

With the traditional AND-OR operation symbols the above equation can be expressed as

$$
f=c \times(a \times e+b \times d)+(a \times d+b \times e) .
$$

Obviously, the BDD representation for the above function will have a different and more complicated form compared to the circuit in Fig. 12 (b). From the above discussion, we demonstrate that the new description
for MOS transistor promises a more comprehensive circuit construction than BDD. Besides, we find that in the circuit two bridges transistors are used to connect two signals. Thus, the bi-directional characteristic of MOS transistor is used in the design.

## 5. Conclusion

The traditional description of CMOS circuits is based on Boolean algebra, where three basic operations, NOT, AND and OR, are used to describe functional relationship between inputs and the output, and to describe the circuit structure composed of gates. However, it cannot be used to describe the internal structure of MOS transistor switches. Besides, there exist some problems with Boolean algebra when describing complex gates or gates with high-impedance state. This paper introduced another variable to describe the switching state of transistors in addition to original variable, which describes signal in the circuit. The two variables have their own independent operations. Since there exists a mutual relationship between the on-off states of switch elements and the signals, we proposed two connection operations for describing their interaction, whereby a new description for CMOS circuits at the switch level is presented. Based on the new description the design of CMOS circuits at switch level can be realized. For CMOS circuits the traditional inverting-logic stage design and pass-transistor design have been considered to be two different design methods. However, the new description proposed in this paper can unite the two and overcome other difficulties in the traditional theory. The theory is also applicable to the description and design of nMOS pass-transistor circuits.

## Acknowledgment

This work was supported in part by DARPA under contract \#F33615-95-C-1627 and NNSF of China.

## References

[1] N. H. E. Weste and K. Eshraghian, Principles of CMOS VLSI Design: A Systems Perspective, 2nd Edition, Addison-Wesley Publishing Company, New York, 1993.
[2] J. P. Shen and S. Hirschhorn, "Switch-level techniques," IEEE Design \& Test of Computers, Vol.4, No.4, pp.15-16, 1987.
[3] P. Hares, "An introduction to switch-level modeling," IEEE Design \& Test of Computers, Vol.4, No.4, pp.18-25, 1987.
[4] T. Kuroda and T. Sakurai, "Overview of low-power ULSI circuit techniques," IEICE Trans. Electorn., Vol.78-C, no.4, pp.334-343, April 1995.
[5] D. Radhakrishnan, S. R. Whitaker and G. K. Maki, "Formal design procedures for pass transistor switching circuits," IEEE J. Solid-state Circuits, Vol.SC-20, no.2, pp.531-536, April 1985.
[6] K. Yano, T. Yamanaka, T. Nishida, M. Saito, K. Shimohigashi and A. Shimizu, "A 3.8-ns CMOS 16*16-b multiplier using complementary pass-transistor logic," IEEE J. Solid-state Circuits, Vol.SC25, no.2, pp.388-395, April 1990.
[7] F. S. Lai, W. Hwang, "Differential cascade voltage switch with the pass-gate (DCVSPG) logic tree for high performance CMOS digital systems," Proc. IEEE VLSITSA, pp.358-362, 1993.
[8] M. Suzuki, N. Ohkubo, T. Yamanaka, A. Shimuzu and K. Sasaki, "A 1.5ns 32b CMOS ALU in double pass-transistor logic," ISSCC Dig. Tech. Papers, pp.90-91, Feb. 1993.
[9] A. Parameswar, H. Hara and T. Sakurai, "A high based multiply and accumulate circuit for multimedia applications," Proc. IEEE CICC, pp.278-281, May 1994.
[10]M. Matsui, H. Hara, K. Seta, Y. Uetani, L.-S. Kim, T. Ohto, Y. Watanabe, F. Sano, A. Chiba, K. Matsuda and T. Sakurai, " 200 MHz video compression Macrocells using low-swing differential logic," ISSCC Dig. Tech. Papers, pp.76-77, Feb. 1994.
[11]K. Yano, Y. Sasaki, K. Rikino and K. Seki, "Top-down pass-transistor logic design," IEEE J. Solidstate Circuits, Vol.SC-31, no.6, pp.792-803, June 1996.
[12]D. Radhakrishnan, S. R. Whitaker and G. K. Maki, "Formal design procedures for pass transistor switching circuits," IEEE J. Solid-state Circuits, Vol.SC-20, pp.531-536, 1985.
[13]A. Mukherjee, Introduction to nMOS and CMOS VLSI System Design, Englewood Cliffs, NJ: Prentice-Hall, 1986.
[14]M. Pedram, "Power minimization in IC Design: Principles and applications," ACM Transactions on Design Automation of Electronic Systems, vol. 1, no.1, pp.3-56, Jan. 1996.
[15]S. C. Prasad and K. Roy, "Circuit optimization of power consumption under delay constraint," in Proceedings of the 1994 International Workshop on Low Power Design, pp.15-20, April 1994.
[16]T. Sakurai, B. Lin, and A. R. Newton, "Multiple-output shared transistor logic (MOSTL) family synthesized using binary decision diagram," Memorandum UCB/ERL M90/21, Electronics Research Laboratory, College of Engineering, University of California, Berkeley, March 1990.
[17]N. Calazans, Q. Zhang, R. Jacobi, B. Yernaux and A.-M. Trullemans, "Advanced ordering and manipulation techniques for binary decision diagrams," Proc. Eur. DAC, pp.452-457, 1992.

## Authors' biography

Massoud Pedram received the BS degree in Electrical Engineering from California Institute of Technology and MS and Ph.D. degrees in Electrical Engineering and Computer Sciences from the University of California, Berkeley in 1989 and 1991, respectively. He then joined the Department of Electrical Engineering -Systems at the University of Southern California where he is currently an associate professor. He is a recipient of the National Science Foundation's Young Investigator Award in 1994 and a Presidential Early Career Award for Scientists and Engineers in 1996. His research has received a number of awards including one DAC Best Paper Award, one ICCD Best Paper Award, and the IEEE Trans. VLSI Systems Best Paper Award. He has served on the technical program committee of the DAC since 1992 and was the co-founder and General Chair of the 1994 International Workshop on Low Power Design. He is currently the General Co-chair of the International Symposium on Low Power electronics and Design. His research interests include computer-aided design of VLSI circuits and systems. His present research focuses on developing methodologies and techniques for lowering the power dissipation in electronic circuits and on layout-driven logic synthesis. He is a Member of IEEE - Circuits and Systems Society and ACM - SIGDA.

Xunwei Wu graduated in Physics from Hangzhou University, Hangzhou, China, in 1962. He then joined the Department of Physics (1962) and Department of Electronic Engineering (1989) at the Hangzhou University. Since 1990 he has been a Professor in Electronic Engineering. From 1986 to 1987 he was a visiting professor in Computer Science Department at Indiana University, USA, and from 1996 to the present he is a visiting professor in Department of Electrical Engineering -Systems at the University of Southern California, USA, to join Prof. Pedram's research group. He is a recipient of the National Education Commission's Science-Technology Progress Award (1988, 1994), National Natural Science Award (1995) and National Outstanding Scientist Award (1995) in China. He has served on the committee of Multiple-Valued Logic and Fuzzy Logic, Chinese Computer Federation since 1990 and is the vicedirector of the committee from 1996. His research interests include logic synthesis, multiple-valued logic, switch-level design, current-mode circuits, and low-power analysis and design. He is a senior member of IEEE - Computer Society, a Fellow of Chinese Institute of Electronics, and a Fellow of Chinese Institute of Communication.

## Figure captions

Fig. 1 Definition and circuits for Exclusive-OR operation (a) truth table, (b) circuit composed of NOT, AND and OR gates, (c) circuit composed of NOT and NAND gates.

Fig . 2 Switch structure of a few CMOS gates (a) inverter, (b) NAND gate, (c) composed Exclusive-OR gate, (d) transmission gate.

Fig. 3 Connections between binary switching variables and binary signal variables.

Fig. 4 Circuit realizations of a two-variable function (a) at gate level, (b) at switch level.

Fig. 5 CMOS design of a full adder.

Fig. 6 Mapping synthesis of some CMOS circuits at switch-level (a) NAND gate, (b) Transmission gate, (c) Exclusive-OR gate.

Fig. 7 (a) A nMOS pass-transistor circuit, (b) output inverter.

Fig. 8 nMOS pass-transistor circuits with constant source (a) $\overline{x \mathrm{I} y}$, (b) $x \oplus y$.

Fig. 9 nMOS pass-transistor circuits with variable source (a) $x^{\oplus} y$, (b) $x \mathrm{I} y$, and (c) $x \mathrm{Y} y$.

Fig. 10 nMOS pass-transistor design of a full adder
(a) With simple nMOS MUX, (b) with inverted nMOS MUX.

Fig. 11 BDDs (a) $x^{\oplus} y$, (b) $x \mathrm{I} y$, (c) $x \mathrm{Y} y$, (d) $C_{+}, S$ and $C_{P}$.

Fig. 12 (a) Three AND gate, (b) nMOS circuit with bridge connection.

## Table captions

Table 1 Relationship between signals and switching states in a CMOS inverter.

Figure 1

| $x$ | $y$ | $x \oplus y$ |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

(a)

(b)

(c)

Figure 2

(a)

(b)

(c)

(d)

Figure 3


Figure 4

(a)

(b)

Figure 5


Figure 6
(a)

(b)

(c)


Figure 7

(a)

(b)

Figure 8

(a)

(b)

Figure 9

(a)

(b)

(c)

Figure 10


Figure 11


Figure 12


Table 1

| $x$ | $\alpha_{\mathrm{p}}$ | $\alpha_{\mathrm{n}}$ | $\bar{x}$ |
| :---: | :---: | :---: | :---: |
| 0 (low level) | T (on) | F (off) | 1 (high level) |
| 1 (high level) | F (off) | T (on) | 0 (low level) |

