Reversible Sequential Element Designs by Min-Lun Chuang & Chun-Yao Wang
Reversible Sequential Element Designs 
 
Min-Lun Chuang    Chun-Yao Wang 
Department of Computer Science,  
National Tsing Hua University, HsinChu, Taiwan R.O.C. 
{mr934327,wcyao}@cs.nthu.edu.tw 
  
x y z x y xy♁z Abstract – To construct a reversible sequential circuit, reversible 
sequential elements are required. This work presents novel designs 
of reversible sequential elements such as D latch, JK latch, and T 
latch. Based on these reversible latches, we construct the designs of 
the corresponding flip-flops .Comparing with previous work, the 
implementation cost of our new designs, including the number of 
gates and the number of garbage outputs is considerably reduced.  
 1
 
I. Introduction 
 
Landauer proved that if we use conventional irreversible 
logic gate to build a circuit, it necessarily consumes power no 
matter what the underlying technology is [5]. Bennett also 
showed that for power not to be dissipated in any circuit, it is 
necessary that this circuit has to be built with reversible gates 
[1]. There are many insistent reasons to consider the logic 
with reversibility. Also, reversible logic has applications in 
various future technologies, such as ultra low power CMOS 
design [12], optical computing [3], quantum computing [10], 
and nanotechnology [6], etc.   
To realize a function with reversibility, many reversible 
logic synthesis algorithms have been proposed in [4][8][14]. 
But most of them address this issue from the aspect of 
combinational logic. To synthesize reversible sequential 
circuits, reversible sequential elements such as latches and 
flip-flops are necessary. Thus, this paper proposes novel 
designs of reversible sequential elements such as clocked D 
latch, clocked JK latch, and clocked T latch. The 
corresponding flip-flop designs are also introduced. 
The remainder of this paper is organized as follows. In 
Section 2, we introduce the background of reversible logic. 
In Section 3, we review some existing implementations of 
reversible sequential elements. Then we propose our new 
designs of these reversible sequential elements and verify the 
functionalities of them in Section 4. The statistics and 
comparison of these new designs and previous work are 
presented in Section 5. Section 6 concludes the work. 
 
II. Background 
 
Definition 1: A gate is reversible if and only if the (Boolean) 
function is bijective. 
It means that a reversible function  f:(x1, x2, …,xn)→
(y1,y2, …,ym) satisfies the condition of one-to-one and onto 
mapping between the input and output domains. 
It is obvious that the conventional logic gates are almost 
irreversible. Among the commonly used gates, only the NOT 
gate is reversible. The AND gate and OR gate are irreversible 
because they violate the requirement of reversible function. 
One way to make the AND function reversible is to add one 
input and two outputs as shown in Figure 1(a). The AND 
function can be obtained in the third output column xy♁z of 
Figure 1(a), when setting z = 0. The truth table of AND 
function is shown in bold. 
 
 x 
 
 
 
 
 
 
 
 
Definition 2: A garbage bit is the additional output that 
makes an n-input m-output function reversible. 
In the reversible AND function as shown in Figure 1(a), 
the outputs x, y are garbage outputs which are used to make 
the function reversible.  
A set of reversible gates is needed to synthesize reversible 
circuits. Several reversible gates have been proposed in the 
centuries. Here we introduce Toffoli gate and Fredkin gate 
because they will be used in our work. 
Toffoli gate: The truth table of 3-bit Toffoli gate is shown in 
Figure 1(a) and its symbol is shown in Figure 1(b) [2]. The 
function of the third column is xy♁z. That means when 
x=y=1, the output is z, otherwise the output is z. This gate 
can be used to realize a 2-input reversible AND function by 
setting z as a constant 0 as mentioned. A Toffoli gate can be 
generalized as TOF(C;T), where C is a set of control 
variables {x1, x2, …, xn-1}, T is a target variable {xn} and C ∩ 
T = Ø . TOF(x1, x2, …, xn-1; xn) is a gate which maps a 
Boolean pattern (x1, x2, …, xn-1, xn) to (x1, x2, …, xn-1, 
x1x2...xn-1♁xn). 
Fredkin gate: Fredkin gate is also called controlled SWAP 
gate. Figure 2(a) is the symbol of Fredkin gate and Figure 2(b) 
is its truth table [2]. Its behavior can be described as follows: 
if the control bit x is set to 1, the outputs of y and z are 
swapped, otherwise they remain unchan ed. g
 
 
 
 
 
 
 
 
 
Two restrictions on reversible logic synthesis have to be 
followed [14]: 
1. The fanout count of a signal net must equal one. If two 
copies of one signal are needed, a duplication is necessary. 
2. A combinational reversible network has to be loop-free. It 
contains no cyclic path. 
The first restriction is due to the fact that fanout structure 
itself is not reversible. For fanout, the number of input signal 
is one, but there are two or more output signals. Therefore, 
for the first restriction, we use a 2-bit Toffoli gate (also called 
Feynman gate) to duplicate a signal. The symbol of a 2-bit 
Toffoli gate and its truth table are shown in Figure 3(a) and 
 
y
z
♁xy♁xz
♁xy♁
xx
y
z xz
 
x y z x y♁xy♁xz z♁xy♁xz
0
0
0
0
1
1
1
1
0 
0 
1 
1 
0 
0 
1 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
0 
0 
0 
1 
1 
1 
1 
0 
0 
1 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
0 
1 
1 
 (a) (b) 
Figure 2: Fredkin gate (a) symbol; (b) truth table. 
0
0
0
0
1
1
1
1
0
0
1
1
0
0
1
1
0
1
0
1
0
1
0
1
0
0
0
0
1
1
1
1
0
0
1
1
0
0
1
1
0 
1 
0 
1 
0 
1 
1 
0 
 (a) 
Figure 1: 3-bit Toffoli gate (a) truth table; (b) symbol.
x
y y
z 
(b) 
xy♁z
3(b), respectively. The function of the second output column 
is x♁y. If y is set as a constant 0, a copy of input variable x 
will be obtained in the second output, which is shown in bold. 
Therefore, the fanout structure in a conventional network can 
be implemented in this way. 
 
 
 
 
 
 
 
 
 
 
 
 
 
These two restrictions have to be met to reversible 
sequential circuits as well. According to [14], a sequential 
circuit is reversible if its transition function is constructed by 
reversible logic. Its structure is presented as Figure 4. The 
transition function in Figure 4 acts as a combinational 
network. Therefore, the synthesis of this transition function 
has to conform to the restrictions mentioned.  
There are two objectives in the reversible circuit synthesis: 
1. Minimize the number of gates: the number of gates gives a 
simple estimation of the implementation cost of a reversible 
circuit. 
2. Minimize the number of garbage outputs: We need extra 
implement cost (area and power) for those garbage outputs in 
reversible circuit. Minimizing the number of garbage outputs 
leads to minimize area and power. 
 
III. Previous Work 
 
Picton [11] first proposed a new design of reversible RS 
latch without clock signal. This work decomposes a clockless 
RS latch into two conventional NOR gates. Then each NOR 
gate is replaced by a Fredkin gate, which can implement the 
function of NOR gate. This new structure of RS latch is 
considered reversible because it is entirely constructed by 
reversible gates. 
A recent work proposed by Thapliyal et al. [13] exploit 
similar approach, direct transformation, to design other 
sequential elements such as D latch, JK latch, etc. In addition, 
not only Fredkin gate, but also some other reversible gates 
are used to implement conventional logic gates such as NOR 
gate, AND gate, etc. Although many reversible sequential 
elements are considered in this work, the implementation 
cost of them is quite large because they did not further 
optimize these reversible sequential element designs. 
 
IV. Novel Designs of Reversible Sequential 
Elements 
 
This section presents our new designs of reversible 
sequential elements. Also, our approach to getting these 
results is introduced in detail.  
 
A. Clocked Reversible Latches 
Our synthesis method is a truth table extension method. 
We extend the original irreversible truth table of a sequential 
element to an augmented reversible one. We take D latch as 
an example. First, we get the truth table of D latch and make 
it reversible. Obviously, the truth table of D latch in Table 1 
is not a reversible function. The mapping between the input 
and output domains is not one-to-one. Therefore we have to 
add some garbage outputs to make it reversible. The 
minimum number of garbage outputs required for 
reversibility is ⎡ ⎤log(q) , where q is the maximum number of 
times an output pattern repeated in the truth table [7]. In this 
case, 0 and 1 are repeated 4 times in the output column Qn+1. 
Therefore, we add log(4)⎡ ⎤⎢ ⎥ =2 output variables clk’ and D’ in 
the truth table and make the table reversible as shown in 
Table 2. Note that different values assigned to these two 
output columns will affect the result of our design. Under our 
assignments in Table 2, we observe that Table 2 is identical 
to Figure 2. Thus, a D latch can be modeled by a Fredkin 
gate. This means we only need one Fredkin gate to 
implement a reversible D latch. However, if we assign these 
values in different ways, the design may be different.  
x x 
y x♁y 
(a) (b) 
Figure 3: 2-bit Toffoli gate (a) symbol; (b) truth table.
 
x y x x♁y 
0 
0 
1 
1 
0
1
0
1
0 
0 
1 
1 
0 
1 
1 
0 
reversible finite 
transition function
input output
Figure 4: The structure of a reversible sequential circuit. 
 
clk D Qn Qn+1
0 
0 
0 
0 
1 
1 
1 
1 
0 
0 
1 
1 
0 
0 
1 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
0 
1 
1 
Table 1: The truth table of D latch.
 
 
clk D Qn clk’ D’ Qn+1
0 
0 
0 
0 
1 
1 
1 
1 
0
0
1
1
0
0
1
1
0 
1 
0 
1 
0 
1 
0 
1 
0 
0 
0 
0 
1 
1 
1 
1 
0 
0 
1 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
0 
1 
1 
Table 2: The augmented reversible truth table of D latch.  
 
 
 
 
 
 
 
Comparing with previous work, if we use direct 
transformation method to implement reversible D latch, the 
synthesis result would be not good. This is because a 
traditional D latch is built by many irreversible gates, using 
direct transformation method to construct a reversible D latch 
will cause a large number of gates and garbage outputs 
required. 
After synthesizing this augmented reversible function, we 
need to consider the fanout problem. The input Qn in the next 
state comes from the current output Qn+1. Thus, an additional 
Qn+1 is needed for feedback. Here a Feynman gate is used to 
duplicate the output variable Qn+1. Thus, the final structure of 
D latch is shown as Figure 6. 
clk
 
Similarly, a reversible T latch can be modeled as Toffoli 
Q
Figure 6: The complete implementation  
of reversible D latch. 
n
D D’
clk’
Qn+1
0 Qn+1  
 2
gate using the same method. The implementation of 
reversible T latch is shown in Figure 7(a). Figure 7(b) shows 
the verification result. Figure 7(c) is the augmented truth 
table. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
As for JK latch, because its function is quite complex, it is 
not easy to model its function using a single reversible gate. 
Therefore, we exploit a transformation based synthesis 
algorithm [8] to construct the reversible JK latch. First, we 
also derive the augmented reversible truth table as shown in 
Table 3. Then, we apply the transformation based synthesis 
algorithm to implement the reversible function. The 
philosophy of the transformation based algorithm is to 
cascade some reversible gates such that the output of the 
truth table is equal to the input. Next, we describe how to 
construct our reversible JK latch in detail. 
First, we inspect the augmented truth table in the 
lexicographical order until the first output assignment differs 
from the input assignment. The first output assignment which 
is not equal to input assignment in Table 3 is 1110.  
Then we want to add some generalized Toffoli gates from 
the end of constructed circuit towards its beginning to make 
the output assignments be equal to input assignments. There 
are two rules when we choose a generalized Toffoli gate. 
1. Deal with those bits that should become to 1 first: we want 
to change the output assignment 1110 to 1011. Hence the 2nd 
bit should be changed from 1 to 0 and the 4th bit should be 
changed from 0 to 1. Therefore, we deal with the 4th bit first. 
2. Remain the output assignments which are prior to the 
current one intact: the output assignments prior to 1110 are 
identical to their corresponding input assignments, so we 
leave them unchanged. Using TOF(clk’,J’,K’;Qn+1) or 
TOF(clk’,J’;Qn+1) are effective to invert the 4th bit of 1110 
and leave the output assignments prior to it unchanged. In 
our design, we choose a TOF(clk’,J’;Qn+1) and add it to the 
end of constructed circuit in this iteration. Note that this 
process might change other output assignments after 1110, 
such as 1101 or 1111. Nevertheless, we can reform them in 
the same way in the later iterations. 
In each step, we choose an appropriate generalized Toffoli 
gate to synthesize the reversible function according to these 
two rules. The algorithm is terminated until all of the output 
assignments are equal to the input assignments. Figure 8 
shows the process of synthesizing this reversible JK latch. 
After adding a generalized Toffoli gate in each step, we show 
those changed output assignments in bold. Note that the gates 
are identified sequentially from the output side to the input 
side. The resulting circuit has to be reversed and is shown in 
Figure 9(a), and the final structure of reversible JK latch is 
shown in Figure 9(b). 
clk
T
Qn Qn+1
T’
clk’
Qn+10  
 
clk T Qn clk’ T’ Qn+1
0 
0 
0 
0 
1 
1 
1 
1 
0 
0 
1 
1 
0 
0 
1 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
0 
0 
0 
1 
1 
1 
1 
0
0
1
1
0
0
1
1
0 
1 
0 
1 
0 
1 
1 
0 
(a) 
Qn+1 = TC Q♁ nQn
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
B. Clocked Reversible Flip-Flops 
A flip-flop is an edge-triggered sequential element while a 
latch is a level sensitive sequential element. A traditional D 
flip-flop consists of two D latches and one inverter, and is 
shown in Figure 10 [9]. Since a reversible D latch has been 
built, a reversible D flip-flop can be constructed directly by 
replacing the D latches and inverter with its reversible 
versions. The behavior and structure of a reversible D 
flip-flop are shown in Figure 11(a) and Figure 11(b), 
respectively. We can trace the D flip-flop design and 
compare the function with its truth table. The behavior of 
implemented D flip-flop is the same as that of the truth table 
in Figure 11(a). The implementations of reversible T flip-flop 
and JK flip-flop are shown in Figure 12 and Figure 13, 
respectively. 
 
 
 
 
 
 
Figure 9: JK latch (a) the reversible transition function; (b) the 
complete implementation. 
 
clk
J
K
Qn
clk
J
K
Qn
0
clk’
J’
K’
Qn+1
Qn+1
 (a) (b) 
D
D latch
(master)
D
C
Q
D latch
(slave)
Q
C
D Q
QQ
Q
 
 
Figure 10: An irreversible conventional D flip-flop. 
inv
0000
0001
0010
0011
0100
0101
0110
0111
1000
1001
1010
1011
1100
1101
1110
1111
0000
0001
0010
0011
0100
0101
0110
0111
1000
1001
1010
1011
1100
1111
1110
1101
0000
0001
0010
0011
0100
0101
0110
0111
1000
1001
1010
1111
1100
1011
1110
1101
0000
0001
0010
0011
0100
0101
0110
0111
1000
1001
1010
1110
1101
1011
1111
1100
0000
0001
0010
0011
0100
0101
0110
0111
1000
1001
1010
1011
1100
1101
1110
1111
S3S2S1OutIn
clk
J
K
Qn
S1 S2 S3
Figure 8: The synthesis process of reversible JK latch. 
Figure 7: T latch (a) structure; (b) functional verification;  
(c) the augmented truth table.  
(c) (b) 
C’ = C 
C’ = C 
Qn+1 = TC Q♁ n
C 
T T’ 
Table 3: The augmented reversible truth table of JK latch
clk J K Qn clk’ J’ K’ Qn+1 
0 
0 
0 
0 
0 
0 
0 
0 
1 
1 
1 
1 
1 
1 
1 
1 
0 
0 
0 
0 
1 
1 
1 
1 
0 
0 
0 
0 
1 
1 
1 
1 
0 
0 
1 
1 
0 
0 
1 
1 
0 
0 
1 
1 
0 
0 
1 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
0 
0 
0 
0 
0 
0 
0 
1 
1 
1 
1 
1 
1 
1 
1 
0 
0 
0 
0 
1 
1 
1 
1 
0 
0 
0 
1 
1 
0 
1 
1 
0 
0 
1 
1 
0 
0 
1 
1 
0 
0 
1 
1 
0 
1 
1 
0 
0 
1 
0 
1 
0 
1 
0 
1 
0 
1 
0 
0 
1 
1 
1 
0 
 3
Figure13: JK flip-flo
 
VI. The Disc
 
Table 4 shows the statis
designs against that propos
shows the types of the s
number of gates and the n
cost functions to measure th
separated into two parts by
three columns. In Table 4, t
of our design. The column 
[13]. The column “Ratio” i
example, for a D latch d
gates while [13] has 7 gates
row “Average” shows th
different reversible sequent
According to the statistic
D
J
  
clk D Qn+1 
0 * Qn 
1 * Qn 
 0 0 
 1 1 
  
clk J K Qn+1 
0 * * Qn 
1 * * Qn 
 0 0 Qn 
 0 1 0 
 1 0 1 
 1 1 
____
nQ   
 (a) 
clk
J
Qn
0
K
(a) 
clk
D
Qn
0
 
Figure11: D flip-flop 
clk T Qn+1 
0 * Qn 
1 * Qn 
 0 Qn 
 1 
____
nQ  
T 
latch
clk
T
Qn
0
Figure12: T flip-flop
(a) 
 Table 4: The statistics and comparison of our new designs and previous work [13]. 
NO. of gates NO. of garbage outputs Types Ours [13] Ratio (%) Ours [13] Ratio (%) 
D latch 2 7 28.6 2 8 25.0 
JK latch 4 10 40.0 3 12 25.0 
T latch 2 10 20.0 2 12 16.6 
 flip-flop 5 — — 3 — — 
K flip-flop 7 18 38.9 4 21 19.0 
T flip-flop 5 — — 3 — — 
Average — — 31.9 — — 21.4  
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 p (a) behavior; (b) structure.
ussion of Results 
tics and comparison of our new 
ed in [13]. In this table, column 1 
equential element. We use the 
umber of garbage outputs as the 
e quality of a design. This table is 
 these two costs and each part has 
he column “Ours” shows the cost 
“[13]” shows the cost reported in 
s the percentage of Ours/[13]. For 
esign, our implementation has 2 
. The ratio is 2/7=28.6%. The last 
e averaged ratio among these 
ial elements. 
s in Table 4, the implementation 
cost of our designs is smaller than that of [13]. 
 
VII. Conclusion 
 
This paper proposes novel designs of basic reversible 
sequential elements such as latches and flip-flops. The design 
process is also introduced in detail. As comparing with 
previous work, the implementation costs of these new 
designs are more competitive. Thus, the resulting reversible 
sequential circuits are more cost efficient.  
 
References 
 
[1] C. Bennett, “Logical reversibility of computation,” IBM 
Journal of Research and Development, 17: pp. 525-532, Nov. 
1973. 
[2] E. Fredkin and T. Toffoli, “Conservative logic,” International 
Journal of Theoretical Physics, vol. 21, pp. 219-253, 1982. 
[3] E. Knill, R. Laflamme, and G. J. Milburn, “A scheme for 
efficient quantum computation with linear optics,” Nature, pp. 
46-52, Jan. 2001. 
[4] P.Kerntopf, “A new heuristic algorithm for reversible logic 
synthesis,” in Proc. of the IEEE Design Automation 
Conference, pp. 834-837, 2004. 
[5] R. Landauer, “Irreversibility and heat generation in the 
computational process,” IBM Journal of Research and 
Development, 5: pp. 183-191, July 1961. 
[6] R. C. Merkle, ”Two types of mechanical reversible logic,” 
Nanotechnology, 4:pp. 114-131, 1993. 
[7] D. Maslov and G. W. Dueck, ”Garbage in reversible design of 
multiple output functions,” in Proc. of 6th International 
Symposium on Representations and Methodology of Future 
Computing Technologies, pp. 162-170, 2003. 
[8] D. M. Miller, D. Maslov, and G. W. Dueck, “A transformation 
based algorithm for reversible logic synthesis,” in Proc. of the 
IEEE Design Automation Conference, pp. 318-323, 2003. 
[9] M. M. Mano, “Computer engineering: hardware design,” 
Prentice-Hall, Englewood Cliffs, NJ, 1988. 
[10] M. Nielsen and I. Chuang, “Quantum computation and 
quantum information,” Cambridge University Press, 2000. 
[11] P. Picton, “Multi-Valued Sequential Logic Design using 
Fredkin Gates,” Multiple-Valued Logic Journal, vol.1, pp. 
241-251, 1996. 
[12] G. Schrom, ”Ultra-low-power CMOS technology,” PhD thesis, 
Technischen Universitat Wien, June 1998. 
[13] H. Thapliyal and M. B. Srinivas, “A beginning in the reversible 
logic synthesis of sequential circuits,” in Proc. of MAPLD, 
2005. 
[14] T. Toffoli, “Reversible computing,” Tech memo 
MIT/LCS/TM-151, MIT Lab for Comp. Sci, 1980. 
 
(b) 
JK 
latch
D 
latch
J’
Qn+1
Qn+1
D
Qn
0
D’
Qn+1
Qn+1
clk’
K’
D 
latch
D 
latch
D’
Qn+1
Qn+1
D
Qn
0
D’
Qn+1
Qn+1
clk’
inv  
(b) 
 (a) behavior; (b) structure. 
D 
latch
T’
Qn+1
Qn+1
D
Qn
0
D’
Qn+1
Qn+1
clk’
 (a) behavior; (b) structure. 
(b) 
4
